From 0470e00d2ec1bc716fa298cef9a6bfd5de1a73f4 Mon Sep 17 00:00:00 2001 From: "H.F.M" Date: Fri, 2 Apr 2021 14:14:29 +0200 Subject: [PATCH] update 1.9 --- .gitignore | 4 + CHANGELOG.md | 41 +- Godeps/Godeps.json | 92 - LICENSE | 2 +- README.md | 74 +- assets/glade/main.glade | 1300 +- assets/images/Cross-icon-48.png | Bin 0 -> 3387 bytes assets/images/Search-Engine-400x27.png | Bin 23583 -> 0 bytes assets/images/Search-Engine-700x48.png | Bin 53896 -> 0 bytes assets/images/Sign-Error-20.png | Bin 672 -> 0 bytes assets/images/Stop-48.png | Bin 0 -> 2546 bytes assets/images/Tick-icon-48.png | Bin 0 -> 2454 bytes .../images/artWork/search-and-replace-top.xcf | Bin 0 -> 66117 bytes assets/images/artWork/search-engine-top.xcf | Bin 0 -> 51388 bytes assets/images/calendar-18.png | Bin 2123 -> 0 bytes assets/images/calendar-48.png | Bin 4999 -> 0 bytes assets/images/calendar-pers-48.png | Bin 0 -> 2838 bytes assets/images/cancel-18x18.png | Bin 2203 -> 0 bytes assets/images/checked-18x18.png | Bin 2589 -> 0 bytes assets/images/clear-hist-48.png | Bin 0 -> 1529 bytes assets/images/find-18.png | Bin 1096 -> 0 bytes assets/images/find-48.png | Bin 3911 -> 3488 bytes assets/images/floppy-save-48.png | Bin 0 -> 2224 bytes assets/images/folder-48.png | Bin 0 -> 3400 bytes assets/images/folder-open-20.png | Bin 997 -> 0 bytes assets/images/logout-48.png | Bin 0 -> 1140 bytes assets/images/open-18.png | Bin 2001 -> 0 bytes assets/images/reset-18x18.png | Bin 890 -> 0 bytes assets/images/reset-48.png | Bin 0 -> 2180 bytes assets/images/save-all-18.png | Bin 891 -> 0 bytes assets/images/search-engine-top-370x32.png | Bin 0 -> 12103 bytes assets/images/search-engine-top-550x48.png | Bin 0 -> 20425 bytes assets/images/search-folder-48.png | Bin 0 -> 5071 bytes assets/lang/eng.lang | 371 +- find-48.png | Bin 3911 -> 0 bytes gohAssets.go | 103 +- gohFunctions.go | 408 +- gohImages.go | 89 +- gohObjects.go | 101 +- gohOptions.go | 130 +- gohSignals.go | 21 +- gohStartGtk.go | 52 +- main.go | 145 +- miscFunc.go | 55 +- objectHandler.go | 147 +- popup.go | 253 +- SearchEngine.proj => search-engine.proj | 440 +- searchFunc.go | 162 +- timeWindow.go | 143 - translate.go | 113 +- .../dustin/go-humanize/bigbytes_test.go | 220 + .../dustin/go-humanize/bytes_test.go | 146 + .../dustin/go-humanize/comma_test.go | 145 + .../dustin/go-humanize/commaf_test.go | 44 + .../dustin/go-humanize/common_test.go | 18 + .../dustin/go-humanize/ftoa_test.go | 123 + .../dustin/go-humanize/number_test.go | 79 + .../dustin/go-humanize/ordinals_test.go | 22 + .../github.com/dustin/go-humanize/si_test.go | 124 + .../dustin/go-humanize/times_test.go | 124 + .../github.com/gotk3/gotk3/cairo/antialias.go | 27 + vendor/github.com/gotk3/gotk3/cairo/cairo.go | 65 + vendor/github.com/gotk3/gotk3/cairo/canvas.go | 423 + vendor/github.com/gotk3/gotk3/cairo/errors.go | 7 + .../github.com/gotk3/gotk3/cairo/fillrule.go | 22 + vendor/github.com/gotk3/gotk3/cairo/format.go | 33 + .../github.com/gotk3/gotk3/cairo/linecap.go | 23 + .../github.com/gotk3/gotk3/cairo/linejoin.go | 23 + vendor/github.com/gotk3/gotk3/cairo/matrix.go | 98 + .../github.com/gotk3/gotk3/cairo/mimetype.go | 13 + .../github.com/gotk3/gotk3/cairo/operator.go | 49 + .../github.com/gotk3/gotk3/cairo/pattern.go | 112 + vendor/github.com/gotk3/gotk3/cairo/region.go | 381 + vendor/github.com/gotk3/gotk3/cairo/status.go | 124 + .../github.com/gotk3/gotk3/cairo/surface.go | 300 + .../gotk3/gotk3/cairo/surfacetype.go | 45 + vendor/github.com/gotk3/gotk3/cairo/text.go | 125 + .../gotk3/gotk3/cairo/translations.go | 78 + vendor/github.com/gotk3/gotk3/cairo/util.go | 20 + vendor/github.com/gotk3/gotk3/gdk/gdk.go | 2464 ++++ vendor/github.com/gotk3/gotk3/gdk/gdk.go.h | 48 + .../gotk3/gdk/gdk_deprecated_since_3_10.go | 33 + .../gotk3/gdk/gdk_deprecated_since_3_16.go | 12 + .../gotk3/gdk/gdk_deprecated_since_3_20.go | 79 + .../gotk3/gdk/gdk_deprecated_since_3_22.go | 113 + .../gotk3/gotk3/gdk/gdk_since_3_10.go | 50 + .../gotk3/gotk3/gdk/gdk_since_3_12.go | 7 + .../gotk3/gotk3/gdk/gdk_since_3_16.go | 197 + .../gotk3/gotk3/gdk/gdk_since_3_16.go.h | 22 + .../gotk3/gotk3/gdk/gdk_since_3_18.go | 32 + .../gotk3/gotk3/gdk/gdk_since_3_20.go | 89 + .../gotk3/gotk3/gdk/gdk_since_3_20.go.h | 21 + .../gotk3/gotk3/gdk/gdk_since_3_22.go | 248 + .../gotk3/gotk3/gdk/gdk_since_3_22.go.h | 22 + .../gotk3/gotk3/gdk/gdk_since_3_8.go | 231 + .../gotk3/gotk3/gdk/gdk_since_3_8.go.h | 26 + vendor/github.com/gotk3/gotk3/gdk/keys.go | 2278 +++ vendor/github.com/gotk3/gotk3/gdk/pixbuf.go | 668 + vendor/github.com/gotk3/gotk3/gdk/pixbuf.go.h | 26 + .../gotk3/gdk/pixbuf_deprecated_since_2_32.go | 16 + .../gotk3/gotk3/gdk/pixbuf_since_2_12.go | 33 + .../gotk3/gotk3/gdk/pixbuf_since_2_14.go | 23 + .../gotk3/gotk3/gdk/pixbuf_since_2_2.go | 97 + .../gotk3/gotk3/gdk/pixbuf_since_2_22.go | 18 + .../gotk3/gotk3/gdk/pixbuf_since_2_24.go | 23 + .../gotk3/gotk3/gdk/pixbuf_since_2_26.go | 25 + .../gotk3/gotk3/gdk/pixbuf_since_2_32.go | 68 + .../gotk3/gotk3/gdk/pixbuf_since_2_36.go | 23 + .../gotk3/gotk3/gdk/pixbuf_since_2_4.go | 143 + .../gotk3/gotk3/gdk/pixbuf_since_2_4.go.h | 34 + .../gotk3/gotk3/gdk/pixbuf_since_2_6.go | 74 + vendor/github.com/gotk3/gotk3/gdk/screen.go | 114 + .../gotk3/gotk3/gdk/screen_no_x11.go | 25 + .../github.com/gotk3/gotk3/gdk/screen_x11.go | 30 + vendor/github.com/gotk3/gotk3/gdk/testing.go | 38 + .../gotk3/gotk3/gdk/window_no_x11.go | 17 + .../github.com/gotk3/gotk3/gdk/window_x11.go | 47 + .../gotk3/gotk3/glib/application.go | 196 + vendor/github.com/gotk3/gotk3/glib/connect.go | 153 + vendor/github.com/gotk3/gotk3/glib/gaction.go | 227 + .../gotk3/gotk3/glib/gactiongroup.go | 113 + .../github.com/gotk3/gotk3/glib/gactionmap.go | 66 + .../gotk3/gotk3/glib/gasyncresult.go | 73 + .../github.com/gotk3/gotk3/glib/gbinding.go | 98 + .../gotk3/gotk3/glib/gcancellable.go | 83 + vendor/github.com/gotk3/gotk3/glib/gfile.go | 367 + vendor/github.com/gotk3/gotk3/glib/gfile.go.h | 13 + vendor/github.com/gotk3/gotk3/glib/gicon.go | 177 + .../github.com/gotk3/gotk3/glib/giostream.go | 437 + .../gotk3/gotk3/glib/giostream.go.h | 14 + vendor/github.com/gotk3/gotk3/glib/glib.go | 1403 ++ vendor/github.com/gotk3/gotk3/glib/glib.go.h | 190 + .../gotk3/gotk3/glib/glib_export.go | 27 + .../gotk3/gotk3/glib/glib_extension.go | 18 + .../gotk3/gotk3/glib/glib_since_2_42.go | 50 + .../gotk3/gotk3/glib/glib_since_2_44.go | 30 + .../gotk3/gotk3/glib/glib_since_2_44.go.h | 16 + .../gotk3/gotk3/glib/glib_since_2_46.go | 23 + .../gotk3/gotk3/glib/glib_since_2_46.go.h | 10 + .../gotk3/gotk3/glib/glib_since_2_64.go | 20 + .../github.com/gotk3/gotk3/glib/glib_test.go | 133 + .../github.com/gotk3/gotk3/glib/glistmodel.go | 164 + .../gotk3/gotk3/glib/gmain_context.go | 65 + .../gotk3/gotk3/glib/gpermission.go | 126 + .../gotk3/gotk3/glib/gpermission.go.h | 24 + .../gotk3/gotk3/glib/gsimpleactiongroup.go | 58 + .../gotk3/glib/gsimpleactiongroup_test.go | 70 + vendor/github.com/gotk3/gotk3/glib/gsource.go | 31 + .../github.com/gotk3/gotk3/glib/gvariant.go | 451 + .../github.com/gotk3/gotk3/glib/gvariant.go.h | 26 + .../gotk3/gotk3/glib/gvariant_test.go | 188 + .../gotk3/gotk3/glib/gvariantbuilder.go | 52 + .../gotk3/gotk3/glib/gvariantclass.go | 39 + .../gotk3/gotk3/glib/gvariantdict.go | 52 + .../gotk3/gotk3/glib/gvariantiter.go | 52 + .../gotk3/gotk3/glib/gvarianttype.go | 147 + .../gotk3/gotk3/glib/gvarianttype.go.h | 39 + .../gotk3/gotk3/glib/gvarianttype_test.go | 118 + vendor/github.com/gotk3/gotk3/glib/list.go | 175 + .../github.com/gotk3/gotk3/glib/list_test.go | 76 + vendor/github.com/gotk3/gotk3/glib/menu.go | 447 + .../github.com/gotk3/gotk3/glib/menu_test.go | 143 + .../gotk3/gotk3/glib/notifications.go | 94 + .../github.com/gotk3/gotk3/glib/settings.go | 304 + .../gotk3/gotk3/glib/settings_backend.go | 70 + .../gotk3/gotk3/glib/settings_schema.go | 95 + .../gotk3/glib/settings_schema_source.go | 69 + vendor/github.com/gotk3/gotk3/glib/slist.go | 159 + .../github.com/gotk3/gotk3/gtk/aboutdialog.go | 328 + vendor/github.com/gotk3/gotk3/gtk/accel.go | 447 + .../github.com/gotk3/gotk3/gtk/accel_test.go | 34 + .../github.com/gotk3/gotk3/gtk/actionable.go | 121 + .../gotk3/gotk3/gtk/actionable.go.h | 1 + .../gotk3/gotk3/gtk/actionable_test.go | 35 + .../gotk3/gotk3/gtk/actionbar_since_3_12.go | 109 + .../gotk3/gotk3/gtk/actionbar_since_3_12.go.h | 21 + .../github.com/gotk3/gotk3/gtk/app_chooser.go | 408 + .../github.com/gotk3/gotk3/gtk/application.go | 172 + .../gotk3/gotk3/gtk/application_since_3_12.go | 62 + .../gotk3/gotk3/gtk/application_since_3_14.go | 49 + .../gotk3/gotk3/gtk/application_window.go | 75 + .../gtk/application_window_since_3_20.go | 28 + .../gotk3/gotk3/gtk/box_since_3_12.go | 48 + .../github.com/gotk3/gotk3/gtk/button_box.go | 98 + .../github.com/gotk3/gotk3/gtk/cell_area.go | 580 + .../gotk3/gotk3/gtk/cell_area_since_3_14.go | 23 + .../gotk3/gotk3/gtk/color_chooser.go | 170 + .../github.com/gotk3/gotk3/gtk/combo_box.go | 413 + vendor/github.com/gotk3/gotk3/gtk/fixed.go | 72 + vendor/github.com/gotk3/gotk3/gtk/fixed.go.h | 1 + .../gotk3/gotk3/gtk/font_chooser.go | 221 + vendor/github.com/gotk3/gotk3/gtk/gdk.go | 41 + vendor/github.com/gotk3/gotk3/gtk/glarea.go | 183 + .../gotk3/gotk3/gtk/glarea_since_3_22.go | 17 + vendor/github.com/gotk3/gotk3/gtk/glib.go | 20 + vendor/github.com/gotk3/gotk3/gtk/gtk.go | 11983 ++++++++++++++++ vendor/github.com/gotk3/gotk3/gtk/gtk.go.h | 651 + .../gotk3/gtk/gtk_deprecated_since_3_10.go | 336 + .../gotk3/gtk/gtk_deprecated_since_3_12.go | 95 + .../gotk3/gtk/gtk_deprecated_since_3_14.go | 508 + .../gotk3/gtk/gtk_deprecated_since_3_14.go.h | 28 + .../gotk3/gtk/gtk_deprecated_since_3_16.go | 55 + .../gotk3/gtk/gtk_deprecated_since_3_18.go | 11 + .../gotk3/gtk/gtk_deprecated_since_3_20.go | 86 + .../gotk3/gtk/gtk_deprecated_since_3_22.go | 67 + .../gotk3/gtk/gtk_deprecated_since_3_24.go | 66 + .../gotk3/gtk/gtk_deprecated_since_3_8.go | 41 + .../github.com/gotk3/gotk3/gtk/gtk_export.go | 109 + .../gotk3/gotk3/gtk/gtk_export_since_3_10.go | 36 + .../gotk3/gotk3/gtk/gtk_export_since_3_14.go | 19 + .../gotk3/gotk3/gtk/gtk_export_since_3_16.go | 14 + .../gotk3/gotk3/gtk/gtk_since_3_10.go | 918 ++ .../gotk3/gotk3/gtk/gtk_since_3_10.go.h | 64 + .../gotk3/gotk3/gtk/gtk_since_3_12.go | 574 + .../gotk3/gotk3/gtk/gtk_since_3_12.go.h | 27 + .../gotk3/gotk3/gtk/gtk_since_3_14.go | 134 + .../gotk3/gotk3/gtk/gtk_since_3_14.go.h | 10 + .../gotk3/gotk3/gtk/gtk_since_3_16.go | 371 + .../gotk3/gotk3/gtk/gtk_since_3_16.go.h | 47 + .../gtk_since_3_16_deprecated_since_3_20.go | 22 + .../gotk3/gtk/gtk_since_3_16_glib_2_44.go | 25 + .../gotk3/gotk3/gtk/gtk_since_3_18.go | 103 + .../gotk3/gotk3/gtk/gtk_since_3_20.go | 283 + .../gotk3/gotk3/gtk/gtk_since_3_20.go.h | 33 + .../gotk3/gotk3/gtk/gtk_since_3_22.go | 66 + .../gotk3/gotk3/gtk/gtk_since_3_24.go | 14 + .../gotk3/gotk3/gtk/gtk_since_3_8.go | 36 + vendor/github.com/gotk3/gotk3/gtk/gtk_test.go | 875 ++ .../github.com/gotk3/gotk3/gtk/icon_view.go | 481 + vendor/github.com/gotk3/gotk3/gtk/info_bar.go | 133 + vendor/github.com/gotk3/gotk3/gtk/label.go | 299 + .../github.com/gotk3/gotk3/gtk/level_bar.go | 158 + .../gotk3/gotk3/gtk/level_bar_since_3_20.go | 15 + .../gotk3/gotk3/gtk/level_bar_since_3_8.go | 18 + vendor/github.com/gotk3/gotk3/gtk/menu.go | 172 + .../gotk3/gotk3/gtk/menu_before_3_22.go | 19 + .../github.com/gotk3/gotk3/gtk/menu_shell.go | 157 + .../gotk3/gotk3/gtk/menu_since_3_22.go | 45 + vendor/github.com/gotk3/gotk3/gtk/print.go | 1596 ++ vendor/github.com/gotk3/gotk3/gtk/print.go.h | 23 + .../gotk3/gotk3/gtk/print_export.go | 23 + .../gotk3/gotk3/gtk/print_since_3_16.go | 34 + .../github.com/gotk3/gotk3/gtk/print_test.go | 55 + vendor/github.com/gotk3/gotk3/gtk/settings.go | 57 + .../github.com/gotk3/gotk3/gtk/settings.go.h | 1 + .../gotk3/gtk/shortcutswindow_since_3_20.go | 156 + .../gotk3/gtk/shortcutswindow_since_3_20.go.h | 33 + .../github.com/gotk3/gotk3/gtk/socket_plug.go | 205 + .../gotk3/gotk3/gtk/socket_plug.go.h | 6 + .../gotk3/gotk3/gtk/stack_since_3_12.go | 32 + .../gotk3/gtk/stackswitcher_since_3_10.go | 81 + vendor/github.com/gotk3/gotk3/gtk/style.go | 236 + vendor/github.com/gotk3/gotk3/gtk/testing.go | 161 + .../gtk/testing_deprecated_since_3_20.go | 62 + .../gotk3/gotk3/gtk/testing_since_3_10.go | 13 + .../gotk3/gotk3/gtk/testing_test.go | 125 + .../gotk3/gotk3/gtk/text_child_anchor.go | 81 + .../gotk3/gotk3/gtk/text_child_anchor.go.h | 23 + .../github.com/gotk3/gotk3/gtk/text_iter.go | 423 + .../github.com/gotk3/gotk3/gtk/text_mark.go | 97 + .../github.com/gotk3/gotk3/gtk/text_view.go | 448 + .../github.com/gotk3/gotk3/gtk/toolshell.go | 13 + vendor/github.com/gotk3/gotk3/gtk/tooltip.go | 83 + .../github.com/gotk3/gotk3/gtk/tree_view.go | 657 + .../gotk3/gotk3/gtk/tree_view_column.go | 323 + vendor/github.com/gotk3/gotk3/gtk/version.go | 29 + .../gotk3/gotk3/gtk/version_test.go | 20 + vendor/github.com/gotk3/gotk3/gtk/widget.go | 962 ++ .../gotk3/gtk/widget_export_since_3_8.go | 23 + .../gotk3/gotk3/gtk/widget_since_3_10.go | 44 + .../gotk3/gotk3/gtk/widget_since_3_12.go | 49 + .../gotk3/gotk3/gtk/widget_since_3_14.go | 20 + .../gotk3/gotk3/gtk/widget_since_3_16.go | 10 + .../gotk3/gotk3/gtk/widget_since_3_18.go | 12 + .../gotk3/gotk3/gtk/widget_since_3_20.go | 21 + .../gotk3/gotk3/gtk/widget_since_3_8.go | 83 + .../gotk3/gotk3/gtk/widget_since_3_8.go.h | 30 + vendor/github.com/gotk3/gotk3/gtk/window.go | 727 + .../gotk3/gotk3/gtk/window_since_3_10.go | 25 + .../gotk3/gotk3/gtk/window_since_3_12.go | 14 + .../gotk3/gotk3/gtk/window_since_3_14.go | 13 + .../gotk3/gotk3/gtk/window_since_3_16.go | 17 + .../gotk3/gotk3/gtk/window_since_3_16_test.go | 34 + .../gotk3/gotk3/gtk/window_since_3_18.go | 19 + .../github.com/gotk3/gotk3/gtk/window_test.go | 548 + .../github.com/gotk3/gotk3/gtk/windowgroup.go | 108 + .../gotk3/gotk3/internal/callback/callback.go | 37 + .../gotk3/gotk3/internal/closure/closure.go | 79 + .../gotk3/internal/closure/closure_go_1_14.go | 14 + .../gotk3/internal/closure/closure_go_1_15.go | 13 + .../gotk3/gotk3/internal/closure/funcstack.go | 94 + .../gotk3/gotk3/internal/slab/slab.go | 52 + .../gotk3/gotk3/pango/fontconfig.go.h | 7 + .../gotk3/gotk3/pango/pango-attributes.go | 367 + .../gotk3/gotk3/pango/pango-attributes.go.h | 23 + .../pango/pango-attributes_since_1_44.go | 18 + .../gotk3/gotk3/pango/pango-context.go | 139 + .../gotk3/gotk3/pango/pango-font.go | 720 + .../gotk3/gotk3/pango/pango-glyph-item.go | 43 + .../gotk3/gotk3/pango/pango-glyph.go | 85 + .../gotk3/gotk3/pango/pango-gravity.go | 63 + .../gotk3/gotk3/pango/pango-layout.go | 613 + .../gotk3/gotk3/pango/pango-layout.go.h | 23 + .../gotk3/gotk3/pango/pango-types.go | 135 + vendor/github.com/gotk3/gotk3/pango/pango.go | 62 + .../github.com/gotk3/gotk3/pango/pango.go.h | 36 + .../gotk3/gotk3/pango/pangocairo.go | 138 + .../gotk3/gotk3/pango/pangocairo.go.h | 0 .../hfmrow/genLib/files/fileDirCopy.go | 121 - .../github.com/hfmrow/genLib/files/files.go | 275 - .../hfmrow/genLib/files/filesTools.go | 245 +- .../genLib/files/findFiles/findFiles.go | 543 +- .../hfmrow/genLib/files/permsOwner.go | 77 - .../hfmrow/genLib/slices/sliceOperations.go | 30 +- .../genLib/strings/cClass/characterClasses.go | 6 +- .../github.com/hfmrow/genLib/strings/eol.go | 54 +- .../hfmrow/genLib/strings/formatText.go | 14 +- .../hfmrow/genLib/strings/stringOperations.go | 234 +- .../hfmrow/genLib/tools/bench/bench.go | 134 +- .../github.com/hfmrow/genLib/tools/cLine.go | 131 +- .../hfmrow/genLib/tools/errors/errors.go | 188 +- .../gtk3Import/dialog/about/aboutDialog.go | 282 - .../hfmrow/gtk3Import/dialog/aboutBox.go | 226 + .../dialog/chooser/calendarChooser.go | 306 + .../gtk3Import/dialog/chooser/colorChooser.go | 39 +- .../gtk3Import/dialog/chooser/fileChooser.go | 46 +- .../hfmrow/gtk3Import/dialog/dialogBox.go | 346 +- .../hfmrow/gtk3Import/dialog/dialogError.go | 38 +- .../hfmrow/gtk3Import/dialog/dialogMessage.go | 25 +- .../hfmrow/gtk3Import/misc/clipboard.go | 18 +- .../hfmrow/gtk3Import/misc/cssWdgScnLoad.go | 48 +- .../github.com/hfmrow/gtk3Import/misc/dnd.go | 155 +- .../hfmrow/gtk3Import/misc/popupMenu.go | 941 +- .../hfmrow/gtk3Import/misc/progress.go | 142 + .../hfmrow/gtk3Import/misc/statusBar.go | 75 +- .../hfmrow/gtk3Import/misc/timeOut.go | 85 + .../gtk3Import/pango/pangoMarkupBinder.go | 282 - .../pango/pangoSimple/pangoSimple.go | 151 + .../gtk3Import/pixbuff/misc/RGBA/RGBA.go | 133 + .../hfmrow/gtk3Import/pixbuff/pixbufByte.go | 652 + .../hfmrow/gtk3Import/pixbuff/pixbuffByte.go | 211 - .../gtk3Import/tools/widgets/widgets.go | 90 + .../hfmrow/gtk3Import/treeview/treeView.go | 1774 ++- .../gopkg.in/djherbis/times.v1/bench_test.go | 56 + .../gopkg.in/djherbis/times.v1/times_test.go | 125 + .../djherbis/times.v1/times_windows_test.go | 75 + .../gopkg.in/djherbis/times.v1/util_test.go | 81 + 347 files changed, 58959 insertions(+), 5136 deletions(-) delete mode 100644 Godeps/Godeps.json create mode 100644 assets/images/Cross-icon-48.png delete mode 100755 assets/images/Search-Engine-400x27.png delete mode 100755 assets/images/Search-Engine-700x48.png delete mode 100644 assets/images/Sign-Error-20.png create mode 100644 assets/images/Stop-48.png create mode 100644 assets/images/Tick-icon-48.png create mode 100644 assets/images/artWork/search-and-replace-top.xcf create mode 100644 assets/images/artWork/search-engine-top.xcf delete mode 100644 assets/images/calendar-18.png delete mode 100644 assets/images/calendar-48.png create mode 100644 assets/images/calendar-pers-48.png delete mode 100644 assets/images/cancel-18x18.png delete mode 100644 assets/images/checked-18x18.png create mode 100644 assets/images/clear-hist-48.png delete mode 100644 assets/images/find-18.png create mode 100644 assets/images/floppy-save-48.png create mode 100644 assets/images/folder-48.png delete mode 100644 assets/images/folder-open-20.png create mode 100644 assets/images/logout-48.png delete mode 100644 assets/images/open-18.png delete mode 100644 assets/images/reset-18x18.png create mode 100644 assets/images/reset-48.png delete mode 100644 assets/images/save-all-18.png create mode 100644 assets/images/search-engine-top-370x32.png create mode 100644 assets/images/search-engine-top-550x48.png create mode 100644 assets/images/search-folder-48.png delete mode 100644 find-48.png mode change 100644 => 100755 gohFunctions.go rename SearchEngine.proj => search-engine.proj (56%) delete mode 100755 timeWindow.go create mode 100644 vendor/github.com/dustin/go-humanize/bigbytes_test.go create mode 100644 vendor/github.com/dustin/go-humanize/bytes_test.go create mode 100644 vendor/github.com/dustin/go-humanize/comma_test.go create mode 100644 vendor/github.com/dustin/go-humanize/commaf_test.go create mode 100644 vendor/github.com/dustin/go-humanize/common_test.go create mode 100644 vendor/github.com/dustin/go-humanize/ftoa_test.go create mode 100644 vendor/github.com/dustin/go-humanize/number_test.go create mode 100644 vendor/github.com/dustin/go-humanize/ordinals_test.go create mode 100644 vendor/github.com/dustin/go-humanize/si_test.go create mode 100644 vendor/github.com/dustin/go-humanize/times_test.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/antialias.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/cairo.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/canvas.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/errors.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/fillrule.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/format.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/linecap.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/linejoin.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/matrix.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/mimetype.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/operator.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/pattern.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/region.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/status.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/surface.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/surfacetype.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/text.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/translations.go create mode 100644 vendor/github.com/gotk3/gotk3/cairo/util.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_10.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_16.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_20.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_22.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_10.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_12.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_16.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_16.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_18.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_20.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_20.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_22.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_22.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_8.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_8.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gdk/keys.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_deprecated_since_2_32.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_12.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_14.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_2.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_22.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_24.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_26.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_32.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_36.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_4.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_4.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_6.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/screen.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/screen_no_x11.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/screen_x11.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/testing.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/window_no_x11.go create mode 100644 vendor/github.com/gotk3/gotk3/gdk/window_x11.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/application.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/connect.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gaction.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gactiongroup.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gactionmap.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gasyncresult.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gbinding.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gcancellable.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gfile.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gfile.go.h create mode 100644 vendor/github.com/gotk3/gotk3/glib/gicon.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/giostream.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/giostream.go.h create mode 100644 vendor/github.com/gotk3/gotk3/glib/glib.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/glib.go.h create mode 100644 vendor/github.com/gotk3/gotk3/glib/glib_export.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/glib_extension.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/glib_since_2_42.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/glib_since_2_44.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/glib_since_2_44.go.h create mode 100644 vendor/github.com/gotk3/gotk3/glib/glib_since_2_46.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/glib_since_2_46.go.h create mode 100644 vendor/github.com/gotk3/gotk3/glib/glib_since_2_64.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/glib_test.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/glistmodel.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gmain_context.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gpermission.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gpermission.go.h create mode 100644 vendor/github.com/gotk3/gotk3/glib/gsimpleactiongroup.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gsimpleactiongroup_test.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gsource.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gvariant.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gvariant.go.h create mode 100644 vendor/github.com/gotk3/gotk3/glib/gvariant_test.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gvariantbuilder.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gvariantclass.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gvariantdict.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gvariantiter.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gvarianttype.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/gvarianttype.go.h create mode 100644 vendor/github.com/gotk3/gotk3/glib/gvarianttype_test.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/list.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/list_test.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/menu.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/menu_test.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/notifications.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/settings.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/settings_backend.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/settings_schema.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/settings_schema_source.go create mode 100644 vendor/github.com/gotk3/gotk3/glib/slist.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/aboutdialog.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/accel.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/accel_test.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/actionable.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/actionable.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/actionable_test.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/actionbar_since_3_12.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/actionbar_since_3_12.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/app_chooser.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/application.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/application_since_3_12.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/application_since_3_14.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/application_window.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/application_window_since_3_20.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/box_since_3_12.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/button_box.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/cell_area.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/cell_area_since_3_14.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/color_chooser.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/combo_box.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/fixed.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/fixed.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/font_chooser.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gdk.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/glarea.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/glarea_since_3_22.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/glib.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_10.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_12.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_14.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_14.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_16.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_18.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_20.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_22.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_24.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_8.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_export.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_10.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_14.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_16.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_10.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_10.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_12.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_12.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_14.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_14.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16_deprecated_since_3_20.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16_glib_2_44.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_18.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_20.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_20.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_22.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_24.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_8.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/gtk_test.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/icon_view.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/info_bar.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/label.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/level_bar.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/level_bar_since_3_20.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/level_bar_since_3_8.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/menu.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/menu_before_3_22.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/menu_shell.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/menu_since_3_22.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/print.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/print.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/print_export.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/print_since_3_16.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/print_test.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/settings.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/settings.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/shortcutswindow_since_3_20.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/shortcutswindow_since_3_20.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/socket_plug.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/socket_plug.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/stack_since_3_12.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/stackswitcher_since_3_10.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/style.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/testing.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/testing_deprecated_since_3_20.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/testing_since_3_10.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/testing_test.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/text_child_anchor.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/text_child_anchor.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/text_iter.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/text_mark.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/text_view.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/toolshell.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/tooltip.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/tree_view.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/tree_view_column.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/version.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/version_test.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/widget.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/widget_export_since_3_8.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/widget_since_3_10.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/widget_since_3_12.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/widget_since_3_14.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/widget_since_3_16.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/widget_since_3_18.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/widget_since_3_20.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/widget_since_3_8.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/widget_since_3_8.go.h create mode 100644 vendor/github.com/gotk3/gotk3/gtk/window.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/window_since_3_10.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/window_since_3_12.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/window_since_3_14.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/window_since_3_16.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/window_since_3_16_test.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/window_since_3_18.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/window_test.go create mode 100644 vendor/github.com/gotk3/gotk3/gtk/windowgroup.go create mode 100644 vendor/github.com/gotk3/gotk3/internal/callback/callback.go create mode 100644 vendor/github.com/gotk3/gotk3/internal/closure/closure.go create mode 100644 vendor/github.com/gotk3/gotk3/internal/closure/closure_go_1_14.go create mode 100644 vendor/github.com/gotk3/gotk3/internal/closure/closure_go_1_15.go create mode 100644 vendor/github.com/gotk3/gotk3/internal/closure/funcstack.go create mode 100644 vendor/github.com/gotk3/gotk3/internal/slab/slab.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/fontconfig.go.h create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango-attributes.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango-attributes.go.h create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango-attributes_since_1_44.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango-context.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango-font.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango-glyph-item.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango-glyph.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango-gravity.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango-layout.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango-layout.go.h create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango-types.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/pango.go.h create mode 100644 vendor/github.com/gotk3/gotk3/pango/pangocairo.go create mode 100644 vendor/github.com/gotk3/gotk3/pango/pangocairo.go.h delete mode 100644 vendor/github.com/hfmrow/genLib/files/fileDirCopy.go delete mode 100644 vendor/github.com/hfmrow/genLib/files/files.go delete mode 100644 vendor/github.com/hfmrow/genLib/files/permsOwner.go delete mode 100644 vendor/github.com/hfmrow/gtk3Import/dialog/about/aboutDialog.go create mode 100755 vendor/github.com/hfmrow/gtk3Import/dialog/aboutBox.go create mode 100755 vendor/github.com/hfmrow/gtk3Import/dialog/chooser/calendarChooser.go create mode 100755 vendor/github.com/hfmrow/gtk3Import/misc/progress.go create mode 100644 vendor/github.com/hfmrow/gtk3Import/misc/timeOut.go delete mode 100644 vendor/github.com/hfmrow/gtk3Import/pango/pangoMarkupBinder.go create mode 100644 vendor/github.com/hfmrow/gtk3Import/pango/pangoSimple/pangoSimple.go create mode 100644 vendor/github.com/hfmrow/gtk3Import/pixbuff/misc/RGBA/RGBA.go create mode 100644 vendor/github.com/hfmrow/gtk3Import/pixbuff/pixbufByte.go delete mode 100644 vendor/github.com/hfmrow/gtk3Import/pixbuff/pixbuffByte.go create mode 100644 vendor/github.com/hfmrow/gtk3Import/tools/widgets/widgets.go mode change 100644 => 100755 vendor/github.com/hfmrow/gtk3Import/treeview/treeView.go create mode 100644 vendor/gopkg.in/djherbis/times.v1/bench_test.go create mode 100644 vendor/gopkg.in/djherbis/times.v1/times_test.go create mode 100644 vendor/gopkg.in/djherbis/times.v1/times_windows_test.go create mode 100644 vendor/gopkg.in/djherbis/times.v1/util_test.go diff --git a/.gitignore b/.gitignore index d3adafa..355cad8 100644 --- a/.gitignore +++ b/.gitignore @@ -31,11 +31,15 @@ # Personal unwanted files and folders gohBackup/* +package/* +assets/artWork/* *.opt +*.log *~ *.debug *.xz *.7z *.SUM *.desktop +git-push.sh diff --git a/CHANGELOG.md b/CHANGELOG.md index 9574cd5..095887b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,9 +1,41 @@ -## Changelog +## Informations + +At the bottom you can find a compiled standalone ".deb" version with its checksum. The ".tar.gz" & ".zip" sources contain a "vendor" directory ensuring you can always compile it even if the official libraries have been changed. -### SearchEngine ©2018-19 H.F.M +## Changelog All notable changes to this project will be documented in this file. +### [1.9] 2021-04-02 + +#### Added + +- Add the time zone selection (UTC, Local), which is used in the file view and to search by time function. + +- Context menu: adding option to set date/time at newer and older than from selected file. + +- Context menu delete file(s): confirmation window display the names and their count. + +#### Fixed + +- Search choosing "Directory" as type of file, will work correctly now instead of before where directory name was displayed only in the "All" mode. + +- Sort by size, works properly and reflects a natural order. + +- Sort by date, works correctly even if you have enabled Human readable mode. + +- Some strange behavior with context menu (handling has been rewritten). + +#### Changed + +- Artwork changed, image / icons. + +- Calendar section rewritten. + +- Repository name was changed to [https://github.com/hfmrow/search-engine](https://github.com/hfmrow/search-engine) instead of `https://github.com/hfmrow/searchEngine` + +--- + ### [1.8.5] 2019-10-03 #### Added @@ -13,10 +45,13 @@ All notable changes to this project will be documented in this file. #### Fixed - And operand: now correctly manages the functionality of the splitted words. + - Solving issues on errors occuring sometimes on opening text file with "GDK_FATAL_ERROR" or while opening directory that getting permission error with a"GVFS-WARNING" #### Changed - some parts of the search function have been rewritten to avoid some minor issues. + - Display current path in the title bar rather than the tatusbar. -- Lot of parts of the code have been rewritten for more stability and a really faster processing. And, resulting a lower weight executable file. \ No newline at end of file + +- Lot of parts of the code have been rewritten for more stability and a really faster processing. And, resulting a lower weight executable file. diff --git a/Godeps/Godeps.json b/Godeps/Godeps.json deleted file mode 100644 index 8e625c6..0000000 --- a/Godeps/Godeps.json +++ /dev/null @@ -1,92 +0,0 @@ -{ - "Deps": [ - { - "Comment": "v1.0.0", - "ImportPath": "github.com/dustin/go-humanize", - "Rev": "9f541cc9db5d55bce703bd99987c9d5cb8eea45e" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/genLib/files", - "Rev": "281f1c2fe78be2dadcc4bb68e9bd53fa577d9f10" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/genLib/files/findFiles", - "Rev": "281f1c2fe78be2dadcc4bb68e9bd53fa577d9f10" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/genLib/slices", - "Rev": "281f1c2fe78be2dadcc4bb68e9bd53fa577d9f10" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/genLib/strings", - "Rev": "281f1c2fe78be2dadcc4bb68e9bd53fa577d9f10" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/genLib/strings/cClass", - "Rev": "281f1c2fe78be2dadcc4bb68e9bd53fa577d9f10" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/genLib/tools", - "Rev": "281f1c2fe78be2dadcc4bb68e9bd53fa577d9f10" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/genLib/tools/bench", - "Rev": "281f1c2fe78be2dadcc4bb68e9bd53fa577d9f10" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/genLib/tools/errors", - "Rev": "281f1c2fe78be2dadcc4bb68e9bd53fa577d9f10" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/gtk3Import/dialog", - "Rev": "4653d5eb593d534c0da671944e673378948fd1e7" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/gtk3Import/dialog/about", - "Rev": "4653d5eb593d534c0da671944e673378948fd1e7" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/gtk3Import/dialog/chooser", - "Rev": "4653d5eb593d534c0da671944e673378948fd1e7" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/gtk3Import/misc", - "Rev": "4653d5eb593d534c0da671944e673378948fd1e7" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/gtk3Import/pango", - "Rev": "4653d5eb593d534c0da671944e673378948fd1e7" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/gtk3Import/pixbuff", - "Rev": "4653d5eb593d534c0da671944e673378948fd1e7" - }, - { - "Comment": "", - "ImportPath": "github.com/hfmrow/gtk3Import/treeview", - "Rev": "4653d5eb593d534c0da671944e673378948fd1e7" - }, - { - "Comment": "v1.2.0", - "ImportPath": "gopkg.in/djherbis/times.v1", - "Rev": "847c5208d8924cea0acea3376ff62aede93afe39" - } - ], - "GoVersion": "go1.13", - "GodepVersion": "v80", - "ImportPath": "github.com/hfmrow/searchEngine" -} \ No newline at end of file diff --git a/LICENSE b/LICENSE index 9cbcf9b..3cd3404 100644 --- a/LICENSE +++ b/LICENSE @@ -1,6 +1,6 @@ MIT License -Copyright (c) 2019 H.F.M +Copyright ©2018-21 H.F.M - Search Engine v1.9 github.com/hfmrow/search-engine Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal diff --git a/README.md b/README.md index 1672779..b114394 100644 --- a/README.md +++ b/README.md @@ -1,18 +1,23 @@ -# Search Engine 1.8.5 +# Search Engine 1.9 + *This program is designed to search files over directory, subdirectory, and retrieving information based on date/time, type, patterns contained in name. i'm using it as a replacement for native search function.* +##### Last update 2021-04-02 + Take a look [here, H.F.M repositories](https://github.com/hfmrow/) for other useful linux softwares. -- If you just want to use it, simply download the compiled version under the "release" tab. You can see at [the Right way to install H.F.M's softwares](https://github.com/hfmrow/instHFMsofts) page to integrate this software in your debian environment. - +- If you just want to use it, simply download the *.deb* version under the "release" tab. + - If you want to play inside code, see below "How to compile" section. ## How it's made + - Programmed with go language: [golang](https://golang.org/doc/) - GUI provided by [Gotk3 (gtk3 v3.22)](https://github.com/gotk3/gotk3), GUI library for Go (minimum required v3.16). - I use homemade software: "Gotk3ObjHandler" to embed images/icons, UI-information and manage/generate gtk3 objects code from [glade ui designer](https://glade.gnome.org/). and "Gotk3ObjTranslate" to generate the language files and the assignment of a tooltip on the gtk3 objects (both are not published at the moment, in fact, they need documentations and, for the moment, I have not had the time to do them). ## Functionalities + - Search files based on patterns (contained in filename). - Search files based on file type (all, files, dir, link). - Search files based on date time (newer than, older than). @@ -36,44 +41,57 @@ Take a look [here, H.F.M repositories](https://github.com/hfmrow/) for other use ![Main](assets/readme/whole.jpg "Main") ## How to compile + - Be sure you have golang installed in right way. [Go installation](https://golang.org/doc/install). -- Open terminal window and at command prompt, type: `go get github.com/hfmrow/sAndReplace` + +- Open terminal window and at command prompt, type: `go get github.com/hfmrow/search-engine` + - See [Gotk3 Installation instructions](https://github.com/gotk3/gotk3/wiki#installation) for gui installation instruction. + - To change gtk3 interface you need to use the **devMode = true** to disable embedding assets. see below ... -- To change language file you need to use another home made software, (not published actually). So don't change language file ... -- To Produce a stand-alone executable, you must change inside "main.go" file: - func main() { - devMode = true - ... -into +- To change language file you need to use another home made software, (not published actually). So don't change language file ... - func main() { - devMode = false - ... +- To Produce a stand-alone executable, you must change inside "main.go" file: + + func main() { + devMode = true + ... + + into + + func main() { + devMode = false + ... -This operation indicate that externals datas (Image/Icons) must be embedded into the executable file. +This operation indicate that externals data (Image/Icons) must be embedded into the executable file. ### Os information (build using) -| Name | Version / Info / Name | -|-----------------|-----------------------------------------------------| -| GOLANG | V1.13 -> GO111MODULE="off", GOPROXY="direct" | -| DISTRIB | LinuxMint | -| VERSION | 19.1 | -| CODENAME | tessa | -| RELEASE | #31~18.04.1-Ubuntu SMP Thu Sep 12 18:29:21 UTC 2019 | -| UBUNTU_CODENAME | bionic | -| KERNEL | 5.0.0-29-generic | -| HDWPLATFORM | x86_64 | -| GTK+ 3 | libgtk-3-0:amd64 3.22.30-1ubuntu3 | -| GLIB 2 | 2.56.4 | -| CAIRO | 1.15.10 | + +| Name | Version / Info / Name | +| ---------------------------------------------------------- | ---------------------------------------------- | +| GOLANG | V1.16.2 -> GO111MODULE="off", GOPROXY="direct" | +| DISTRIB | LinuxMint Xfce | +| VERSION | 20 | +| CODENAME | ulyana | +| RELEASE | #46-Ubuntu SMP Fri Jul 10 00:24:02 UTC 2020 | +| UBUNTU_CODENAME | focal | +| KERNEL | 5.8.0-48-generic | +| HDWPLATFORM | x86_64 | +| GTK+ 3 | 3.24.20 | +| GLIB 2 | 2.64.3 | +| CAIRO | 1.16.0 | +| [GtkSourceView](https://github.com/hfmrow/gotk3_gtksource) | 4.6.0 | +| [LiteIDE](https://github.com/visualfc/liteide) | 37.4 qt5.x | +| Qt5 | 5.12.8 in /usr/lib/x86_64-linux-gnu | - The compilation have not been tested under Windows or Mac OS, but all file access functions, line-end manipulations or charset implementation are made with OS portability in mind. ## You got an issue ? -- Give informations (as above), about used platform and OS version. + +- Give information (as above), about used platform and OS version. - Provide a method to reproduce the problem. ## Website + - [H.F.M Linux softwares](https://hfmrow.yo.fr/) Free linux software on Github. Sharing knowledge. diff --git a/assets/glade/main.glade b/assets/glade/main.glade index 5dcc39d..8669d02 100644 --- a/assets/glade/main.glade +++ b/assets/glade/main.glade @@ -1,5 +1,5 @@ -NQ<`vH@#}|MhW$6a`&ypQCwt@FtTN_u0pZ>v(tgsEs|K;EVAQsmI!;Y_tFJCDGsfYtkW?h}h%yDf zu#LiAhpoofzk6ATY2{1qks7+bE-ZiFG($AIf~04$r=u25&Q0bMNZtOxsKyA><}=hu z-7zj&qoVwgsC+Gb=Rw9PVZ_lVVF{Yg>cU2$gCMV+I|M*C`% zD|}9`z#C9pX^Plf%9k*Ei^Z^LCKG5@)?Ri1BVfW?e0Z!A<0)8OOns`ST(>QS8c1Zf zcQ5L&|72$mPV0$*66{?vsMuSAc<3X)z`j_`x1E^7MndM%97=8(_gFumKxQ zYDPO|>*MkeY3WI08VioU#5n4*c52p?uib0`6?}d?gDzl`R?4K|SDF-sS@%y1W9wuZ zu*@k^)WI$u_k~hj29+B1pE4(YZ;wt#xgH$u=gSSvnslEc)a?FTS62l=<1_v0Y>|oq zuk-xh`;_Nj2ZxT69^SfM|3RG7(3MfR^0QJk=ZFHwU&>;*s5sMYMp%s$-Kg;M)85XF zwZ%X3TD9NB^XZ72$m8-|tck6!vzutiPg8qqp z6U;)QcvyWb3jETJ0r63uB~I%-;o(Ri#(x4)Cip#Y(<|5zI`d9e4LWbyu*q4v&cL$; z+$L`FpPRc5$?DoH?P6Mbd}l9qXKS9iAA)G7+a{UlRCqv0HiX93C37eX0ZPeG zqgknbQ#j@t5Y=LPN|iNG!PAbG(Y>7#vmqvJUyE@8a(L>BXq_X%WtcLS#Y`Ar#MaX1 zY|B>y8B-aXBZIAM9p-^r`h9Dlobq%_VgI<3*MyXZJKu!ie9RI%ynvw(h?P8Hye+|- z$%BtVbCTAl+V%vQ86T?@a>Q@PDa3HL@uqqn3R3(J36gwD0~)0h+2(fyGi~; z9GJxi#R2}rGL$7QbU;=0OuyN^;3;2^c;9Q#N7)&o5OhIfIlA42g6u^qgz|#g#THb- z!uzK0F;wdJq_Zz&E*?gUYmyRh5SxbSvY#9b z#pLaLQO(A$tYoG55^32la;hdXYmEF<@iOa-wb!TC^;fzyKNOrGC1KXGa=^dpA&UVw zE7{rlIRxV!>bP>u_CknxFaadPxFVM`$6UIEh(2Qs1&DYMR{_a@mfYM1E=X85^EU7L z32-n4498NM5dNX`yfpmWzd-hh(G7%g7|fQITAqtGYs%%9~FVP5q^|`00C= zY-P_lPHnp0X$y>Nk-qhFUcvDX%nz5WR@&z0vJO*_5a8g%~G|+Nl1&x z(&d4$)gGbA4o0OQ0cvC_Xw#yjNA}X_by{L=H@jYDl`CAK>%%Ol^8_tHoVWzLh-^_K zg^m&*DvomI-A_--^5+&d{1`-X1o-%T|BeVeHqbJ*?oJ-+G;Ie|irjV9fQ$>P6u!(JpA$wjtKDvXNhN9TT@45QEWmPdwnX+uy5#$yY z0pY31eV)#h=jT<5JU0E0e0sh9mav0*-JQek;oL#oB}GL>4zyFB35n^FJPX*k3ZVV+ z=Rinyy1hVUI@Xe2xgBP#dsg-Fv6a`6t)@*vAw~B|dcE0j*bDb@C$?7OXc~DLQS3&N z?7Xcqc-}Jjc&e)VR5V-%DRzaZrXs+}-@Rs4rFaN23p~LeFkUp2fk?VW1GNI08)Z#1 z8%`z!7A6W;ijy`MhT~ezX&@!`X{QbPJK@`iBKU|#F9(L1!J;3-R%<5>vvV@vHcPEe zpv|nxk3ep?c8~Wj0)mkC(Wp@1=tJ%i(0&NW1fqadas1ir%{Shfyqn74pery#zml2r zj+Q@^l5UhuwnpW0Phm_16fZ6hf%UGk8I)m^qOg_eZMiPE|Fzg^C*x~#$pcSJy5HB% zQK=IhgHVPKRU7u(^;_NO-k7k15fZhNCQY`E%ghf$8V6OM4Oqt%&Ou&Q53|b_WSTC$ z2kx{nLL}?oaXw9b$g2+QXP-TzLZC&Lq`}ZuD4g^Oh4`BoX*KG6WEoO?a#?xj zGqWmr3ghl^upXL09Q5jZ&b zTb|-}^7ug`9*6C-!AP#}EiDaznTu_3Vgf*01J`0{AtNp)`|mpqI_rU^NHh$OGo>JSTjv+^AjQb#$gf{#klyhim> zXLTJ?n}yqorqzF6YBxbu{;`a^dGyWxhMwsU4qp^sXY!P{f4@`NYS~`bq3)OT#p`X= z$@kV%p%4<#PQhnA+8Oi9G7(_o2&ExyK=&- zSwj;{6Wtie<=SA=Y)dGZ4s2mkNjKY2&j_iikmd3!kLFzi+lEE(L0}EoRdpzs;!j$* z9IPNT0Yq7nUARR+A{A8d5f{31Ff+g~NL8Bf{2aL{$3@#>gYBK69!+nukla$1 zguaR9BI;hIf89kbgpy3;1so)f*e%N*7Q|l(Ne}AMJm8O8m}^TsTQd)HCmf%-Khb5B zBhjeW6nHSd{q#oo99XIl?TjW=q7LdsR!N8-@lnuvJ-#48)UvQDM!`HSrbS%tK&Pmj$C2T%!7gPU0*}H|eOQVNp@y`uFEh4?FE! zepr^$q7ZVqO$HjNk0+V)#y0?e=V}zTJA|${D6Xmh3Csd0ogsfZ@FXsxlxeAH>8_Y| zM1io4faDi*HeUU?akX+Ae(11Wa??(hF16K3ph}gnK^Wilx@_^TxwTn(x^&j_D8@9k zxn8keX6g!=q?r!^BrT%qe}M*n1{r>>+)c&gL6;waB|%?4i;sw|J>~VBFSC9gq-DRF z6tSN-MNGYlAYkEMo!V{)=vUX?o_2DAP18D3W56x^`SYi<)7v{trRy*di5>v=sbsZy`; zmT%Xc^1V&Te}6b#r~>|1S#=>z@(fw@_G;H{;h!#2rAhj0IyG_NJWfeTIiHe}!izsr zF$pfNm9?v+!xm>kC0B!1EKUQ@&HNEg&K$uG&t>d9H%r`XJ4-iPBh7W#ISpu^{XAqBJnlVpx%%w&*mOQ4Bl7$pdN;9Z zVWI&Ot07G@z}Ys8+3qnh_cKRGVY9a_#Wa$p0XsGN*T}+T3=7^z_p53OR>eX#$o&r3 zJiN^QipnTW;t?qXThO}mIfjU&v?Qctos)Du#S`r$6M|=Tc1hgME?)if&l5B*5zA8( zf@cbd-QLKX)IW%HBA5u*0ZA_a5#Ca(@QY`o@K8%VrI6~MLa8B^lhA8_1H?$I)pU{rH)~V3~_IBKqJu+xpX*>FcpK%0sy9F)9<0GW3xSOrEOG{bze* zHD5~N%^=cmh-XB8L`mGD&)GNK!p^Yw##qD_h_{QZrg##TlMJLEeL z+9v4^7HEnP0PK-R$#fh~(MEt^^>D8Mi*& za7Z_o_4}8-NgakK+Mry}g~?jx%na$aC|KmkU-vSr;zmAu9^PpF`iyM>I-x^fF`mgp zv%a_nmjE=LKy~6w)0wBlyqFU3dMxzoAV+y)28A*62n;F=r#pn6rGhf{xMVOzh@ZL} zOKo@2(_u)1=0z<9#cXqkQ|ChER&##wcO%ZsG&)_S4A$vx>I~kWWq9+bZ8~A9gxr z6`HE4?EQ_Cw0=<9zYNo?MJEBlx1PNJOd>H!0W|CWdoF2s8tgi zY3KOfT{?!DEZJgX5!WqZk0ekmUWw_8qe*0Qub1`LeMAM#mqTR1mBQ@0Sv9DD?ySdfB zRMLKx%{bM+gYhzEn|T7Yrhkc^m9ng;us705iJmk@Ney`T53;WtK8kPsV1*r;7!G`B z9Ye}tnvn}A%(mFarU1Ljn;lx(TUvxb-&IXoiR;h*z?En2mNotxRopR+Y#32(wb3T6 zz=t7^XUnmbKv#NOMtZ!6W%!pRC{G3?pVh`yRd{T^Lj4t-x;vcNbJuD;)O4hi%!$or32RM^?XliED{rbrwaXlgN?QP|7C zRrs<)<;0q4=7VxzVyZYuAzQs^WuFyLz{ad^_@7?>61X7i(@lcVu=No?IwBqOUsSYu zx-p3n_vV)zHCD$*+srf(GF#~tuIsZ{L~T~(y$e;%GC!1Hni=b8l%68+! zW+C_(G)G93s@E=CksDGr4!Bm`qelYBo_7p$5;>Z|3fr_YOevydx{^iXT+AW5mpaDhaKVD?VuP#Jp>7g&F<@%vdymW zII*7wwxp65ZY^8#e2!mTe(JULgC1!D^t?DqKpG<@E@{3Emw@6RX8zukseA z1-GiJ`Anl!8aC9t4py)%c~ZyZ{IGTDlGt#^D}aUQ$xt+H&mL{3z@`O!A->qUfK0FR zh7o^Nnl$rP!O!PXF_sm6R(^gpnzYMRpvANUBK-c10aG4U8v@a8=r>$atKZ}MGV=EN zs!tJ$5+@N-BAb!-jWvAN3oL7#^suSPwQVXFXukc6nmPzWV!`pR4hTra8{@1-8@;a5uN$Q(JLMqowY|7BYb5r${`u)^~iSrsb zZ*hG|dD&{(M$h2Ko=5Iw!u#db{p4C}e$w=j-~-!|Jc7{hgq;F(pb)@94KcG_%D&UE zC)KGfp7~SDWE)KagU{x(7BCB8RbX4>F_h>x{5pK6NrXGn*%lNJd(2i~tS(fYyWh!| zionKD4rQ+e@v|EHm@$OCVh%^$5?hrnkuvf@C>yD8)@e_7?N#&T8)sl^0*=q0cRHv4 zwaT&@(?_KA`sc$|3!V;Um61sU#xJopdywdpqUcnsDn;hY>fsUxJK4o0zf(A4XeGan zc^x>5b9~HO)Bh<F|clh*l!6eNR3AdAHN!W^nAS+H91lh98J zx?6TX<(~E+^M|q}T}1;uEDAEsH>IOJK>$b%{#rHevpopNx}88AX|2d+-x zoKsKlENY1T3Jr7%1G2>-f|Swq;6Xn7cQWZAaI@_uJD_Aqcc`*Iz{ADfh}qmw#af-f zoVvhW+ZbB@Lfg=4jv#EO}?^_p5R8M#%6WaAuU}9CQ-IfFKPzF3bPcf z+A$aYlcJdc4jD+%2J>J5q|L5j05PUL3KBKB?=R>&g=wuVS^9jo^n1&?^qfmNt_Jsl zX4Wt9zoO$EQ`=bCRde76!DEA7ly~nF#4%Vve!Tt@f`}-0x!Qb2`Rx|1lxR_1M_vaN z6%|gbieF||<2o|}3_Vw6Dix|a&!zjs9+k7&(;qsS2UY4-spDp;%A`qhEko$AOU^km z9d&irqj~&8kYF?%B9#wib3ZXxsv(tte@z?c6U{LsH~!qU4>7Z=P=Vw$|T^M%nkmYmS+w1dU=9j&1c& zmG)ecg6w;qsH&x+BdCR3o+;fD-Qj6nx={Yj&}B#rFq4+YO34>>npWNaC;g zQI{ujK~scASd4F4n5JogMtMR^Nl+c!H}_Wl9!cD9&3xA!E;O#xT7ID~;!`DRJJ#=< zF@GChbMEaL-G9pV_fq|Kd`-%Yiwm6@%^v*f#)!fsTpS3QE z?z7@Jhyp?JKZ?86HQT8Nh3%j z{=%P8r*aTX8nwCfizfY8K;f6~@PDvU2T$!w-vn3b2ad~b8T8MMmf;j1>;BTY^Rd-gr`)c!H^^8?<%WeRZNnEOen*uxjYB z#@Fb12qxS99cLN85$5w70j2|`?dCevvMwmbhNnV7HAi(laPjbh^D2#gJ^}Em$cVX& zUhT-;K&0kMg-cm%Z$m*lntxN!a;>;lL>J#uZk$L<+OTU^wR^NseMMEP-!NT36suh$ zhzFAf>K)ojnP?Qx_BEri5zA-&d#r}>_D;)_0ICR}j7Bq^da2}~o=#LsB=SMW_B^jl z3q1A+e(dMl{R9G$*hZT$<2-YIi1Qf9<}^MMcR-?TVEAG!t$$$^Aq;OFNb;fiM^4&^fJXjiY=;X-QG zM%;Ru)!uvSQIg@l@#H(>il1LxY(WVmhoG)8{u)vdnw+U7PkF6C5*+b(xQ7n!2otK$ z;xHud()T>xMa^BOQ({_TL==SoZ6AR0*AyXU-n=i_LafiI7*!(Kh+W9}&aU;MYr9af zK)Cx-eB{~2`+A9Jt%mS&;-p(|!}Y#)XVoTP2;H?BoF@Y{(Zi;F`>`t|6 zn^i)1N#c0Qy-m=b%@6TVWM!*kM2OCZXksrqRlGx>421j>TfKGGFfV4@XW*6wW*K!X ze4QO0iZ1vkRz1eSVz6L}`2IKLqpH-GdQ9FfK|+6^6Wjrk+KEsCP<{FgDM@4cY1Uu8 z)0@4b$E!x)6{CG~+&2^*JqtsfLemhq07+sXThx=&fi-y1$Q{9c*NvlPvjoDH@WD$S z5Ff~{r4g&eC|W@$0tTx|AR9E)D12_6(PsFtP) zf<(3&V^Z}e=5tnN*=OO<$pPR4tp11D0GGbi)Ks+Aq>aT{wGv@J(wxxmz6StsvwH!j zuADj@^3_0wqQsLd5uc{vZ}W33B&}JWT8*8ovxH4>y-^|!w5>dHRt0l@05b?XT^r1_ z(;NgY2~H-v4;{k0c{ma=;e|tsS7K>0i!d;;4>l8Sp2VB4zn>ezR=zbb7B=~m)X0um-*Q&30bBq?j@qIF2|2X~6um)rIKC4B~+lK+~XKIEXFIyLot;^5nDLykA z*bK<7SX$3pB3NklxQPC|m>y=FgeLn4vQxmz43V94Y#Wwrr%-;JY65wZ&47vD-xbyFcx9Ij1Sfn+1OxeqnWTW2U!5aMGc3MOT_@iy@%5QLUN;WXU zKYt?3)52rxv6u-!BD^gO@{ec_K2Am$)V4ZiZUvu@eAw+Fa|jc~6Fb}Y`MZgyAm8LM zV#o=-@6FE!u6lj1n7j21T7&OpWue4 z&$wX>QRW!9>JUvfqyNek&rSBT^u0H;iIbR0rj>sea{$zXN-(T#Q~3k*Os!j2z-zr8 z8;uBu%T`{1>QDk;>bi!sQTM{9#5X(BsW`7%!DbE`<(l>4y9%+J=%)z&2?YQO)2#kW z>yGw{;`n0;k;>JCVl8F!fZ-eH-VmHNkWRBn{91LlwWf$!P353+OOMl$!mgtu5-^O( z+q)U_fA#oVKQtheLwj4}TvCKENrWPLv0X%L$S#p+vqTy!M!QTWrw5|B$cf{TZhb&& zNQ3WFZXw5t-Gbv~K}*E~?PwPGo20+OJBra-)bHR*ASa)knH3GAk;?I>i}Q^8np(3R zbgEudc%@~Z6-ZOHaI&q<7<(u0Z?vs`mk8;&&t$Io`r}JI>(_g(N{%h-ivE=ldqbxS zY!09etS93#WS2|f!M*ozf~e+H@T@$%IXi*VcLpH-H-p1zFw5kX zg`ZRR;cDwOX6<9f*RQrBC93t=%}syvW3DviZ{E>%jUr9vyOt1j*3niQvzYZ==u4;53QkqN zTmf2;9RFD3nyPmYl9J|}AgPk9bjo9O#08t?(%mZN?tcfGa0LA7MSdgDOd35|LES7qpMrAEuF;Jd}Kcz`XU?era~nW}^hZbm z)`NLU0qdEh#fgiVn7@WT2pi_z(k44pbJ?X&g1qXq&G^zbhcXktTaj&_(PXdNkz%a9Y zA?qRfQz{DfOVum8?j)+w)yh7?{u)|b*5>jUSpL;)45!)yE2psK2190+%;z4 zyV!HQNgFhdEJaPfjd`<+EQcZj=*M^01V1p4FFW&`XH8sv_8f@1t?xP6vR@9!3aA0h zYaJD`Nl8cXvvhv06Myof!DQ|*)iJ`-U~ZU1SZ9-%l4R*Iv?B_I_7Kd(B++9ghGJiG zu5)E;U%cp@^$4OS(3AY;3tp5bASPLqcneQ51JaFAC4|MPPO4w3>v0WqISD+U=O*ea zOYJ`chCr&XCy&#eP=1zDd0&eziqG2OXu{!2p;|>t0X3q3jUY_{`l?7P7Bxes^3PgD zSPAexzILj}ttp)4B}jQ`Z@hD|7^e0a=L&kQ6(3(%xFjd%cqM;m*@=0DvO7zvoT8cJt1NVM!=NGVt z`vj^c#pZ;>!n`h-6Clf0{t0bAv&l^yLAw#&!2 zBF`4{Z*+E*nnhQmD(0WG5TEs~Z8OnEE+X7P99K+y`;R2>@sMzP?S?Pm8)<|K1B((1o|;lfRX&}SB*g7`%JcERz8*mSx|_D|I6=j_CJ;TW z8S~n}s3|2Qulg1DlLgvpkuJ+Wekm3gj$QuxGD+^aa6}3jKuR4=9o$39Ak40|r={OI zfPa}PT~tgq++m+n#DtfQNST}ZHrKqQSKm~(XyB4zNz&wQ%sky8JuEOjMX9wVddATPR~FkiR^iA4@m(Wtq}W#S7lNRa_d zRYcT5^2udiPcYh?+wocC58PzS>COtm791g%iXd2_$ZL-fFzbh_GD$aMKhl}876{b7 zlPL3}Maw(j3luk8VyLI{f-)QXkHeBESJSKTI3%B3vgfwM!D5)l)LLgryTkzaC4EtW z?$oD}PHuUsyHetzf6F1ha-2n?o+$)|1)Dn4mxsLk-l#S(u^&7^awXbjhu_ zZFKcyb~o$!-;wh<{EBSC$~d~A)KcSOrzB+PJ?#Q^fl(HZCgfoFevfqk_&0$U^SY9_ z4JkBLwD_<;6W78}jUVAd?5o2H;Hv|HRCMk6$T%P6alfg-@^HP8s@uH&R+!|C!@uc( zK1Q1)_(;Fal^kukkJA^aSGbDnzI2lL{O(e!YsHQ18lO7;cL+$zItz0j;hiufCj{-| z;p?0ZW72focK&=hDr4+8E)*2pjU*GG35`^gmk)czwr&Qr>&AcQ6X6jNRZp8P(+>V# zdvROccSnM~8 zxNA(L2wQ(tK-}>Le)@744&V3x#R=U&U+MbIOq1(>+5Qq!_q@CG%|e8od8Z$FiP*^V z|yxSja*0`BsoF6RCK4@o6h?Ge0(a4Mm^^PU_Q_`#DEv!iRB|pJbJo;4 z^8B|FOl~BTvUrx)$F;x6HacXZH6bf;;Y5&q=@cJ$M-y`_&76nSw29JtWJ5BkC*k>7c&Ok+&b{&jh_inj zGK1XZGn*=@Lf}{*rU^-cih6FLdjFpQ2oLx0d=6wk&DMSc&SvlvQCTf3F)1~oTHt}L_j8SSYP+kVPCdc|DE99eB<6HR!Ft(| zGa@5tg;}%z>V{?Z*uPhwWrBgwp*j)37u7su&0K}83hD;bdt#mz$c%&mEmiZmAs{N7 zy&tkh2mSuJfgl)*g#g#|lFCGwn6L=Krch`6P&RB*-q^X0 z2#Z*scm7ml&2;AxNA?`I>7|$c;Kx6#mdlkdR;%UTEP!7N8>Kq)&O}(v8H(S1Gw+j! z1E3h)N?3#B9T#v zKz#OG8_>0wsG!{(@N$HD4Uv94QmK_ZtT^4mt->+_0 z&-Cpy8SJfOO(<~&e0xaONgR8+aY+B$bPv&@tS^l27 zGOSArSRjJr(WDpzN%vpzPWikTOES&Fj#e0i0?1h*w7VAuDhKRDlVwDa6z7x}U6X7I zp>TZ^crwn`6=V|8`C9Jt}E|mpP?*VfL4k&wkq_??f+8MVnjLsMVJd=wY2ex`PMUN0eEPGB#VIG2bqhg z`{Zpck`l<-ElB(tyhd{Ptc*#6=jav#qWW%(NGbk4(<_Jp63Ds&NM}L9o#1P0^F4Hq zuV4l(%K%)Shpa~p-pOwdn0Rxr`4Pjgur_UYUIg#5`1hI&ik<@~O600{-udp=&wcOR z-(0x*-zfTv2y>*wjw%}jr&XOaAn3e5#3`JD6#<&KeHlF>?!Et`i$>2V5Z_(uf?ux z0BiwveA2{Elkq0$c-qirCB^;DjME~s9O5a+@Xr!p(^jS-VO<&EB)~}ImPv|F-4@xc zrIKBJ^N^fn=e5GmDd=&Jb6iDI;03V>{v6p^)_9Tk;CIbHB8kAWqJj2qf~-;})3rDR zFgL+B>49`5zLYh7HZ4n9v9q6;vvVN1g#fZpYRdsT)mFy;-~)Z^r7$q^myo&-V?@tO zK;4@fl$;2pTBVZmkxKFT*hxYDudUbUdYGrzyf^5F6n6ns5s~r~6?8-twK^-g4%)O* zU!{+C9@7rb$Iz0aWNZZ-dtgwV(B^Q`9M6RbmGr|jVACTl9-0*Q?C7igJejg*@sr8f zOGRxeGG#7Bd_9x=CzavsFkmkQ49Ym6fxpG~n}zR@!)3QL%lCsY?q#BRmT9J7<00&y z_@Jgieoc%mui+lARa?AvHC5aPWneHcS17#oiw}POtIz-bk9@7R^S6bK=btXb&snNN zWsL3lC-Y*HbJfG@h`QB+wZc=$Gov&x8AUHDT@P!K(PM<%2{&#b8 zb3ZtF@?`Mn(W8GYFE4+3^XAPzUcP+!OFFoh#Op^REAh_0GQ_itSWBJd=l7!82kTLa zK}Aln(Xcw8DVOiPz#S>)c(G{{(W8EJ%5n?{Ue}z6bF+Ru&|V|jZvT%#SG&(^m|*5) zflYU_+_a_gb3h$)F2n+4z8p z;Qv7Ls-h%Yg6;M@qyZ$;UJ?hIMI&GmvH-GVhc7!d0bRBPsl-9Ay>Jx{7EuYSHG-I^B6v zr7uAG^DXa6XvtuBC}{xq5u!(ql2m*ui;gmw^^80oQ)L0!gdv`iC%H>fukpM6oWaGw zJ+Mkf9-gN7eJTR$f}pGotZN2@D=?k+qD6_g$T zkPw(HS}d2p{r&ge`(Sl#ExhsBXTNQ3Z~t2nHQGeA2GM3)sn*%EXM=0kt_5e#oY6zd zQyCb;Y0ec{U`ynAb&mb09#S{lvgvRw^5(vd(HUvU)1^z7epDTNxtFRpJVg>OMhJ$@nSq40N6kvOsXBoP`mQ;{zh=+PxGl9pw};D*6CMgk_b) zsDL#InNizj7AvucESaRM4)dLaHvSm^Lmjz6b<0Ajau6~vF!(A3sF3BAkz+YJ&mXqv zXtu|>Bz;yC$UFkPJ0Bo11`mc@?z-QN7&muZVBkLmlB$3%k&eWqE5`W%WGR&*%?VhP zmIHZUDLcLuGF_CnDL!IglQ)IoubR|Zpp=TvojVuZx^*j!)z4{jghfUf;3;cG zq|F=)V0`L_A={LazPt>uh_Xo^`rIDrBJ|;hA5Inug>$Q`tN*-s@#0r>gl8L!2G;8f6+Jy;^hf6EArVOo**_8&vAE0&5P^fA(f0TYN9upVis>kjj7P4GK*ql?JNbI zi)1tnl;%3Wq^p&fp&91*irjPpWF~2;FY-lAcUQM`d<DZs&&T(HELELO*Z&wWZ7{E#V$06b`mkx;NJ_f*pJ zLe@2t#YUvDF9%&KQ`s9^u1d#jsn0A?9c1}f$a-&Z{5n8Z8wn?C0jkX-oPW~pV4l}7 z0ZtyXP*_#gwxmInd;AoTD|4yNQq&4>x*DTMs=S^TSOS`Ybpu&S9B4kPqI2$6XH1wO zS|9cEFL8OeP8!2;9wMt+uMV;LckFb3DN| zhuuQj`kf~jSj+&s(9-6-q&6jwoA>4VlmSGuuv6F~(@5)CWx(#n2fU|gW~OF1fs3z2 znhbg>nZP1!Qk9a#36iCT#1=5{3fTM}kSST01*_BPxzZ=azGNz_yfIi~bjm-Vu@Q~8 zRC$FqS4##cdvNb!CY`p}Nl8}PO0b~?ny3fpvq2Lkz$`ys@tR3u7U}8PD9dqoTkE7M zNSltnd5eXKENK$&Pe8X)v9$eyVt?2M?O|FT;yp;esac9Qol<0iKvwQSdi^vgzTVBF z03f9#Gt-%8)p3!ET#PN~@hLv|DmbJ`I?Xh#bjED4mm|PLQ8p8LLKYBhOrySvJvh&f z>baF;nt6eBZ8Q+$jt}LUMAI|qAtaPLk?92!Qp^}_4BE>lC2@HvJNmTGJ3IMNNET%y z4TwA-<+nLX_iJ=2V)Q;2sa?LlOBMnjP0u6@%!sFxMqXrcdNC&A<*|XJwphi8lKp-N zOs&$NB_TJd{vO4VN>Br^n?+{*Cba3>=dKDGOLjr_1`{nN z&Vau-f~J00s@obC_}T-Q`PA)iIaZ-f7hy4B=HSDp^pbG9o?P_+c=kuAO?8(I9Hh@u zO(j`i{ooMh!Vumc>8d+V=1|EDY&Oy=&IDMtxGHgdT-J}0VY&(w`-&z3bO_7Q(ncoS zrr3|t7?&|A!TM9(rMl6Di;*%f(*GlkjxQOC)8}1kP<=^ui#C8Db3(Wz5KmjBx0c5t zf}NpMK-4Q^00<8wmUi#6l4i2i1F|mTvgXP4N26l7#%NqK)Vl(Tw2^D2l1TuAQt1pC zn$QDyZ)$L=c<|teJsA5~FQh+9fqQG&%_osH+M$?r9=mm+l&q|>ncViUH@6PBxHwke ziBj6Slhq@@#l9C`kxllJPZFTRGU;}eDOZlcn3TKAt-F{GN#c;q$w~~iX*cS}On-n% zvGBnw0IJKTGRLzXDjvIFSM9Z>kIu{d49Zq%J~QXx%X0k=xVUiP!o@L;rEbINxW`N7 z-*Mr9iwhSnTpSlbVY66i3B2p$!7*nK`;n;j84&{|$I3e3;=+Xs7cTaZjMMx-Y8NmQ z9Y(TU>aWVGS9A>F6~~~saKOcd3l}b2ydr=NJ0y=HUJ2ih3l}b2xNzaZg$oxhT)1%I f!i5VLgT?;=kr!3`@aF?A00000NkvXXu0mjfp@gUu literal 0 HcmV?d00001 diff --git a/assets/images/search-folder-48.png b/assets/images/search-folder-48.png new file mode 100644 index 0000000000000000000000000000000000000000..4541d1b528a8dbcae84dee50a29d5d2987110410 GIT binary patch literal 5071 zcmV;=6EN(FP)NKR zwVh<9&2+U*I%%0CYtm^F=;~@#o@7c05O5yg1h7*(1p^`2mW^x+Y|FAG%X&*!_i^S2 zvaqp9R_Nobb(XH~(Y^Qk_Wt%h`<^3$zo7m8`4@E+t}@#Oxsw#{I zBWmmFux{Nt$>nmz-F^Mf)YUHk$>nZ%-+lLe5x`TMHf<_8efl)>qa-{<#KJj{r20T*Xyx=|9))WzWs-X4jp>p zuS($j`Qh(Nvi!^5-dJtqUEFe{X7P`dWQ`JvffT;NT!6NkU#;9=31a z{@$yvzPjOZSZ=%RwvB=yEP3ahceaN@A?Z^IjEs(cTdNfwKXj;-ag{C7cBScE^q#>xYJh z4g&ypIq(C6-sM`Y@T<4qd568K)TzxYEFLXf=nOFw+++rWNrhxs2H+V$!vILP)mX@+BSFXIatE+2I z7PO$%YBv=Y7Cygr?ONT^rAtGPKmNEa7K>%3ue&S(qfx)}#EC9F#}XLwiw3ME&VZtV zR~e}OG)6KMiiv=5+n<0@pBrUXM&*aG>hr z{?p&CxT>_IZcQ_$LLp2}O~O%ZM{HRGIF3Vqe?KZJDxfGz?wP@05I5g^GjuxL#=Gyn zd-vkSi*LU3&O5n-2M?Y(eE6`BQYx`5TPe%(1c2lx5?H*r^535Q?K1$wrAn4Ix+jBS zJC!q~ECa9_?eJt$CvuDi90TwysD=fSV?)k?lY_UKcxK%->(;_zFu>>YfvPHamVrUb zqOh|%z1eQMsr?)D5mRUJ)N7?;HZr= zB0)oA_VJFl?$t)de!8N1>AL3CO`s}8a54ar1xE77tX|y=uh$EfWx=v6 zLZJ}6UN7`|J#N1FW(*7r3~bxB?U*QvF+mV005A+=R1`%kisBf6%g2DT)Y;T_^oTy4 zkx)@xYh37D1cm^VssN=hTWn~kUQ&O&>-cY!k>iuBPGei!w302%w?K?X5syZ}P!$Xz zP-keIBLo@_u-FPQJTi)kiV6gSL5z)!!DKRF>(;I4=;(mo?}yjxH4B13X2c2QIL@jl z3YW=bf&i3x2|V`LFUw-l$SplRy@V11N5xVA6h;n6NE8`L0hJ;z&x{T0*E5VN+pR_e zWHE_YGz^|lFeK~NO9}!)2soC3PRqj|ieq6(3EJA*al;Kaz~OLU@7}#gBoZ*2&9GQ3 z_GB_C5JKVrz;T?FQmR!|m6IeXF!R1S0?$47oP+22HbD>;4h(oeSRR5&fL2vu<_T1l zASuzT?kE&R0UgsBQ!(p60eHx0Q zfMFP9G8tGb76bwTmn2E2Se9iujj5bx^)X}HXB4S4Z&c7 ztO6V%P*fnAp^#MyRiz*VIZHDPxp@oWLd)1 zS6>Y&okS=QMO>z!AW-Oq&{wl^UzNDPTo5>>867#tjg zUa!xAztj_czaLhsRimn^Fw;RgosOHA0K+g127>_rP*PHY^0KRNzONS%Q3V0L2#Nxf z&eeR5#5^^QPNzdOooG@620 zS?HN(o-q+Zb}U`G^ozB%wP0Bm;YbAkbn7kn=%eE(udc;-640>(qC#iX;B=1e$vml3 z6f@B2jYy^?B+?R^RxHJV1N&hznIH%PL{Xdre!9evWf?l1&J>TwCkY|)yfF}q#b7iV z7p`8tnw{2UQDGqp>~^TJ3B)5|gi^}vU?sDIcBb`b%7;>lNHhY#4TdJyJMrMRwuLr|0HcBZNhEXq_VVH*=dMGwBGO~YkbTl_02m&grs<6zp z2q)fafg}M5Q35Ch0ljGPY5B|oe}O?H62ZB1!zgi4z_sbmUbDg#+kpsE+5nIijOMMWqa#_5l{QCQ+c!Gcos4vu2jKZ$h>i{bUS@#tfZ zp{c0}TCFzsCZ?+DEZIzhCxpOkHlwkz5k*BsU|AMC&qJ%#+U6}K5{blrbaizdbvPWk zLA_p&B}sHdYeUc3Axw;(hiicW zYTS?SfA2f!{P07pYG}YeZrTLzz(BTS$jl1hX*t>LcC1;m29=eSv(z9-5(0q$SeCT` zU~^+L*)%sdk6W$QJEpxbZ6TiLQBzZc-d;Cee(?n?E_0x9SviVK1T+;!L7o699)J=X z2d}0vdVUbwpL-U6{No={UtbTG%Y~xiV)%xKv8<*BZ|y$-uXhMmn+*)ZKvh+69EaN4 zTC7;H0xZkU@=P!oM0CUn&lF1}mTU+7rcp!=*L{UUW6cLF=kw_#EjYeTG7*JhZjg>1`!fLf5l}h1*4?Y0T z^C&7RLSy49?Af~qf9mMO^&8g1>2zYr(xosM43H!Vs;Yugig-MZ?(S}!IB^1lgM(cj zkLO9Z+kF5)vn4hG%d#MZ zAdyHQolZlNB*f!!3=R%rWOxLp&h+5UuWrGpZxmf!$MO5${SL`w5{jbaCNZDShqksh z^!4>+dU|^P+vD-P7>PvA&U~4fBcZH}!l_j1%XM{i+Gz=0+NW#xp`jsERaL=gG(r#r zXtmm0ftF6EXRZ6NEQ{T{cjM((UPdyJ#ORnGcYN`7jE;=q$dMzs=9+b<L6meDu*r zIB?*A>UO((4j(>zugBwgA^R#hXWeuTf%f)xUtL|@hO)A6tW>$sm)-d&z?wB{K37~^?6O!abF5DY!PwXs7=}SnQBls?vMeK&O66i@ z+WK0p7EMh}C@n38-EK!y(<;37+W#RIi$Y9`2u+1?_g!DZI|p0w-r@Hj3Wq{_KgsH! zN&o(}A;2iA`VCR#IMdh9PEuzdOQP%IW(-q6snL=c2o za$pz+eSLj!I-TG+E(a`~PUk#fHk(mbR|mV@4u)Z7<#nIWhyMP4jQV^C1_Fr1A_z`~ zAge0Ay7?=*{<8zOjt-AJL!ru7OyIOB!CzIAhB96() zDOhY)T)S?q$$S3%mT~{sb^!7f5y-|ue?>*bbqQ$t zjE@IVTe}=<*Q~L)`v=xUrlPx5s${N+001}~j(5}P^bhOn>vM6SC<;!UI)&A%S0f&e zBb7>_w6qij1qI+ZZccG_?AS59_~MJ`=;%1q($ez4*|TSNP0yyWXf$feFKE|jwO@^d z!(1vA$B=gfjVo7TP4nuq?p}BPR4BOriV1XgcgJgMYbBG(w880gLY8I7vW&sOLDbdN zL6&8dl$3zy`8n4HgF&>kwBU_5-UxJbbUb?K(4ilv)9JoTXVXX|JYrw4K+$M48^Yl! zWYTGPyyvlQ?HX9EmX-eT2`M}kYP%u=*-UaKolf7nYSk(`!!SrDlNcQxMNLf&1VNbh zny#)cy#D&@IB?*=>+S9BKj`V{c^yFXa?c2dLhS{GMT@i=ZGC7m07=TgH#UxczU>QC ztJQ8u#$turwr%_Ko;`b#SF|7d&2N75u9seVDMKlxUayz#-o2a7*F;gIufF;!eel5t z$E&KU?qONB@U!fOmRD3AwHFpqhGA(@v4d{7{wDh7zI}9Ub2Ghu2mMlAOvD&E7Xrxa+ z{WR_G@2C6Tc!OTOY8748*!Z>2ETI`vdOH${-0yTc`BW-}^78WO(qmfd{T&@0zj*V_ zH-Dih%GvBX*k@`}p~;v|Z#Z3E;oAJ&Z$H3jG#V^eumEe;u7%xh$KJhr%csKO=RS3h zY`(T@*DjycYW>E0@4feOZEfvzkfWug1t(6Ncx~s-osR+N{j}WuX>H`Zx7D6+9m==c zE2t#l!w)}1K|ukox$Zi+Dk{PQLqk{Qfvgui02&r9Tv$0UFo0dVcJ=SwyY~mJt*uW0 zIDgA6w-8lT*+e42DvH8ojl^fWHrs`4*AYSlmSuGS3;;|3@(3Zev9Yl?$Nc`y*R5Z# z4UUbW-{V1RYb)Gt_m4(KMuv<=BV(~xD7g{~ed}A_s@CiEkDfbsZm7Mz{SWDMy1%Qd zOMT^)S2U+iozl47ZjIOL)g%%Leg^oNeVP=@vMfUg;T1*EQc6t#@&OcPi8$)&>gpF) zRayG``=g^iU;D(w#9JK4jajYMUYpG}Nv_n*X0utFNF<1&DCwS_9&+;JNz&KX$8>jh zGrhgNtk>)1lF1~=dYR3Z?%a&y3)>498c`I5&+Y>lvt18B1Ar1jG5}JP(l~%P%d)Zj l{QOCW!|`|hXUyNE{XY?NMEgAEjQjuq002ovPDHLkV1gW;lJNil literal 0 HcmV?d00001 diff --git a/assets/lang/eng.lang b/assets/lang/eng.lang index efb3b1e..cf3aa5f 100644 --- a/assets/lang/eng.lang +++ b/assets/lang/eng.lang @@ -1,18 +1,20 @@ { "ProgInfos": { - "Name": "SearchEngine", - "Version": "v1.3", + "Name": "Search Engine", + "Version": "v1.8.7", "Creat": "H.F.M", "MainObjStructName": "mainObjects", - "GladeXmlFilename": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/glade/main.glade", - "TranslateFilename": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/translate.go" + "GladeXmlFilename": "assets/glade/main.glade", + "TranslateFilename": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/translate.go", + "ProjectRootDir": "github.com/hfmrow/search-engine", + "GohProjFile": "search-engine.proj" }, "Language": { "LangNameLong": "English", "LangNameShrt": "eng", "Author": "H.F.M", "Date": "Mon, 11 Mar 2019 09:49:19", - "Updated": "Thu, 03 Oct 2019 01:30:02", + "Updated": "Thu, 03 Dec 2020 02:45:27", "Contributors": [ "" ] @@ -23,557 +25,428 @@ "SkipEmptyName": false, "DoBackup": true }, - "ObjectsCount": 42, + "ObjectsCount": 32, "Objects": [ { "Class": "GtkImage", "Id": "ImageTop", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Click to show Aboubox.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 0 }, { "Class": "GtkButton", "Id": "SearchButton", "Label": "Search", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Search for defined parameters in\nselected directory.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 1 }, { "Class": "GtkButton", "Id": "SearchButtonExit", "Label": "Exit", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Bye.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 2 }, { "Class": "GtkButton", "Id": "SearchButtonExport", "Label": "Export", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Export results to text file.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 3 }, { "Class": "GtkButton", "Id": "SearchButtonNewerThan", "Label": "Newer than", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Select date time to restrict\nthe results to their newer than.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 4 }, { "Class": "GtkButton", "Id": "SearchButtonOlderThan", "Label": "Older than", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Select date time to restrict\nthe results to their older than.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 5 }, { "Class": "GtkButton", "Id": "SearchButtonResetComboEntry", "Label": "Clear history", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Clear history content for\nAnd, Or, Not entries.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 6 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonCaseSensitive", "Label": "Case sensitive", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Take care of the character case\nfor searching.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 7 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonCharClasses", - "Label": "Character classes", - "LabelMarkup": false, - "LabelWrap": false, + "Label": "Char. class", "Tooltip": "Use character classes to search.\ni.e: \u003cspan foreground=\"#6D0000FF\"\u003e\u003cb\u003eOk!\u003c/b\u003e\u003c/span\u003e\n\u003cspan foreground=\"#230B49FF\"\u003ewill be converted to:\u003c/span\u003e\n[[:\u003cb\u003eupper\u003c/b\u003e:]][[:\u003cb\u003elower\u003c/b\u003e:]][[:\u003cb\u003epunct\u003c/b\u003e:]]", - "TooltipMarkup": true, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": true, "Idx": 8 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonCharClassesStrictMode", "Label": "Strict mode", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Use all character classes equivalents,\n\u003cb\u003e\u003cspan foreground=\"#6D0000FF\"\u003enot only\u003c/span\u003e\u003c/b\u003e: [[:\u003cb\u003eupper\u003c/b\u003e:]][[:\u003cb\u003elower\u003c/b\u003e:]][[:\u003cb\u003epunct\u003c/b\u003e:]]", - "TooltipMarkup": true, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": true, "Idx": 9 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonFollowSL", - "Label": "Follow symlinks", - "LabelMarkup": false, - "LabelWrap": false, + "Label": "Follow symlink", "Tooltip": "Follow symbolic links when they are folders\nand retrieve their contents.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 10 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonRegex", "Label": "Regex", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "\u003cb\u003e\u003cspan foreground=\"#6D0000FF\"\u003eAnd\u003c/span\u003e\u003c/b\u003e search entry is considered\nas regular expressions.", - "TooltipMarkup": true, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": true, "Idx": 11 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonSplitedAnd", "Label": "And", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "Arguments are splitted and searched\nindependently as \u003cb\u003e\u003cspan foreground=\"#6D0000FF\"\u003eAnd\u003c/span\u003e\u003c/b\u003e logical operator.", - "TooltipMarkup": true, + "Tooltip": "Arguments are divided at the space character and searched\nindependently as \u003cb\u003e\u003cspan foreground=\"#6D0000FF\"\u003eAnd\u003c/span\u003e\u003c/b\u003e logical operator.", "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": true, "Idx": 12 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonSplitedNot", "Label": "Not", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "Arguments are splitted and searched\nindependently as \u003cb\u003e\u003cspan foreground=\"#6D0000FF\"\u003eNot\u003c/span\u003e\u003c/b\u003e logical operator.", - "TooltipMarkup": true, + "Tooltip": "Arguments are divided at the space character and searched\nindependently as \u003cb\u003e\u003cspan foreground=\"#6D0000FF\"\u003eNot\u003c/span\u003e\u003c/b\u003e logical operator.", "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": true, "Idx": 13 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonSplitedOr", "Label": "Or", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "Arguments are splitted and searched\nindependently as \u003cb\u003e\u003cspan foreground=\"#6D0000FF\"\u003eOr\u003c/span\u003e\u003c/b\u003e logical operator.", - "TooltipMarkup": true, + "Tooltip": "Arguments are divided at the space character and searched\nindependently as \u003cb\u003e\u003cspan foreground=\"#6D0000FF\"\u003eOr\u003c/span\u003e\u003c/b\u003e logical operator.", "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": true, "Idx": 14 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonWildCard", "Label": "Wildcards", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Allow using of wildcards\nlike \u003cb\u003e\u003cspan foreground=\"#6D0000FF\"\u003e*\u003c/span\u003e\u003c/b\u003e and \u003cb\u003e\u003cspan foreground=\"#6D0000FF\"\u003e?\u003c/span\u003e\u003c/b\u003e.", - "TooltipMarkup": true, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": true, "Idx": 15 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonWordAnd", "Label": "Word", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Look for the entire word that is not part of another.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 16 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonWordNot", "Label": "Word", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Look for the entire word that is not part of another.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 17 }, { "Class": "GtkCheckButton", "Id": "SearchCheckbuttonWordOr", "Label": "Word", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "Look for the entire word that is not part of another.", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 18 }, { "Class": "GtkComboBoxText", "Id": "SearchComboboxTextAnd", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": false, "Idx": 19 }, { "Class": "GtkComboBoxText", "Id": "SearchComboboxTextDateType", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "Select how to display dates times.", - "TooltipMarkup": false, + "Tooltip": "Select how to view dates.\n\n\u003cspan background=\"#FCE94FFF\"\u003eHR means human readable, less accurate\nbut more user-friendly.\u003c/span\u003e", "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": true, "Idx": 20 }, { - "Class": "GtkEntry", - "Id": "SearchComboboxTextEntryAnd", + "Class": "GtkComboBoxText", + "Id": "SearchComboboxTextDateZone", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "Search for arguments as\nAnd logical operator.", - "TooltipMarkup": false, + "Tooltip": "Choose applied Time Zone.\n\n\u003cspan background=\"#FCE94FFF\"\u003eThat will be applied to the files list display\nand the searches when using time limit..\u003c/span\u003e", "Text": "", "Uri": "", "Comment": "", + "LabelMarkup": false, + "LabelWrap": false, + "TooltipMarkup": true, "Idx": 21 }, { "Class": "GtkEntry", - "Id": "SearchComboboxTextEntryNot", + "Id": "SearchComboboxTextEntryAnd", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "Search for arguments as\nNot logical operator.", - "TooltipMarkup": false, + "Tooltip": "Search for arguments as\nAnd logical operator.", "Text": "", "Uri": "", "Comment": "", - "Idx": 22 - }, - { - "Class": "GtkEntry", - "Id": "SearchComboboxTextEntryOr", - "Label": "", "LabelMarkup": false, "LabelWrap": false, - "Tooltip": "Search for arguments as\nOr logical operator.", "TooltipMarkup": false, - "Text": "", - "Uri": "", - "Comment": "", - "Idx": 23 + "Idx": 22 }, { - "Class": "GtkComboBoxText", - "Id": "SearchComboboxTextNot", + "Class": "GtkEntry", + "Id": "SearchComboboxTextEntryNot", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "", - "TooltipMarkup": false, + "Tooltip": "Search for arguments as\nNot logical operator.", "Text": "", "Uri": "", "Comment": "", - "Idx": 24 - }, - { - "Class": "GtkComboBoxText", - "Id": "SearchComboboxTextOr", - "Label": "", "LabelMarkup": false, "LabelWrap": false, - "Tooltip": "", "TooltipMarkup": false, - "Text": "", - "Uri": "", - "Comment": "", - "Idx": 25 + "Idx": 23 }, { - "Class": "GtkComboBoxText", - "Id": "SearchComboboxTextType", + "Class": "GtkEntry", + "Id": "SearchComboboxTextEntryOr", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "Select type of file to scan.", - "TooltipMarkup": false, + "Tooltip": "Search for arguments as\nOr logical operator.", "Text": "", "Uri": "", "Comment": "", - "Idx": 26 - }, - { - "Class": "GtkFileChooserButton", - "Id": "SearchFilechooserbutton", - "Label": "", "LabelMarkup": false, "LabelWrap": false, - "Tooltip": "Select directory to be scanned.", "TooltipMarkup": false, - "Text": "", - "Uri": "", - "Comment": "", - "Idx": 27 + "Idx": 24 }, { - "Class": "GtkSpinButton", - "Id": "SearchSpinbuttonDepth", + "Class": "GtkComboBoxText", + "Id": "SearchComboboxTextNot", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "Choose depth of subdirectories scanning.\n\n\u003cb\u003e-1\u003c/b\u003e mean infinite.", - "TooltipMarkup": true, + "Tooltip": "", "Text": "", "Uri": "", "Comment": "", - "Idx": 28 - }, - { - "Class": "GtkTreeView", - "Id": "SearchTreeview", - "Label": "", "LabelMarkup": false, "LabelWrap": false, - "Tooltip": "", "TooltipMarkup": false, - "Text": "", - "Uri": "", - "Comment": "", - "Idx": 29 + "Idx": 25 }, { - "Class": "GtkButton", - "Id": "TimeButtonOkNewer", - "Label": "Ok", - "LabelMarkup": false, - "LabelWrap": false, + "Class": "GtkComboBoxText", + "Id": "SearchComboboxTextOr", + "Label": "", "Tooltip": "", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", - "Idx": 30 - }, - { - "Class": "GtkButton", - "Id": "TimeButtonOkOlder", - "Label": "Ok", "LabelMarkup": false, "LabelWrap": false, - "Tooltip": "", "TooltipMarkup": false, - "Text": "", - "Uri": "", - "Comment": "", - "Idx": 31 + "Idx": 26 }, { - "Class": "GtkButton", - "Id": "TimeButtonResetNewer", - "Label": "Reset", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "Reset newer than value.", - "TooltipMarkup": false, + "Class": "GtkComboBoxText", + "Id": "SearchComboboxTextType", + "Label": "", + "Tooltip": "Select type of file to scan.", "Text": "", "Uri": "", "Comment": "", - "Idx": 32 - }, - { - "Class": "GtkButton", - "Id": "TimeButtonResetOlder", - "Label": "Reset", "LabelMarkup": false, "LabelWrap": false, - "Tooltip": "Reset older than value.", "TooltipMarkup": false, - "Text": "", - "Uri": "", - "Comment": "", - "Idx": 33 + "Idx": 27 }, { - "Class": "GtkImage", - "Id": "TimeImageTopNewer", + "Class": "GtkFileChooserButton", + "Id": "SearchFilechooserbutton", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "", - "TooltipMarkup": false, + "Tooltip": "Select directory to be scanned.", "Text": "", "Uri": "", "Comment": "", - "Idx": 34 - }, - { - "Class": "GtkImage", - "Id": "TimeImageTopOlder", - "Label": "", "LabelMarkup": false, "LabelWrap": false, - "Tooltip": "", "TooltipMarkup": false, - "Text": "", - "Uri": "", - "Comment": "", - "Idx": 35 + "Idx": 28 }, { "Class": "GtkSpinButton", - "Id": "TimeSpinbuttonHourNewer", + "Id": "SearchSpinbuttonDepth", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, - "Tooltip": "", - "TooltipMarkup": false, + "Tooltip": "Choose depth of subdirectories scanning.\n\n\u003cb\u003e-1\u003c/b\u003e means infinite.", "Text": "", "Uri": "", "Comment": "", - "Idx": 36 - }, - { - "Class": "GtkSpinButton", - "Id": "TimeSpinbuttonHourOlder", - "Label": "", "LabelMarkup": false, "LabelWrap": false, - "Tooltip": "", - "TooltipMarkup": false, - "Text": "", - "Uri": "", - "Comment": "", - "Idx": 37 + "TooltipMarkup": true, + "Idx": 29 }, { - "Class": "GtkSpinButton", - "Id": "TimeSpinbuttonMinutsNewer", + "Class": "GtkTreeView", + "Id": "SearchTreeview", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", - "Idx": 38 - }, - { - "Class": "GtkSpinButton", - "Id": "TimeSpinbuttonMinutsOlder", - "Label": "", "LabelMarkup": false, "LabelWrap": false, - "Tooltip": "", "TooltipMarkup": false, - "Text": "", - "Uri": "", - "Comment": "", - "Idx": 39 + "Idx": 30 }, { - "Class": "GtkSpinButton", - "Id": "TimeSpinbuttonSecondsNewer", + "Class": "GtkStatusbar", + "Id": "Statusbar", "Label": "", - "LabelMarkup": false, - "LabelWrap": false, "Tooltip": "", - "TooltipMarkup": false, "Text": "", "Uri": "", "Comment": "", - "Idx": 40 - }, - { - "Class": "GtkSpinButton", - "Id": "TimeSpinbuttonSecondsOlder", - "Label": "", "LabelMarkup": false, "LabelWrap": false, - "Tooltip": "", "TooltipMarkup": false, - "Text": "", - "Uri": "", - "Comment": "", - "Idx": 41 + "Idx": 31 } ], "Sentences": { "no": "No", + "ok": "Ok", "yes": "Yes" } } \ No newline at end of file diff --git a/find-48.png b/find-48.png deleted file mode 100644 index dfc7aa8a79218b6cb3b3f78f2991b7aefe2ca908..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3911 zcmV-N54iA&P)q(33!IZfEi;P za3IE!9K}lvcCaitQlcobz;du-MGBU{vZ4@d$4+8on`PV>%oxmOFdo2|&9gBx%nZ#; zch|nXdds~he^d`4KO1$|b59XY!M3mY$WShszu2|iEkejO zQph19@&pMDpelqsY)a#K%d{UO#v@<((dT@;!$ymJV5)zc9POR>{hn0spShNMu3;FW z&_@^^X5?}V#{rlL%_d`ho^bRCqtzrb4YOvO_V*pjz2(LopLyy31mN6dA3Sd)Klash zA~Q9e+T;H# z0LyZl?6sro|85{R{OP4jC4KNp#;Vo&jSlncw|GN$_x8jX6vYCMK4RdWA8K&qR?>;| zwSTkYGk5)u0<0~Z-7`79>8}1<-#M3Eu5i(N8A5=&PJ`np;)5@1eeeMI_;JmRmVzM& z$)uveL8gfbMPo~BVOlnI$0MrOCBFSFiQO*=&LwkSv<&-8H{5wGpA3NU+nhgR;;f&H z^ySa^LVXl<5eqblmlTTQ>QVVshQ`gEeBC;&4q6pge4U5T4CoPcVPu2Rg1H6sinQ969cIR5M|ul>@mGwBds ze_qO~u4)8<5;d)T3-8!kGwjvWlK3TFw}rF+c9$|R@@1~sH37N5JHBTk%>IWX)eb3A(D{#(|_ivdT z-}LC^SAZ`4fB*n)w@KZ6lZcKUli|pfm%LV(T3b~botSke)(As|DAXJWVZ?s5MnSVF zJJp(@qR5h_=`i4E6+1`n-_c)as-6qZ3guPXEkj5{C@tycZ(G!A=Juo$>CM;QaZPyA z3QS}sY2DbS+gB|0Mn3wdAR&k~3;mB@m(k%@?QrGCuR4-jxvWe;lYxe2ZfHhBF&dH5 z&9Lpa+og){SF4?7sTlgTY81BHDrhvcR+{tc&Io3X?4#mg!*yhbmW~-D1ZZSX(Br?1 z3$EqPKeFfEUH@GG@#c=<{KR{DQoUO~aD{@D!~pR_4;t~y`=na-huddzONOhG&?G`# z5UKq_IM=8gJ=_W! zjduQ=^Jixpweao-4aHh9nECuIF}FLdVa@sjC$)^O$Zk%1PHOv>b2Nwq1H_L$B$S4& zMz?R9BNDya#tN?(Qj%beJDA!3vD;6C>mSL|N9Mm9^0Ki8MlQs;4Qxiii z5{L;10R#+mNW*8MHW4)i>qcLXRV69>PHs?nX-}jxDf{W2535KBp|rLDxBz^B0@gZY zts@=Bu_*NVwPG_{t<`icC&fU45vhnZ^lAXR7o`9Z4P>(1-5rQfE)iQ^A~qZ=CLl() zMFI$gKp+J=2BDKq7%k5hZA+qUOSDs&WV>(aczbNcMANV=Um8Y-hyo%J3LzqCT9J@4 zCLxqar$c6Nr49hZ$pnK)L$e-Ov;tDdL^tQ^?r~u#ARS8qVCtrrdZ8%-6o43n$h9bx zgb0jC2`I}DB3;Od!IjJ7FbzT{ z^plGQh*cbGrC%3j>v=3H!)t5wrfr+vkTerOtU+QyPg4W71hj2ZeryO{z5uck2>lkc z($Fe~lg_|SBw)G@h=>Fcm{s>c!33=tQW){cWTTZY{X!WdEWf{kg8J$MMh=Y#QaV*_zRywJauslzo z(=mt$xwIev2qHqP2trV4(Ewo_94gL>g(wk-B8g|d_0yi2{q5}V=E+ybF56lI!34nq z;4Dl`H;y@|)Z#dul2Q=G5)fge9OY(Hxna+hmg)GFsvY^ht(7vZM8dF=o^-QW$)$>8 znKAM`CILjHDj-M_GY%~ppxP=wSDYV1yVXI$vj|L-Fq@`cQJ7C|THXL)0kBUv4!~Pj zl~gCx!Y^qDf>aPI(Tdo%BzejK3lm>wa zuO1VSLdH=PzPRXp;ArvCqka%z@1E{^(~Rlk*C^|Pk6hMPT3G&UIlbU`0zhh^WdY;> z^e`hI#hh1)^AhMW1m!G28OJiyUM8LLdU`ysH}AUHjN_)0_G{1VN~DG5Y+TC%)Lr`a zy&_4Fc;WBw|I5mv6%di$TWOZ|KKoSfs*RhO0FXc+s}J2ZwD%`vWS5T=CqH^c13BtR2^1i_L-t|8b1QCg5p8`4QK;1S?PL0~tY+?5|qk=U?C3V3nX-NV=&%7uRE2$*#os&Kf zNNw-#N%miBkZrG<>aGl{)+(`PDn+~Yr~Mahy=x?yO2O&xi2z9M{sZuM0VN?#5aO0{ek29ZT}U|9 zAw`4~fFyyEM}GOMOzH0X#zuM!`x76EOve@yMD)Pp2JJa0V%GfOXAVD7KBY6U)b>-Z zmAazzTCVV}vlSVJ04pF(jL9v7VY7d-{nMLn8;o`z9Vl#>Y6M|qOA-!)90n2qdkdkG z1dt?xr!{-~c0QD^-~Y(iV3zD_{wOqZ87V;|4jq+r=lv!{as1_5AH8u=b)vTgs0Oo2 zDEn~}g+HzpZF9qBrm##%nK9+evMG=KI`z_%VPfRmGwa4cuX^wcH!b&Knevv8DgZ8n z6I~E^vF60w-h;UV-iml{kxKQ1 z-?(|N?KccT0AKdM%dct#( zmtKFzHMLW&PA|)C7+%`H`fKBTOD|hF?(nv=BCKAnSxWJyBJb-}UE=>JSW~kFdir^R zpFLyH%v{BPt^DeZrN->9CdW74F*-8gHLG>3A2TpqFo}pzZfZQWKY(kcpYR;-eb?V{ zP5mADe_&nTITw!?mVJI8H*|I(m&B@x7)wSq26{DT(hSS&ro?TZQLYiq92a=`u*88Q zM8#UMGgmwIuSez&e(B}PFOLGiWdGI+)-O48dMuyw){n$6EfY?{=`QI_ja~Z#xK`@t zo}Ju&{he=xSTw-v6^x$E8wPWuS7*JROI$m#Ch4RM+jJm^zyOp|@WVEmoqE#`{a?&i zk4={vbKg5ydv5;C-*x%=kAHXd(CCLZj_Pg>W}9%_w?MpYIGr@W8*NqotaPm6m4-Bi z9Mer{)~XZv6|L1_)36WhDgGk*P0w#0x$x>uOSjyu%qNd4S%lG{%}$kPF!8XSkz);&QSjYIZrNSFdi8_=p-E;395 zu0_bFBo5EFN15roOU}6Rj)!(n2d4!9091lGw%C~tqHqah-}?Uqq2C4qV%sHWTy^_t z0{{T!&MX^9Ob1c$Rwdp9@ycv_%#;?NRsajxFbi!>|F&>y1&q3{bEh3ZcTUW)0e3o# z!X=P}w+*McszSrZ{AmerLJ7&vboe&mRQG{>$24N4zIoaLoPZ#0O^0zbuBmrJGcZtU z5ni6vC^ag(n(f9X3I7jld2XXfxtTv1$PHgDNIKP4`GKb2{OWVZA8z4y_B%T@`*#CP VPQ#UP!gl}w002ovPDHLkV1g)bV7veT diff --git a/gohAssets.go b/gohAssets.go index 8d2753b..4fecef5 100644 --- a/gohAssets.go +++ b/gohAssets.go @@ -1,69 +1,58 @@ // gohAssets.go -// Source file auto-generated on Wed, 02 Oct 2019 23:28:15 using Gotk3ObjHandler v1.3.8 ©2018-19 H.F.M - /* + Source file auto-generated on Fri, 02 Apr 2021 13:10:55 using Gotk3 Objects Handler v1.7.5 ©2018-21 hfmrow + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2018-21 H.F.M - Search Engine v1.9 github.com/hfmrow/search-engine This program comes with absolutely no warranty. See the The MIT License (MIT) for details: https://opensource.org/licenses/mit-license.php - - Embedded part of the source-code below is derived from the work of: - [github.com/jteeuwen/go-bindata], his work is subject to the CC0 1.0 Universal - (CC0 1.0) Public Domain Dedication. http://creativecommons.org/publicdomain/zero/1.0/ - which I thank the author (jteeuwen) for his great work. */ -/************************************************************************/ -/* NOTICE: This file is completely rewritten when updating the assets. */ -/**********************************************************************/ - package main -import "fmt" +import ( + "embed" + "log" +) + +//go:embed assets/glade +//go:embed assets/images +var embeddedFiles embed.FS + +// This functionality does not require explicit encoding of the files, at each +// compilation, the files are inserted into the resulting binary. Thus, updating +// assets is only required when new files are added to be embedded in order to +// create and declare the variables to which the files are linked. +// assetsDeclarationsUseEmbedded: Use native Go 'embed' package to include files +// content at runtime. +func assetsDeclarationsUseEmbedded(embedded ...bool) { + mainGlade = readEmbedFile("assets/glade/main.glade") + calendarPers48 = readEmbedFile("assets/images/calendar-pers-48.png") + clearHist48 = readEmbedFile("assets/images/clear-hist-48.png") + copyDocument20 = readEmbedFile("assets/images/Copy-document-20.png") + crossIcon48 = readEmbedFile("assets/images/Cross-icon-48.png") + find48 = readEmbedFile("assets/images/find-48.png") + floppySave48 = readEmbedFile("assets/images/floppy-save-48.png") + folder48 = readEmbedFile("assets/images/folder-48.png") + globalNetwork20 = readEmbedFile("assets/images/Global-Network-20.png") + logout48 = readEmbedFile("assets/images/logout-48.png") + play20 = readEmbedFile("assets/images/Play-20.png") + reset48 = readEmbedFile("assets/images/reset-48.png") + searchEngineTop370x32 = readEmbedFile("assets/images/search-engine-top-370x32.png") + searchEngineTop550x48 = readEmbedFile("assets/images/search-engine-top-550x48.png") + searchFolder48 = readEmbedFile("assets/images/search-folder-48.png") + stop48 = readEmbedFile("assets/images/Stop-48.png") + tickIcon48 = readEmbedFile("assets/images/Tick-icon-48.png") +} -/***************************************************/ -/* ASSETS declarations: When "embedded" is set */ -/* to false, they are loaded from the hard disk. */ -/* Otherwise, datas are available as []bytes */ -/* and internally managed for use as icons or */ -/* images. You can put any type of data. */ -/*********************************************/ -func assetsDeclarationsUseEmbedded(embedded bool) { - if !embedded || devMode { - fmt.Printf(" ... Assets used directly from the source files.\n") - calendar18 = absoluteRealPath + "assets/images/calendar-18.png" - calendar48 = absoluteRealPath + "assets/images/calendar-48.png" - cancel18x18 = absoluteRealPath + "assets/images/cancel-18x18.png" - checked18x18 = absoluteRealPath + "assets/images/checked-18x18.png" - copyDocument20 = absoluteRealPath + "assets/images/Copy-document-20.png" - find18 = absoluteRealPath + "assets/images/find-18.png" - find48 = absoluteRealPath + "assets/images/find-48.png" - folderOpen20 = absoluteRealPath + "assets/images/folder-open-20.png" - globalNetwork20 = absoluteRealPath + "assets/images/Global-Network-20.png" - mainGlade = absoluteRealPath + "assets/glade/main.glade" - open18 = absoluteRealPath + "assets/images/open-18.png" - play20 = absoluteRealPath + "assets/images/Play-20.png" - reset18x18 = absoluteRealPath + "assets/images/reset-18x18.png" - saveAll18 = absoluteRealPath + "assets/images/save-all-18.png" - searchEngine400x27 = absoluteRealPath + "assets/images/Search-Engine-400x27.png" - searchEngine700x48 = absoluteRealPath + "assets/images/Search-Engine-700x48.png" - signError20 = absoluteRealPath + "assets/images/Sign-Error-20.png" - } else { - calendar18 = HexToBytes("calendar18", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x4b\x08\xb4\xf7\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x12\x00\x00\x00\x12\x10\x06\x00\x00\x00\x06\x5e\x52\x14\x00\x00\x00\x04\x67\x41\x4d\x41\x00\x00\xb1\x8f\x0b\xfc\x61\x05\x00\x00\x00\x20\x63\x48\x52\x4d\x00\x00\x7a\x26\x00\x00\x80\x84\x00\x00\xfa\x00\x00\x00\x80\xe8\x00\x00\x75\x30\x00\x00\xea\x60\x00\x00\x3a\x98\x00\x00\x17\x70\x9c\xba\x51\x3c\x00\x00\x00\x06\x62\x4b\x47\x44\xff\xff\xff\xff\xff\xff\x09\x58\xf7\xdc\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0e\xc3\x00\x00\x0e\xc3\x01\xc7\x6f\xa8\x64\x00\x00\x00\x07\x74\x49\x4d\x45\x07\xe2\x09\x18\x02\x05\x08\x7f\xcd\xa5\x31\x00\x00\x07\x3a\x49\x44\x41\x54\x48\xc7\xad\x56\x69\x54\x93\x67\x16\x7e\x2b\x58\x1d\x33\x6e\x65\xb4\x67\x4e\x19\x14\xb4\x9e\xca\x28\xae\x73\x9c\x51\x4f\x3b\x33\x8a\xcb\xe0\x69\x75\x3a\x16\x47\x61\xb0\xad\xa2\x9d\x41\x8a\x07\xb0\x50\x64\x0b\xb2\x49\x31\x26\x7c\x18\x31\x40\x16\x08\x04\x4c\x40\x49\x50\x81\x60\x48\xc2\x22\xa0\x6c\x12\x0a\x84\x2d\x61\x13\x01\x03\x8a\xd2\x82\x70\xe7\x26\x24\x85\xe3\xe9\xfc\x9a\x7e\x7f\x9e\xdc\xfb\xde\xf7\x79\x9e\xef\xbe\xf7\xfd\x4e\x08\x79\xe3\x61\xbd\x7b\x3e\x8d\xc7\x25\x36\xd4\x35\x3f\x3a\x7f\x3d\x21\xb9\x51\x09\x17\x32\x3f\x20\x84\xa2\xfc\x2e\xf1\x1d\x09\x61\x5e\xf2\x99\xe2\x85\x92\x15\x41\x1f\xba\x7a\x72\xe8\x84\x64\x5c\x8d\x5d\x2f\xc4\xba\x0c\x46\xac\xa3\x10\xd7\x83\xb6\xbb\x7e\xc1\x09\xc1\xba\x48\x9f\xd7\xbc\x8b\x64\xc5\xff\xe2\x61\xad\x44\x1d\x01\xb1\x79\x53\x9f\xc4\x47\x78\x7d\xce\x8d\x21\xd6\xf1\x21\x5e\x27\xb8\xd1\x84\x30\x7e\xe3\xbd\x91\xfb\x0c\x09\xf3\xce\x6f\xe6\x85\xae\xaa\x48\x12\x7f\x7b\x5c\xf0\x51\xd0\x66\xa6\x18\xe3\x6f\x57\x95\x5d\x79\xee\xbd\x88\xdb\x4f\x88\x83\x0f\x21\xd1\x1d\x24\x98\x5d\x1e\xe0\xc8\xd7\x1c\x17\xb2\xd5\x88\x0d\xc7\xf9\xf6\x47\x31\x4f\x27\x17\xaf\xbc\xc4\xba\x01\x13\xcf\x26\xe4\xa9\x7c\x83\x47\xcd\x58\xe6\xbd\x81\x3b\x88\xfa\xfe\x5e\xae\xdc\x40\xc4\x8b\x5e\xee\xdc\x60\x62\x4d\x62\x5d\xdd\x3c\x58\x3c\x42\x62\x3e\x3d\x46\x31\x12\xac\x02\xc3\xd7\x39\x0b\xe9\x69\x8b\x6b\xd8\x75\xfe\x5d\x5c\xf7\x33\xf3\xe4\x07\x04\x76\x59\x5a\x00\x76\xa3\xff\x10\xf7\x4b\xcf\x81\xb0\xec\x3d\x9f\x84\x89\x96\xc4\x06\x69\x0e\xb9\x30\xd6\xd8\x6d\xbf\x7d\x3d\x31\x20\x73\x75\xed\x7c\xc4\x40\x44\xab\xa0\x46\xcc\x3b\xd8\x6d\xb3\xd4\xb1\x35\xb8\xef\xb4\xe7\xe0\x4f\x3c\xb5\xc8\xeb\xe6\x09\xe1\x6b\x9d\xd3\xe8\xbc\xc5\x8f\x62\xf6\x1d\x63\x30\xc2\xad\x02\x62\xff\xee\x76\x82\x95\x88\x1d\x62\xff\xea\x6a\xa1\x1c\x9d\x32\x97\x06\x3e\xcf\x8e\x39\x59\x9d\x44\x71\x0e\x97\xa5\xd7\x77\x73\x8a\x59\xb1\x85\xcb\xbb\x4b\xcb\x9c\xc4\x1f\xdf\xac\x00\x1d\x27\x83\xf5\xfb\x82\xd2\xee\xeb\x9c\x13\x82\xd5\xd5\x0e\x0d\xb6\xd7\x37\x72\xb6\x96\x3f\xd3\x9c\x95\x4e\xa4\x96\xe5\x88\xc7\xdf\x32\xe3\x3c\x4b\xde\x52\x67\xd9\xf7\x13\x8f\x99\x37\x29\x01\x75\xd2\xea\xf5\x4c\x1a\xea\x46\x9e\x2c\x63\xcf\xbf\x9a\x27\xef\x45\x43\xf7\x3e\x07\x7c\xf0\x6c\xd5\x31\xef\xe5\x8f\x25\x66\x8b\x86\x34\xcd\x63\x6a\x80\x8c\xbd\xca\x5a\xfd\x3c\x00\xd9\xd9\xe4\x49\xf1\x27\x18\xbf\x5d\xd2\xa7\xdb\x07\x20\xae\xea\xc9\x37\xee\xc8\x1a\x6b\x7b\x3c\xb9\x09\xe3\x22\xe1\x17\xc5\x4b\xcc\xb8\x14\xf3\x2f\xcd\x79\x73\x5d\xc6\x82\x92\x5e\x9d\xf3\x1c\x9e\xbd\xca\x3a\xbd\x15\x80\x68\x70\x46\xc7\xac\x9b\x75\xcf\x7d\xc6\x07\xc9\xf7\x30\x1b\xb2\x89\xdc\x26\x4d\xa4\x96\x89\xfe\x58\x7f\x63\xd4\x1e\x89\xf7\x6b\x3e\x1b\x7b\x07\x20\xcd\x5d\xbe\xbf\x73\x37\xc6\xe1\x4d\x1b\xc6\xee\x03\xdc\xfc\x47\xfb\xc9\x89\x64\x80\xec\xd7\x6d\x1b\x7f\xbc\x09\x20\x94\x94\xaf\xee\xf7\x99\xc5\xec\xa9\x99\xbc\xa5\xce\xb2\x0f\x79\x0e\x98\x78\x0e\x68\x5c\xc7\x6c\xd0\x90\x59\x87\x7a\x67\x46\x37\xdf\x62\x88\xf5\x3e\x5f\x5f\xe3\x42\xc8\x15\x0f\xff\x89\xcc\x71\x8a\x46\x7d\x25\x93\x74\x78\x63\x61\xb0\xac\xa5\x83\x81\xd8\x7b\x4f\xac\xeb\x01\x48\x5c\x21\x7f\xb7\xa7\x1b\xe3\xcb\x77\x7d\xbb\x7a\x11\x9d\x65\xca\x8e\x2b\x98\x77\x28\x62\xf4\x9c\x99\x45\xcc\xab\x8c\x79\x2a\x16\xeb\xe6\xee\x33\xf2\xf4\xce\xe1\x3d\x8b\x3a\xe7\x00\x4c\xba\xaf\x28\x1a\xcb\x9e\xdf\x51\xe3\x8c\x86\xe8\xbc\x27\x42\xa3\xb3\x38\x55\x98\x32\x4f\x46\xd1\xa2\x3e\x2c\x66\x0c\xd6\x03\x44\x56\x29\xb7\x18\xf0\x88\xa2\x36\x4b\x59\x7a\x25\xc6\x03\xd2\x64\xbd\x1e\x63\x1f\xa9\xc8\x14\x43\x9e\x48\x37\x85\xf1\x76\xe9\x43\xfd\xab\x59\xc4\x7c\xa6\x6e\x12\x63\x5f\xe9\x6d\x7d\x23\xc6\x63\x52\x55\xf7\x66\x8c\x77\x4a\x73\xf5\x58\x1f\xd9\xa3\x74\x36\x1c\xc6\xf8\xcf\xc5\x4c\xa3\x8e\x49\x57\x4a\xd1\xe8\xdc\x27\x69\xa6\x0e\x85\xd7\x8c\xf7\x9b\x0c\x09\x22\x6c\x65\x3a\x34\xf4\x4f\xd5\x02\x83\xb1\x50\x7e\x2b\xba\x63\x05\x80\xdc\x36\xb7\xec\x51\x20\x40\xe5\x94\x72\x4b\x73\x11\x40\x4e\x44\x4a\xb3\x12\x8f\xa4\x7a\x9f\xea\x55\xcb\x53\x80\x82\x47\x62\x8f\xea\x75\xb3\x58\x7d\x58\xbd\xb2\xd5\x09\x40\xd2\xcc\xc9\x2f\xfe\x2b\x40\xc5\xbe\x7b\x21\xe5\x55\xb8\x3e\x9a\xf5\x5b\x85\x06\x20\x76\x3a\xd7\xb6\xdd\xc6\x68\x50\xf9\xd2\x50\x87\x3a\xe9\x11\xbf\x33\xea\x5a\x7c\x90\x70\xdd\xf8\x22\x93\xa1\xcf\xe8\x6a\x99\x98\xa2\xc5\x4e\x97\x9e\x1f\xc9\xc3\xeb\xf9\xdd\x9d\x1d\x9d\x38\xac\xdd\x22\xad\x5d\x3f\x1a\x7c\xdd\x30\xe9\xfb\x1a\x0d\x54\xdd\x2e\x6c\x69\x40\x63\xe0\x34\x1d\x33\x6d\x00\xe8\x3c\xa8\x39\xd3\x63\x33\x8b\xf0\x97\xe9\x52\xf8\x37\xbe\x40\xe0\x9d\xd1\xaa\x1c\x80\xf1\x8e\xc1\xc4\xb6\x0d\xb8\xce\xae\xe9\xa8\x41\xc9\xb8\x07\x12\x49\x2b\x1e\x5d\x94\xbd\xb2\xca\x70\x07\xe3\x4c\xfa\xa4\x4c\x89\x86\xcc\x3e\x66\x0d\xc5\xd3\x07\x64\x85\x14\x2d\xfa\x92\xaa\x62\x04\x89\x19\xad\xb7\x6c\xdb\x76\x61\x87\x8a\xb2\x4e\x57\x04\xa0\x11\xff\xc2\xe1\x06\x1d\x40\xae\x15\x9b\x59\xf4\x10\x3b\x51\x22\xe7\x37\x12\x80\xc2\x83\x19\xef\x95\xb9\xcc\x62\x75\x95\x5c\xd9\xb8\x17\x3b\x79\x2c\xd1\xfb\xee\x29\xec\x90\x22\x6f\x77\xc9\x18\xae\x7b\x0b\xd2\x0a\x6a\x01\x2e\xab\xc5\x1e\xad\x47\xd0\xd0\x57\xaa\xb7\x0d\x18\xc7\x09\xe8\x3f\xc8\x4a\x7e\xce\x50\x36\x7d\x4a\xa6\xa2\x68\x91\xa0\xcc\x35\xf0\xb0\x70\xbf\x24\x5d\x8b\x47\xd3\x5c\xf8\x88\xdf\x89\x6f\x68\x58\xf2\xd4\x76\x14\x3b\xa7\xb6\xbd\x1d\xfc\xb0\x00\x60\xd4\x6e\xa8\xf6\xc5\x37\x00\x9a\xf5\x0f\xd4\xda\xe1\x59\x1c\x75\x1a\xb6\x7e\x81\xc3\xac\xa2\xe5\x2c\x2f\xc3\xfd\x4f\x65\x6d\x5b\x71\x94\x40\xe3\xae\x5e\x58\xf9\x25\x0e\xf3\x56\x69\x60\xfb\x76\x34\xf6\x69\xa9\x74\xa4\x19\x75\x0e\xd2\x0b\x65\xa2\x9f\x33\x14\x4e\xd7\xc9\xee\x62\x87\x34\xaa\xe9\x91\x0f\x00\xbe\x7b\x9c\x73\x48\x2b\x43\xa2\xcb\x0f\x9c\xb4\x38\xdc\x83\x6f\x75\xfb\x0d\x4d\x00\x94\x18\x24\x1f\x55\xb2\x01\x86\x26\xfa\x16\x3d\x93\x00\x34\xec\x50\x47\x37\xaf\x9d\xc5\xe1\x45\x7d\xbb\x0d\x38\x7b\x8a\x81\xac\x1f\x55\x38\x33\x7d\xdf\x37\xd9\xd7\x87\xe3\xfa\xb9\xfb\xb6\xe5\xbe\x78\xab\x96\xe5\x34\x6a\xff\x00\x10\x7d\x4a\x95\x3f\xb2\x12\x0d\x5d\xa6\xf7\xcb\x0a\xe6\x18\x0a\xb3\xfe\x21\xda\x64\xc8\x3e\x62\x6d\xfe\x42\x34\xf4\x8d\x7a\xd7\xc8\x21\xdc\x00\xc5\xe9\x83\xcb\xf1\xe8\x7a\x85\xed\x0d\x78\xf6\x2c\x17\x91\x6b\xa3\x1b\x40\x7c\x87\x40\x52\x87\x6f\xce\x0a\x15\x09\x1b\x99\xb8\x9e\x2b\xb4\x6e\xd8\x36\x8b\xac\x70\x51\x76\x23\x7e\x7f\xe2\xd5\x82\xa3\xb5\x78\xeb\x98\xda\x8c\xd1\x7a\xbc\x14\x0c\x49\xba\xae\x0e\xbf\x47\x91\x4f\xe4\x8e\x4f\xff\x83\xe8\xa0\xe4\x1a\xf0\x85\xe2\x8e\x46\x1c\xc8\x5f\x49\xd1\x2c\x3e\x88\x60\x69\x17\xcd\xf8\x83\xb9\x2b\xb4\xf5\x96\x8e\xda\x93\x52\x9e\xb2\xa3\xb2\x18\x20\xd9\x8d\xd9\xa9\x88\x01\xe0\x24\x33\xa7\x14\x4d\x88\x17\x98\x0f\x15\x38\x84\x1c\x05\xcb\x51\xf1\x02\xd1\x97\x59\xa1\x90\x22\xf2\x59\x56\x8a\xd6\x39\x68\xcc\xe3\xd1\x72\x94\xac\x4d\x8a\x69\xc4\x10\x66\xb7\x02\x87\x98\xc3\x63\x2d\x51\x60\x87\x93\x7d\x99\x06\xc5\x55\x80\x14\x5d\xca\xdf\x2a\xcb\xd1\xf0\x9f\x42\x5b\x6e\x75\x51\x7b\x04\xbf\xee\x5a\x6c\x32\xd4\xaf\x0e\x5d\xc3\x6b\x27\x84\x47\x7c\x0e\x72\xfb\x99\x2d\x8f\xd9\xfe\xf5\x1c\x6c\x75\xdb\x62\xbf\xb0\x24\x3b\x00\xed\x29\xbf\xd0\x24\x1c\x6e\xed\xe9\xff\x13\xcd\x3c\x16\x5e\x8b\x0e\x77\x1a\x75\xfb\x98\x4d\xfd\xf9\xa1\xab\x78\x9d\x68\xe8\x46\xdc\x39\x56\xea\xbf\x08\x49\xd0\x78\x3d\x4f\x7d\xb5\x53\xc1\x1f\xf6\xae\x49\xdd\xc2\xfc\x5e\xf8\xf1\xd7\x9e\xa9\xef\x53\x7b\x84\x6b\xbf\xf6\x48\x5d\x47\xd1\x7e\x31\x34\xf3\xf2\x87\x4c\x3a\x4d\x09\x8f\xbd\x46\x53\xc7\x76\x16\xdd\x88\x99\xf1\x41\x5a\x8e\x5c\xb0\xe5\x1c\x21\x0b\x6e\x2c\x3c\x37\x95\xaa\x25\xc4\xa0\x0a\x90\x27\xe1\xff\x22\x80\x10\x97\x6b\x39\x46\x0c\x7e\x76\xad\xe3\x97\xc4\x19\x5e\x83\x3c\xe0\x7e\x52\x14\x36\x64\x3e\xea\xb6\xa0\x0f\x9b\x0b\x6b\x38\x6e\x64\xc1\x7f\x01\x89\xdc\x24\xff\x05\xaa\x80\x23\x00\x00\x00\x25\x74\x45\x58\x74\x64\x61\x74\x65\x3a\x63\x72\x65\x61\x74\x65\x00\x32\x30\x31\x38\x2d\x31\x30\x2d\x31\x34\x54\x31\x34\x3a\x30\x32\x3a\x31\x36\x2b\x30\x32\x3a\x30\x30\xa9\xfa\x63\xbf\x00\x00\x00\x25\x74\x45\x58\x74\x64\x61\x74\x65\x3a\x6d\x6f\x64\x69\x66\x79\x00\x32\x30\x31\x38\x2d\x30\x39\x2d\x32\x34\x54\x30\x30\x3a\x30\x35\x3a\x30\x38\x2b\x30\x32\x3a\x30\x30\x13\xe6\xcd\x46\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\x2d\xf6\x8f\x68\x4b\x08\x00\x00")) - calendar48 = HexToBytes("calendar48", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x87\x13\x78\xec\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x30\x00\x00\x00\x30\x10\x06\x00\x00\x00\x07\x92\x25\xc4\x00\x00\x00\x04\x67\x41\x4d\x41\x00\x00\xb1\x8f\x0b\xfc\x61\x05\x00\x00\x00\x20\x63\x48\x52\x4d\x00\x00\x7a\x26\x00\x00\x80\x84\x00\x00\xfa\x00\x00\x00\x80\xe8\x00\x00\x75\x30\x00\x00\xea\x60\x00\x00\x3a\x98\x00\x00\x17\x70\x9c\xba\x51\x3c\x00\x00\x00\x06\x62\x4b\x47\x44\xff\xff\xff\xff\xff\xff\x09\x58\xf7\xdc\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0e\xc3\x00\x00\x0e\xc3\x01\xc7\x6f\xa8\x64\x00\x00\x00\x07\x74\x49\x4d\x45\x07\xe2\x09\x18\x02\x05\x08\x7f\xcd\xa5\x31\x00\x00\x12\x76\x49\x44\x41\x54\x78\xda\xed\x5c\x79\x5c\x94\x55\xf7\x1f\x32\x35\x7a\x2b\x7b\x2b\x33\x4c\xdb\xdf\xcc\xb4\xb4\xcd\x70\xc7\x25\x11\xc9\x7d\x23\xc4\x52\x51\x13\xe6\x61\x1b\x64\x15\x72\x81\x01\x04\x9e\x01\x01\x41\x64\xb9\x0c\x03\xca\xb0\x0e\x22\x48\x98\x80\x05\x0a\xcc\x8c\x08\x82\xc4\xab\x32\x2c\x83\xa4\x10\x90\x20\xcb\xb0\xdc\xf7\x3c\x0f\x73\x81\xf7\xf7\xcb\xd4\xb7\x34\x45\x9f\x7f\xbe\x9f\xe7\x2e\xe7\xdc\xf3\x3d\xf7\x9e\x73\xee\x83\x23\x87\xf3\xf8\x79\xfc\x3c\x7e\xfe\xc4\xe3\x9d\xc8\x1d\x8f\x26\x71\x38\xb4\x3d\xa5\x8f\xbe\xe3\x68\xd2\xdb\xa9\x59\x68\x37\xbc\xbb\x51\x9b\x91\x2b\xe0\x77\xd4\x46\xe4\x08\xb8\x16\xda\x37\x01\x72\xa9\x95\xc8\x9a\xa3\x49\xe6\x0d\x75\xf9\xf7\xfc\xa1\x1d\x60\x41\x7b\x60\xe1\xbb\xa9\x55\x68\x1f\xbc\x9b\x52\x5f\xa0\x5d\x9a\x66\xf4\x4a\xea\x1d\x64\x31\x7d\x19\xad\x47\xbd\x8e\xb6\x4d\xd7\x05\x03\xe6\xa3\xd5\x9a\xa6\xb4\x0d\xb5\x96\x35\xcc\x1a\xc6\x0b\x38\x9a\x43\x5d\xfe\xbd\x77\x80\x09\x35\x8d\xdd\x21\x16\xd4\x6c\x64\xa3\xc9\xa5\x57\x51\xef\x21\x4f\xff\xc9\xb4\x8c\x4a\x41\x31\x2d\x49\x74\x01\x75\x0c\x1d\x6d\x89\xa3\x97\x50\xef\x23\x17\xff\x71\xf4\x97\x94\x1e\xb2\xd6\xdc\x42\xeb\x83\x41\x0e\x43\x5f\xfe\xbd\x77\x80\x23\x1c\x51\x6f\xc0\xd9\x94\x16\x72\xd6\x6e\xa3\x6b\xa8\xf3\x28\xa9\x65\x6b\xe6\x27\x51\x2b\x62\xf5\x30\xce\x9c\x1c\xa5\x1f\xfb\x05\xc6\x74\x15\x55\x88\x12\x5b\x0c\xe9\x19\xd4\x58\x64\xa7\x7d\x95\xb6\x83\x79\xfb\x87\xbe\xfc\xff\x9d\xd8\xd5\x54\x69\xb8\x8c\xc3\xf1\xaf\xdb\xd8\x1a\x3f\x0a\xde\x5d\xa8\x4d\x68\x1a\x20\x4d\x6d\x65\x17\x4c\x53\x66\x28\x02\xd0\x93\x32\x41\x61\x80\xc3\xb9\xe7\xd1\x6e\x3d\x17\xdf\xa7\x2c\x16\x45\xbc\xaf\x8a\xaf\x2a\x92\xcf\x3b\x36\x16\xe3\xaa\x42\xb9\xce\x31\x2d\x8c\x7d\x47\x42\xfb\x44\x55\x1c\x3d\x82\x5b\x8c\x9c\xf4\xf6\xd1\x5e\x94\x29\x0a\x61\xe5\x50\x08\xfd\x01\x3e\xf8\xf2\xfb\x78\xf0\xa6\x8c\x91\x17\x20\x8f\x5a\x8a\x26\x72\x38\x41\x73\x4c\xb6\x1f\xcb\x83\xf7\x0f\x28\x97\xf0\x15\x77\x43\xfc\x72\xee\xaf\x90\x64\x34\xe8\x31\xdc\x74\x34\x8b\x4d\x42\x1b\x50\x28\x7b\x54\x75\xc2\x53\x34\x12\x40\xe1\x16\xe4\x31\x3c\xa6\x4f\xf1\xf0\x30\x40\x2e\x42\x1a\x3e\xf4\xb3\xdc\x72\xe4\xb2\xd4\xcc\xf7\x35\x8b\x6f\x22\xa6\xa8\x5c\x2b\x9b\x65\x73\x92\x7f\xc1\x98\x20\x69\x27\xe3\x58\x02\xc2\x61\x1e\x4b\xc4\xf0\xd0\x3f\xc0\x07\x5d\xbe\x19\x12\x02\x0f\xde\x6a\x5e\x3e\xa6\x5e\x08\xb7\xd3\x88\x83\xdc\xf2\x0d\x3a\x0c\x49\x3e\x8a\x7b\x3d\xbc\x05\xf0\x3a\xf5\x26\x5a\xc4\xd1\xb8\xbd\x03\xc6\x72\xdd\x91\x11\x87\x23\x78\xd6\x6c\x12\xca\x84\x77\x5b\x70\xc0\xc1\x39\x36\xf4\x9b\xa6\x3f\x87\xaf\x14\xbd\xe3\xfd\xb3\x49\x4a\x18\xf7\xc4\x58\xc0\x13\x61\x96\x69\xc1\xde\x25\x26\x47\xc3\x8c\x53\xb7\x7b\x5f\x33\x75\x08\x9f\x22\x15\xf9\x3e\x6f\xa1\x1b\xf1\x4e\xaf\x71\x25\x96\xad\x48\x6e\x00\x03\xd4\x48\xda\xc9\xb8\xfe\x79\x7d\x72\x02\x6f\x89\x0f\x87\xfc\x60\xc2\x0b\x3d\xde\xf4\x62\xb8\xbe\x68\x2c\x24\x73\x23\xc4\x9f\xc3\x15\x84\x50\x17\x51\x07\x38\xc0\x81\x5b\x87\xc6\xdf\xc9\x09\xb0\x86\xaa\xc0\x85\x2d\xb7\xe6\x21\x9b\x37\xf6\xd2\x56\xd4\x68\xf4\xd5\xc5\xd8\x03\x25\x4e\xc5\xf1\x57\x30\x0e\xdc\x28\x98\x9d\x01\x3b\x22\x70\x9d\x60\x42\x46\x29\xa0\x83\x20\xfe\xa4\x0e\xc6\xfe\xc7\x5c\x77\xa4\xbc\x08\x0b\x9d\x67\xf9\x6c\xc4\x59\x38\xba\x4f\xca\x96\x25\x2b\x71\x2f\x41\xd2\x4e\xc6\x91\x79\x81\x6b\x05\x6f\x67\x14\xff\x01\x3e\xe8\xf2\x09\x0f\x46\xc0\x4b\x1d\xc6\x07\xce\x3b\x9d\x8f\xff\x37\xe4\x0c\x33\xea\x65\xb4\xfe\x62\x30\xbd\x09\x92\xf5\xce\x37\x2c\x21\x82\xac\x66\x78\xbd\xbd\x03\xf6\x41\x2c\x0b\x04\xdc\xc2\xbd\x89\x66\x2f\x72\xa4\xbb\xcd\xc7\x46\xa8\x54\x23\x84\x05\x19\x63\x2b\xbe\xc4\x38\xde\xb2\xba\x0b\x2f\xc4\x38\xae\xb7\x4a\xb7\x47\x09\xef\xbb\x6a\x26\x62\x13\x8c\x45\xe3\xb2\x0e\x56\x17\x81\x01\x27\xad\x2a\x22\x67\x81\x01\x1a\xb2\xcf\x93\x0b\x07\x90\xb4\x93\x71\x64\x5e\x5c\x4f\xd5\x17\x3d\x35\xb7\xc6\x07\x5e\x3e\xe1\x41\xcd\x8b\x30\x37\xe3\xe5\x0a\x5d\x70\x40\x97\xb9\x56\x44\x87\x6a\x18\xf0\xd8\x86\xa6\x2d\xb2\x06\x5e\xb7\x21\xbf\x3b\x71\x00\x49\x4e\x3b\xb8\x15\x68\xb2\x5e\x98\x60\x81\xc5\x04\xe1\x05\x95\x83\xa8\xf4\x74\x8b\x32\x1c\xe3\x04\xed\xda\x5e\x0c\x4f\x7c\x9a\xf2\x1f\x0c\xc2\x7b\x0f\x83\xa2\xa0\xd3\x26\xca\x25\xb0\x50\xa1\x55\x4a\xe4\x44\x58\x78\x95\x7c\xfa\x31\x0d\xc0\x4a\xb9\xf6\x31\x0e\xb4\x47\xf4\xb5\xc3\x38\x53\x66\x1c\x99\x47\xe4\xdc\x0a\x1f\x16\xf9\x84\x17\xe0\xa9\x55\x89\x30\x56\xf3\xe6\xc8\xf2\xf8\x81\x5e\x18\xe1\xf5\x6e\x1c\x50\x89\x3e\xd4\x33\x11\xcc\xb5\xd0\x12\xe6\xa9\x8c\x45\xe9\xa7\x5d\x95\x50\x8e\x25\x7c\x50\x5b\xcc\x2a\x8e\xaf\xa9\x61\x15\x8f\xae\xb5\x61\x30\x3a\x35\x7f\xd1\x75\x6f\x8c\x7d\xb8\xbc\x94\x28\x1e\x94\x6f\x7a\xa2\xf3\x62\x21\xa0\x8e\x28\x4f\x1c\xca\xb6\xa7\x46\xc1\xc8\xe8\xb4\xfc\x2f\xaf\xfb\xb1\xf3\x76\x0e\x96\x73\x2b\x7c\x58\xe4\x13\x5e\x08\x4f\x84\x37\xc2\xe3\x3d\x73\x40\xfc\x69\xe5\xa7\x0c\xc6\xb9\x2b\xf6\x75\xc3\x02\x0f\xc7\xa2\xb7\xf3\x02\x61\xc1\x8b\x79\xb6\x51\x2b\x01\x75\x01\x57\x41\x7b\x3c\x9a\x90\x77\x18\xc6\xed\x57\xb8\x76\xdb\x0f\xcc\xbb\x1d\x41\x0f\x8b\xfc\x7b\xe1\x80\x2b\x10\x82\x4c\x04\x0b\x2d\x26\x09\x2f\x82\x03\x9a\x7e\x5c\xaf\x6c\x02\x45\x9f\xd6\xfe\xca\x2a\x8e\xab\x51\xe0\x6e\xc0\x46\x65\x15\xbb\x80\x7f\xd6\x7e\xcb\x1a\xe2\xa6\xf8\xae\xdb\x0a\x76\x8a\x24\x7f\xda\xf5\xbd\x18\x1f\x79\xa2\xc0\xba\x7e\x1f\xb4\x4b\x2a\xdf\xea\x6e\x83\xf1\x52\xa5\x21\x3b\x3f\x53\xf9\x3e\x3b\xef\x99\xda\xd5\xec\x7b\x96\xf2\x43\x16\xc5\x35\x65\x98\x19\x77\x51\xe9\xc2\xf6\x0f\xab\x9d\xca\xb6\x5f\x50\x3a\xfe\x97\xfc\x5f\x0b\xde\xae\xd7\x51\xe3\x7c\x68\xe7\xf7\xb5\x93\x71\x30\xef\x23\x76\x5e\xa9\x72\xdf\x7f\xc9\xcd\xee\xd3\xd3\xaf\x57\xbd\x0e\xb2\x2e\x76\x9d\x37\xd5\xeb\xde\xab\xb6\x63\xdf\x80\x7c\x62\x27\xd8\x5d\x39\x98\x07\xc2\x0b\xf0\x64\xc0\xf0\x44\x78\x23\x3c\xde\xbd\x03\xac\xa9\x91\x68\x19\x4c\x6c\x34\xab\x8a\x90\xa9\x8c\x23\xde\x4c\x89\x2b\x1f\x0d\x0a\xe5\xca\xc9\xac\xe2\x73\xca\xd9\x0c\xc6\x2c\xbe\xc0\xb9\x61\x04\xb8\xa4\x18\xdf\xd8\x00\xed\x4a\xa5\x8f\xba\x7f\x01\x83\x47\xf5\x0a\xa7\x35\x2d\xc5\x38\xf6\x95\xf2\xaa\x76\xa8\x9e\xe2\xeb\x95\x31\xac\xa1\xf6\x8a\xf7\xba\x21\xa6\x1e\x59\x2b\xa5\x1b\xbe\x82\x77\x47\xc5\xc4\xee\x49\xd0\xdf\xa0\x8c\x67\xfa\xc5\xb8\x9c\x6e\x8f\x82\xfe\x6a\xb9\xa8\xf1\x29\x68\xdf\x56\x1d\x8f\x39\xac\x7c\x01\xab\x37\xb9\x24\xa0\x25\x12\xf0\x78\x49\x50\x4b\xd4\x20\xbd\x5b\xab\xe3\x98\x60\x7c\xa4\x52\x1e\xd9\x38\x12\xf4\x3e\x51\xee\xdb\x7e\x74\x40\xee\x2d\xf5\xaa\xd7\x15\xfb\x52\x79\x45\xfb\x55\x58\xb7\x7e\xe1\xe7\x4d\xcb\xa0\xfd\xbc\x72\x21\x2b\x97\xe8\xd5\x2d\xee\xbe\x61\x00\xa8\x7f\x61\xd8\x8d\xaf\xa1\xbd\xb0\x8f\x87\x78\x99\x72\x12\x83\x11\xe3\x53\x62\xca\xa1\x4a\x22\xbc\xf5\xf3\x78\xd7\x0e\xf0\x86\x1b\x62\x28\x4c\xd4\xe7\x6e\x09\x87\xa3\xe4\x27\xdc\x13\x9e\xd4\x05\x8a\x63\xcb\x8a\xda\x82\x60\xe1\xc1\xd5\xf6\x78\x3c\xc6\x41\x19\x01\xda\x59\xf9\x80\x99\x01\x33\xb3\xce\x41\xfb\xa1\x6a\x3b\xfc\x1a\x8c\xab\x2f\xbb\xda\x06\x94\xf8\x95\xec\xb9\x29\x81\xc3\x1a\x3e\x35\xc1\xaf\x64\x39\x73\x64\xaf\x66\x30\x0b\x8d\xfa\x2a\xb7\xba\x4e\x05\xc9\xad\xdd\x21\x9c\xb9\xea\x47\x19\xe5\xd6\xd6\xf5\x32\x3b\xaa\xaf\x3f\x7c\x52\x82\x4f\x09\x24\x3b\xbf\xb2\x3d\xed\x92\xcf\x41\xde\xaf\x65\x75\x6d\x07\xd4\xf2\x1f\x24\xbd\x87\x81\x87\xd7\x61\xdc\xd1\xb2\xc2\xb6\x83\x30\x2f\x6c\x4f\x48\x52\x3b\x38\x40\x9f\x6b\xcc\xf0\xd6\xcf\xe3\x5d\x3b\x80\xa6\xcc\x91\x90\x99\xc8\xf5\x09\x67\x8e\x52\x90\x9d\xbb\x38\x16\x62\x62\x74\x6e\x67\x13\x94\x5d\xbe\xc7\x8b\x96\x74\x7e\x0f\x47\xcd\xc8\xed\x97\x13\xb0\x60\xc1\x46\x40\x7d\x68\x97\x14\xe9\x76\xa6\x03\xae\x3e\x63\xd6\xac\x09\x0b\xb9\x64\x93\x75\xb4\x05\xe6\x8d\x0a\xd7\x90\x36\x43\xfb\xcf\xa5\x97\x7a\xe4\xf0\xfe\xd3\xf1\x2b\x95\x70\xe8\xe9\x38\x8b\xd9\x91\x6f\xc2\x7b\x0e\xbc\x1b\x0d\xea\x7f\x2e\x9c\x23\x6d\x84\xfe\xcb\x36\xd9\x47\x5b\x59\x79\xe6\xcd\x4f\x0f\xc8\x7f\x60\xf4\xaa\x79\xf0\x89\x02\x5e\x20\x1b\xd0\x81\x76\x6e\x62\x31\x20\xe1\xad\x9f\xc7\xbb\x75\x80\x2f\xa5\x8f\xf6\xc0\x44\x3f\x6a\x21\x72\x54\x19\x7b\x06\x0a\xda\xb2\xc1\x30\xbe\xc1\xd9\xf9\xad\x10\xe3\x5c\x95\x52\xab\x0e\x50\xe8\x91\x1f\x59\x51\x0c\x0b\xf3\x90\x45\xd6\x14\x67\xb3\xed\xbc\x0e\x70\x10\xdf\xe8\xcc\xb1\x56\x53\x8c\xf7\x97\x06\x15\xe5\xad\xc7\xd8\xdd\x56\xd2\xac\x80\xd8\xea\x9a\x2e\x9f\xac\xe2\x63\xec\x36\xfd\x54\x4e\xc3\x30\x8c\x3d\x67\xf9\x07\xe4\x00\x01\x6e\x33\x4f\xe5\x35\x68\x0e\xf4\xbb\x5b\x4b\xea\x15\x40\xc4\xfe\xb2\xa0\x92\x3c\xe8\xe7\x6f\x3c\x73\xbc\xd5\xfc\x01\xd6\xbb\xfe\xac\x4e\x2b\xdc\x98\x3d\xfd\x05\x37\xb2\x41\x3e\xf0\xf6\x05\xda\x05\x0e\x20\x3c\xde\xb5\x03\x02\xb9\xbd\x48\x1b\x26\x6e\x36\x77\x10\x7a\xa9\x8c\xdd\xcb\x25\x53\x15\xe3\x40\xd1\x66\xb9\xa3\xca\x0b\xd0\x45\x5a\xd1\xc9\x38\xc4\x53\x7a\xa8\x03\x8e\x24\xdf\x43\x2a\xee\x80\x1b\x20\xdf\x4e\x66\xd7\x19\x0c\x68\x25\x4b\xe9\x84\x0b\x0b\x7f\xb7\x4c\xab\x13\xb2\x01\x7f\xa7\x2c\xa0\x33\x15\xd0\x46\xe6\xdd\x19\xaf\xee\x87\xba\x81\xbf\x57\xc6\xe9\x84\xac\xc2\xe7\xa9\xdf\x49\x3f\x19\x4f\xe6\xf3\x64\xc9\x9d\x70\x21\xe2\x5b\xcb\x42\x3b\x7f\x00\x74\x94\xad\xef\x74\x1e\x84\xa4\x9d\x8c\xfb\xab\xf4\x12\x3b\x88\x5d\xc4\x4e\x62\x37\xe1\x41\xcd\x8b\xfb\xcf\x92\x29\x0c\x4f\x84\xb7\x7e\x1e\xff\x07\x07\x74\xa3\x69\x30\xf1\x1b\x73\x5f\x61\x04\x38\xa0\x44\xb2\x45\x01\x47\x8e\xbf\x55\xbe\x4e\x05\x3b\x8c\xcf\x97\x4a\x3b\x3a\xd8\x05\x28\x3b\x47\x01\x06\x15\xd4\x77\xbc\x0b\x3b\x4a\xff\x47\xaf\x66\x48\xba\x6e\xbb\xb3\x3f\x69\x7c\x15\x70\x57\xf6\xe6\xc6\x45\x80\x4e\xd9\x06\x8d\x73\x58\x5c\xdd\x38\x9d\xc5\xb5\x8d\x33\xd9\xfe\x2d\x8d\xba\x83\xde\x07\xfa\xfb\xc6\x0f\xcc\x27\xed\x7d\xb8\x2b\x7b\x63\xe3\xfc\x41\xf8\xff\xfb\xff\x1a\xbd\xc4\x0e\xb5\x5d\x60\x67\x03\x63\x67\xbf\xdd\x84\x07\x35\x2f\x84\x27\xc2\x5b\x3f\x8f\x7f\xc2\x01\x3e\x42\x04\x0e\x28\x95\x6c\x50\x2c\xf8\x1d\x07\x98\xc9\x6a\x55\x70\x63\x74\x1f\x9f\x7e\xb9\x0e\x0c\xf1\x1e\xe3\x3c\x23\x69\x13\xc6\x5e\x76\xb6\x63\xc4\x63\xe1\x48\xb6\xd8\xe4\xc5\xc0\x9d\xd1\x53\x65\x53\x24\x7e\x62\x10\xb6\xda\xe4\xc7\x40\xf2\xf3\x92\xda\x56\x88\x53\x60\x9e\xa9\x5d\x7c\x2c\x10\xe0\x35\xc9\xf6\x79\x31\xec\x4c\xcf\x36\x1b\x99\x98\x33\x68\x7c\xa7\xcd\x79\x06\xbd\x86\xd9\x5c\x16\x43\x4c\xf6\x7e\xd7\x6e\x4d\x2c\x67\x00\x49\x3b\x19\xd7\x3f\x4f\x2d\x87\xc8\x05\x3d\x71\xb1\x90\x5c\xbd\x4a\x6c\xbb\xc4\x10\x6a\xbc\x46\xd8\x3e\x29\xb6\x03\x7c\xc6\xf6\x69\xb1\xe3\x20\x1c\x6e\x3b\x4c\x6c\x0b\xe8\x6a\xab\x23\x86\x10\xe4\xfd\x8a\xf3\xec\xa4\xed\x60\xe7\xeb\xe9\x8a\x3a\x1d\xb5\xdd\x9c\xdf\x71\x80\x9a\x27\xc2\xdb\xbd\x73\x80\x9b\x54\xc6\x2a\x5e\x27\x5f\xa9\xe2\x82\x62\x94\x54\x53\x71\x1d\x92\x53\xb2\xc5\x7c\xe1\x05\x8c\xd3\x2c\x23\xa6\x9e\x86\x8a\xfb\xec\x4f\x69\x31\x85\x10\x23\xcf\x5c\x4c\xb5\x2b\x1c\x3f\x80\x67\xa3\xd2\xf6\x16\x16\x40\xb9\x79\xd6\x07\xa7\x41\x19\xe9\x9f\x6c\xed\x12\x05\x04\x66\xb5\xc6\x1f\xca\x87\x0b\xd0\xd9\xc5\x69\x4f\x17\x3a\x0f\x9a\x77\x2d\xd5\xb7\xf0\x03\x8c\x73\x0f\xa6\x94\x9f\x7b\x0e\xe3\x30\xad\xdd\xd1\x71\xed\x03\x48\xda\xc9\xb8\x7e\x3d\x6a\x39\x44\xae\x7f\x86\x75\x44\x14\xec\xec\x18\x37\xaf\xae\x44\x88\xf1\xb9\x5a\x89\x46\x99\xb0\x11\x72\xd6\x24\x58\x64\x7a\x0f\x60\xee\xb4\xc4\xdd\x59\xb0\xc3\x8f\x47\x1f\xb6\x49\x85\x72\x53\x70\xc4\x62\x8c\x10\x1c\xe5\x9e\x27\xd1\xa8\x80\x2a\x8a\x6f\x2c\xdf\xa0\xb2\xf8\x3b\x1d\xb0\x43\x7a\xa2\x03\xaa\x0b\xb7\xca\x73\x1b\x55\x10\x23\x05\x7e\xa9\x4f\x56\x8d\x81\xaa\xe0\x5f\x56\x37\x44\x79\x18\x57\xae\x29\x1b\x51\xfb\x19\xbe\xed\x73\x26\x3e\xed\xa5\x42\xa8\x22\x82\x2b\x9d\x56\x30\x3b\xb9\xe5\x48\xf3\x8b\x37\x83\xff\x60\xc2\xf3\xbd\x52\x3c\x0d\xca\xc6\x9b\x01\xf5\x19\xff\x1c\x40\xd2\x7e\xab\x87\xc8\x0d\xbe\xe1\xe4\x15\xeb\x00\x44\xbf\x99\xd0\x94\x09\x57\xa7\xde\x97\x5a\xc4\x95\x50\xb5\x74\xbb\xfe\x96\xaf\xf8\x71\x00\x7b\x97\xb7\xfc\x56\x29\xc5\xf8\xf2\x71\xa9\xa9\x7c\x2e\x54\x39\xe7\xac\x2c\x22\xe1\xc2\xe5\x9e\x20\x59\xf8\xbb\x91\xe0\xbe\x39\x60\xb9\x5c\x57\xb5\x95\xa9\x0e\xa4\x92\x0e\x30\xc0\x67\x6f\xc9\xba\x9e\xb7\xc1\x30\x87\x1f\xfc\x95\x4f\x82\x03\x9c\x78\x13\x45\x90\xa4\x14\x13\x4a\xdd\x95\x33\x6f\xef\x80\xdc\xaa\xd4\x51\x85\xb0\xd3\x82\x8f\x3b\xbd\x22\xbe\x84\xf1\x8d\x59\x8d\x3a\xad\x3b\x6e\x3d\xbe\xc7\xb9\xfb\x27\xf6\x2b\x26\x3f\x60\xc3\xf7\x29\x03\x48\xda\x6f\xf5\x10\xb9\xc1\x67\x9c\x56\xc6\xae\xc2\xf8\xa7\x6f\x12\x46\x66\x7e\x37\x40\xb8\x4a\xd5\xd4\x54\x51\x31\x80\xdd\x59\x37\x46\x29\xe0\xe4\x5e\x0a\x29\x78\x45\x16\x06\x76\x9e\xb1\xda\x1a\x09\x27\xcd\x3d\x51\xf2\xc5\xdf\xe3\x80\x6c\xc9\x52\x05\x93\x9c\x3c\xce\xbd\xa1\x82\x2b\x8b\x9f\x61\x49\x72\xb7\x25\x84\x80\x86\x8a\x15\x8c\x81\x87\x2d\x4f\xcd\x66\xbe\x81\xf8\xee\xe4\xbd\x23\xfa\xf9\xb1\x03\xfe\x7a\x07\xe4\x49\x56\x29\x20\xf9\xb8\x69\xca\xf3\x54\x70\x13\x16\xbc\x5b\x74\xb6\x0b\xaa\x82\x90\xa7\x2f\xf7\x39\xc0\xf5\x94\x3e\xfb\x39\x77\x0f\xef\x63\x51\x15\x84\x20\x87\xb2\x99\xb5\x06\x77\x10\x82\xa4\x69\x33\x0b\x21\x67\x04\x5f\x75\x32\x88\x1d\x0e\xa1\xe2\x4a\xf3\x57\x37\xcf\xfe\xc1\x84\xa5\x58\x8b\xf9\x0e\x9f\x30\xfc\x20\x27\xe3\xf5\x01\x24\xed\xb7\x0c\x41\x6a\xb9\xc1\x9d\x4e\xfe\xb1\x40\x7c\xce\x9c\xc4\x17\x98\xd8\x4f\x42\x0d\x21\x9c\x60\xaf\x57\xeb\xf4\x4a\x48\xd2\x97\x15\xd2\x50\x39\xd8\xe1\x73\xde\xca\x32\xb2\xe7\x41\x08\x41\xeb\xe4\x4b\x55\x50\x0d\xb8\x36\x49\x8d\x3b\xa0\xde\xf6\x36\x2c\x9e\xd8\x0d\xc4\x07\xd5\x9f\x74\xab\x89\x80\x85\x66\x58\x7d\x26\x9a\x05\xc9\x2f\xfa\xc4\x67\xe7\xa1\x7a\xa8\x34\x28\xfb\xb0\x16\x2e\x44\x8a\x91\xa5\xbb\x98\x13\x41\xb0\x72\xf2\xc5\xb6\xda\x8f\x31\x4e\x3d\x1a\xf1\xd6\x69\x08\x69\x81\x9f\xda\x05\x1c\xf9\x05\xe3\xd2\x19\x79\xe5\x97\xba\x60\x9c\xf8\xe2\x52\x65\xce\xa0\x79\x6f\x95\x22\x25\xec\xdc\x2b\x73\x2e\x7c\x58\x7d\x12\x63\x51\xb0\xc7\xbf\x8f\x4d\x1d\x40\xd2\x4e\xc6\xf5\xcf\x53\xcb\x21\x72\x03\xe7\xd9\x9d\x3a\x3a\x1b\xe3\x94\x8a\xc3\xa6\xa9\x90\x13\x2e\x7b\x4b\x37\xca\x17\xc3\x4e\xdf\x59\xf0\x8c\xec\xc8\x00\x5e\x4e\x93\xfa\xca\xa1\x9a\xcb\x7d\x23\xe9\xc5\xac\x70\xb0\x6b\xb4\xa5\x6f\xe4\x01\x20\x38\x1d\x36\xe2\x12\x36\x09\xaf\xfd\x7b\x1c\x40\x3c\xbf\x4b\x9a\xd3\x01\x37\x4c\xb7\x51\x72\x99\x0a\x0c\xf1\x0a\x49\x79\xb6\x12\x16\x4c\x1f\x32\xcf\x10\x42\x48\x38\xf0\x96\xe5\x2f\x91\xae\x10\xaa\xa2\x79\xbd\xa2\x6b\x80\x07\x78\x35\x4c\x68\xea\x47\x11\xaf\x4b\x54\x07\x27\x66\xb8\x45\x08\x33\x5e\x30\xda\x6c\x5c\xc4\x0b\x30\xaf\x8d\x37\x4e\xb4\x0e\xfa\x43\x78\xcd\xa2\xca\x41\xe3\xfd\x78\xb5\xa2\x72\x40\x1b\x5e\x96\x08\x6e\xa0\x82\x5f\xcc\x27\x47\xe4\x0c\x20\x69\xef\x1f\x47\xe6\xa9\xe5\x10\xb9\x82\x97\xcd\x5e\x8b\x80\x62\xc1\xe7\x9a\xc5\xbc\x88\x4e\xe8\x37\xe5\x2d\x8c\x84\x8d\xe2\x67\xc0\x9b\x12\xb9\x75\x10\x52\x3c\xdd\x48\x08\xb1\xbe\x5d\x96\x3b\x84\xbb\xc0\x2e\x27\xf3\x28\x21\x54\x6b\xee\x3f\x49\xb6\x2b\xd6\x80\xfd\xda\x72\x6d\x15\x54\x47\xfc\x3d\xd2\xbc\x8e\xf6\xbf\xa7\x0c\xed\xf3\xfc\x57\xf2\xe5\xaa\x6f\x41\xb1\xbb\xe4\x03\xc5\xa7\x60\xd8\x04\xcb\x42\xd1\x4b\x70\x02\xe2\x4f\xcc\x38\x6f\x39\x74\x4e\x80\x40\x65\xe9\x1c\xb9\x1f\xe3\xfd\x1f\x25\x1b\x28\x24\x70\xf2\x3d\x8a\x97\x76\x1b\x82\xfd\x01\xd2\x8b\x1d\x50\x1d\xf1\x57\xc9\x97\xa8\xb6\xdd\x4f\x07\xfc\xdf\xa3\x17\x27\x99\xab\xd0\x06\x07\x34\x58\xc9\x44\x50\x56\x56\xee\x2b\x9b\x57\x6b\x38\x04\x72\xc0\x25\xe9\x61\x39\x6c\x20\x9f\x62\x2b\x1e\x93\x03\xfc\xd7\xa7\x1b\x56\x83\x9e\x50\xb3\x2b\x7a\x8c\x5c\x41\x69\xf1\x9c\x2e\x38\x21\x6e\x1c\xf9\x8f\xaa\x00\xf6\x9e\xc0\xe6\xca\xfb\xef\x80\x78\x89\x0e\xeb\x80\x6a\xab\x2c\x51\x32\xec\xbc\xa9\xa5\xb4\x72\xce\x10\xa8\x82\x82\x0a\x46\xcb\x42\xc0\xae\x66\xab\x7d\x22\xb8\x59\x07\xce\xcc\x58\x5f\x03\x17\xcc\xf0\xa0\x8a\x5c\x46\xae\x5f\x72\xc9\xb5\x6e\x08\xb5\x6e\x2e\xe7\xc6\xab\x4e\x00\x0f\xea\x6a\xf1\xde\x39\x60\x9b\xda\x01\x56\xd2\x53\x1d\x2d\xcc\x57\x40\x48\xca\xdf\xb2\xd5\xc1\xd0\x74\x00\x29\x43\x43\xad\x16\x47\x32\x5f\x3b\xd1\xb1\x65\x95\x70\xe3\xf6\x3d\x5a\xfa\x56\x0f\x0f\x88\xd7\x96\x2d\xea\x7c\x0f\x78\x58\x2c\x5f\xa0\xda\x72\x3f\x42\xd0\x22\xf9\x3c\x46\x91\x5b\x94\xec\x40\x27\xf3\xb1\xea\x09\x79\x8e\xea\x20\x28\x0e\x96\x7c\xac\xf8\x04\x16\x5a\x6f\x55\x20\x4a\x87\x10\xb4\xae\xec\xa9\x21\x75\x13\x2e\x54\xdf\x84\xe3\x25\x0b\x58\x1e\xa2\xe5\x7c\x95\x13\xa0\x93\x34\xb7\xa3\xed\x7e\x5e\xc4\x5c\xce\x8d\x63\x8e\x5a\xc0\xa4\xd2\xa6\xee\x7a\xd8\x09\x73\x4b\x2e\xf5\x18\x81\xe2\xab\x92\x17\x2b\x60\x81\x82\x44\x0b\x1d\x61\xf1\x10\xfc\x16\x14\x6d\x31\x46\x68\x0b\x76\x9e\x95\x70\xd8\x6f\x41\x46\x40\xb8\xd9\xfd\x2c\x43\xf3\xfb\x92\x0b\xbf\x5b\x9e\xa5\xf2\x03\xe2\x3f\xbf\x30\xa5\xab\x0c\x14\x8d\x2f\xfe\xb8\x1b\xca\x47\xf7\x71\xe9\x97\xeb\xa0\xba\xf0\x1e\xed\x3c\x3d\x69\x9b\xfa\x6b\xa8\xd6\x10\xfa\x1a\xfa\xaa\xf3\xdc\x24\x0a\xec\x7c\x2d\xbd\xaa\x6e\xe1\xdf\xf9\x35\x74\x95\x5c\x9f\xb9\x88\xf1\x91\xb4\xad\x73\x34\x5b\x07\x77\x75\xfe\x0b\x50\x50\xd0\xd3\x31\x03\x4e\xc8\x92\x1f\xe3\x9b\x2d\x06\x7d\x5f\x77\xcc\xb6\x6e\x34\x78\x88\x91\xd8\xa1\xdf\x67\x17\x3f\x50\x3a\xac\x63\x36\xf3\x07\x1d\xb5\xdd\x2e\xd2\x9a\xce\xe7\x58\x07\xac\x67\xbf\x0a\xdf\x33\x07\x14\x83\x60\xc6\xf3\xd3\xe5\x47\x54\x27\x99\x85\x14\x38\xb6\x67\x01\x4a\xf2\x8f\xb4\x31\x17\x91\xe4\xfc\xdc\xf6\x17\x98\xd8\x58\xb0\xac\xdd\x1f\x30\xb2\xc0\xa6\xfd\x04\x8b\xd6\xed\xa9\x0f\x35\xf6\xd9\x41\xec\x4a\xce\xcf\x61\xed\x4c\xc9\x8f\x69\x63\x76\x7e\x48\xc1\x77\xed\xd9\x2c\x2f\xd1\x0c\x2f\x84\xa7\x3f\xef\x80\x43\xdc\x2e\xf4\x19\x4c\x5c\x63\x1e\x24\x14\x83\x03\x5e\x4a\x4e\xad\x84\x58\xed\xb1\x31\x73\x53\xc3\xcb\x70\x21\x09\xa3\x97\x65\x0a\x01\x53\xdc\x67\x7d\x3f\x02\x50\xe2\x1e\xf0\xfd\xfa\x47\x08\x89\xdd\xe1\xf4\xf2\x4c\x86\x97\xaf\x33\xb7\x36\x8c\x03\x07\xbc\x98\x7c\x9c\xe1\x89\xf0\xd6\xcf\xe3\x5d\x3b\xc0\x85\xfa\x07\xd2\x85\x89\x63\xcc\xf3\x84\x55\x2a\xe3\x68\x41\xb0\x71\x4e\x11\xc6\xf9\xbd\x9e\x4f\x48\xe0\xe8\x25\x7d\x66\xb1\x3c\x74\x05\x24\x33\x6c\x3e\x3f\x14\x6e\xbc\xe2\x95\xe6\xeb\x42\xad\x1f\x1d\x64\xed\x86\x90\x94\x34\x03\x78\x80\xb2\xb6\x40\xc3\x73\xb8\x64\x12\xc6\xd1\x1e\xc1\x5b\x73\x4a\xc0\x01\x6a\xde\xfa\x79\xbc\x6b\x07\x4c\xa0\xd6\xa2\x50\x3d\x33\x9f\xaf\xa9\x0e\x74\x4e\xb5\xad\x88\x63\xd3\xc6\x28\x6c\x3e\x6d\x57\x72\x68\x1f\xc6\x0d\x11\xf6\xba\xc1\x31\x18\xd7\xe7\xda\x7f\x12\xfc\x03\x60\x91\xfd\xa7\xc1\x27\x1f\x21\x54\xdb\x4d\x78\x60\x79\xd9\x8b\x31\xe1\x89\xf0\x46\x78\xbc\x73\x07\x30\x3f\xd9\x61\x7e\x11\xa3\x45\x19\x22\x91\x5e\xb6\x8f\x98\x8a\x45\xf6\xaa\xc4\x0b\x23\x6d\x34\x42\xa6\x60\xfc\xdb\xcb\xf6\x57\x82\x21\x09\x37\x05\xd8\x27\x04\xef\x06\x0c\xb3\x4f\x0c\x86\x0b\x4d\x53\xe8\x23\x86\xc4\x6e\x35\x0f\x84\x97\x0b\x23\xfa\x78\xf2\x89\xa1\xe2\x80\xb7\x04\xe0\xd1\x08\x45\xea\x65\x01\xaf\xa6\x0c\xaf\xb7\x77\xc0\x2e\xea\x1b\xe4\x09\xa8\x4b\xad\x43\x1e\xda\x37\xe8\x22\x8a\x87\x82\x5a\x36\xa7\xe6\x59\xd9\x84\xbd\x8a\x71\xf1\x75\x1b\xad\x90\xc5\x80\x9f\x83\xa2\x35\x80\x9f\x00\xae\x7d\x84\x91\xf0\x70\xad\x8f\x97\xd4\x2c\xe0\x69\x2c\x84\xa0\x42\xe0\x2d\xb0\xc5\x80\x9e\x0b\x3c\xba\x68\x57\xd3\x3b\xa9\xaf\x91\xdb\x9d\x38\x60\x2b\xb5\x08\xd9\x32\xff\x38\x97\x9a\x83\x4c\x34\xbf\xa5\x57\x51\x06\x48\xe0\xff\x2a\x08\xb4\x06\x81\x86\x3e\x22\x2a\x11\x39\xab\x12\x7c\x4e\x50\xc9\xc8\x49\xb5\xcd\x27\x8d\x45\xe3\x47\x16\x09\x0f\x6a\x5e\xfa\x89\x5f\x0d\xbc\x79\xf9\x3f\x4b\x7f\x4b\xbd\x8b\x0c\x35\x37\xd1\xdb\xa9\x8f\xd0\x8e\x3b\x71\x80\x07\x84\x9e\x03\x1c\x4d\xda\x95\x32\x66\x4f\x82\x21\xa5\x87\x56\x68\x1a\xd3\x3a\xd4\x6a\xe4\xa6\x7d\x95\x1e\x0b\x82\x99\x23\x35\x0e\x3c\x7a\x04\x62\x5b\x1f\x9a\x3c\xe2\x68\xc6\xf2\x22\x02\x5e\xe6\x52\xcb\x80\xa7\x2a\x7a\x29\xa5\x8f\x16\x00\xf1\xf6\x90\x03\x98\x5f\xde\x3b\x53\xcb\xd1\xfe\x3b\xf8\x61\x77\xff\x4f\xf7\x6d\xc0\x01\x4e\xe0\x88\x0d\xd4\x0a\xb4\x99\x7d\xdf\x88\x3c\xd8\x1c\xb1\x83\xfd\x59\xe7\xed\x7e\xfe\xf9\xa8\x21\xe1\x65\x27\x6c\x60\x37\xe6\xd7\xa6\x40\xf8\x5a\xf6\xd7\xa5\x6b\x91\xc5\x03\xf4\x5f\x1b\x3c\x7e\x1e\x3f\x0f\xd4\xf3\x1f\x2a\x77\xb1\xb0\x36\x6b\x49\x23\x00\x00\x00\x25\x74\x45\x58\x74\x64\x61\x74\x65\x3a\x63\x72\x65\x61\x74\x65\x00\x32\x30\x31\x38\x2d\x31\x30\x2d\x31\x34\x54\x31\x34\x3a\x30\x32\x3a\x31\x36\x2b\x30\x32\x3a\x30\x30\xa9\xfa\x63\xbf\x00\x00\x00\x25\x74\x45\x58\x74\x64\x61\x74\x65\x3a\x6d\x6f\x64\x69\x66\x79\x00\x32\x30\x31\x38\x2d\x30\x39\x2d\x32\x34\x54\x30\x30\x3a\x30\x35\x3a\x30\x38\x2b\x30\x32\x3a\x30\x30\x13\xe6\xcd\x46\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\x0c\xe4\xa1\x46\x87\x13\x00\x00")) - cancel18x18 = HexToBytes("cancel18x18", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x9b\x08\x64\xf7\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x12\x00\x00\x00\x12\x10\x06\x00\x00\x00\x06\x5e\x52\x14\x00\x00\x00\x04\x67\x41\x4d\x41\x00\x00\xb1\x8f\x0b\xfc\x61\x05\x00\x00\x00\x20\x63\x48\x52\x4d\x00\x00\x7a\x26\x00\x00\x80\x84\x00\x00\xfa\x00\x00\x00\x80\xe8\x00\x00\x75\x30\x00\x00\xea\x60\x00\x00\x3a\x98\x00\x00\x17\x70\x9c\xba\x51\x3c\x00\x00\x00\x06\x62\x4b\x47\x44\xff\xff\xff\xff\xff\xff\x09\x58\xf7\xdc\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0e\xc3\x00\x00\x0e\xc3\x01\xc7\x6f\xa8\x64\x00\x00\x00\x07\x74\x49\x4d\x45\x07\xe2\x09\x17\x01\x31\x22\x45\x79\x31\x1f\x00\x00\x07\x8a\x49\x44\x41\x54\x48\xc7\x7d\x56\x7d\x54\x93\xe7\x15\x7f\x5b\x81\x58\x37\xcb\x10\x74\x56\x3b\xfb\xb5\xee\x74\xce\x9d\xb6\xe3\xac\x4d\x75\x3a\x1d\x26\x6d\x1e\x41\x3a\xe0\x8d\x89\x9a\x22\xa1\xf4\xb4\xe3\xb0\xd3\xc6\xcf\xc8\x67\x4c\x5e\x4b\xde\xbc\xc1\x55\xc0\x78\xda\x29\xa2\x6b\x89\xc8\x20\x4a\x45\x11\x02\xdd\x4a\x41\x51\x21\x7c\x83\x56\x51\x50\x14\x44\x58\x75\xee\xd0\xd6\xf1\xec\xf7\x3e\xc0\xe2\xd9\x47\xf3\xcf\x3d\xe7\xc9\xf3\xdc\xfb\xbb\xf7\xfe\xee\xef\xbe\x1c\xf7\x1f\xbf\x4d\xdf\xd3\xdc\x17\xef\x72\x5c\xca\x67\x24\x5a\x5a\xc0\x71\xdb\xd6\x6b\xba\xc5\xc5\x1c\x17\xfe\x51\x54\x8b\x6b\x19\xc7\x25\x9b\xc9\x3e\xe9\x28\xc7\x99\x6f\x69\xbc\xf6\x61\xe5\x41\x8b\x51\xb3\x22\x7b\x93\xe1\x8c\x65\x03\xb3\xa7\x71\x5e\x6b\xbf\xa5\xdc\x9f\x9c\x4a\xfe\x28\x1d\xc3\xbb\xf7\xa3\x3a\x5c\x6a\xf8\x89\xd7\xf4\xc8\x7e\x52\xaa\x88\x5e\xfa\x31\xe2\x28\xc8\xc3\xe2\x18\xf7\xff\x7f\x9b\xe6\x92\x50\x47\x10\x1e\x3c\x42\xcc\xd2\x7a\x8e\xa3\x74\x69\x7d\xc2\x06\x8e\x33\x55\x92\x45\x8e\xd7\x15\x4f\xe5\x1c\x7e\x2d\x51\xb8\xe0\x2c\x2c\xd6\xaa\x33\xb2\x0c\x7d\xa1\xde\x2b\x2a\x47\xda\xe7\xe3\x07\x1a\x82\x54\xe9\xa9\x7a\x4a\xa7\xac\xf7\x32\x3b\x2f\x28\xe6\x71\xef\x8d\xbe\xe0\x9c\x22\xf6\x6e\x8f\xe9\x14\xfc\x44\x2a\x42\xe1\xd7\x67\x7c\x0e\x71\xbe\x4f\x32\x24\x23\xe2\x2e\x20\x8f\x39\x82\x1f\x04\x12\x48\x02\xc4\xdb\xb8\x30\x9d\xa4\x4a\x6b\x39\x2e\xa2\x2b\x72\x30\xef\x25\x8e\xcb\xa8\xd5\x6c\xc9\xfe\xa7\xea\x88\x7b\x4c\x7d\x34\xeb\xd3\x81\xfb\x3e\xaf\x6a\xbf\xf9\x1b\x4a\xfb\x6e\x93\xc5\xdb\x53\x29\xbd\xd9\x1a\xdd\x99\x2e\x52\x3a\x54\x12\x73\x28\xf3\x57\xcc\x1e\x94\xed\x4d\x5f\x74\x87\x7c\xde\x37\x8c\x7b\x69\x94\xfa\xaa\x54\x05\xf2\x3b\xf7\x3f\xd4\x9e\xac\xe3\x03\x5f\x65\xd4\x68\xb6\xda\x39\x55\x7e\xc4\x85\xc8\x7b\x79\x04\x71\x1f\x25\x59\x52\x12\x70\x3c\x4a\xa6\x3b\x64\x40\x29\x27\xc9\x3a\x69\x2e\xab\x48\x56\x42\x36\x80\xe0\x41\xf6\xb8\xea\x48\x79\x98\xfa\x47\x19\xa7\xc7\xda\x7b\x57\xbc\xda\x66\x5e\x43\xe9\xad\x84\x98\xfc\xcc\xf9\x94\x8e\xb4\xe9\xbe\xd8\x71\x1b\xb6\x5c\x5f\x6f\xfd\x18\xb6\x14\xf6\x93\x07\x6c\xf9\xa4\x6d\xc5\xbd\x61\xbc\x8b\x8f\xf9\x43\x66\x18\xa5\xbd\xcb\x5e\x6d\x35\xeb\x28\x2d\x0f\x81\xdf\x33\x63\xcd\x72\xc2\x00\x96\x8b\xb8\x23\xc6\xe7\x81\xa3\x8e\x18\xa4\x85\xdc\x24\x47\x5e\x66\xad\x79\xde\xb1\x4a\xf1\x14\xab\x48\xc5\xc0\x7d\x06\x04\x0e\xae\x3f\x12\x67\xb5\xbc\x45\x69\xcd\x27\xfa\x39\xe2\x3c\x4a\x5b\xdb\xb4\xe7\x84\x0a\x4a\x47\x37\xea\x97\x5b\x17\x22\xf0\x16\x7d\x8a\xf5\x5d\xbf\x1d\x35\x4d\x9c\xb7\x76\x6a\x5b\x85\x3a\xbc\xfb\x8b\x7e\xa5\xb8\x13\x7e\xa6\xc7\xed\xb0\x24\x02\xd8\xaf\x27\x80\xb9\xef\x21\xce\xf1\x81\x21\x53\x15\x79\xd1\xb1\x5a\x11\xb4\x6d\xad\xe6\x4b\x71\x09\x00\x85\x7f\x18\xd5\xea\x8a\xe2\x38\x70\xe4\x4d\xf4\xfa\x20\x6b\xcd\xd7\xc8\x2c\x31\x66\x4f\xe6\x13\x70\x68\xd6\xb5\xdb\x77\x50\x5a\x97\x56\x12\xe2\x4d\xa6\xb4\xfa\xfd\x9c\x3f\x97\x7d\x88\x56\x74\xf1\x6b\x85\xa7\x01\x60\x9f\x3e\xc2\xfa\x2c\xb3\x2b\xad\x3f\xc1\x79\x13\xbf\x4a\x40\xbd\xab\x6f\xec\x7a\xcd\x03\x3f\x0d\x0f\x79\x9e\xa9\x47\xc5\x6a\xe3\xf4\x6b\x44\xb4\x7a\x98\x8f\x29\xcd\x9c\x86\x7b\x15\x13\x14\x60\x71\x7b\x9c\x62\x78\x42\x54\xb3\x2b\x12\x80\x92\xd3\x88\x4b\xf2\x70\x1c\xc8\x9a\x06\x12\x86\x32\x8e\xa0\xf7\x23\xed\xba\xfa\x1d\x7f\x43\xa6\xa7\xb5\x35\x82\x8b\xd2\x53\x87\x1c\xb5\x87\x67\x83\x2b\xd7\x2e\xcd\xee\xf1\x21\x60\x98\x73\xb0\x6c\x2f\x1c\xdf\xe0\x67\xd9\x46\x60\x2f\xf3\x81\xb6\x66\x9c\xab\x73\x96\x78\x62\x29\xbd\x5d\x70\x75\x7b\xbf\x07\x09\x29\x77\x99\x3c\xd7\x90\xd0\x5d\x7e\xce\xce\x43\x94\xf6\x2c\xd4\x86\xd8\xd4\x94\xf6\xbf\x47\xc8\xf6\x8d\x94\x16\xbf\xce\x86\x44\x91\xbc\x95\xec\x91\x4a\x00\xc8\x3c\xa4\xa9\xb6\x0f\x29\x0b\xbd\xbd\x2a\x51\x9e\x1a\x46\x4a\x87\x9f\x23\xa3\x9b\xf4\x2a\xeb\x4b\x94\xb6\xd4\xf2\x89\xb6\x3e\x00\x73\x8a\x67\xdd\x5b\x51\xc1\xd9\x5f\x5e\xec\x71\x53\x5a\xc9\x3b\xcf\x97\x8d\xc1\x3a\x73\x7e\xea\xa9\x07\x10\xdf\x55\x65\x3f\xfe\xf7\xe6\xe6\x24\x79\x96\x51\xfa\xf9\xae\xd8\x3f\x09\x6d\x94\x36\xbd\xcd\x3f\x2d\xbc\x42\x69\x47\xa0\x76\xb7\xb0\x02\xe4\x6f\x89\x6e\x4f\xb7\xe3\xde\x45\x4c\x65\xdd\xf8\x01\xf3\x00\x70\xdc\x52\xba\x38\x4b\x02\xf4\x63\xb3\xe1\x0c\x1b\x5b\xf4\x76\xe8\x08\xa6\x66\xb1\x9f\xa4\xa3\xb1\x7a\xbb\xd5\x48\x69\xe7\x22\xed\x3c\x5b\x23\xa5\xf5\xa6\xd8\x0a\x01\x99\x9d\xe8\x15\x4b\xdd\xb5\x94\xde\xf9\xe0\x7a\xd8\xa5\x51\x4a\xef\x2d\x1d\x34\xdc\xc8\x03\x60\x7d\xce\x6f\x3c\x95\x94\xfe\xf5\x64\xec\x72\xe1\x18\x80\xbc\xcb\x2f\x10\x94\x00\x92\xa4\x8d\x94\x5b\x39\x9a\xaf\xef\xb7\xee\x65\x71\x0a\xe5\x38\x0d\x01\x13\x72\x61\x89\x07\x8e\xad\x06\x0f\xc7\x84\x6d\x8b\xa1\x01\x80\xd2\x1e\x04\x34\xf5\xb0\xe3\x4d\x6d\x94\x8d\xc2\xf1\x46\xfe\x19\x21\x02\x81\x3e\x8b\x8d\x14\xce\x03\xd0\x80\xb8\xae\x08\x2d\x1d\xed\xbd\xd2\xd8\x4e\xfc\xc0\x2a\xaf\x38\x2f\x97\x0d\x02\x78\x6a\x6c\x9d\x00\x80\x9d\x0b\xb5\xb3\x6d\x5e\xdc\x8b\x9b\x48\x6c\x2a\x51\xc4\x39\xc8\x00\x4d\xfb\x37\xa0\xe5\xc0\x51\x2a\xb7\x4c\x56\xdc\xfd\x10\x3a\x49\x16\x34\xe8\x4b\x87\x5c\xca\x76\xaa\xfd\x40\x2e\x6d\x53\x0a\xff\x9c\xb0\x12\xa5\xcf\x8b\x2d\x11\xae\x52\x5a\x15\x2e\xee\x2b\xfa\x14\x25\x5f\xd3\x9d\xd5\xdc\x03\x60\x73\xc4\x15\x45\x20\xe7\x89\x38\x71\x9f\xfb\xec\x64\x2b\xd1\xea\xea\x9d\xce\x91\x32\x64\xd2\x72\x9e\xdf\x26\x84\x00\xd0\x7b\x98\xbe\x9f\xf9\xa9\x70\xb3\x39\xba\x55\xd6\x2b\x6f\x37\xa8\xf2\xc5\x78\x01\x5a\x56\x05\x1c\xb9\x32\xa9\xf7\x4a\x87\x41\x6a\x9e\x91\x2b\xb8\xdf\x44\x56\xc9\x64\xeb\x59\xa4\x0d\xb3\x21\xf3\xba\x61\x7e\xc6\x4e\x38\xae\x3a\xef\x38\xe0\x06\x97\x6e\x3e\xd9\xed\xf5\x05\xa0\x12\x5d\xe2\xdb\x45\x18\x6b\xdf\x35\x3e\xc4\x36\x04\x7b\x89\x0f\xb0\x9d\x43\xcb\xe6\x8b\x0d\x6e\x1b\x23\xff\xdc\x1e\x54\xb2\xda\x94\x73\xa0\xcc\xc9\xe4\xe2\xac\x70\xdc\xaf\x63\x7d\x43\xe4\x65\x59\x60\x8b\xa3\xd9\x30\x05\x80\xd4\xf9\xf2\x70\x71\xe1\xb9\x51\xe7\x5c\x11\x18\x7b\x37\x93\x78\x97\xef\xe4\x84\xb2\x0e\xeb\x62\x2a\x32\x67\x61\x5c\xe7\xe8\xa8\xfd\x28\x2a\xa4\x2d\x26\x95\xef\x20\xe0\x3b\x0e\xa3\x1b\x15\xf3\xf9\xf8\xdf\x0a\x33\x91\x79\xa1\x5e\x63\x7d\x71\xd2\xfe\x02\xe7\x8d\xbc\xda\x76\x07\xf7\x4e\x3a\xda\x0e\x3f\x8e\x84\xd2\x4b\xc2\xbc\x29\x98\xb6\x52\xfd\x5c\xf1\x31\x54\xd0\x18\xb3\x3b\x13\x7a\x86\x38\xfb\xcd\xdf\xb2\xb1\x37\x22\x6e\x56\xf8\xda\xa8\xd3\xae\x0d\xb2\x30\xbe\x01\x41\x92\x85\xb1\x9a\xbc\xe0\x20\x8a\x50\x48\xbc\x2c\x58\x5f\x4d\x09\xd8\xf5\x19\x71\x82\xe5\x77\x70\xb8\x5b\x37\x62\x3f\x85\x4c\x7d\xda\x3a\x41\x9e\xbe\xcd\x98\xbe\x5f\xfe\x0f\x61\x9c\x3c\x6f\x6d\xd6\xd6\x0a\xe0\x60\x8d\x5d\xd7\x69\xb7\x30\x3f\x16\x4b\x12\x53\xec\x16\x26\x8c\x77\xd4\xc7\x10\xa7\xd7\x54\x41\x7e\xee\x58\x15\xf4\x35\x84\xf1\x82\xbc\x7c\xb9\x94\x13\xc4\x28\x05\xb3\xd5\x51\x67\x4c\x9c\xd8\x61\x90\x74\x17\x24\xfe\x71\x59\xe2\xa7\x1c\x30\xa1\x7c\xd2\xaf\x4f\xdf\xb9\x3a\x3e\xf6\xdf\xc3\xbb\x7c\x59\x60\x7b\x97\xc2\x0f\x56\x50\x79\x30\x56\x47\xe3\x58\x23\xe2\x98\x11\x27\x1d\x71\x9b\x12\x9f\x05\x8e\x53\xe4\x2d\x69\xbe\xbc\x5c\x1f\x26\x33\xc5\x41\xb6\x7d\x2d\x52\x3c\x96\xeb\xa5\xc8\xb1\xbc\xd5\x93\xcb\x75\x5c\x95\x0b\x89\xf7\x60\xb9\x0e\xb1\x12\x7f\xc3\x7a\xff\x0a\x5b\xae\xbe\x09\xf2\x63\xa9\x16\x66\x2e\xf1\x5b\x46\xd6\x6c\xdc\x1b\x04\x47\xb6\xb3\xd6\x4c\x2c\xd7\xbb\xea\x32\xb9\x22\xf0\xbb\x19\x7e\x33\x22\x6a\x22\xbf\xcd\x53\x21\xae\x82\xd8\x24\x03\x70\xcc\x20\xb3\xc4\xbf\x3f\xb8\xf5\x9f\x20\xf3\xe4\xcf\x80\x94\x60\x6c\xdf\x78\x56\xb1\xb3\xc6\x6e\xb4\xb2\x4a\x2e\xa9\x42\xc1\x24\xfe\xa2\x53\x82\xb2\xa6\x83\x84\x0a\x6f\x0f\xa6\x12\x82\xd6\x10\xa8\x4a\x95\xe5\x02\x7a\xc2\x2c\xa6\x46\x16\xba\x02\x90\x35\x13\xf7\xa6\xe1\x5d\x92\xcc\x11\xb4\xe6\x05\xc7\xea\x20\x48\xe8\xb2\x70\xe3\x19\xc4\x99\x89\x38\xf2\xe7\xc7\x0f\xc9\x7c\xc7\xf4\xef\xfa\x2e\xfa\x01\x09\x64\x9f\x23\xf5\x64\xbd\x14\x0a\x8e\xe9\x34\x5d\xa2\x12\xe4\xff\x7d\x54\x97\x4b\xcb\x3e\xd0\x3e\x92\xa7\xc1\x7c\x03\x1f\x62\x43\x4a\x17\xd3\x31\x93\xa1\x0c\x76\x39\x6c\xa9\xf9\x1a\x64\x64\x50\xb9\x3b\x79\x33\x3e\xd0\xca\xf0\xce\x80\x5d\xa9\x83\x9f\x75\x9a\x8b\xe2\x52\xf8\x6d\x22\x71\xd2\x22\x56\x00\xce\xf1\xd0\x7f\xc7\xff\x17\xb6\x07\x8e\x53\xd1\x98\x93\xb1\x00\x00\x00\x25\x74\x45\x58\x74\x64\x61\x74\x65\x3a\x63\x72\x65\x61\x74\x65\x00\x32\x30\x31\x39\x2d\x30\x31\x2d\x32\x34\x54\x32\x30\x3a\x32\x39\x3a\x35\x36\x2b\x30\x31\x3a\x30\x30\xd5\x66\x4b\x8a\x00\x00\x00\x25\x74\x45\x58\x74\x64\x61\x74\x65\x3a\x6d\x6f\x64\x69\x66\x79\x00\x32\x30\x31\x38\x2d\x30\x39\x2d\x32\x32\x54\x32\x33\x3a\x34\x39\x3a\x33\x34\x2b\x30\x32\x3a\x30\x30\xff\x19\xf2\x5a\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\x0b\xb9\x9a\x0e\x9b\x08\x00\x00")) - checked18x18 = HexToBytes("checked18x18", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x1d\x0a\xe2\xf5\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x12\x00\x00\x00\x12\x10\x06\x00\x00\x00\x06\x5e\x52\x14\x00\x00\x00\x04\x67\x41\x4d\x41\x00\x00\xb1\x8f\x0b\xfc\x61\x05\x00\x00\x00\x20\x63\x48\x52\x4d\x00\x00\x7a\x26\x00\x00\x80\x84\x00\x00\xfa\x00\x00\x00\x80\xe8\x00\x00\x75\x30\x00\x00\xea\x60\x00\x00\x3a\x98\x00\x00\x17\x70\x9c\xba\x51\x3c\x00\x00\x00\x06\x62\x4b\x47\x44\xff\xff\xff\xff\xff\xff\x09\x58\xf7\xdc\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0e\xc3\x00\x00\x0e\xc3\x01\xc7\x6f\xa8\x64\x00\x00\x00\x07\x74\x49\x4d\x45\x07\xe2\x09\x17\x01\x2b\x1c\x34\x35\xd6\x6f\x00\x00\x09\x0c\x49\x44\x41\x54\x48\xc7\x65\x96\x7b\x3c\x95\xe9\x16\xc7\x1f\x73\x6a\x52\x69\xea\x54\x34\xe9\x5e\x53\x9a\x6a\x8c\xa6\xd3\x4d\xa6\x8b\xfb\xa6\x9b\x4a\xe9\xd4\xa4\xd0\x65\x23\x93\xdc\x22\x35\x36\x3b\xec\xf7\x65\xdb\xa8\x6d\x6f\xdb\xc6\x76\xbf\xe5\x4e\x85\x3a\xda\x21\x8c\x5c\x23\xb9\x64\xb4\x43\x85\x3d\x92\x94\x4a\xeb\xac\xd7\xf9\xe3\x9c\xcf\x99\xf7\xf3\xd9\xd6\xe7\x7d\x3d\xef\x5a\xdf\x67\xad\xdf\x7a\xd6\x4b\xc8\xff\x5d\x2e\x5c\x56\x3f\xe5\x4a\x88\xeb\x2c\xb3\x59\xb4\x1a\x21\xce\xd1\x26\x36\x54\x32\x21\x97\x97\x58\x34\x05\x4d\x21\x04\x60\x2c\x52\xe6\x4e\xc8\x4f\x3f\xa8\xb8\x71\x6a\x08\x31\x87\x45\x3d\xd7\xd8\x84\x18\x96\xa9\xf7\x72\xcf\xff\xc7\xc7\x45\x6d\x42\xf8\xcb\xce\x54\xf0\x73\xd0\x9f\x09\x4b\x8b\xea\x23\xe4\xbc\x96\xfe\x12\xde\x3c\xf4\x3b\x99\xf5\x86\xaa\x45\xab\xc2\x1a\xa5\x14\xf8\xff\x57\x66\x2a\x54\x0f\x21\x6e\x25\xa6\x6c\x7a\xd2\xff\x82\x8c\xb3\x86\xa8\x17\x84\x44\xbd\xf6\x98\x1c\x6a\x8a\x0b\xca\xcc\x95\xb4\x21\x21\x26\xab\xbe\x8d\xe4\x16\xe3\x7d\xbe\x79\x2b\x6d\x34\x17\x04\x7d\xec\xc6\x90\x19\x17\xbd\x12\x6b\x7d\xda\x42\xdf\x65\x50\x59\x9a\xb4\x7a\xf8\xcf\xf7\xbd\xd3\xd9\xfe\x9f\xc3\x72\x8a\xbe\x8f\xbc\xed\x7a\x5d\x70\x2c\x4c\xd3\x77\xff\xd1\x92\xe0\x29\xbb\x36\xd9\x6d\xde\x22\x08\x7c\x44\x88\xe8\xd3\xc5\xbb\x82\x3d\x84\x38\x2e\xdd\x5e\xc3\xdb\x41\x88\xbb\xda\x89\x62\xc1\x7c\x42\x38\x21\xbd\x0b\xb3\x3f\x60\xfc\xcf\x66\x25\xb4\x16\x03\xd2\xc3\xfa\x48\x55\x11\xb2\x0e\x7f\x3e\xfe\xb8\xc0\xda\xaa\x20\x48\x89\x2f\xa6\xee\xea\xe2\x8d\x13\x12\xa1\x71\x21\x3e\x64\x20\x5c\xa5\x72\x4e\xd2\x45\x21\x67\xf4\xe0\xf3\xf9\x72\x4b\x31\xe6\xe9\x0f\xdb\xd2\xe3\xa2\x78\x80\xb6\x90\x22\x81\xa8\x18\xa0\x8b\x5f\x1a\x26\x1e\x00\x18\x30\xad\xe5\x48\xf0\xf9\x93\xca\x5b\x3b\x23\x7a\x01\x32\xaa\x02\xcf\x84\x15\xd6\x7c\xb8\x7a\xce\xf2\x52\x10\x67\x63\x80\xfa\x2e\x42\x3c\x3c\x71\x83\xf3\xf7\x6c\xa6\x7b\xa6\xea\xba\xdd\x3b\xc2\xe7\x9f\xb2\x91\xb8\xb4\x99\x1b\xd2\x7a\x08\xe4\x21\xdf\x3b\x9d\xce\x20\xc4\x3b\xe6\xa0\x73\x90\x01\x96\x48\xdd\xf8\x01\x25\x55\xd1\x4f\x69\xe7\x6e\x0a\x63\x57\x9e\x56\x24\x97\x39\x88\x4b\x01\x1a\x66\xe7\xea\x46\xda\x03\xa4\xeb\x8a\xf4\xd2\x23\x00\xe2\x5e\xc7\x76\x3f\x68\x01\x88\x77\x4d\x5b\x5f\xa7\x04\xc8\x9f\x75\xc7\xa4\xd9\x16\xa0\xb6\xa0\x32\xb9\x46\x02\x50\xed\x95\xa7\x9f\xe4\x00\x30\xcc\x6e\xb1\x8e\xbe\x0e\x50\xa9\x9f\xe4\x28\x64\x8f\x3a\xf9\x4d\x3f\xba\x28\xa8\xef\x37\xca\x5d\x1e\xf0\x87\x38\xb9\x66\xc8\xe9\x6c\xc4\xb7\x12\x23\x80\x0b\x63\x07\x06\x82\x1c\x5d\x56\x91\x8b\xea\x26\x5d\xd4\x2d\x42\xec\xba\xb7\x5a\x06\x3e\x23\x24\x3e\xf8\xaa\x6d\x68\x46\xd1\xbd\x3e\x8d\xca\xe5\x91\x2b\x00\xee\xb4\xc6\x6c\x8c\x15\x63\x60\x49\x7a\x6f\xa3\x10\xa0\x60\xf3\x93\xe6\x0f\xb3\x00\x8a\xc6\x14\xa1\x80\xd7\x83\x17\x2f\x6f\x33\xf6\xe9\xd6\x61\x3e\x63\xab\x2d\xfa\x1e\x33\xb6\x6a\xc6\x33\xd3\x77\xb8\x11\xf9\xe2\x7c\xd5\x7b\xcd\x00\xe5\xdf\xc5\xab\x09\xf1\x7d\xff\x57\xc1\x4a\x31\xbe\x6f\xff\x32\x3f\x5a\x86\x7e\xcf\x75\x7b\xbd\x0d\x57\xc8\xcb\x5d\x3c\xcc\xd6\x50\x4a\x55\x07\x46\xa4\xfa\xb2\xab\x84\xf0\x1a\x6c\x54\xf8\x33\x4f\xf1\x3a\x76\x96\x9c\x15\xf5\xa3\xa3\x99\x49\x93\xa2\x03\x01\x92\xd5\x0b\x73\x3a\xa7\x02\x94\xf8\xf5\x54\x33\x81\x8a\x39\x8a\x3a\xc8\x41\x10\xd2\xeb\xcc\xdc\xb7\x4a\x86\x28\xc6\x3e\x62\xf5\xef\x64\x6c\xad\x74\x60\x1a\x63\x9f\xa9\xbe\xb3\x64\x6c\x76\xe4\x1d\x8d\x67\xae\x00\xde\xee\xfe\x6f\xa4\xe6\x00\x0e\xc2\x82\x7e\xd9\x15\x00\xa7\x99\xee\x5a\x61\xa5\x23\xda\xae\x43\xc6\xeb\x28\x2d\xf5\x06\xe7\xf3\xfb\x13\x82\x50\x53\xc4\x7a\x70\x43\x7b\xe0\x8f\x84\xe4\xb8\x05\xa7\x84\xf3\x6a\x8b\xba\x57\xdf\x6f\x12\xc7\x62\x46\xea\xe3\xbc\xca\x1a\x31\x13\xdc\xee\x3b\x5f\x9e\xa3\xe3\xb4\x6a\xdb\x41\x63\x80\xd2\xd7\xdd\xd3\x3e\x9f\x44\x90\x0f\x6f\xcc\x26\x40\x4c\xfa\x7f\x9e\x00\xf1\xed\xef\x64\x6c\xa7\x70\x64\x11\x63\x6f\x1f\xa9\x68\xed\xbb\x03\xe0\xf7\x75\xc4\xd7\x69\x6d\x00\xec\xc4\xbc\xb2\x58\x3b\x80\x2b\x42\xae\xcd\xf5\x85\x00\x77\x43\xc5\x95\x37\xbe\xc2\x8c\x9d\xf9\xa5\x3e\x98\xbb\xad\x94\x7f\xed\x4c\x27\x3f\x17\x81\xdc\x7b\xf7\xac\xa6\xed\xb5\x2c\xea\x0e\x67\xae\x8f\xd0\x1a\x8b\x28\x17\xa5\x2d\x8b\x39\x00\x70\x33\xac\xe2\xd0\x6b\xdc\x63\xfc\x8b\x82\x8a\xb6\x0e\x74\x34\x37\x40\x3b\x7e\x39\x66\xac\x2b\xb5\xad\x5a\x00\xf0\xbb\xa8\x37\x11\xe6\x23\xc8\xfb\x81\xd4\x09\x90\xb0\x11\x8d\x09\x10\xab\x8a\x9a\xbe\x02\x00\xdf\x48\xe1\xa6\x34\x7d\x04\xb9\x95\xf7\x4d\xcc\x0c\x80\xdf\x4a\x05\x3d\x69\x6b\x00\x12\xf9\xf4\xee\xf4\x12\x00\xc5\x0f\x0f\x7a\xc4\x52\x80\x28\x23\x77\x2b\x41\x5c\x48\x14\xd3\xe9\x8e\xdf\xe1\x1f\xbf\xc8\x63\x1b\x83\x59\x47\xae\xb5\x7f\x29\x8e\x17\x6d\x42\x8d\x44\xcb\xf6\xa4\x46\xa3\x48\x4b\x5b\x5e\xbe\xbf\x0f\x20\xc9\x92\x6d\xa9\xc2\x8c\xd9\x1f\x92\xce\x95\xb4\x03\xb8\xb5\x24\x6b\xc8\x30\x60\xfc\xae\xa4\xc4\xaa\xf7\xa8\x9d\x92\xc1\x5b\x13\x20\xd7\x1f\xae\xea\x1b\x41\x10\x91\x70\x65\xda\x66\x04\xc9\xc9\x9b\xcc\x80\xf8\xe4\x84\x66\xa6\x3e\xc5\x4c\xd2\xcd\x1e\x7f\x7e\x04\xc8\xb3\xcf\xac\xaf\x9b\x04\xd0\xde\x51\xfc\x56\x74\x02\xbb\x70\x5e\x40\x4b\xd8\xc8\x6d\x1f\x7d\xdd\x39\xd3\xfd\x06\x10\x08\x53\x16\x11\xe4\x6e\x23\xef\x38\x92\xff\x90\x3e\x03\x90\x63\x21\x51\x4d\x3c\x8c\x29\x85\xce\x91\x4f\x3e\x00\x8f\x2f\xbd\xba\x0d\x2e\x00\x91\x6a\xb1\x5b\xcb\xb0\x64\xe7\xb6\xc7\x85\x4a\x6d\x00\x2e\xe9\xa4\xf8\xc6\x21\x8a\xc8\xfe\xc6\xb9\xbb\xa8\x44\xbf\x1b\x11\x3a\xe9\x1b\x11\x24\x17\x33\xf2\xcd\x04\x48\x36\x03\x52\xa3\x68\x92\x29\x51\x5d\x8d\x3e\x43\x7f\x32\xe0\x09\x9d\xa9\x9e\xb5\x19\x78\x2c\xf4\x64\x6b\xd3\x2a\x00\x99\x92\x00\xd3\x60\xdb\x52\x17\x73\xd6\x92\x10\x9e\x0c\x81\xae\x36\x1c\x12\x51\x3b\x8d\xfd\x9b\xf7\xa7\x08\x7c\xd7\xa2\x68\x6b\x25\x57\x44\x9e\xb8\xa3\x39\xcf\x76\x7f\x30\xc0\x92\xb8\x0e\x9a\x33\x8e\x6a\x76\xf6\xd0\x5f\xb0\x44\x32\x8b\x78\x56\xf9\x39\x80\xb3\x1f\x65\x89\xd2\xe3\x00\xce\xeb\xf2\x0d\x64\x28\x6b\x76\x59\x2e\xc4\xb8\x23\x48\x51\x68\x46\x6a\xeb\x7f\x41\x1a\xa2\x94\xf1\xcc\xfb\x25\xad\x2f\xae\x31\x56\x66\x24\xbd\x50\x7a\x03\xa0\x63\x6f\xe6\x5b\xce\x62\x04\xcc\xf7\xcc\x0a\x30\x48\xdf\xa6\xd3\xa5\xaa\x27\xc0\x63\x87\x38\x15\x1b\xd6\xd1\xe7\xa7\x25\xca\x67\x0b\x1d\xb9\x4d\x83\x53\x1a\x2c\x93\x0d\x02\xd5\x00\x72\xa5\xc5\xd2\x4e\x6c\xe4\xfa\x19\x4a\x77\xc6\x51\xc7\xf3\xb7\xba\x8c\xad\xdc\xa1\xb8\x39\x8e\x19\x8b\x12\xcb\xe2\xca\xee\x02\xd8\x6d\x10\xea\x8b\x45\xa8\x91\x96\x50\xff\x54\x3f\x04\x51\x36\xa5\x2a\x0d\x11\x44\xa2\x8c\x63\xd6\xdf\xd5\x7e\x61\x05\x72\x94\x40\xf3\x13\xff\x0f\xe8\x37\xc5\x49\xb0\x23\x2e\x1b\xbb\xd0\x27\xc7\x9e\x83\x9e\x05\xd6\xa7\x6b\x03\x5f\x5e\x28\x04\x68\xca\xf5\xa1\x11\xc8\x6c\xc3\xd2\x77\xfc\x35\x84\x44\x7f\x72\x5d\x15\xf0\x28\xb9\x5c\x91\x53\xf8\x90\xa3\x0a\x90\x35\x5f\xa4\x96\x86\x9a\x6a\xac\xeb\x31\xfe\xdc\x8d\xe7\x4b\x53\xff\x2a\x26\x40\x63\x83\x32\x60\x02\x70\x7c\x50\x87\xb1\x79\x3e\x59\x55\x8d\xa8\xb5\x9a\x05\x4d\xf9\x83\xf7\x10\x24\x4c\x19\x31\x91\x11\xa5\xa2\x1e\x30\x83\xc5\x69\x2f\x0e\x33\xf7\x71\xec\xd4\xd8\xfa\x61\x5c\x37\x10\x37\xec\x8f\xfd\x58\xde\x14\xa9\xce\x95\xbc\x4b\x70\x4b\x32\x8f\xa0\x5e\xcd\xf1\xf6\x1a\xde\x5f\x49\x5d\x43\x20\xdf\x62\xab\x5f\x79\x23\x84\x78\x5e\xde\xf7\x0b\x15\xb3\x62\x63\xd9\x74\x91\x23\xb7\x61\xf4\x75\x5b\x73\xa6\x82\xab\x8d\x3b\xfa\x4a\x3a\xb9\x18\x45\x5d\xbd\xb5\xdb\xe8\x93\x23\x76\xc7\xba\xf7\xa7\x99\x00\xcf\xfb\x47\xbd\x27\xec\xe5\xd1\x5f\x19\xdb\xb0\x5d\x79\x74\x22\x23\x79\x3d\x5e\x8c\x2d\xf2\x7b\x7e\x12\xf0\x49\x62\x47\xfe\x95\x76\xcc\x55\xc1\xef\xe1\x07\xc2\x50\xd4\x5d\x1f\xf3\x4c\x39\xd8\x0c\xc2\xe3\x0e\xf9\x81\xee\xa1\x7b\x8d\x35\x17\x8e\xf3\x4f\xe2\x84\x48\x30\xc9\xa2\x97\x30\x25\x5b\x69\xb8\x81\xc6\x69\xad\x6b\xf1\xf7\xbd\x21\xc6\x84\x50\x6b\xad\x8b\x78\xb6\x0e\x96\xf5\x75\x09\xed\x7e\x59\xd8\x45\x01\x99\x73\xb9\x73\xb0\x84\x94\x68\x3c\x0d\x67\xd3\xfd\x72\xf9\x8a\xae\x21\x14\xfb\xe2\xee\x83\x63\xa8\x91\x6a\xb1\xe2\x9f\xe3\x7a\x18\xb0\xed\xc9\xbe\xf7\x95\xd8\x35\x1a\x65\xda\x2f\x31\xa0\x4c\x57\x6a\x54\x9a\x82\x80\xeb\x44\xb3\xf9\x58\x32\x85\x66\xa1\x09\x27\x12\x8f\x8d\x0c\xef\xdc\x80\xd5\x15\xaf\x1c\x93\xf4\x1f\xd2\x11\x38\xd3\x8a\xcc\xd3\xa9\x7e\x9c\xfe\x4b\xcd\x34\xa9\x2f\x08\xe4\x3a\xcf\x6c\x2a\x85\xd3\xd6\xc9\xd2\x90\x4d\xbb\x11\x72\x54\xae\xa3\x17\xac\x82\x60\x3f\x59\x3f\xe0\x9d\x72\x98\x56\xa6\x21\x72\xc1\x8c\xe5\x3d\x1f\x29\x9c\xc9\x51\x47\x91\xcb\x13\x3a\x03\x67\x62\x29\x96\x8a\x2f\x89\x70\x86\x65\xe9\x0b\xd7\xc4\x59\xe0\xc1\x69\x70\x63\xbd\xb4\x0b\x0f\xce\x65\x92\x49\xfc\x28\x2c\xe9\xc6\xac\x14\x5f\x2b\x3c\x40\x3f\x66\x84\xf9\x16\x61\xc9\x28\x8f\xe4\x00\xfe\x9d\x69\xce\x6a\x26\x0b\xe8\xad\x38\xc8\x15\x87\xe3\x28\x3c\x77\xc2\xf9\x6c\xc2\xdb\x82\x43\x3e\xd5\x4c\x8b\xb2\x64\x86\xeb\x33\xa3\x53\xc1\x0c\xd8\x71\x33\x4b\x5a\x15\xc1\x0e\x20\xd8\x25\x42\xb6\x2e\x9c\xf5\x63\x88\x1d\x96\x92\xb3\xef\x04\x95\xb0\x3c\x31\x46\xd3\xd5\x00\x35\xa6\x23\xd7\x14\xba\x70\x9b\x07\x32\x1e\xd7\xa6\x58\xf8\x62\xd1\xda\xd6\xdf\x5c\xc9\x89\xc1\xc0\x9e\xe9\x14\x07\x4b\x52\x93\x1d\x1b\xe2\x57\x30\xb6\x3c\xfb\x6f\xdc\xc7\xfe\x9e\x8f\xa2\x78\x17\xac\x55\x78\xe7\xad\x0b\xed\x3a\xb6\xcd\x0f\x5a\x8b\x43\xfc\xe0\x81\xb5\x94\x3d\x21\x53\xb0\xa3\x42\xdb\x10\x64\x98\xd5\x46\x35\x92\xbf\x5e\x17\x7b\x4c\x9f\xf2\xf0\xbb\xc5\x55\x13\x3f\xcc\x30\x43\x4e\x1a\x86\xdf\xd3\xce\xa8\xb1\x02\x2b\x36\x6f\x94\x10\x96\xe7\xd2\x5d\xfc\x7f\xe0\xf3\x74\xc3\x7f\xd1\x6e\x53\x87\xae\xf6\x1f\xca\xa1\xf4\x8c\x2c\xfc\xcd\x8f\x0d\xf2\x52\x4f\xad\xf4\x3b\x75\x74\x36\xaf\xdb\xb2\xd5\xbd\x6e\xb7\x9c\x6a\x5a\xd9\x6e\xfd\x76\xd3\xa1\xa0\x10\x42\xc6\x4d\xeb\xc5\x3e\x2d\xe8\x7f\x89\xe9\x32\x1a\x3f\xdc\x3c\xbc\xf6\x38\x51\x2f\x31\xce\x02\xd6\x03\xaa\xfb\xaf\x1c\xff\x06\x85\x52\xd2\x5b\x5d\x01\x92\x40\x00\x00\x00\x25\x74\x45\x58\x74\x64\x61\x74\x65\x3a\x63\x72\x65\x61\x74\x65\x00\x32\x30\x31\x39\x2d\x30\x31\x2d\x32\x34\x54\x32\x30\x3a\x32\x39\x3a\x35\x36\x2b\x30\x31\x3a\x30\x30\xd5\x66\x4b\x8a\x00\x00\x00\x25\x74\x45\x58\x74\x64\x61\x74\x65\x3a\x6d\x6f\x64\x69\x66\x79\x00\x32\x30\x31\x38\x2d\x30\x39\x2d\x32\x32\x54\x32\x33\x3a\x34\x33\x3a\x32\x38\x2b\x30\x32\x3a\x30\x30\xe3\x31\x08\x79\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\xc7\xc9\xf4\xc5\x1d\x0a\x00\x00")) - copyDocument20 = HexToBytes("copyDocument20", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x05\x04\xfa\xfb\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x14\x00\x00\x00\x14\x08\x06\x00\x00\x00\x8d\x89\x1d\x0d\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0b\x12\x00\x00\x0b\x12\x01\xd2\xdd\x7e\xfc\x00\x00\x03\xb7\x49\x44\x41\x54\x38\x8d\x85\x94\xcd\x6b\x5d\x45\x18\xc6\x7f\xf3\x75\xbe\x92\x73\x6f\xd2\xdc\xdb\xdc\x24\x24\x12\x22\x56\x2c\xd5\x2e\xfc\x03\x44\x71\x23\xb4\xea\xaa\x2e\xa4\xed\x4e\x28\xb8\xf6\x4f\x30\xae\x25\x45\x29\x82\x1f\xc5\x0f\x10\x14\x5c\xb8\xb0\x62\xf7\x2e\x2c\x58\x11\x6d\x42\xda\xda\x98\x62\x6e\x6e\x4b\xda\x9c\x73\xee\xbd\x67\xe6\x75\x71\xd3\xd2\x48\x6b\x9f\xcd\x30\x33\xcc\xc3\xef\x9d\x77\x9e\x51\xfc\xbf\x92\xe3\xc7\x8f\x7f\x7a\xec\xd8\xb1\xd7\x9d\x73\x56\x44\xa8\xbd\xe7\xee\x6e\xc9\x8d\xcd\x2d\xfe\xde\xdc\x2c\xbf\xf8\xe4\xdc\x09\xe0\xbb\x7b\x07\xd4\x63\x0c\xdf\xfa\xf5\xf2\x6f\x1f\x4c\x4e\xb5\x11\x09\x88\x40\x08\x42\xd9\xef\x73\x73\xab\x47\x23\x4b\xb9\x7c\xe9\xe7\xfe\xa9\x53\x27\xdf\x00\xbe\x05\xd0\x8f\x31\x9c\x6f\x34\x1a\x78\xef\x09\x41\x10\x11\x94\x82\x24\x72\x4c\xb7\x26\x19\x1f\xcf\x78\xe1\xa5\x97\xe3\xcf\xce\x9f\xff\x0a\x78\xed\x1e\xa1\x02\x5e\x04\x96\x1e\x62\xf8\xea\xd5\x6b\x7f\xbd\xb2\x5b\x94\x5c\xba\xf4\x0b\x79\x9e\x33\x1c\xd6\xf8\xe0\x89\xa3\x98\x23\xcf\x1d\x45\x21\x68\xa5\xb9\xf8\xd3\x0f\x83\x53\x27\x4f\x9e\x50\x87\x0f\x1f\x5e\x5e\x59\x59\x79\x67\x76\x76\x0e\x01\x44\x84\x61\x5d\xb3\x73\xa7\x60\xfd\xc6\x4d\x0e\x1e\x6c\xf3\xe4\x13\x73\x54\x65\x81\xf7\x1e\xad\x35\x22\x42\xde\x68\x60\x8c\xc5\xfb\x40\xed\x3d\xbd\xdb\x3b\xbc\xb7\xbc\x5c\xd9\x33\x67\xce\xbc\xfd\xf4\x33\x47\xd8\x2d\xcb\xfb\x58\x56\x04\xe3\x52\x94\x8b\x89\x9d\x25\x89\x23\xd6\xd7\xd7\x91\x50\x63\xb4\xc1\x3a\x47\x77\xeb\x1f\x5c\x14\xe1\x6b\x4f\xde\x9c\x00\x0c\xb3\x73\x73\x89\x4d\x92\x34\x0b\x21\x80\x08\xce\x5a\x50\xa3\x3e\x39\x6b\x31\x46\xa3\x8d\xa6\xa8\x06\x1c\x3a\xf4\x14\x9b\x9b\x37\x69\xe6\x63\x80\x42\x69\x45\x3d\x1c\x62\x8c\xc1\xb9\x88\x38\xcd\x98\x9d\x6e\x61\x45\x02\xc6\x18\xae\x5f\xbb\x4a\xaf\xb7\x0d\x68\xbc\x1f\x82\x52\x68\xa5\x78\xf6\xe8\xf3\x8c\x8d\xc5\x14\x65\x45\xbb\x35\xc5\x9f\xab\x6b\x34\xc7\x33\xb4\xd2\xd8\xc8\x12\x7c\x60\x7e\x7e\x9e\x24\x49\x49\x93\x08\x2b\x02\xc6\x68\x16\x17\x17\x69\xb7\x5a\x28\xa5\x09\x12\x00\xc8\xf3\x9c\x38\x49\xd8\x2d\xfb\xa0\x34\xbd\x9d\xbb\x6c\x76\xef\x30\xdd\x9a\x22\x8a\x1c\xce\x39\xa2\xc8\xd1\xc8\x73\x82\x08\x5a\x6b\x6c\x10\xc1\x18\x4d\xbf\xaa\xe8\x76\xb7\x30\xd6\x51\x96\x05\x59\x9a\xd1\xdb\xde\xc6\x5a\x8b\x00\xd6\x39\xf2\xe6\x01\xd2\x2c\x63\xb7\x28\x30\x7a\x8c\x10\x3c\xc3\x41\x9f\xeb\x55\xc5\xc2\xc2\x02\x12\x04\x1b\x42\x40\x6b\x4d\x9a\xa6\xb4\xdb\x6d\x00\x64\x72\x02\xad\x35\x4a\x29\x06\xfd\x01\x4a\x81\x75\x11\x53\x07\x9a\x2c\xcc\xb6\xe9\xb4\x26\x69\xe4\x63\xa3\x64\x28\x85\x35\x06\xa5\x14\x41\x02\x56\x44\x30\x5a\x13\xc7\x11\x65\x69\x71\xce\xe1\xbd\xa7\xae\x6b\x8c\xd6\x64\x59\x4a\x08\x9e\x46\xa3\x49\x96\x24\xe4\x59\x42\xef\x56\x0f\x4d\x60\x30\x18\x90\xa6\x29\xd3\x9d\x0e\x21\x84\x3d\xc2\xbd\xda\xab\xb2\x64\xbb\xdb\x65\x3c\xcf\x29\x8a\x02\xa3\x35\x82\xe0\xac\x43\x69\x45\xa7\x33\x83\xb5\x06\x6b\x34\xbd\xdd\x82\xc5\x85\x79\x00\xea\xda\xef\xa5\xe3\x1e\x61\x10\x94\x52\x64\x59\xc6\xcc\xcc\x0c\xb5\xaf\x69\x36\x1b\x54\x55\x45\x1c\xc5\x23\x52\x6b\xe8\x6d\x77\xe9\x74\x66\x40\x8d\x1a\x38\x31\x31\xb1\x2f\x52\x55\xbf\x62\x67\xe7\xce\xae\x0d\x21\x8c\xee\xc8\x5a\x40\x88\xa3\x68\x94\x84\xf1\x9c\xc1\x60\x40\x1c\xc7\x28\xa5\xf0\xc1\x63\xad\x25\xf8\x9a\x0b\x3f\x5e\xa4\x35\x35\xb9\xcf\x70\x63\x63\x43\x3e\x3a\x77\xfe\x5d\x2b\x22\x28\x14\x45\x59\xd0\xed\x76\x51\x4a\x23\x12\x98\x9d\x9b\xc3\xb9\x51\x87\x8d\xd6\xcc\xcc\x74\x00\x08\xde\x73\xfa\xcd\x13\x67\x81\x6f\xfe\x93\xfb\x0d\xe0\x77\x1b\x24\x80\x82\xf1\xb1\x31\x3a\x9d\x0e\xc6\x18\x00\xbc\x1f\x11\x89\x08\x55\xd5\xa7\xdf\xef\x93\x24\x09\x22\x02\xf0\x07\x70\xe1\x61\xdf\x93\x0d\x61\x44\xf8\xa0\x6a\xef\x49\xe2\xf8\xfe\x33\x7a\x50\x61\x64\xf8\x48\xd9\x2b\x6b\x6b\x6b\xdb\xb7\x6e\x2f\x4d\x34\x1b\xb4\xdb\xc9\xbe\xcd\x7e\x7f\xb0\x6f\x3e\xac\x6b\xae\xac\xae\x02\xac\x3e\xd2\xf0\xc3\x95\xf7\x4f\x23\xe1\xe3\xc5\xc5\xa5\xa5\xfb\x9c\x0a\x90\x07\xc6\xbd\xb5\xa2\x2c\xcb\xaf\xbf\xfc\xfc\x2c\xf0\xfd\xa3\x0c\xff\x05\xea\x43\x9a\xaa\xcd\x45\x16\x52\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\xf9\x2b\xe0\x0f\x05\x04\x00\x00")) - find18 = HexToBytes("find18", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x48\x04\xb7\xfb\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x12\x00\x00\x00\x12\x08\x06\x00\x00\x00\x56\xce\x8e\x57\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0b\x12\x00\x00\x0b\x12\x01\xd2\xdd\x7e\xfc\x00\x00\x03\xfa\x49\x44\x41\x54\x38\x8d\x85\x94\x5d\x4c\x5b\x75\x18\xc6\x9f\x73\xce\xbf\x9f\x07\x7b\xda\xd2\x7f\x8b\x50\x60\x7c\x0f\xc2\xc7\xc2\x9c\x48\xc9\x86\x8b\x6c\x10\xb3\x0b\x8c\x46\x8d\x99\x17\xc6\x68\xa2\x37\xde\x7b\x69\xe2\xc5\x6e\x5d\x96\xa8\x59\x62\x0c\xf3\xc2\xb9\xb8\x0f\x62\x96\x4c\x44\x34\x81\x0d\xed\x86\x96\x0e\x28\xdf\xa5\x05\x5a\xce\x80\x7e\xd0\x7f\xdb\xd3\x9e\x73\xbc\x60\xce\xaa\x89\x3e\x77\xef\x7b\xf1\xbb\x78\xde\xe7\x79\x39\x3c\x16\x05\x15\xe0\x95\x55\x39\xda\xd7\xf8\xee\x8b\xc7\x3e\x18\x3a\x4b\xcf\x50\x27\x2a\x55\x95\x53\xc2\x61\x43\x68\xf4\xdb\xbd\x2b\xd7\x02\x0f\xbe\x00\xc6\x73\x00\xe5\x01\x59\x43\x89\xb8\x43\x08\x78\x19\xd0\x5a\x30\x7c\xfe\xd2\xe5\xce\x8b\x3d\xdd\x8a\x3d\x9d\x4c\xeb\x8f\xf6\x75\x85\x10\x95\xa7\xe5\x3c\xd1\xe0\xe2\x6e\xdc\x32\x4f\x5d\xbe\xb0\x78\x7e\x9d\x7e\xb9\x26\xcb\x7f\x87\x09\x14\x54\x90\x29\xd3\x28\x1b\x7e\xe3\xf6\xe8\xf1\x2b\x6d\x4d\x19\x72\x75\xbc\x2e\x76\x7d\x77\x70\x6d\x1a\x2f\x44\xee\x6c\x75\xec\xdc\xf9\xc9\x98\x71\x68\xab\xc2\x4b\x83\xf9\x26\xab\xbd\x66\xf0\xde\xf7\xd2\x35\x42\xef\x1f\x30\x46\x39\x80\x1d\x82\x9c\x5e\xa6\xa7\x62\x9d\xf4\xea\xa5\x53\x37\x3a\xda\x72\xd6\x4f\xbe\x3b\xb9\x0e\xdf\x70\xd0\x53\x57\x1d\x12\x0c\x86\xd5\xe2\x6e\x3c\x96\x05\x9f\xf8\x70\xb6\xa2\x58\xb3\xb4\x61\x3a\xe7\x63\xb5\x39\xad\x49\xf2\xfb\xe5\x51\x86\x35\x1e\x80\x0e\x00\x7c\x34\x0a\x9c\x6d\x69\x7f\xdd\xd7\xc3\x55\x8c\x4d\x37\xc6\x69\xff\xc0\x82\xc7\x26\xcc\x6b\x79\xe5\xc1\x41\x3a\x73\x6f\x23\x38\xf7\x4b\xe4\xe7\x89\x87\xaf\x58\xf6\x16\x2f\x44\x3b\xa2\x91\x58\x26\x7f\xa6\xaf\xf8\xaa\x09\xed\xb5\xa0\xd0\x28\x28\x0f\x00\x3c\x00\x0c\x9d\x73\x9f\xd4\x0b\x0a\xb6\x48\xd7\x23\xea\x30\x6f\x73\x45\x6d\xd5\x6e\x21\xbf\x35\x55\xdb\xa7\x5d\x1e\xc9\x5f\x50\xf5\xf9\xbd\x8d\xe8\xa6\xdb\x61\x8e\xcf\x6c\xd0\x44\xa5\x2b\x23\xf5\x76\x56\x75\x43\xfe\xcb\x67\x02\x00\x0e\x09\x1e\x55\x33\xa3\xac\xd2\x93\x11\x38\xfd\x80\x70\xfc\x9e\x43\xe4\xb6\xad\x76\xeb\x46\x61\xc0\x27\x46\x83\x2b\x4e\x14\xb3\x49\x9b\x68\x61\xbb\x79\x9b\x62\x24\x32\xcc\x52\xb1\xb2\xf4\x6a\x04\x00\x92\x49\xf5\xc0\xe9\x36\xc2\xb0\x25\x9b\x8b\x79\x8f\x91\x10\x98\x8a\x05\x58\x35\x05\xa2\xcd\xe1\x14\x9b\x87\x06\x2d\xe9\x48\xd8\xa8\xbb\xbd\xe4\xa9\x78\x48\xd0\x54\x0e\x4a\x4e\x48\x96\x82\x78\x00\xb8\x3f\x93\x9e\x29\x16\x14\x50\x75\xc9\x91\xd8\xcb\x78\x0c\x46\x52\x95\x57\xb4\x96\x1d\x59\xe9\x62\x4c\x6d\xf7\x36\x1e\xa9\x3b\x7a\xba\xdf\xcd\x59\x2c\xce\x56\x7b\xd4\xb6\x97\x29\x2b\x7e\xfd\xeb\x66\x00\x14\x78\x62\xb6\xd7\x0b\x8c\x8c\x2f\x7c\x33\x3b\xa7\x15\x7c\xc7\xc2\x2e\x16\x0e\x35\x25\x13\xf9\x36\x83\x91\x1c\xe7\x78\xf8\xcc\x84\xeb\x71\x4b\xd6\xf6\xbc\xaa\xd7\xd5\x06\xc7\x6a\xdb\x1b\x48\xd9\x84\x5f\x19\x03\x96\x02\x14\xe0\xe4\xc7\x59\x12\x4c\x26\x2a\x30\xb6\xb8\xbd\xbf\x5d\x53\x36\x74\x4a\x3a\xdd\x6c\x8a\x91\xf9\xb9\x9c\xb4\x93\xe5\x9d\x9a\xa9\xcc\xc5\xf2\x6a\xf5\xf6\x46\xbc\x5e\x9c\xbc\xde\xf2\x76\xef\xc3\xf2\xf9\x88\xdb\xf8\xf9\xc8\xee\x47\xeb\xa9\x5b\x01\x91\x51\x83\x08\x51\x67\x60\x10\x18\x63\xa0\x14\xf0\xcf\x07\x7e\x94\xd7\xeb\xbd\xcf\x36\x98\xfb\x7a\x6b\x36\x1d\x15\xf9\xd5\x72\xe9\x20\xe2\x31\x84\xee\xd6\x9e\x50\xc7\xeb\xfb\x5b\xf7\x9d\x33\x21\x2b\x17\xcc\x76\x0b\x95\x2e\xa1\xb7\xb9\xac\x8b\x14\x2c\x64\x72\x71\xf7\x77\x9d\x82\x72\x02\x00\x30\x06\x8e\x52\xe8\x53\xc1\x99\x9b\x53\x7e\x71\x85\x08\xd6\x7a\x87\xa8\x54\x39\xb9\x98\x5d\xb2\xa4\x45\x39\xcd\x1d\x8c\xdc\x4e\xdc\x7c\xff\xe2\xe4\x5b\x5e\xa3\xd0\x78\x82\x0a\x9d\x8d\x5e\xdb\x00\xd1\x6b\x9f\x2e\xa8\xfa\xe8\xd2\x7e\x90\xe7\x4a\x7b\x47\x29\x38\x00\x9a\x2c\x53\x02\x1c\x69\x00\xa4\x6a\xa0\x98\x03\xb6\x97\x81\xd0\x0e\x00\xad\x85\xf6\x9d\x7e\xa7\xff\xf9\xb1\xa3\x5e\x93\x9a\xd1\xcc\x06\xff\xb2\xfe\xe9\xc4\xc2\x0f\xef\x95\x82\x9e\x7c\x01\x13\x95\x35\x00\x7a\xf4\xb0\xd0\x30\x99\x00\xe4\x29\x9f\x97\x21\xc8\x90\x0b\x9d\xde\xa1\xd7\xde\x7c\xee\x99\xaf\x5a\xbd\x46\x3d\xad\x9a\xc8\x6c\x98\xfb\x4c\xf8\x27\x88\x81\xe9\x29\x06\xa4\x18\x78\x30\xca\x33\xc6\xf8\x54\x0a\x48\x31\xa6\x33\x30\x0d\x80\x10\x4f\x2d\xcf\xee\xa6\xcc\x8b\x15\xb6\x8a\x97\xab\xec\x02\x9f\x2d\xf0\x75\xff\x02\x95\x48\x07\x98\xfe\x67\x4e\x4a\xf7\x14\x20\x2b\xa9\x95\x40\x22\x67\x0c\xa4\xb3\xc6\x9a\x40\x38\xfc\xf1\x7f\x70\xfe\x57\x7c\xe9\xf0\x07\x91\x55\xc8\x7c\x0a\x64\x6b\xf2\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\x1a\xec\xae\xd7\x48\x04\x00\x00")) - find48 = HexToBytes("find48", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x47\x0f\xb8\xf0\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x30\x00\x00\x00\x30\x08\x06\x00\x00\x00\x57\x02\xf9\x87\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0b\x13\x00\x00\x0b\x13\x01\x00\x9a\x9c\x18\x00\x00\x0e\xf9\x49\x44\x41\x54\x68\xde\xed\x99\x79\x8c\x64\xd5\x75\xc6\xbf\x73\xef\x5b\xeb\xd5\xda\xd5\xd5\xfb\x32\x3d\xfb\xd2\xcd\x6c\xe0\x09\x78\x86\xc5\x80\x19\x63\x1c\x70\x20\xc6\x91\x1c\xc5\x4b\x0c\x76\xb0\x2c\x39\x52\xa2\x28\xb2\xc0\x72\xb0\x63\x45\x0a\x96\xc0\xb2\xa2\x10\x6c\xc7\x4e\x62\x64\x9b\x65\xdc\x18\xcc\x18\xcc\x66\x30\x1e\xc0\x98\xcd\xb3\x31\x33\xcc\x0c\xcd\x4c\x77\xd7\xbe\xbd\x7a\xcb\xbd\x27\x7f\x54\x0f\x21\x40\xec\xf4\x0c\x49\x26\x92\x8f\x74\xeb\xbd\xba\xa5\x57\xf7\xfc\xea\x3b\xf7\xde\x73\x4f\x11\x4e\xc1\xb6\xaf\xf9\xc8\x50\x2e\x99\xbf\xd8\xb5\xdd\x2d\x42\xc8\x35\x52\xc8\x21\x22\xf2\x04\x09\x0d\xa0\x2a\x84\x3c\x6c\x4a\xe3\x79\xcb\xb4\x1f\x23\xc6\x23\x5f\xf9\xd1\xe7\x7c\xbc\xc3\x46\x8b\x7d\x60\xaa\x7f\x9b\x1c\xed\x9d\xf8\xfd\x9e\x54\xef\x9f\xb9\x96\x7b\xae\x61\x18\xa2\xd0\x47\x18\x1e\x66\xe4\x72\x0c\xc7\x01\x98\x09\xcd\x26\x63\x7e\x9e\x70\xf4\x08\xa3\xd5\x24\x32\x0d\xb3\x66\x9b\xf6\xf7\x1d\xcb\xbd\xe5\xc6\x1d\x9f\x79\xe9\xff\x04\xe0\xdc\x65\x1f\x3c\x6f\x24\x3f\xf6\xd5\x74\x22\x33\x35\xbe\x84\x70\xce\x36\xc6\x19\x1b\x18\xd9\x0c\x03\x60\x9c\x78\xe9\x5e\x88\x00\x06\x33\xe1\xe8\x51\x89\xa7\x9f\x02\x9e\xf8\x19\xd0\x69\x19\xda\x73\xbc\xef\x7a\x56\xf2\xaf\x6e\xb8\xfb\xda\xe3\xff\x2b\x00\xcb\x72\x9b\xec\xb5\xa3\xeb\xff\x6e\x20\x37\xfc\xe9\xa5\x4b\x25\x7d\xf0\x4a\xc6\xaa\xd5\xfa\x8d\x0e\xf3\xeb\xb7\x78\x43\x77\xf7\xf6\xc4\x18\x14\xc5\x02\x8f\x3e\x62\xe0\x9e\x1f\x6a\x70\xe4\x56\xd2\x89\xf4\xb5\x7f\xb3\xe3\x33\x77\xfd\x8f\x02\xac\x2d\x9c\xdd\x33\x39\xbe\xe9\xae\xfe\x5c\xdf\x39\x97\x5d\xae\x70\xd1\x7b\x19\x42\x80\xbb\x4e\x83\xe3\x28\xe2\x83\x2f\x6b\x7d\xf0\x00\xf8\xf8\x71\xcd\x8d\x96\x82\x21\x08\xc9\xa4\xa2\xc1\x41\xa6\x89\x09\x45\x63\x4b\x6c\x61\x5a\x36\x75\xc7\x23\xaa\xd7\x25\xbe\xfd\x2d\x89\xdd\x2f\x09\xce\x25\x73\x5f\xb4\x0c\xfb\x4b\x37\xdc\x79\x2d\x9f\x0c\x80\xf1\xdb\x9c\x3f\x63\xe2\xac\x9f\x8c\xf4\xe5\xcf\xf8\xe4\xa7\x63\xac\x5c\x85\x85\x58\x61\xae\x94\xb5\x7e\x60\x27\xd4\x93\x4f\x58\xba\x52\x0b\x75\xad\x53\xd7\xca\x32\x22\xb2\x2c\xad\xa2\x08\xda\xf7\x0d\x8b\xc9\x4c\x27\x32\xd4\x9b\x0f\xc5\xd6\xad\x55\x79\xd1\xc5\xa6\x4c\xa6\x3c\x4a\xa7\x63\xba\xee\xb3\x9a\x76\xdc\x65\xd0\xce\xfb\x4a\x5f\xc8\xa5\xf2\x09\x00\x7f\xfd\x8e\x2a\xb0\x34\xbb\xde\xda\xbc\xec\xdd\x3f\x1e\x1f\xec\xdf\xf6\xd9\x3f\x8f\x31\x3a\x46\x0c\x80\x95\x66\xbd\xf3\x5e\xc4\x3f\xbe\x57\xaa\x4a\xc7\x8f\xcd\x15\x63\xb5\xcc\xd4\xda\x46\xdf\xea\x49\x5f\xda\xae\x52\xcc\x88\x35\x23\x0c\x22\x51\x3a\x7c\xc8\x38\xfe\xec\x2e\xaf\xfd\xd2\xaf\x33\xe9\x10\x5e\x7f\x5e\xca\xab\xae\x6a\x19\xdb\xce\xcb\x49\x22\x41\x80\xa0\xfb\xee\x33\x31\x7d\x97\xa0\x7c\xba\xf0\xb9\x1b\x77\x5c\x77\xcb\x62\x01\xe4\x7f\xf5\xc1\xd6\x15\xef\xfb\xdb\x91\xc2\xe8\xd5\xd7\x5e\x17\x63\xd9\x72\xc1\x00\xb8\xd5\x22\xfd\x0f\x5f\x93\xd1\x63\x3f\xe3\x58\xae\x59\x5a\x5e\xfb\x89\x8f\xbc\x3a\xb2\x65\x4b\x39\x33\x30\xd4\x80\x34\xdb\x31\x73\x27\x56\xdc\x09\xc2\xa8\xa3\xa2\x28\x10\x42\x86\x99\x91\x89\x4e\xff\xd9\xef\x6e\xd6\x10\xb7\x67\xf6\x1d\x30\xf7\x3f\x9f\x91\x95\x72\x95\xd7\xad\x31\x29\x2c\x69\x8c\xe4\x22\x54\xeb\x02\x87\x67\xe2\x0b\xdf\xbf\xf1\xea\x07\x1e\xde\x7d\xcf\xcc\x29\x2b\x70\xce\x92\xf7\x6f\x99\x1c\xdf\xf4\xe8\xe5\x57\x80\x2e\xfd\x80\x00\x00\x6e\xb7\x49\xdd\x7c\x93\x88\x8e\x1e\x93\xe1\xc8\x95\x97\xbc\x56\x98\x5a\x5b\x55\x1a\x9d\x98\x75\x27\xd6\x08\x43\x85\x28\xd4\x1c\x07\x61\xc4\x7e\xb5\x46\x41\xb3\x29\x3b\xd5\x9a\xa1\xa2\xc8\x92\xa6\xe9\x30\xe0\x68\x15\x3b\x47\xee\xdf\xd1\x5f\x68\xaa\x9e\x0b\xce\x0a\xe5\x55\xdb\x2d\x43\x48\x43\x28\x2d\xe9\xe6\x6f\x5b\xd4\x6a\xe6\xf6\xa4\x13\xe9\xcd\xd7\xdf\x71\x4d\x78\xd2\x0a\x4c\x64\x26\x69\xdd\xd8\xa6\xdb\x57\x2c\xf5\x46\x3e\xfa\xa7\x20\x21\x88\x35\x0b\xfd\x8f\x5f\x97\xd1\xe1\x57\xed\x70\xe5\xc7\xaf\x3a\x92\x5b\xb9\xac\x4c\x40\x93\x81\x86\x66\x6e\x68\x46\x43\x31\x1a\x91\xd2\xcd\xb0\xed\xb7\xdb\xa5\x8a\xef\x57\xab\x9d\x66\xa9\x18\xfa\xb5\x6a\x14\xb6\xdb\x2a\x68\x34\xb4\x56\x9a\xf3\xeb\xce\x08\x66\x8e\xec\xa3\xe2\x61\xc3\x75\x64\x87\x96\x8e\x19\x24\x04\x68\x64\x50\xd0\xe3\xbf\x8c\x0b\xae\xe5\xce\x3f\xb2\xe7\xde\x5d\xff\x5d\x00\xf1\xe6\x8e\xe1\xfc\xc4\x7b\x7a\x52\xbd\x5b\x3e\x70\x85\x82\x94\xc4\x00\xf1\x43\x0f\x1a\xf1\xcb\xfb\xa4\x5a\xf6\x87\xdb\x67\x72\x4b\x86\xab\x92\xd0\x24\x42\x5d\x10\xaa\x04\x2a\x03\x28\x31\x50\x54\x4a\xcf\x07\xcd\xd6\x5c\xa7\x5e\x9f\x6b\x97\xcb\xf3\xed\x72\xb9\xd8\x9c\x9f\x2f\xb7\x8a\xc5\x4a\x63\x6e\xb6\xd6\x2e\x15\x1b\x71\x27\x68\x8d\x5c\xb0\x7d\x7e\x4e\x86\xb5\xfb\x9e\x48\xa9\xc3\x47\xdb\x1a\x60\x1e\x1d\x88\x78\x6a\x95\xe2\x66\xa7\xf5\x17\x5f\xbc\xf2\x56\xeb\xa4\x01\x86\x7a\x46\x3f\xd5\xdf\xcf\x3c\xb5\x41\x10\x40\xdc\x68\x19\x7a\xe7\x3d\x14\x17\x36\xae\xab\xf4\x4e\xae\xac\x00\xd4\x12\x84\x86\x20\xd4\x04\x50\x91\x44\x25\x49\x54\x94\x84\x39\x29\xc5\x9c\xb4\xac\x39\x00\x73\x2a\x8a\xe6\xc3\x66\xa3\x18\xb6\x9b\xa5\x76\xb9\x58\xf1\x6b\xd5\x5a\xb3\x38\xd7\xa8\x1c\x3d\xdc\x0a\x1a\x8d\x76\xfe\x9c\xf3\x67\x67\x1b\xb5\xf0\xee\x07\x0d\xc5\x5a\x31\x98\xf9\xfc\x2d\x31\xb7\x3b\xad\x61\xcd\xfa\x03\x27\xb5\x8c\xae\xc8\x6e\x4e\x7b\x4e\x6a\xfb\x96\x73\x34\x88\x04\x03\xc4\x8f\x3e\x24\x94\x86\xad\x46\xb7\x6f\x9b\x23\x12\xbe\x00\xb7\x18\x68\x00\x5c\x63\x42\x4d\x0a\xd4\x34\xd0\x94\x1a\xbe\x24\x0a\x84\x10\x9a\x99\x85\x8e\x23\x33\xea\x74\xdc\x38\x0c\x3d\xad\xe2\x08\x44\xac\xe3\x98\x40\x42\x92\x90\x46\xaa\xaf\xdf\x8c\x47\x06\x4b\x07\x66\xda\x83\x87\x8e\xd4\xf5\xd2\x25\x49\x1a\xee\x57\xd4\xd7\x1b\xb3\xef\xb7\x3e\x04\xe0\x8e\x45\x2b\x30\xd0\x33\x72\x6e\xd2\x49\x39\x93\xeb\x35\x00\x62\x86\xe4\xa7\x7f\x2e\x54\xef\xe4\xca\x9a\x9d\xf2\xda\x02\xe8\x48\xa2\xb6\x24\xd1\x94\x24\xea\x86\x40\xd5\x20\x54\x0c\xa2\x92\x29\xa9\x68\x4a\x51\x34\x5d\xa7\x28\x2d\x73\x9e\xa4\x2c\x82\xa8\xc4\x5a\x55\x00\xd4\xc0\x5c\x67\xd6\xcd\xb8\xe3\xb7\xa2\x76\xbb\x13\xf9\xed\x20\xbf\xfe\xcc\x5a\xad\xd3\x88\x76\x3d\x2f\x35\x98\x19\xac\xb1\x76\x05\x23\x8c\xc3\xf7\x7c\xe5\xc2\xdb\x8c\x45\x03\x14\x32\xfd\xef\x72\x13\x8a\x87\x86\xba\xdd\xaf\xcd\x08\x5d\xaf\x0a\x9d\x9f\x5a\x59\x17\x40\x28\x80\x80\x00\x5f\x00\x6d\x41\xb4\x00\x41\x35\x53\xa2\x6a\x4a\x2a\x67\x3d\x59\xec\xb5\xa2\x39\x4f\xb7\xe7\xd9\x6f\x95\x48\x50\x05\x44\x35\x00\x35\x00\x0d\x66\x6e\xa9\x38\xf2\xa3\xc0\xef\x84\xed\x76\xe8\xa4\xb3\x61\xe8\xda\xad\xdd\x87\x0c\xcd\xac\x00\x80\x97\x8e\x68\x8e\xe2\x28\xd7\x49\x45\x2b\x16\x1d\x42\x96\x61\xaf\x1a\x1c\xd4\x20\x92\x00\xc0\x47\x0e\x93\x36\x0c\x83\x53\x13\x43\x2d\x12\x88\x09\x08\x01\x04\x0c\x74\x48\xc3\x67\xa2\x36\x11\x35\x05\xeb\x46\x5f\x8f\x55\x25\x29\xfc\x4e\x6e\x50\x79\x69\x4f\xa4\x33\x29\xfb\xe9\x9d\x0f\xab\x48\x08\xa1\xb4\xb6\x00\xb8\x00\x7c\x80\x02\xd6\x3a\x64\xad\x23\x1d\xc7\xb1\x28\xf4\xfa\xb5\x62\x33\x5b\xad\xd5\x74\x2e\x27\xc5\x40\x81\x11\xa9\x88\x35\xf4\x6a\x00\xbb\x17\xa5\x00\x11\x0d\x64\xb2\xdc\xdd\x1d\x88\x50\x2e\x11\x5b\x5e\x22\x36\x1c\x2b\x26\x20\x46\xb7\x45\x02\x08\x85\x40\x20\x05\x3a\x06\xa1\x93\x4e\x18\x2d\xcf\x16\x6d\x4b\xa2\x6d\x4b\xb4\x53\x99\x64\xbb\x6f\xe9\x78\x7b\x6c\xc5\x44\xd3\xb0\x2c\x5f\x1a\x46\x87\x88\x02\x22\x11\x0a\x21\x22\x69\x5a\x91\x90\x32\x26\x21\x94\x48\xa7\x43\x66\x70\xa5\x0e\x00\xc4\xc9\x04\x83\x48\x43\xb3\x1e\x58\xb4\x02\x52\xc8\x44\x37\xe7\xea\xee\x71\x61\x28\x20\x1d\x4b\x01\x60\xea\xa6\x98\x7a\xa1\x29\x02\x14\x80\x18\x84\xc8\xb5\x28\x94\x84\x08\x8c\x48\x09\x28\xcb\x10\x22\x5d\xc8\x89\xc1\x95\xcb\xe3\xe3\xb3\xe5\xa8\x59\xab\xc7\x2a\x8a\x15\x6b\xa5\x40\xa4\x0c\xcb\xd2\xd2\xb6\x59\x9a\x26\x1b\x6e\x42\x31\x33\x62\x65\x2c\xf8\xc0\x30\x0d\x42\x27\xf4\x93\x8b\x06\x88\x55\x1c\x6b\xa5\x5f\x17\x66\xeb\x79\x2c\x2a\xc3\x6b\x6b\xf4\xa6\x6d\x9b\xde\x90\x34\x13\x40\xac\x41\x62\x41\x4f\x53\x03\xb6\x04\xb4\x6d\x52\x7e\x6c\x08\x5e\xbe\x00\xb2\x12\x08\xfd\x16\xb4\xd2\xd0\x2a\x86\x93\xce\xc0\x4e\x24\x60\xba\x0e\x88\x88\x04\x11\x98\x55\xf7\x40\xc1\x04\xad\x19\x52\x18\xf1\xc9\x64\xa3\x95\x56\x8b\x5e\x77\xb1\xd0\x17\xd1\x2a\xaf\xc0\x33\x6d\x25\x0c\x29\x04\x11\x09\x00\x12\x04\x09\x40\x12\x60\x80\x61\x74\x02\x6d\x7b\x09\x69\x12\xa0\x04\x41\x19\x02\xc2\x12\x30\x3b\x7e\x68\xf5\xac\x58\x65\x19\xc7\x8e\x19\x9d\x46\xc3\x88\x83\x8e\xd4\x71\x2c\xdd\x6c\x56\x3a\xa9\x94\xb0\x3c\x4f\xa0\xd3\x31\x88\x08\xb9\xb4\x20\x00\x08\x22\x42\xac\x08\x42\x50\x69\xd1\x00\x61\x1c\x1c\x2a\xce\x8b\x85\x28\x11\x88\x22\x89\x67\xbe\xf5\xd3\x9e\x99\xfd\xed\xec\xf0\xe6\xc9\x57\xc7\x2e\xdb\x5a\x03\xc1\x04\xc1\x02\xe0\x2c\x4c\x4c\x37\x8e\x39\xa8\xd4\xe2\x38\x9d\x92\x52\x10\xc5\x12\x10\x61\xa4\x1c\xe5\x66\x53\xb9\x61\xcf\x95\x96\xe9\xf8\x95\xaa\x1d\xf9\xbe\xad\x95\x32\xad\x44\xc2\xb0\x92\x9e\x74\xb3\x59\xc9\xa5\x8a\x63\x99\x31\xf2\x3d\x26\x01\x44\xa5\x2a\x20\x48\x12\x33\x0e\x2d\x1a\xa0\xda\x2a\x3f\x57\x9c\x1f\x43\xbb\xd5\x41\xc2\xb3\x08\x4c\x94\x30\x9b\xa6\x5e\x51\x98\x4f\x6e\x5a\xde\x00\x60\x01\xb0\x4f\x38\x0e\xc0\x5b\x58\x95\x54\x27\xd4\xc2\x2f\x69\x07\x82\x54\x10\x2b\xd1\x8a\xd8\xb6\x24\x79\xca\x36\x53\x5c\xe8\x4d\x9a\xae\x9b\x08\xdb\x6d\x97\x95\x76\x0c\xdb\xb6\x0c\xdb\x36\xa1\x62\x03\xc5\x92\xb7\x6c\x05\x84\x94\x06\x81\x08\xaf\x1e\x13\x90\x42\xc6\x51\x14\xbe\xb8\xe8\x7d\xe0\x68\xf1\xd0\xa3\x7e\x10\x60\xef\x9e\xee\x7b\xd3\x8c\xe9\xe3\xd7\x28\xeb\x82\x8f\x5c\xd6\x56\x5a\x58\xfe\x6c\x39\xbd\xe0\x78\x02\x40\x6a\xa1\x65\x01\xe4\x00\xf4\x30\x23\x1f\xc5\x9c\x57\x8a\xf3\x12\xe8\x31\x04\xe5\x2c\x41\x19\xc7\x32\xd3\x5e\x26\x9d\xf2\x7a\x7a\x3c\xaf\x37\xef\xba\xd9\x8c\xe3\xa6\x93\xf6\x6b\xcf\xec\x4a\xa4\x85\xe5\x6c\x5c\xcb\x02\xd4\x5d\xfa\xf6\xbd\x22\x49\x90\x78\xe1\xef\xef\xff\xcb\xca\xa2\x15\x10\x91\xde\x5b\x69\x96\xf6\x3e\xfb\x54\xef\xaa\x8d\x9b\x99\x00\x90\x40\x20\xab\x0f\xdd\x35\xb4\xf7\x27\x65\x64\x97\x8f\x14\x27\x3f\x7a\x45\x03\x40\xb4\xb0\xa4\x6a\x30\x04\x00\x73\x01\x2c\x24\x40\x13\x81\x04\xc1\x92\x44\xae\x21\xd8\x03\x51\x5a\x90\x4c\x1b\xd2\x49\x32\xe0\x11\xe0\x46\x41\x60\x37\x9e\xdc\x95\x1f\x4d\x91\xd8\xb0\x46\x0a\x80\x28\x08\x05\xf6\x1e\x20\x48\x21\x76\x9c\x54\x2e\xb4\xb7\xf1\x2c\x0f\xd6\x27\xfe\xf9\x85\xe7\x86\xbe\x5c\x2d\x77\x90\xed\xb1\x08\x00\x25\x55\xc9\x1d\xfc\xbd\xf1\xd2\xf0\x45\xef\x2d\x69\xc0\x13\x0c\x75\x62\xa2\x30\x60\x30\x60\x33\xe0\x31\x10\x31\x58\x13\x11\x11\xb1\x69\x08\x38\x9a\x29\x21\x98\x93\x00\x52\x92\x29\x05\xc0\x63\x86\xbb\xe7\x47\xd3\xd9\x6c\x48\xe9\x4b\x2e\x88\x84\x69\x49\x02\x40\xcf\xbc\x28\x11\x2b\xa9\x24\xf0\x9d\x93\x3e\x0f\x48\x6d\xef\xee\x49\xf6\x5f\x6b\x90\x6d\xaf\x9b\xea\xae\x0c\xab\xd6\x2a\xb1\x66\x2a\x45\xbb\xf6\xa7\xfd\x17\x6e\xbd\x6b\x24\x99\x4a\xc1\xe9\xef\x89\x00\x48\xee\xfe\x08\x16\x00\x87\x19\x2e\x40\x09\x8d\xae\xc3\x0c\xa4\x99\x29\x4d\xa0\x34\x88\xd3\x82\x90\x94\x84\xe4\xc1\x5d\x4f\xa5\xfd\x87\x1f\x1f\x5d\xbb\x04\xc6\x15\x17\xc3\x20\x12\x22\x8c\xa5\xf8\xb7\x1d\x06\x45\xb1\xfc\xc1\x2d\x0f\x7e\xfe\x1b\x27\x0d\x50\xe9\x1c\xef\x64\x9d\x7e\x11\x37\x47\x2f\x58\x3b\x15\x20\x93\x95\x00\x40\xae\x68\x18\x8f\x7d\xe7\x40\xd2\xaf\x0b\x39\x78\xee\xc6\x5a\x08\x02\xfb\x81\x2d\x1d\x4b\xf2\xc2\xe4\xd6\x0c\xb7\xab\x04\x27\x19\x48\x82\x91\x02\x21\x45\x84\x14\x80\x24\x81\x92\x47\x7e\xf9\xab\x4c\xe9\xee\xfb\xc6\x46\x7a\x0c\xfb\x13\x1f\x8a\x4c\xc7\x16\x12\x44\xf4\xc0\xe3\x06\xed\x39\x28\x62\xd6\xfc\xe1\x67\x0e\x3f\x52\x3e\xa5\x33\xb1\xd4\xf6\x53\xae\x95\xba\xa2\xf4\x5a\xae\xf0\xae\xb3\x15\x19\x86\x00\x2b\x20\x4d\x8c\xc9\x2d\x83\x61\xb3\x7f\xb2\xfd\xd3\x9b\x6e\x1b\x8c\x76\x1f\x1d\x28\x6c\x99\x6a\x04\x61\x64\x4b\x12\x0e\x83\x1c\x06\x12\x00\x7b\x0b\xa1\x92\x04\x90\x24\x82\xa7\x35\x7b\xfb\x76\x3e\x94\xaf\xdf\xff\xc8\xd8\x60\x96\xec\x6b\xfe\x28\x34\x72\x19\x29\x41\x24\x0e\x1d\x95\x74\xe7\xfd\x26\x45\x71\xfc\xe5\x5b\x1f\xbd\x71\x51\x75\xa2\xb7\x05\xa8\x06\xb3\x4a\x28\xfb\x71\x13\x85\x3f\xae\x15\x6d\x73\xc3\x66\xa6\xb0\x4c\x48\x99\x31\xe5\xcc\xb2\x29\x8f\xfd\x3a\xf5\xd2\x93\x61\x62\xe4\xdc\x33\xeb\xc6\x40\xaf\x7a\xf0\x0b\x37\x2d\xf7\x62\x99\xf2\x96\x8f\x2a\x00\x2e\x83\x13\x5d\x10\x78\xb1\xe6\xc4\xdc\xde\x83\xb9\x03\xdf\x9b\x1e\x8e\x5e\xdc\x57\x58\xb7\x8c\xcd\x8f\x5d\x15\x99\xd9\x34\x49\x80\x44\xb9\x2a\xe9\x1b\xdf\x37\x29\x56\x06\x15\x32\x7d\xd3\x8f\xee\xbd\xf7\xc9\x77\xa4\x2a\x31\xdf\x7e\x75\xce\x82\xb7\x27\x6a\xf5\xff\x41\xbd\x22\xc5\xca\x51\x0d\x68\x10\xc0\x94\xb2\x23\x59\xe8\x61\x3a\x6b\x2a\x34\x67\x67\xab\xe6\xcc\xae\x99\xdc\xc0\xa6\xc9\xc0\x19\xee\xa3\xb9\x43\x47\x53\xfe\xd1\xd9\x4c\x75\xff\x2b\xd9\x63\x4f\x3e\x57\x38\x72\xcf\x4f\x07\x6b\xbb\x9e\xeb\xcd\xc9\x86\x7b\xf9\x45\xb1\xb1\xfd\x3c\x65\xd8\x16\x04\x40\xa2\x54\x95\xf4\x4f\xb7\x9b\x44\x76\x0e\xd9\xf1\x1e\x54\x67\xcb\x97\x9c\xbb\xfa\xd2\x03\x4f\xec\xdf\xf9\xc2\x3b\x56\x99\x3b\x73\xf4\xe2\xab\xd7\x8d\x6e\xf8\xe6\xc6\xd5\x29\xe3\x43\x97\x85\x9c\xf4\x04\x83\xe8\x44\x31\x54\x77\x02\x83\x77\xec\x94\xea\xfc\x8b\x33\x91\x4a\xf5\x84\xdf\xb8\x79\xaf\xed\x37\x0c\x41\x00\x65\xd2\x1a\x4b\x46\x94\x98\x5c\xa5\xc4\xca\x09\x25\x88\x20\xba\x63\x32\x1d\x38\x22\xe8\xbb\x3f\x34\xc9\x70\xb3\xb8\xf0\x63\xdb\xb5\x93\x74\xe8\x9e\xaf\xdf\x2d\xfd\x72\x2b\x22\xd0\xd3\xae\x9d\xb8\xcf\xb5\xdc\x9b\x6e\xb8\xf3\x53\xfe\x29\xd7\x46\xd7\x0f\x9e\x77\xe1\xaa\xe1\xc9\x7f\x59\x3e\x3c\x98\xbf\xf4\xfc\x80\xa7\xd6\xf0\xc2\x91\x13\x6f\x6c\x00\x98\x3b\x81\x40\x10\x82\x5d\x47\x93\x65\x6a\x62\xee\xee\x27\x27\xae\x9d\x00\xf4\xe0\xe3\x06\x1e\x7b\x1a\xd4\xea\xb4\xb1\x66\x6a\x1d\x6d\xfd\xf0\xf9\xfa\xb1\x1f\x3c\x2c\x67\xf6\x1c\xa1\xde\xb4\x20\x43\x10\xe6\xea\x1a\x9e\x9d\x7a\xc2\x73\x92\x97\x5e\x7f\xc7\x35\xb5\x53\xae\x4e\x2f\xcb\x6d\x18\x5e\xda\xbf\xfa\x6b\xe3\x7d\x4b\x2f\x5b\x39\xee\xf0\xb6\xb3\x22\xac\x5e\xae\x59\x4a\xf1\xa6\x22\xef\xeb\x55\x5d\xe2\xff\x28\x58\x53\xb3\x05\x7a\xfa\x79\x81\x9f\x3d\x63\xd0\xcc\x5c\xc5\x7f\xad\xfc\xea\x8d\xa5\xc6\xec\xaf\x26\xc7\x37\xde\x31\x3a\x32\xe1\x35\xab\x75\xac\x1f\x33\x30\x5c\x30\x89\x88\x50\x6e\x6a\x3c\xb5\x3f\x80\x6b\xa5\x9f\xf0\x1c\xef\x7d\xd7\xdf\x71\x4d\xfd\x1d\xf9\x7f\x60\x5d\xdf\x39\x17\x8f\x17\x96\x7d\x7e\x20\x37\x74\x76\x21\x97\xc4\xaa\x89\x18\x4b\x46\x35\x06\x7a\x35\x67\xd2\x0c\xcb\xec\xa6\xc4\x6d\x9f\x51\xae\x11\xcd\x1c\x17\x78\xf9\xb0\xc4\x81\x23\x44\xc5\x5a\xb1\x33\x57\x3b\xf6\xaf\x47\xe6\x0f\x7e\xe9\xe5\xca\x2f\x8f\x02\xc0\x64\xff\xd6\x0b\xd6\x2f\x39\x73\x7a\x2c\x9f\xf3\xd6\x8f\xc4\x30\x2d\x13\x4e\xc2\xe9\x2e\xe9\x4d\x8d\x5d\xfb\x03\xb8\x56\xea\xe7\x9e\x9d\xdc\x7e\xfd\x9d\x6f\x85\x58\x34\xc0\xeb\x15\x8c\x9e\xcd\x1b\x06\x73\xa3\x57\x67\xbd\x9e\x4b\x5c\x3b\xb1\x26\xe9\xa4\x0c\xdb\x74\x20\x88\xc0\x00\x94\x52\xf0\xc3\x36\x9a\x9d\x7a\xd3\x0f\xfd\x5f\xcc\x57\x8f\x4d\x97\x1a\x73\xdf\x3b\x58\x7b\x6e\xfe\xcd\xdf\x75\xf9\xfa\x8f\x7f\x77\xf5\xd0\xe8\x87\x37\x8e\xea\x6e\x0e\x66\x9b\x70\xdc\xb7\x40\xbc\x6d\x38\x9d\x34\xc0\x1b\x6d\x55\xfe\xac\x74\xac\xe2\x95\x86\x34\x86\x1c\xd3\x4d\x69\xd6\xaa\x13\xf9\x15\xad\xd5\x61\xd3\xb0\x0f\xec\x29\xfe\x22\xfa\x4d\xcf\x6f\x1e\xb9\xf0\xea\x4d\x4b\xb7\xdc\xbe\x6e\xc8\xc0\x40\xba\x1b\x85\x6f\xaf\xc4\x5b\xc3\xe9\x1d\x01\x38\x55\x9b\xc8\x6c\xa0\xd1\xde\xf1\xdb\xd6\x8c\x4e\x7d\x6c\xed\x80\x40\xff\x6f\x84\x48\xfd\xdc\x73\x92\xdb\x4f\x40\xc8\xd3\x01\xa0\x1a\x1c\x87\xd4\xd6\x3d\x41\x1c\x8d\x43\xf6\x6d\x48\x98\x02\x49\x1b\xd0\xaa\x5b\x2e\x32\x4c\x03\xae\x45\xc8\xa7\x24\x0e\xcf\xb7\x47\x99\xe9\xbc\x4b\xce\xb8\xf2\x8e\x87\x76\x4f\x07\xa7\x05\x00\x00\x54\x82\x39\xb6\xd8\x99\x0e\xa2\x70\x09\x64\xdf\xfa\xff\x04\xa1\xdf\x06\x02\x62\xdb\x25\x67\x5c\x75\xfb\x69\x03\x00\x00\xe5\xce\x2c\x1b\x48\x4c\x07\x51\xf0\x56\x25\xde\x04\xf1\xca\x6c\x7b\xcc\x94\x16\x9f\x56\x00\x0b\xd9\x30\x0b\x6d\x4d\xff\xb6\x70\x6a\x05\x8c\xba\xaf\x73\xa7\x1d\x40\x77\x4e\xcc\xb1\x01\x77\x3a\x8c\xc2\x25\x90\x85\xb7\x0d\xa7\xb9\xaa\x42\xc3\xc7\xfc\x69\x09\x70\x42\x09\xc9\xce\x74\xf8\x36\xe1\x54\xf7\x81\x7d\xc7\x34\x62\xa5\xbe\x79\xda\x02\x9c\x80\x20\x6d\x4d\x87\x71\x34\xae\xa9\x77\x43\x33\x30\x50\x6a\x11\x5e\x9e\xd5\x28\x35\x2a\xbb\x9a\xed\xc6\x27\x09\xff\x0f\x6c\x79\x6e\xa3\x48\xb9\x99\x3f\x19\xc8\x0d\x5f\x2d\x48\x3a\xd5\x56\xf9\x81\xa6\xdf\xfc\xea\x73\xc7\x1f\x6e\xe1\x77\xf6\x3b\x3b\x35\xfb\x77\x03\x4d\x4e\xc3\x95\x71\xc2\x77\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\xe8\x65\x8d\x92\x47\x0f\x00\x00")) - folderOpen20 = HexToBytes("folderOpen20", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\xe5\x03\x1a\xfc\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x14\x00\x00\x00\x14\x08\x06\x00\x00\x00\x8d\x89\x1d\x0d\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0b\x12\x00\x00\x0b\x12\x01\xd2\xdd\x7e\xfc\x00\x00\x03\x97\x49\x44\x41\x54\x38\x8d\xd5\xd4\x5d\x4c\x5b\x65\x18\x07\xf0\x7f\x77\x5a\xa5\x02\x6d\xa5\xb4\x8e\x0c\x1c\x63\xb0\x81\x0c\x24\x63\x4c\xd0\x10\x16\x10\x17\xd0\xb9\xe8\x44\x8d\x09\xc9\xc2\xc5\x88\xbb\x73\x86\x0b\xbd\x21\x6a\x26\x4b\xc4\x98\xcc\x10\xbf\x92\xe9\x85\x2e\xee\x62\x7e\xce\xe0\x36\x36\x9d\xec\x83\xb0\x0d\x08\x50\x71\x39\x65\xfd\xa0\x3d\x5d\x69\x69\xcf\xe1\x7c\xbf\xe7\x3d\x1c\x6f\xe6\x62\x48\xc4\x64\xee\xc6\x27\x79\x92\xf7\x4d\xde\xfc\x6e\x9e\xe7\xff\x02\xf7\xb6\x18\xdb\xbd\x50\x5e\xe9\x3d\x54\xb2\xaf\xa3\x75\x20\x30\x77\x23\x6d\xff\x2f\x50\x4f\x4f\x4f\x4e\x63\x73\xeb\x6b\xb5\xd5\x55\xbd\x26\x35\x42\x57\xae\x5d\xcf\xde\x35\xd8\xff\xee\x60\x67\x5b\xcb\x13\x47\xbc\x0f\x7a\xac\x38\x97\x98\x96\x15\x45\x33\x88\x69\xdd\x15\x38\xf0\xfe\xd1\xae\xe7\xf6\x74\x0c\xca\xa2\xc4\x2e\xa6\x52\xb2\xaa\x69\x24\xb9\x98\xe6\x05\x51\x20\xff\x0a\x76\x1f\x3c\xb8\xe1\xf1\xfa\xc6\xb7\x08\x21\x4d\x97\x27\x26\xf7\x9f\xf8\x6c\x68\xa2\xbe\xae\xb6\x4f\x91\xa4\x1b\xb2\xaa\x68\xa2\x28\xeb\xf3\xf3\x61\x2e\x91\x5c\x94\x88\x6e\x38\xee\x0c\xa5\xa7\xf7\xf5\xa6\x5c\x57\x5e\x03\xcf\x0b\x63\xde\x5c\x4c\xc5\xe3\x0e\xc7\xf6\xc6\x92\x43\xf5\x75\x8f\xf6\xc1\x66\xcb\x8f\x71\xb7\x10\xe3\x12\x9a\xcd\x5a\xf9\x6e\x6f\x67\x7b\x8d\x28\x49\xa1\x54\x2a\x2d\xfe\x11\x0c\xc6\xb2\xbc\x48\x6c\xb0\x18\x83\x50\xa7\xad\xeb\x40\x9f\xbf\x75\x67\xcd\xc0\xae\xe6\xa6\xfd\x4e\xa7\x73\xdd\x42\x8c\x43\x34\x16\x17\x18\x86\x21\x65\xa5\x25\xbe\x78\x22\x05\x59\x91\x91\xe5\x05\x6c\xde\x58\x82\x87\x4b\x8a\x11\xe3\x12\x8b\xa2\x20\x5c\x60\xe7\x43\x41\x49\x91\x57\xb6\x55\x56\xf8\x77\xb7\xb7\xed\x19\x3e\x7b\xee\xbc\xbd\x6b\x77\xf3\x97\x4f\xb5\xb5\xb4\x2b\x9a\x06\x55\xd3\xe1\xf1\xb8\xe1\xb8\xcf\xe1\x56\x14\x0d\xa9\x74\x16\x06\x35\xa0\x69\x3a\x6a\xab\xaa\xe0\x72\xe7\x21\x99\x4a\x23\x71\x6b\xd1\x1f\x8e\xc5\x3b\x2c\x93\x9e\x7a\xe9\xf9\xbd\xbe\x8a\xf2\xb2\x16\x55\x55\xed\xa2\x28\x9a\xf6\x82\x02\x8f\xdb\x5c\x59\x81\x69\x9a\xa0\x94\xde\x6e\x13\xd4\xa4\xa0\x26\x05\x21\x04\x4b\x19\x1e\x4d\x3b\xbc\x48\x67\x97\xb0\x10\xe3\xc0\x25\x53\xf0\x7a\xdc\x79\xcf\x76\x3c\xf9\xb2\xaf\xd0\x8b\x4c\x26\x83\x50\x38\x82\xc9\xe9\xb9\x19\xbb\x2c\xcb\xaa\x65\x59\xb7\x41\x13\xc6\x1d\x94\xc2\x30\x28\xb2\xfc\x32\x6c\x36\x80\xb1\xdb\x11\x59\x88\x23\xb5\x94\x45\x43\xdd\x36\x34\xed\xdc\x0e\x4a\x29\xa2\xd1\x28\x42\xa1\xb0\x35\x76\x75\xf2\x9b\x4f\x3f\x1c\xfc\x88\x71\xe4\x7a\x02\x0f\xf9\x7c\x9d\xbe\xc2\x42\x97\xa2\xa8\xd0\x75\x1d\xba\x6e\x40\x27\x04\x19\x5e\x80\x28\x4a\x70\xe6\xe4\x60\xbd\xaf\x08\x5c\x92\x43\x47\x5b\x0b\xaa\xab\xb6\x40\x10\x04\x84\xc3\x61\x4c\x4d\xcf\x0a\x67\xce\x8f\xf6\x7d\xf0\xde\xe1\x37\x01\xa8\xcc\xf4\xc4\x55\x8e\x68\xcc\x49\x97\x27\x7f\x57\xf1\x86\xa2\xf5\xa2\x24\x43\xd7\x09\xb2\x82\x00\x9e\x5f\x86\x41\x29\x3c\x6e\x17\x2a\xb7\x6c\xc5\x8e\xba\x47\xe0\x74\xde\x0f\x8e\xe3\xc0\xb2\x41\x5c\x1c\xbb\x76\x69\xf8\xd4\xd9\x7d\x27\x8e\x1f\xfb\x09\x80\x09\x00\x0c\x00\x04\x02\x93\x82\x2c\xb9\xbe\x76\xe6\xaf\xab\xde\x54\xba\x71\x6b\x74\x21\x8e\xe5\x65\x09\x06\xa5\x20\x06\xc5\x03\xce\x1c\x34\x36\xd4\x42\x96\x25\x44\x22\x11\x4c\xcf\x06\xd4\x91\x5f\x2f\x1e\x3e\xf2\x4e\xff\xab\x2c\xfb\x7b\xfc\xef\x7b\xcb\xfc\x75\x60\xd9\xeb\xfa\x8f\xdf\x7f\x7b\xb2\xac\xa2\xd2\x5d\x51\x5e\xf6\xd8\x52\x86\x87\x4e\x08\x0c\xc3\x00\x6c\x40\x91\xcf\x8b\x9b\x37\xe7\x71\x65\x7c\x62\xf6\x87\x9f\xcf\xbd\x78\xfc\xf3\x4f\xbe\x02\x60\xac\x0e\x02\xb3\xea\x6e\x8e\x9c\x1e\x3e\x5d\xe0\x2b\x5e\x2a\xdf\x5c\xda\x26\x29\x1a\xa3\xe9\x3a\x60\x59\x30\x74\xc5\x18\xf9\xe5\xd2\xd0\xdb\xfd\x6f\x74\xb3\x73\x33\xc1\x7f\x4a\xd6\x6a\x10\x00\x30\x76\xf9\xb7\xf1\x7c\x8f\x7f\xca\xef\xf7\x3e\x4d\x08\xcd\xe1\x05\x3e\x7c\x61\x6c\xbc\xfb\x8b\x8f\x8f\x0e\x01\xd0\xd6\x8a\xea\x9a\xff\xe1\x0b\xdd\x07\x6a\x1c\x0e\xfb\x33\x31\x76\xe6\xd8\xe8\xe8\x68\x72\xad\xb7\xff\x9f\xfa\x13\x0a\x81\xec\x87\x81\xf4\xd8\x99\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\x68\x88\xeb\xb8\xe5\x03\x00\x00")) - globalNetwork20 = HexToBytes("globalNetwork20", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\xdc\x04\x23\xfb\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x14\x00\x00\x00\x14\x08\x06\x00\x00\x00\x8d\x89\x1d\x0d\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0e\xc3\x00\x00\x0e\xc3\x01\xc7\x6f\xa8\x64\x00\x00\x04\x8e\x49\x44\x41\x54\x38\x8d\x75\x95\x4b\x68\x5c\x65\x18\x86\x9f\xff\x9c\x7f\xfe\x73\xc9\xdc\x33\x33\x69\x92\x3a\xc6\x1a\x8d\x8d\x82\x5a\xd2\xa2\x28\x2e\x54\x04\x37\x25\x4a\xc5\xba\xf3\x02\xe2\x05\x5d\x88\x0b\x05\x11\xba\xaa\x82\x15\x54\xda\x22\x62\x41\x14\x54\x28\x58\x5c\x94\x52\xa1\x8a\x42\x17\x1a\x15\x6f\x54\x53\x93\x92\x26\x69\x92\x33\x99\xce\x34\x73\x39\xf7\x73\x5c\x28\xd5\x56\xfd\xe0\x83\x8f\x17\xde\x67\xf9\x7c\x82\xff\x9a\xbd\xc7\xcd\xe7\xea\x0b\x0f\x58\x86\x3b\x5d\x32\xf2\x53\x41\xb4\x69\xc4\xf7\x8a\xe9\x62\x33\x58\xe9\x78\x8d\x6f\x9a\x8e\x7f\xe4\xc4\xfa\xc2\x61\x0e\xbd\xe8\x5d\x5e\x15\x97\x07\x2f\x7d\x7a\x70\x77\x56\x15\x5f\xab\x64\xeb\xa3\x03\x86\x49\xc1\xaa\x91\xd1\x04\x6b\x17\x5c\x96\x9a\x3e\xcb\x4e\x0b\xc7\xe9\xd0\xe8\xcc\x2d\x75\x8c\x99\xe7\xbf\x79\xf9\xbd\x8f\xff\xd9\xd7\xff\x3e\xdf\xd1\x0f\x7c\x79\xd7\xfe\x4d\x83\xe2\x95\xe1\xc2\xf5\xf9\xab\x37\x5d\x47\x7d\x70\x90\xbc\x25\xf1\x85\xc4\x45\x12\x11\x83\xf9\x03\xeb\xc6\xe7\x58\xb6\xc8\x77\x06\xbe\xda\x55\xb8\x75\x6b\xad\x71\xe2\xed\x63\xf0\x7e\x7a\x09\xf0\x8d\x63\x8f\xed\x1f\x29\x8d\x3f\x39\x94\xbf\x99\x5a\x69\x8c\xbc\xad\x90\x2a\x83\xae\xeb\x08\x3d\x21\x4e\xda\x04\xb4\xd8\x52\xb0\xb0\x32\x3e\xa7\xfc\xcf\xd0\xc4\x79\x3c\x7f\x61\xfb\xc0\x8d\x67\x2a\xad\x93\x73\x47\x2f\x02\x5f\xf8\xe8\xe4\x83\xb5\xf2\xd8\xab\x95\xe2\x08\xb5\x62\x91\xb2\x6d\x50\x34\x33\xd8\x19\x0d\x5d\xd7\x41\xd3\x11\xf1\x22\x42\x2c\x73\xe6\xc2\x2c\xe7\xdc\xdf\x58\x6f\x2d\x93\x78\x1e\x7e\x9c\x90\x27\xd8\xc1\xf0\xf6\x53\x1b\x3f\x9d\xfe\x45\x63\xef\x71\xb3\x64\x5b\xfb\x4a\x59\x93\x82\xad\xa8\xd8\x8a\xb2\x29\xc9\x67\x34\xb2\x19\x0d\xa5\x0b\xb4\x78\x91\x08\x9d\x8e\x9f\x92\xd0\x60\x38\x5b\xa5\xec\xde\xc2\xf9\x55\x98\x54\x77\xe0\x34\x1d\xfc\x70\x61\x1f\x3c\x6a\xca\xa7\x8b\x72\x97\x92\x99\x51\x84\x20\x15\x02\x37\x4e\x51\x69\x8a\x48\x21\x4a\xa1\x1f\x75\x09\x83\x00\x4d\x28\x90\x5b\x89\xd3\x22\x9b\x54\x9f\xa9\xc9\x05\x48\xd6\xb8\xfd\x9a\xdb\xf8\x7d\x7e\x1e\x4b\xf6\x37\x37\xee\x5c\xdf\x25\xaf\x18\x9a\xbf\x2f\x4c\x6a\x44\x09\x84\x49\x4a\x3f\x8a\xd1\x42\x81\x26\x24\x3d\x6f\x85\x30\x58\xa3\x1f\xac\xd3\xeb\x2d\xe0\x75\x23\x16\x5b\x15\xbe\x76\x42\xc6\x94\x83\x08\x7d\xde\x3a\xfa\x2e\x6e\x13\xe6\x9b\x5d\xe8\xb4\xa6\x65\xa3\x7f\x6a\x2a\x1b\x6f\xa3\xeb\x86\xb4\x7b\x01\xba\xae\x11\x6b\x1a\x71\xe2\xe1\x34\x67\xe9\x26\x2d\xf0\x1d\x42\x6f\x05\xbc\xb3\x54\x58\x27\xb5\x03\xae\xce\xdd\xcf\xc6\xca\x57\x38\x6b\x15\x8c\x0b\x25\xd8\x68\x51\xd5\xd5\x76\xe9\xf8\xa7\x47\xa2\xa8\x8d\xdd\xb5\xd0\x95\x8e\x0b\xa8\x30\x46\xe8\x3a\xb2\xdf\x67\xcd\x9b\xa3\xeb\xad\x93\x09\x1d\x96\xba\x6d\xb2\x91\x86\x4a\x2a\x08\x91\x72\xe6\xec\x18\x35\x79\x96\x5f\xce\x17\xa8\xc6\x3a\x28\x6d\x58\x36\xc3\x0d\xb4\x70\x9e\x4c\x33\xcf\x46\x90\x60\xe7\x03\x94\xad\x10\x52\xe2\x45\x13\xa8\xb0\x84\xd3\x3e\x8d\x0c\x96\xe8\xf9\x1e\x81\x28\xb3\xb2\xd6\x26\xd3\xfb\x91\x44\x3b\x8f\xb3\xb6\x05\x62\x09\x71\x06\xc3\x2a\x20\x95\xed\x9d\x93\xe6\x07\xf5\xc6\x5a\x15\xdd\xad\x91\xe9\x19\x48\xdb\x20\x95\x1a\x91\xd0\xe8\x87\x45\xf2\x62\x8a\x56\x7b\x0e\x1b\x68\xb6\xda\xd4\xf4\x1a\xe7\x9a\x1d\x96\xdb\x09\x8d\x9e\x01\xb1\x0f\xca\x60\xa0\x58\x5e\x91\x13\xba\x3e\x93\xa4\x5a\xfd\x87\xd5\x2e\xd2\x34\x51\x39\x83\x44\x49\x34\x25\xf1\xe2\x84\x28\x8a\x59\x0d\x03\x1e\xdf\x31\xcd\x17\x3f\xef\xc7\x88\x6c\xba\x9e\x4f\xdc\xcb\xe1\xcc\x0d\x41\x1c\x80\x0e\xb9\x72\x95\xca\xd0\xd0\x8c\x6c\xaf\x0f\x1e\x59\x74\x46\xef\x5f\x5d\xea\x62\x64\x05\xaa\x63\x43\x46\x12\x6b\x10\xc4\x21\xc5\x8c\x86\xdf\xeb\xb3\x67\xee\x08\x53\xf5\x10\x53\x64\xe9\x47\x2e\xdf\xce\xb6\x30\x8c\x18\x3c\x93\x6a\xae\xc8\xe0\x15\x75\x86\xc6\xeb\x47\xf4\x6f\x47\x1e\x9e\x75\x67\x33\x8f\xb8\x6e\x98\x0f\x82\x80\x6e\xcf\x23\xee\xfb\xc4\x9e\x4b\xd2\xe9\xb3\x74\xae\xc9\x85\x76\x97\x8d\x6e\x8b\x90\x5f\x49\x92\x88\x9d\xdb\x1e\xe5\xfb\xef\x1c\x54\x12\x83\x2c\x30\x3c\x76\x2d\xe3\x37\x8e\x2f\x17\xca\x95\x27\xfe\xb4\xcd\xdd\x7b\x76\x57\xe1\x43\x43\x6a\xa0\x89\x8b\x12\xf2\x49\x21\x49\xfe\x5a\x17\x23\x7b\x16\x3c\x8b\xab\x72\x57\xe2\xb9\x3e\x98\x03\xf8\xa5\x2b\x99\xb8\xe9\x2a\xaa\xa3\xa5\x87\x0e\x4c\x4f\x7e\xf4\xb7\xbe\xee\xdc\x73\xa0\x9a\xf8\x4f\x12\x07\x90\xa4\x97\x3a\x4d\x03\x12\x80\x98\x5a\xce\xc0\xf1\x62\x8c\xfc\x10\xc3\x5b\xc6\x99\xbc\xa1\x4e\xa1\x66\x1f\x7c\x73\xe7\xd6\xa7\x00\xe4\xc5\xd2\x89\x91\x67\xb8\x67\x49\xe0\xf6\x9f\x68\x04\xee\xa5\x34\x5d\x00\x3a\x9b\x6d\x93\xc8\x2e\x53\x1b\x19\x62\x78\xac\x4e\x7d\xcb\x20\xb9\xa2\x3a\xf0\xc6\x4a\xfc\xec\xff\x0a\x76\xf3\xf4\xbe\xdd\x04\x1b\xaf\x11\xf4\x46\x95\x06\x96\x92\xd8\x96\x8d\x2f\xb3\xe4\xca\x35\xac\x6a\x95\xda\xe6\x0a\xa5\x41\x6b\xc9\x30\xf5\xe7\x5f\xbf\x77\xe2\x12\xc1\xfe\x0b\x08\xc0\xde\xe3\xe6\x6d\xab\x0b\x0f\x0c\x1a\xf1\xb4\x65\x99\x53\x56\x3e\x37\x32\x50\x28\xa4\xb9\x42\x61\x25\x32\xac\x99\x50\xa9\x4f\x3a\x9a\x3a\x7c\xe8\x9e\xb1\x7f\xbd\x80\x3f\x00\xa1\xef\x00\x2a\xd8\x55\xe0\xf2\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\xcc\x49\x31\xf6\xdc\x04\x00\x00")) - mainGlade = HexToBytes("mainGlade", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\xec\x5d\x5b\x73\xea\xb8\x93\x7f\xe7\x53\x68\xfd\x34\x53\x0b\x49\x20\xe7\x3a\x95\x30\xc5\x21\x90\xb8\x16\x4c\x0a\x9c\xc9\x9e\x27\x4a\xd8\x02\x6b\x63\x24\x8f\x24\x92\xb0\x9f\xfe\x5f\x92\x21\x37\x0c\xf8\x46\x62\x88\x9e\x12\x64\xa9\xad\xee\x56\xff\xa4\xee\x96\xa5\xb3\xbf\x1f\xa7\x3e\xb8\x47\x8c\x63\x4a\xce\x8d\xea\xd1\x89\x01\x10\x71\xa8\x8b\xc9\xe4\xdc\xb8\xb1\xdb\x95\x1f\xc6\xdf\xf5\xd2\xd9\x7f\x55\x2a\xe0\x12\x11\xc4\xa0\x40\x2e\x78\xc0\xc2\x03\x13\x1f\xba\x08\x9c\x1e\xd5\x6a\x47\x55\x50\x2a\xd9\x1e\x02\x5d\xd3\x06\x1d\xec\x20\xc2\x11\xf8\xa3\x6b\xda\x7f\x96\x4a\x4d\x1a\xcc\x19\x9e\x78\x02\xfc\xe1\xfc\x29\x2b\x94\x4a\xd7\x88\x4d\x31\x97\x2f\x04\x98\x03\x0f\x31\x34\x9a\x83\x09\x83\x44\x20\xb7\x0c\xc6\x0c\x21\x40\xc7\xc0\xf1\x20\x9b\xa0\x32\x10\x14\x40\x32\x07\x01\x62\x9c\x12\x40\x47\x02\x62\x82\xc9\x04\x40\xe0\xd0\x60\x5e\xa2\x63\x20\x3c\xcc\x01\xa7\x63\xf1\x00\x19\x02\x90\xb8\x00\x72\x4e\x1d\xac\xba\xea\x52\x67\x36\x45\x44\x40\x21\xdf\x37\xc6\x3e\xe2\xe0\x0f\xe1\x21\x60\x0c\x16\x2d\x8c\x3f\xd5\x4b\x5c\x04\xfd\x12\x26\x40\x3e\x5b\x3e\x52\x8c\xd2\x99\x00\x0c\x71\xc1\xb0\x23\x69\x94\x01\x26\x8e\x3f\x93\x02\x7a\x7a\xec\xe3\x29\x5e\xbc\x41\x36\x57\xfc\xf2\x92\xa0\x60\xc6\x51\x59\xf5\xb3\x0c\xa6\xd4\xc5\x63\xf9\x17\x29\xb6\x82\xd9\xc8\xc7\xdc\x2b\x03\x17\x4b\xd2\xa3\x99\x40\x65\xc0\x65\xa1\x12\x5f\x59\xf2\x71\x4c\x19\xe0\xc8\xf7\x4b\x0e\x0d\x30\xe2\x40\xf1\xfa\xdc\x3b\x55\x47\x76\x3d\x90\x02\x15\x0b\x11\x71\x59\xf2\xe0\xd1\xe9\x6b\x4e\x30\x2f\x8d\x67\x8c\x60\xee\x21\xd5\xc6\xa5\x80\x53\xf5\xc6\xff\x43\x8e\x90\x25\xb2\xfa\x98\xfa\x3e\x7d\x90\xac\x39\x94\xb8\x58\x72\xc4\xff\x0a\x75\x0b\x47\xf4\x1e\x29\x5e\x42\x75\x12\x2a\xb0\x13\x8a\x5b\x29\x20\x78\xd6\xea\xe2\x11\xf7\xa0\xef\x83\x11\x5a\x08\x0c\xb9\x00\x93\x92\x2c\x5a\xb2\xc3\xe4\xeb\xb9\x80\x44\x60\xe8\x83\x80\x32\xf5\xbe\xb7\x6c\x1e\x95\x4a\xf6\x55\x0b\x0c\x7a\x6d\xfb\xb6\xd1\x6f\x01\x73\x00\xae\xfb\xbd\x7f\xcc\x8b\xd6\x05\x30\x1a\x03\x60\x0e\x8c\x32\xb8\x35\xed\xab\xde\x8d\x0d\x6e\x1b\xfd\x7e\xc3\xb2\x7f\x83\x5e\x1b\x34\xac\xdf\xe0\x7f\x4c\xeb\xa2\x0c\x5a\xff\x7b\xdd\x6f\x0d\x06\xa0\xd7\x2f\x99\xdd\xeb\x8e\xd9\xba\x28\x03\xd3\x6a\x76\x6e\x2e\x4c\xeb\x12\xfc\xba\xb1\x81\xd5\xb3\x41\xc7\xec\x9a\x76\xeb\x02\xd8\x3d\x20\x5f\xb8\x20\x65\xb6\x06\x92\x58\xb7\xd5\x6f\x5e\x35\x2c\xbb\xf1\xcb\xec\x98\xf6\xef\x72\xa9\x6d\xda\x96\xa4\xd9\xee\xf5\x41\x03\x5c\x37\xfa\xb6\xd9\xbc\xe9\x34\xfa\xe0\xfa\xa6\x7f\xdd\x1b\xb4\x40\xc3\xba\x00\x56\xcf\x32\xad\x76\xdf\xb4\x2e\x5b\xdd\x96\x65\x1f\x01\xd3\x02\x56\x0f\xb4\xfe\x69\x59\x36\x18\x5c\x35\x3a\x1d\xf9\xaa\x52\xe3\xc6\xbe\xea\xf5\x65\xff\x40\xb3\x77\xfd\xbb\x6f\x5e\x5e\xd9\xe0\xaa\xd7\xb9\x68\xf5\x07\xe0\x57\x0b\x74\xcc\xc6\xaf\x4e\x2b\x7c\x95\xf5\x1b\x34\x3b\x0d\xb3\x5b\x06\x17\x8d\x6e\xe3\xb2\xa5\x5a\xf5\xec\xab\x56\xbf\x24\xab\x85\xbd\x03\xb7\x57\x2d\x59\x24\xdf\xd7\xb0\x40\xa3\x69\x9b\x3d\x4b\xb2\xd1\xec\x59\x76\xbf\xd1\xb4\xcb\xc0\xee\xf5\xed\xa7\xa6\xb7\xe6\xa0\x55\x06\x8d\xbe\x39\x90\x02\x69\xf7\x7b\xdd\x72\x49\x8a\xb3\xd7\x96\x55\x4c\x4b\xb6\xb3\x5a\x21\x15\x29\x6a\xf0\x4a\x23\xbd\xbe\xfa\x7d\x33\x68\x3d\x11\x04\x17\xad\x46\xc7\xb4\x2e\x07\xc0\xb4\x5e\xa9\xef\xa8\x54\x6a\xcc\x84\x47\xd9\x5f\x0a\x10\x6a\x27\xd5\x1f\x95\xea\x4f\x70\x75\xd4\x3e\xea\x96\x4a\x95\x4a\xbd\x74\x86\x89\x40\x6c\x0c\x1d\x54\x2f\x01\x70\xc6\xd0\xbf\x33\xcc\x10\x07\x3e\x1e\x9d\x1b\x13\x71\xf7\xdf\xc6\x33\x5e\x9d\x1e\x55\x7f\x18\xc7\xaa\x9e\x44\xa8\xa7\x96\x95\x85\x19\x55\xc4\x3c\x40\x40\x1a\x87\xa4\xbc\x52\x8b\xc0\x29\x02\x6d\xec\xa3\x1b\x81\xfd\xe8\x2a\xcf\x03\x5e\x82\x5b\x64\x15\xa8\xf8\xe1\xab\xfc\x2c\xab\xd3\xd0\xc6\x1c\x1f\x72\x7e\x6e\x5c\x8a\xbb\x5b\x4c\x5c\xfa\x60\x00\xec\x9e\x1b\x5d\x88\xc9\xe2\xb7\xac\x0c\xc0\x59\xc0\x68\x80\x98\x98\x03\xd9\xbd\x73\xc3\x81\x64\x38\xa6\xce\x8c\x1b\xf5\x36\xf4\x39\x3a\x3b\x5e\x56\x88\xae\xef\xa1\xc7\x00\x12\xd7\xa8\xdb\x6c\xb6\x5a\xd9\xf1\xb0\xef\x86\xff\xcb\xa6\x3e\x74\x90\x47\x7d\x17\xb1\xe3\x45\x85\xe3\x17\x35\xde\xd4\x5e\xe1\xe3\x17\x7d\x0c\x99\x18\xd1\xc7\x1f\xc6\xb2\xde\x6a\x97\xee\x31\xc7\x23\x1f\x45\x77\x29\x0d\xcf\x51\x6d\xa6\x90\x4d\x30\x19\x0a\x1a\x18\xf5\x5a\x82\x06\x23\x2a\x04\x9d\xc6\x6c\xf3\x24\xdc\xd8\xdd\xa2\x0c\x2f\xa7\x1f\xa3\x7e\x8f\x98\xc0\x0e\xf4\x23\x1b\xbe\x12\x76\xb4\xc0\x5b\xf7\x88\x88\x27\xa9\xdb\x34\x30\xa7\x70\x82\x54\xe9\x88\x3e\x1a\x2f\x1b\xa7\xd0\x42\x5a\x4d\x44\xf7\x3e\x9a\x03\xd5\xe1\xb0\xfb\xea\x5f\x5b\xaa\xeb\x4d\xab\x94\x5d\xcf\xd2\xfd\x48\x5d\x43\x1f\x4f\x88\x51\x77\x90\x34\xf5\x24\x2d\xb9\xa0\xce\x9d\x51\x9f\x88\xbb\x8a\x9a\x13\xc9\xa4\x82\x25\xb3\xeb\x69\x9c\x1d\x87\x92\x7a\x23\xd4\xe3\xd5\x31\x11\x51\xf1\x2c\x80\xce\x1d\x26\x93\xcd\x9a\xdc\x3a\x72\xa3\x1a\x8d\xb1\xef\x27\x1b\x30\x01\xe5\x38\x1c\xec\x27\xd1\x4d\xce\x8e\x57\xba\xbb\xc2\x67\x1c\x5b\x78\x09\x3e\x5f\x3f\x74\xe8\x27\x01\xe0\xcc\x30\x91\xc4\xd8\x06\x28\x80\x0c\x0a\xca\x42\x41\xf1\xe5\xcf\xef\xc5\x30\xb9\xe8\x41\xbf\x6e\x3c\x6f\x1a\xd3\x49\xfb\xb8\x7d\x58\xa7\x1a\xda\x6b\x86\xf7\x1a\x53\x8e\xaf\xc7\x4b\x86\xdd\xa5\x0a\x21\x73\x3c\xf9\xbb\xc8\xc0\x19\x5b\x2d\x91\xfc\x6f\x93\xc1\x84\x61\x37\x6a\x04\x67\xe2\x3f\xab\x0c\x52\xad\x48\x72\x11\xe2\x66\x41\x46\x0b\xb3\xe9\x21\xe7\xee\xd7\x4c\x08\x4a\x42\x99\x0e\xd4\xb8\x52\xc5\x23\x55\x3c\x08\x7c\x2c\x90\xdb\x90\x3d\x58\x43\x76\xb5\xcf\x3e\x1c\x21\xdf\x00\x82\x41\xc2\x7d\x28\xe0\xc8\x47\xe7\xc6\x1c\x71\xa3\xde\x20\xee\x36\x1e\xa2\x08\x3e\x60\x57\x78\x43\xe9\x02\x20\x2e\x8c\xfa\xd7\x93\x34\x44\x12\x8d\x81\x3c\xc6\x41\x14\x0d\x86\x1c\x84\xef\x11\x1f\xba\x68\x0c\x67\xbe\xc8\x40\xca\x65\xf0\x61\x88\x89\x8b\x1d\x05\xed\x31\xd9\x5a\x07\xb6\xdb\x41\x77\xad\xb6\xd1\x58\x0c\xa1\x10\xd0\xf1\x36\x22\xe2\x7a\x0a\x82\x06\x49\x08\xac\x81\xd6\x8d\x10\x9b\xd6\x42\x5e\xc3\x4d\xcd\xd8\xb3\xe1\x96\x08\x3d\xb6\xcb\x67\x0d\x8a\xd0\xe9\x88\xfe\xa2\x8f\x36\x7a\x14\xaf\x60\x44\x96\x8f\xc2\xf2\xcd\x00\x92\x8b\xfc\xf2\x92\x61\x2e\x72\x8c\x22\x02\x1d\x81\xef\x51\x4c\x1b\x89\xf6\x44\xf8\x10\x11\xc1\xe6\x09\xfb\xa1\x74\x1a\x46\x2a\x08\xf4\x2b\xea\xe7\xb9\xb1\xa0\xb4\xb1\x69\xa4\xf3\xa9\xda\xad\xd1\xb3\x7a\xb8\x5d\xd9\xb9\x29\x7c\x8b\xd2\xb3\x92\x52\x2a\x83\xe2\x25\x5e\x27\x23\xb9\x0d\x6e\x63\x40\x56\x7c\x42\xdb\xb1\x3b\x1f\xfc\xce\x01\xc3\x63\xe0\x78\x2c\xc1\xa4\xc2\xab\xad\xab\x9e\x5b\xca\xdc\xe4\x88\xb5\x7e\xd9\x23\xe9\xa5\x15\xec\x9b\xb5\xcf\xb7\xd4\x1a\xca\x1b\x50\xb3\x90\xc9\xb0\x0c\xda\x14\xa2\x41\x24\xb5\x98\xd3\xad\xa6\xde\xd1\x32\xab\x7b\x65\x99\x3b\x5e\x66\x56\x0b\xbd\xcc\xdc\xc4\xfc\x66\xc6\xb3\x61\x73\x06\x86\x37\x30\xbb\x96\xd1\xf4\x6e\xfb\xcf\x98\x6e\xfb\x1b\xec\xfb\x9e\x58\x02\xef\xeb\xf7\xef\xca\xfb\xee\xb1\x5c\x9c\xef\x1e\xd3\xbe\xb7\xf6\xbd\xf7\xd5\xf7\xae\x7e\xd1\xce\x77\x4a\xe7\x7b\x23\x7e\x14\xde\xf7\x4e\x14\x3e\xcd\x92\xe4\xd5\x81\x80\xbc\x03\x01\x5b\x07\x9e\x8e\x03\xe8\x38\x40\xc1\xe3\x00\x89\xc1\x53\x87\x01\x74\x18\x40\x87\x01\x74\x18\xa0\x90\x61\x80\x6a\x91\xc2\x00\xd5\x13\xe3\x33\xb9\xf1\x16\x15\xb9\xf8\xf1\x16\x15\xda\x91\xd7\x8e\xfc\xde\x3a\xf2\x3f\xb4\x23\x9f\xd2\x91\xdf\x8c\x20\x3a\x8b\x7e\x50\xce\xf3\x76\x65\x6b\xef\x59\x7b\xcf\x05\xf7\x9e\x93\x23\x96\x76\x9f\xb5\xfb\xac\xdd\x67\xed\x3e\x17\xd2\x7d\xae\x15\xc9\x7d\x3e\xd5\x9b\xdf\x37\xa3\x23\xc7\xff\x8f\x86\x53\xea\x22\xa3\xfe\xef\x0c\xe5\xbf\x7d\xbe\x13\x4e\x55\x52\x1f\x6a\xd6\x4a\x92\xa1\x4c\xbc\xb5\xa1\xb8\xde\x51\xec\xef\xe3\xb6\xaa\x39\x75\x1f\xd6\x2f\x1a\xda\xea\x53\x7f\x31\x0f\x0e\xc0\xad\xaf\x15\xcb\xad\x8f\xe3\xb1\xda\xf3\x00\xed\x9b\xbb\xbf\x80\x2c\xa9\xbb\x98\x99\xe2\x35\x14\xd4\x07\xe3\x71\x49\x60\x81\xa6\x7c\xe3\x72\x42\xd6\x88\xfc\xa8\xc6\xf7\xcf\x8e\xe5\xc3\x54\xad\xa5\x81\x64\x68\x7e\x81\x19\x72\x04\x65\xf3\x0c\x34\x3a\x98\xdc\x6d\x6b\x1e\x3e\xe7\xfb\xba\x52\xda\x43\xd3\xbd\x80\x02\xed\xa3\xf9\x2e\xe7\x23\x2e\x20\x13\xfb\x63\xff\x39\x6c\x58\xc9\x82\x21\x8e\x83\x38\xcf\x60\xc3\x5d\xea\xe2\xb1\x74\xfb\x30\x25\x19\xc8\x84\xfd\x00\x57\xfd\x9c\xba\x12\x83\xd2\x9e\x23\x4b\xc1\x62\xfd\x6f\xd7\xc4\x6b\x73\x7c\x7a\x51\xfc\x71\x8b\x62\x09\xed\xc0\xc5\x3c\x38\xd2\xb9\xae\x9c\xc7\xff\x20\xc0\x64\x35\x2a\x2a\x4b\xc3\xa0\xe8\x05\x0a\x84\xf7\x41\x53\x6a\x5a\x12\x7b\x3a\x21\x16\x1d\xb9\xab\xc5\x46\xee\xef\xe9\x81\xfb\x9b\x06\xee\x1d\x01\xb7\x44\x8f\xfd\xc7\xec\x6a\xa1\xf7\x27\x9c\x1e\xfe\xfe\x84\xb7\xa1\x52\xfa\x30\xf4\xe8\x94\x4e\x10\x41\x34\xd1\x4c\xb1\x93\xc4\x61\x13\x72\x34\x40\x84\xe3\x30\xd3\x9f\x53\xfa\x50\x52\x05\x7c\x49\x56\xe7\xff\xb2\x3b\xce\x3b\xdb\xe3\x51\xf8\x34\xa2\x4e\xf0\xab\x04\x3f\xf6\xdd\x26\x64\x39\x7e\x27\x8f\x7d\xd7\x81\xcc\xe5\xda\x3a\xb5\x75\x7e\x96\x24\xff\xae\xac\xb3\x8f\x26\xe8\x31\x37\xd3\x54\xd4\xb4\x59\x6a\xb3\x4c\x6f\x96\x35\x6d\x96\x72\x71\xeb\x41\xd6\x94\xf5\xa5\x55\xe5\xb5\xb4\xf5\x20\x83\x8e\x40\x2c\xec\x09\xd2\xf3\xa7\x36\xd4\x0c\x86\x7a\xaa\x0d\xf5\xb5\xa1\x0e\xd4\xad\x0f\x5d\xb5\x93\x28\x27\x93\x0d\x49\x82\x29\x75\xb5\x2b\xaa\x8d\x35\x83\xb1\x7e\xd1\x3b\x5a\x13\x2e\x31\xf6\xf7\xcb\xa9\x6f\xfa\xcb\xa9\xa8\x13\xe0\x57\x50\x3c\x2c\xb1\xd0\x03\x62\xb6\x07\x49\x6e\xa0\xad\x28\x02\xe1\x41\x72\x98\x98\x9d\x85\x5a\x8a\x14\x1f\x28\xd6\x41\x2d\x3a\x3a\xb1\x73\x93\xec\xf9\x6e\xce\x26\xa9\x28\x02\x6d\x93\xda\x26\x75\x68\x22\xab\xc7\xd3\x56\xd7\xbe\x0d\x3a\xb9\x19\x67\x48\x10\xf0\xf9\xd4\xc7\xe4\x4e\x47\x25\x74\xa6\xeb\x93\xbb\x17\xc5\xde\xf8\xf0\xbd\xf0\xee\x45\x0a\xd8\x6b\x63\x1f\x35\x3d\x4a\x39\x62\xab\xe0\x27\x1f\x3a\xe1\xc3\x10\x02\x0f\xe0\xa0\xc4\xac\xb3\x3d\x74\xc2\xcb\x8d\x38\xf2\x91\x23\x2a\x63\x75\x2d\x60\x6a\xde\x18\x82\x02\x0d\x43\x22\x59\x19\xf4\xa9\x03\xfd\x21\x25\xfe\x3c\x23\x21\x81\x85\x8f\xa2\xc3\x72\x8a\x69\xe0\x3e\x7f\xd5\xa2\xb1\xb8\x10\x9e\x43\x7e\x81\x57\x45\x54\xfb\x0a\x3b\x42\x0f\xed\x77\x17\xd1\x7a\xfa\x88\x23\xa1\x3e\xee\x6a\xc5\x38\xaf\x26\x41\xe2\xd1\x47\x90\x01\x0f\xf3\xf8\x58\x59\xf0\x49\xb4\x00\x46\xa5\x7d\xde\x9d\xdb\x43\xeb\x31\xa0\x2c\xbf\x93\x69\x42\x72\x7a\xfc\xef\xd5\xf8\x3f\xd5\x9e\x6d\x8e\x9e\x6d\xed\xb3\x1d\x05\x73\x9a\xf7\x51\x30\xf9\x5d\x83\x9b\xf8\xa6\xd6\xf0\x1e\xdc\xc4\xcd\x9e\x2f\xc2\xad\xe6\x71\x11\xee\x1e\xdd\x69\x5d\xdd\xed\x9d\xd6\x03\x87\x51\xdf\x47\xee\x2d\x26\x2e\x7d\x58\x5c\xf9\xbb\x28\x7b\x50\x65\x2b\x9f\xd5\xe6\x7d\xd5\x75\x92\x66\xf1\xbe\x0f\x4c\x39\x37\xa4\x3a\x50\x28\x97\xbb\xb8\xef\xd3\x34\xe2\x1e\x74\xe9\xc3\x50\xa8\x83\x13\x30\xc9\x7a\x75\xb7\xcd\x10\xfa\x07\xa3\x87\x97\x4b\x18\x59\x76\x2f\xcb\xde\xe7\xde\xe7\xa4\x4d\xbd\xb4\xb7\x71\xdf\xa7\x6d\x18\xde\x86\x3d\x74\xa8\x3f\x9b\x92\x2d\xb0\xbe\x02\x1d\x44\xae\xe3\x86\x13\x86\xdd\xa1\x8f\x89\x5c\xcd\x8d\xe8\xe6\x6f\xec\xd6\x9c\x04\x1a\xc6\xcb\xf0\x9a\x50\x45\xb4\x6a\x07\x4f\x6d\x22\xf4\xfb\xfc\xf0\x38\xe3\x24\xb2\xdf\x60\x5b\xdb\x2d\xd8\xaa\x20\xf8\x6e\xc1\x34\x91\xa8\xe2\x01\x5c\xdc\xab\xff\x05\x14\x33\x3e\x82\x8b\xab\xff\x9f\x7f\x16\xf4\xce\xf8\xf8\x9f\x9a\x67\x70\x35\xd6\x34\x55\x9b\x0d\x8d\x7a\xf5\x24\x45\x5b\x24\x2d\x22\x59\xcb\xd4\x38\x49\x19\x46\x44\xc0\xd0\x38\xee\x11\x13\xd8\x81\x7e\x22\xbc\x0c\xa0\x83\xc9\x64\xa3\x94\xb2\xaf\x46\xe3\x2f\xb5\x53\x3a\x58\xf1\x57\x96\xf1\xed\x65\x7d\xc0\x00\x8b\x18\x36\xb3\x29\x44\x80\x45\xa2\xc9\xf0\x23\xac\x2f\xb9\xf3\x9f\xa3\x15\xc6\xfd\x6e\x3e\xe7\x91\x59\xfd\xd0\x91\xb9\x47\xd3\xf0\x69\xda\x69\xf8\x35\x8f\x2f\x1e\xbe\x7c\xb0\x6a\x8a\x2f\x9d\x1f\x1b\x4f\x51\xf8\x5b\x6d\xc1\x5c\x58\x62\xd2\xa1\xff\x1a\x04\xce\x02\x1f\x3a\xc8\x53\x99\xc9\xe3\x95\xbe\xad\xd4\x5e\x85\x0a\xfa\x18\x76\x6e\x44\x1f\x6b\x2f\xb0\x21\xb1\x25\xa7\xb1\xe0\xc4\x8b\x86\x34\x7b\xba\x52\x4f\x3c\x71\x96\x5d\xe6\x14\x4e\xd0\xb3\x76\xd5\x4f\x9b\x06\x2f\xf5\x5b\x88\xe5\x58\xbc\x03\x41\x72\x71\x38\xb9\xa0\xce\x9d\x51\x9f\x88\xbb\xca\x14\x73\x8e\xc9\xa4\x82\xa5\x58\xd6\x19\xde\xde\x40\xc7\xc9\x8e\xc3\x25\x28\x80\x4c\xed\x9f\x0a\x23\x25\xcb\x9f\xa7\x1f\x37\x8e\x8a\xaf\x1c\xe8\xba\x6a\x0d\xf8\xa5\x70\xd1\xaf\x26\xf4\x11\x71\x97\x2e\x8b\x04\x87\x65\xc9\x7b\x80\x43\x92\x66\x73\x24\x3d\xa9\xda\x49\xf5\x67\x6c\xe7\x8e\x12\xb1\x69\xd1\xb1\xb2\x3f\x10\xce\x8d\x7a\xed\xe7\xde\x23\x40\xed\x63\x10\xa0\x5a\x54\xc7\xfe\x4b\xc2\x46\xcb\x79\xfa\xcb\xde\x8f\x84\xd3\x77\x88\xe6\x3c\x6f\x69\x2c\x92\xfe\xc3\xf8\x64\xfc\x83\x96\xe2\xfa\xac\x6f\x0f\x6e\xab\x15\x35\xb8\xb3\xde\x3b\xbe\xa2\x33\xa6\x63\x11\x5b\x8e\x92\x94\x33\xe1\xf3\x41\x92\x52\x64\x51\xf3\xe1\xc7\xa4\x01\x0e\xca\x29\xcf\x4b\x45\x5d\x4c\x66\x82\x1f\xac\x92\x6a\x07\xa1\xa4\x01\x72\x28\x71\x0f\x57\x4b\xa7\x3a\xbe\x15\x6f\x61\xf2\xe5\x63\x96\xa8\x35\xed\xa4\xee\xc4\x49\xfd\xfa\x9e\xeb\xcc\x6f\x9f\x61\x9d\xf9\x9a\xe5\x1f\x45\x5d\x65\x26\x65\x1f\x24\xbc\x84\xeb\xed\x54\xf2\x62\x87\xf5\xba\x49\x04\x24\x3c\x6a\x8d\x23\x91\x74\x6b\x5a\x5e\x97\x7c\xa5\xbb\x69\x2b\xcd\x9e\xd1\x0c\x5f\x0e\x14\x71\x3f\xe0\xc9\xc7\x5e\x0d\x17\x3d\x2a\x7b\x77\xf9\x0c\xc9\xde\x9d\x1e\x8f\xef\x3f\x1e\xab\x85\x1a\x8f\x9f\xd4\xc5\x5b\xb9\xd0\xa4\xa8\xf3\x5e\xcc\xf1\x7a\x50\xc1\x94\x3d\x72\x2f\xbe\x15\x22\x7d\xae\x8e\x4b\x29\x5c\xfa\xbc\xaa\xd3\xe7\x39\xa5\xcf\x5f\xea\x57\xa7\xcf\x75\xfa\x3c\x4b\x64\xe2\x8b\x8e\x4c\x1c\x56\xfa\xfc\x3d\xc0\x41\xa7\xcf\x0f\x28\x7d\xfe\x55\xa7\xcf\x3f\x77\xfa\xfc\x53\xe6\xcf\x7f\xe8\xfc\xf9\x27\xc9\x9f\x47\x4d\x88\x3a\x7f\x5e\xb0\xfc\xf9\xc1\x2a\xe9\xa0\xf2\xe7\x07\xab\x25\x9d\x3f\x2f\x76\xfe\xfc\x9b\xf6\x52\xf7\x3f\x7f\x5e\xad\x7d\xbe\x04\x7a\xf5\xab\xce\xa0\xaf\x64\xd0\xd7\x4d\x23\x3a\x83\xae\x33\xe8\x1f\x94\x41\xcf\x67\x48\xea\x0c\xba\xce\xa0\xeb\x0c\xba\xb2\x8f\x9f\x3a\x83\xae\x33\xe8\x05\xcb\xa0\x9f\x1d\xab\xe3\x7c\xc6\xd0\x41\xf5\xd2\x7f\x02\x00\x00\xff\xff\x95\xe2\xa4\xa5\x0e\xd1\x00\x00")) - open18 = HexToBytes("open18", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\xd1\x07\x2e\xf8\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x12\x00\x00\x00\x12\x10\x06\x00\x00\x00\x06\x5e\x52\x14\x00\x00\x00\x04\x67\x41\x4d\x41\x00\x00\xb1\x8f\x0b\xfc\x61\x05\x00\x00\x00\x20\x63\x48\x52\x4d\x00\x00\x7a\x26\x00\x00\x80\x84\x00\x00\xfa\x00\x00\x00\x80\xe8\x00\x00\x75\x30\x00\x00\xea\x60\x00\x00\x3a\x98\x00\x00\x17\x70\x9c\xba\x51\x3c\x00\x00\x00\x06\x62\x4b\x47\x44\xff\xff\xff\xff\xff\xff\x09\x58\xf7\xdc\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0e\xc3\x00\x00\x0e\xc3\x01\xc7\x6f\xa8\x64\x00\x00\x00\x07\x74\x49\x4d\x45\x07\xe2\x09\x17\x01\x0f\x22\x04\xbc\x2a\x62\x00\x00\x06\xc0\x49\x44\x41\x54\x48\xc7\xcd\xd6\x7b\x54\x13\x57\x1e\x07\xf0\xf1\x1c\xb7\x4b\xad\xae\x7b\x6c\x75\x85\xf5\x59\xd1\x4c\x90\xd4\x35\x8d\xa0\x11\xc5\xca\xd6\xd6\x5d\xc1\xa2\x30\x56\x13\x68\x79\x18\x2a\x8f\x19\x92\xd0\x24\x13\x5e\xe1\x61\x42\x10\x12\x44\x91\x82\x4f\x84\x24\x16\xad\x84\x80\x18\xe4\xb1\x3e\x20\x80\x5a\x2d\x1c\x50\x69\xc1\x88\x2c\xa7\xa8\x25\xa4\xde\x44\x0b\xcb\xea\xfe\xc0\xf6\xd4\x3f\xba\x9e\xb3\x6b\xff\xe8\xfd\xe7\x73\xee\x6f\x66\xee\xfd\x9e\x99\x3b\x73\x07\xdb\xfe\xa6\x87\x83\x9a\x89\x61\xfc\x22\xd6\x0d\x4a\x0d\x5e\x60\x3d\xa6\x34\x60\xfb\x5b\x93\xa9\xbd\x18\xc6\x53\x79\x3e\xa4\x22\x31\x6c\xdb\x74\xa6\x37\xf9\x25\xd4\x83\x59\x97\x28\x1d\x86\x05\x9f\x66\x3c\x24\x77\x63\xbf\x7e\xfb\x50\xe3\x41\x93\x4f\x60\xe2\x34\xcf\x21\x6a\xe7\xab\x51\x3c\x03\x6b\x1a\x15\xe3\x62\xe7\xd5\xb2\xe6\x50\xe4\xab\xeb\x76\xf8\x2e\xed\xa7\xb8\x93\xe9\x40\x5f\xf7\x28\xf2\x8f\x10\xa8\x98\xf5\x35\x05\x41\x36\x15\x2c\x10\xc4\x45\x40\xb0\x0e\xdc\x87\x34\x81\xed\xf8\x4a\xd2\xf8\x42\xbd\xc9\x2f\xc0\x4b\xf8\x62\x52\x8c\x61\x44\x00\x9e\x49\x0d\x41\x3f\x8c\xd1\x1f\x97\xf2\x5c\x20\x09\xd7\x6f\x9a\xa8\xfe\x8e\x5b\x81\x37\xdf\x2c\x39\x6c\x77\x16\x08\xf8\x56\x49\xa9\x5d\x5c\xa0\xe2\x8f\x4a\x0c\xf6\xdc\x7d\x2c\xde\xef\x25\xbc\xef\xdf\x90\xf8\xf8\xbd\x26\xaa\x2b\x6f\x0c\xfc\x9d\xfb\x1a\x72\x1a\x86\xd9\xce\xeb\x47\xd2\xbe\xc1\xb0\xa7\xd0\x0e\xdf\x7f\x66\x89\xf9\xc5\xea\xab\x31\xac\x84\x27\x68\x93\xf9\x63\xd8\xd6\xa6\x25\x59\x64\x2c\x04\x63\xe1\x2a\xd2\xfc\x5c\xa0\x8c\xb9\xfe\x75\x09\x3b\x1c\x49\x15\xcd\xa2\x1a\x7a\x18\x29\x2b\x8e\x8a\x0a\xe9\xfb\x28\xb7\xe2\xd8\x84\x39\xc6\xd7\x44\x76\xfa\x07\xa4\x2f\x0b\xdc\xc5\x95\x29\x1e\xe3\x49\xfb\xdf\xdf\x2a\x56\x35\xce\x8e\x19\xe2\x2a\x85\xe2\xd8\xae\x58\x11\xd7\x29\xcc\xdc\x55\x1a\x2b\xe5\x8e\x08\x77\xef\xea\xff\xaf\x1e\x5f\x3d\x57\x98\x1d\xa3\x8b\x3c\xcb\xd1\xc4\x2b\x37\x4e\x0a\x0a\x65\xb8\x8c\x07\x0a\xfe\x01\xe7\x93\xa5\xcf\x05\x4a\x57\xf9\xaf\x4d\x78\x0f\x11\xa7\x23\x84\x7b\xe9\x4b\xa0\x8f\x30\x9e\x6e\x04\x8b\x84\x8d\x74\x1b\x22\x2a\xe2\x45\x1f\xd2\x17\xc0\x31\x51\x3d\x5d\x87\x36\x9d\xa2\xa8\xab\xf4\xdf\x1f\x6d\xd0\x6f\x8d\x6e\x94\x65\x8d\xa4\xe9\x67\x46\x67\xcb\x14\x23\x29\x7a\xd7\x68\xcd\x2f\xea\xf6\x4c\xc3\xda\x18\x85\x4c\x37\x9a\x97\x15\x1e\x68\x4f\xb0\x0c\x4e\xde\xd2\xbd\x78\x46\x9c\x1f\x86\x85\xb5\x7b\x55\x48\x9c\x18\x16\x8a\xb3\xa3\x12\x8a\x7e\x29\xd0\x41\xe1\x79\xfa\x32\x22\x4e\xec\x88\x55\xc8\x86\x11\xb1\x6f\x24\x64\x81\xac\x13\x11\xf9\x6f\xf0\x1b\xe4\x02\x30\x9c\xff\x50\x1e\x02\x56\x87\x78\xc9\x3f\x01\x6b\x43\xb8\x13\x9a\x43\x56\xbd\xc8\x7d\x05\x21\xc3\xf2\x74\xd4\x93\x92\xb9\x49\x2b\x1d\xbb\xdf\x16\xf6\xb9\x57\x87\xb4\xf3\x03\xb6\xc0\xcd\x87\x9d\x38\xc3\x75\x75\x48\x1f\x7b\x6e\x82\xf9\xf9\x40\xe1\xc2\xbc\x89\x40\x83\xc2\xab\x74\x1e\x22\xf2\xa4\xbc\x76\xf9\x34\x44\x54\x45\x16\x45\x9d\xec\x40\xc4\xd5\xd3\xe6\xd4\x06\x35\x22\xae\x08\x6a\x06\xeb\x8f\xfc\x1f\xee\xfc\x51\x69\x8d\xb3\xfe\x28\x0a\xbd\x52\x7a\x76\x5e\x7d\x39\xb2\x35\x77\x19\x67\x9b\xbf\x7d\x14\xaf\x10\xf3\x46\xf7\x2c\xab\x76\xfd\x39\x50\x92\x50\x47\x5b\x10\x71\x72\x01\xc9\x96\xc1\xc4\xda\x96\x08\x56\xc6\x5f\x11\x71\x77\x5e\x7b\xea\x85\xf9\x88\x18\xd6\xf4\xfd\xa9\x75\x2b\x22\x6c\x5d\x77\xb8\x2d\xdf\xbe\x84\x37\xef\xac\x06\xb7\x0d\xf7\xf5\xc9\x5b\x15\x28\xac\xe7\xa3\xcb\x2e\x0d\xec\x47\x44\x22\x23\x78\x71\xe6\xb1\xcc\x39\x3f\x07\x72\x8a\xa6\xd0\x5d\x88\x38\x6e\x8d\x72\x95\x2e\x47\xc4\xa1\x01\x59\xd9\xde\x1a\x44\x3c\xe0\xf6\xb8\x36\xc3\x2d\xff\x2e\xa5\x37\xa0\xf9\x3c\x18\xd3\xeb\xdd\x7c\xe6\xe5\xb5\x15\x58\xdb\x2d\x4e\x94\xd1\xd4\xfd\xc5\xe7\xa7\xbb\x86\x9b\x23\xf4\x2b\x7b\x24\x06\xcf\x4d\x58\xba\xf2\x59\xa0\x8a\x62\x51\x2e\xdd\x8f\x88\xc2\xe6\xd0\x16\x49\x2f\x3c\xaa\x4f\x0b\xa9\x52\x0e\x5c\x78\xc2\xfa\xef\x96\x85\x30\x50\x5c\x2f\xb7\xb9\x01\x24\x7b\x57\xbf\x94\x3f\x8e\x33\xf4\xf5\x6d\xbb\x25\xcf\x61\x3b\xd9\xa4\xcd\x38\xc6\xbf\x69\x0b\x08\x9a\xef\x1d\xbd\x6d\x7c\x0d\xfd\x14\xe8\x0f\xc2\xfe\xf1\xb5\xa3\xed\xe6\x3d\x96\xc7\x20\xe2\x5a\x68\x6d\x68\xb5\x09\x11\x76\xe9\xdd\x59\xad\xb3\x20\x58\xbe\xf5\x9a\x65\xec\x7f\xf0\x33\xeb\x0d\xcb\x53\xd0\xdd\xea\x6f\x69\x82\x00\x07\x6e\x1b\x2c\xc9\xd0\x2f\xb5\xfe\xb3\xc5\x05\x11\x83\xc9\xb7\xb2\x2e\xe5\x3d\xae\xcb\x9f\x17\x6f\xda\x9b\x73\xe2\xd6\xb2\x0d\xf0\x91\xe6\x8d\x07\x2a\xf1\x0f\x4a\xf8\x1b\x22\x4e\x4d\xa2\x96\xc8\x6c\x88\xd8\x5d\x4f\xdc\x49\x66\x20\xa2\x61\x72\x59\x4b\xb9\x03\x11\x6d\x1e\xa6\xce\xca\x00\x44\xb4\xc6\x57\x3e\x32\x0e\x82\xe2\xca\x51\xe3\x3d\x50\x65\x9a\x6e\x84\xb7\xb0\x95\x36\x4d\x32\x3e\x00\xe3\x2a\x91\x11\xd6\x48\xab\xc2\xe4\x62\x1c\x02\x67\x55\xee\x31\x9e\x45\xc4\xf5\xd1\x73\x5f\x55\x83\xdd\x85\x96\x59\xb5\xd9\xb0\xa8\xcf\x9d\xe9\x32\x15\xa3\xe0\x8e\x92\x86\x43\x67\xb8\x23\xae\xf2\xd6\x20\x65\x86\x69\x67\xd6\xd3\x89\x36\xfe\x61\x5c\xea\xdf\x92\xc0\x47\x3b\xca\xf2\x77\xbd\x2e\xf3\x83\x40\x55\xdb\xc3\x13\xe1\x6d\xd0\xcf\x49\x53\xab\xaf\x83\x1f\xa5\x15\xa9\x2f\x22\xc2\x50\x93\x31\x23\xfb\x2d\x50\x9c\xde\x96\xed\x0a\x75\xaf\xb4\x18\x35\xac\x05\xc3\xec\xf4\x48\x35\xdc\x11\x43\x5f\xc6\xfa\x6c\x1f\xa8\xeb\xd2\x06\xd4\x37\x11\xa1\xbb\xa1\x18\x53\x2b\x11\x61\x7a\x57\x3b\x5f\x73\x14\x11\xff\x58\x71\xf8\xc1\x7e\x78\xf4\xe5\x56\xa5\x71\x4f\x2e\x52\x54\x5e\xd7\x86\xe5\x25\x3d\xbc\x18\x79\x7f\x95\xfc\xd3\xe9\x6e\x9c\x68\xa6\xaf\x44\xba\x79\x3c\x10\x0a\x88\x4a\x10\x3a\x2f\x17\x8d\x7d\xfc\x54\x2a\x74\xac\x3b\x80\xc8\xd1\xf4\x3c\x07\xc7\xbc\x7c\xbf\x3e\xf7\xbc\x83\x53\xc5\xd4\x4e\xc9\xf9\xb3\x83\x53\x7b\xeb\x40\x94\x66\x95\x83\x73\xee\x50\xa1\xaf\x46\x0a\xf5\xfd\xda\xd4\x9c\x35\x0e\x4e\xcd\xda\x7c\x2a\x77\xa6\x83\x53\x67\xfb\xac\x4a\x73\x17\xfa\xc5\xf9\x9d\xb9\x6c\x38\x1e\xa7\x0d\xca\x01\x6b\xef\x1d\x10\x6b\x3c\x41\x46\x41\x41\xee\x2d\xc7\xdb\x55\x11\xda\xf7\x72\x70\xe7\x37\x25\x82\xc4\x48\xe5\x86\x9e\x07\x9b\x0f\x2e\xdc\x18\x4b\xc3\x16\x62\x62\xba\x91\xf5\x10\x48\xb8\x7c\xed\x97\xa2\x29\xe6\x4e\xe9\xe6\x77\xa7\x88\x8f\x0f\xd0\xf9\x6e\xd1\x75\x69\xed\x03\x2c\x5d\x95\xe2\x1d\x95\x73\x60\x51\x69\x4a\x72\x87\x6a\xfd\xc0\xa2\xb2\xc2\x54\x17\xd5\xc1\x81\x45\x3a\xf7\xd4\x52\x55\x2b\xd4\xaf\xa4\x30\x54\x3c\xb0\x3f\x65\xbd\x2a\x1c\xea\xcb\x52\x2b\x54\x57\xe0\xbc\xc4\x94\x41\x55\x3e\xd4\xd3\x92\xbb\x54\x7e\xd0\x3f\x93\x8a\xab\x74\x70\x9c\x9d\x6a\x52\x5d\x1d\x60\x97\xb0\x13\x37\x2a\xb3\x06\xa7\x26\x15\x6c\xb1\xcb\x6d\x7b\x62\xd7\xb8\x4d\x7d\x22\xb8\x0c\x5b\x08\xc9\xb8\x4e\x8e\x6f\xb2\x81\x83\xee\xff\x22\x97\xc0\x66\x77\x6e\x49\x09\x99\x09\xbf\x19\x8b\x99\x35\xd4\x42\x48\x1c\x88\x37\x91\xdd\xe0\x11\x48\xfe\x3d\xb8\x1d\xbf\x46\xc2\x66\x4a\xac\xc4\xcb\xc9\x76\x30\x87\xf9\x0a\xf9\x1d\xb8\x1b\x7f\x42\xde\x03\x57\xe0\x7a\xf2\x2b\x30\x1c\xbf\x49\xde\x06\x0f\x33\x5d\x27\xae\xdb\x82\x5b\x26\xc6\x79\x1f\xaf\x23\x6f\xc0\xc4\x2d\xb8\x27\x79\x12\xc3\x36\x1b\x16\x0a\x62\x4f\x61\xd8\x07\xbe\x6f\xba\xc7\x4d\x85\xba\x13\xcf\xa2\x18\x10\x88\x98\x8a\xc7\x90\x15\xa0\x17\x5e\x44\x36\x41\xa0\x20\x66\x3f\xb5\x14\x3c\xea\xb1\x82\x5a\x0f\x16\x7b\xfc\x85\x7a\xe7\x57\xf0\x88\x07\x67\x62\xbc\x30\xa6\x9d\x62\xc1\x7c\xeb\xf0\x53\x13\xf3\x5d\xf4\xc8\xa0\xb2\x21\x50\x03\xc3\x49\x86\x61\xbf\xbd\xf6\x1f\xa5\x4f\xba\x9c\xbe\xda\xb0\xc2\x00\x00\x00\x25\x74\x45\x58\x74\x64\x61\x74\x65\x3a\x63\x72\x65\x61\x74\x65\x00\x32\x30\x31\x38\x2d\x31\x30\x2d\x31\x30\x54\x30\x35\x3a\x34\x38\x3a\x30\x35\x2b\x30\x32\x3a\x30\x30\x67\xeb\xee\x83\x00\x00\x00\x25\x74\x45\x58\x74\x64\x61\x74\x65\x3a\x6d\x6f\x64\x69\x66\x79\x00\x32\x30\x31\x38\x2d\x30\x39\x2d\x32\x32\x54\x32\x33\x3a\x31\x35\x3a\x33\x34\x2b\x30\x32\x3a\x30\x30\x94\x72\xbe\x96\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\x28\x3f\x92\x2f\xd1\x07\x00\x00")) - play20 = HexToBytes("play20", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x29\x03\xd6\xfc\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x13\x00\x00\x00\x14\x08\x06\x00\x00\x00\x6f\x55\x06\x74\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0b\x12\x00\x00\x0b\x12\x01\xd2\xdd\x7e\xfc\x00\x00\x02\xdb\x49\x44\x41\x54\x38\x8d\x9d\x92\x4f\x88\x55\x55\x1c\xc7\x3f\xf7\x77\xce\xbd\xf7\xfd\xb9\xef\xdf\xf8\xee\x93\xb1\x37\xea\x4c\xe0\xab\x19\x9a\x60\x48\x14\x47\x1b\x8a\x68\x21\x08\xe2\x2a\x50\x5c\x46\x9b\x16\x45\x52\xc4\x44\x50\x12\x19\x91\xd4\xaa\x45\x90\x8b\xa4\x96\x2d\xad\x26\x89\x2c\xcd\x95\x39\x21\xf2\x04\x75\xc2\x07\x4f\xbb\x39\x93\xe9\x3c\xdf\xbb\x73\xff\xb4\xb8\xf7\xd1\xe4\x28\xce\xf4\x83\x1f\x9c\xc5\x39\x9f\xf3\xf9\xfe\xce\x81\x7e\x7d\x34\xf6\x24\x87\xc7\x47\x01\xe1\x7f\x96\x02\xe0\x83\xf1\xd1\xc9\x29\xe7\xdc\xc6\x47\xcd\x97\x8a\xcf\xd5\x1c\xaf\xdb\x3e\xcb\x25\x7a\x6b\x85\x09\xc0\x48\xf1\xce\x06\x51\x4a\x0b\xca\x74\x87\xb2\x87\xb6\xbf\xb8\xfd\x74\xe3\xed\xc6\xce\xb5\x5a\x26\x9b\x43\x50\x77\x05\xd5\x01\xe9\x40\xce\x32\xc7\x1e\x79\xaa\x76\x72\xe2\xd3\x89\x23\x40\x71\x6d\x30\x1f\xa4\x9b\x34\x5d\x41\x7c\xd0\x01\x66\xd5\x2d\xbe\xb6\xeb\xd8\xe4\x2f\x8d\xd7\x1b\x53\xab\xb1\x4c\x36\x74\x41\x7a\x20\x3d\x41\xf7\xd2\xb5\xaf\x10\x5f\x53\xb0\xf2\x8f\x0f\x3f\x31\x3c\xb3\xf5\xe8\xe4\x87\xec\xa6\xb4\xaa\x98\xe2\xab\x04\xb2\xa4\x90\xc0\x46\x82\x0c\x3a\xcc\xa0\xc3\x1c\x99\xd0\xd1\x43\x03\xf5\x57\x9e\xdf\xb3\xf7\xec\xc8\xab\x13\xcf\x3c\xc8\x52\x01\x54\x76\x54\x46\xaa\xd5\xca\x41\x23\x30\x91\xd0\x42\xc5\x16\x2a\xb2\x50\xa1\x85\x8a\x4c\x54\x64\x23\xb1\x26\x63\xd9\xd5\xc1\x0d\xe5\xfd\xb5\xa9\xf5\xd5\xb9\xe8\xea\x19\x2e\xd3\x5d\x09\x7b\xba\x32\xe2\x56\x6b\x07\x93\xc3\xfd\xb6\x51\xb1\x85\x81\xc6\x10\x03\x31\x63\x94\x8e\xd0\x5a\xa4\x54\x76\xb6\x6d\x1e\x1d\xde\xb7\xd4\xc8\x5f\x5c\xf8\xa9\xfd\x3b\x10\xff\x1b\x73\x09\x74\x94\xc4\x92\x28\x8b\x44\x19\x24\xd6\x18\x02\xca\x8a\xd1\x56\x88\xe8\x08\x43\x83\x28\x30\x0c\xa1\x52\x28\x6d\xd9\xb1\xf3\xb1\x13\xe3\xef\x8e\xef\x05\x0c\x00\xdd\x9f\x99\x0e\xb3\x10\x2a\xc4\x30\x30\x24\x26\x34\x7c\x3a\xbd\xdb\x2c\xde\xb9\x4d\x77\x69\x91\x4e\xd8\x23\x20\x40\x9b\x9a\x82\x93\xc3\x29\xe6\x29\x3b\x03\x5a\xa3\x07\xfb\x31\x13\x18\x65\x04\x85\xa1\x61\xd1\xbf\xc5\xf5\xf9\x36\xd7\x3a\x73\x80\x87\x67\xa4\xf7\x5a\xe0\x66\x80\x1c\xfc\x91\x03\x3b\xac\xcf\xf3\x23\x47\x5a\xef\xb4\x8e\xf7\x63\xa6\xb0\xbf\xf0\xe3\x0e\x73\x37\xe6\x68\xdf\xbd\x06\x46\x0a\x91\x14\x92\x4d\x20\x64\x81\x9c\x0b\x9e\xfd\x7d\xeb\xab\xd6\x9b\xcc\x70\x2e\x19\xd2\x32\xb3\x2b\x0a\xfc\xf6\x29\x7a\xbe\x87\x27\xe9\xb3\xd8\xcb\x20\x69\xdb\x51\xfd\x26\xe7\x79\xbf\xf5\x56\xeb\x73\x60\xbe\x6f\x74\x4f\x4c\xe8\x89\x87\x67\x82\x6b\xf7\x0d\xd2\xce\xc3\x40\xae\x1e\x73\x3d\xff\x5d\xf3\xb3\xe6\x34\x33\xfc\xba\xdc\x66\x25\xcc\x4c\x0e\xb9\xfa\xbf\x90\x5a\xa9\x4e\x2e\x28\xdd\xfc\xfb\xe7\xe0\xbd\xe6\x1b\xcd\x63\xc0\xc2\xbd\x36\x2b\x61\x79\x60\x5d\x32\x1f\xdb\x71\xa9\x95\x0b\xd4\xf2\xe5\xb8\x7b\x35\xf8\xe6\x87\x4f\x66\xa7\xf9\x96\xd9\x07\xd9\xdc\x17\x56\x58\xef\xb2\xae\x58\x60\x53\xa5\x86\xd9\x31\xbd\xd6\xc9\x5b\x87\x4f\xbd\x3c\xfb\xc5\xc3\x6c\x56\xc0\xc6\x82\xec\xc2\xe8\xd0\x60\x3c\xe8\x94\xf8\xb3\xe9\x9f\x38\x7f\xb4\x3d\x7d\xe1\xeb\x0b\xbf\xad\xc6\xe6\x7e\xa5\x76\x7f\xb9\xeb\x85\x67\x3f\xde\x7a\x00\xa8\x90\xfe\xe8\xb5\xd6\x3f\xcc\x8f\xe7\x7e\xbf\xe4\x8a\x88\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\x38\x58\xe3\x9b\x29\x03\x00\x00")) - reset18x18 = HexToBytes("reset18x18", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x7a\x03\x85\xfc\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x12\x00\x00\x00\x12\x08\x06\x00\x00\x00\x56\xce\x8e\x57\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0b\x12\x00\x00\x0b\x12\x01\xd2\xdd\x7e\xfc\x00\x00\x03\x2c\x49\x44\x41\x54\x38\x8d\x55\x94\x4f\x68\x1c\x55\x1c\xc7\x3f\xf3\x76\x93\x9f\xdb\x79\x6e\x61\xb4\x8c\x7b\x70\xbd\x48\xeb\x25\xa5\x41\x41\x29\x2b\x54\x50\x57\x94\x48\x83\x22\xf6\x10\xa4\xb5\x08\xa5\x16\x0b\x22\x1e\x2c\xea\x45\x7a\xf3\x90\x16\x4a\x10\x24\x28\x6a\x40\x8b\x82\xb6\x92\xa0\x11\x11\xa1\xa2\x31\xd5\xb6\x81\x5a\x0f\x3a\x05\x97\xf1\x30\x96\xed\x9b\xb8\x6f\xff\xbc\xf1\x30\x2f\x36\xfd\xc1\x1c\x66\xe6\xcb\x6f\xbe\xbf\xcf\xef\x7d\x27\x98\x9e\x9b\xad\x00\x01\xa0\x80\x01\xa0\x5c\xd7\xee\x23\x4f\x5f\xc4\x30\x01\xd4\x80\x02\x58\x47\xeb\x5f\x08\xc3\x59\x55\x97\x8f\x29\x6b\x0c\x18\x01\x54\xfd\x83\x0a\x60\x9d\xb5\x93\x24\xe9\x02\xb0\x8d\x58\x7f\x48\x14\x1e\x07\xb9\x5a\x4a\xec\x5d\xd8\xbc\x4d\x9a\xbe\xe3\x72\x7d\x8c\x28\x7a\x56\x09\x6b\x80\x00\xc3\xaa\xff\xa2\x71\xd6\x3e\x45\x92\x7e\x42\xac\x4f\xaa\x7a\xf4\x0a\xd0\xf3\x4e\x8b\xb2\x91\xac\x22\xf2\x29\xf5\xe8\x65\xd7\xc9\x66\x49\x92\x4b\xae\x19\xb7\x95\xc8\x12\x20\x55\x67\xed\x0e\xb2\xfc\x0d\x30\xf7\xd3\x6c\xee\x57\xc2\x3c\x30\xbe\x69\xa4\xbe\x77\x3d\xee\x1b\x0f\x54\x23\x7a\xde\x75\xc3\xf3\x24\xe9\x59\xd7\x6c\x4e\x2a\xe1\x82\x02\xea\xac\x9a\x29\xd0\xd7\x95\xf0\x99\x1f\xb7\x00\x9c\x83\x9e\xb3\x76\xaf\xb3\x76\xaf\x2b\x1d\x8e\x00\x07\x6c\x51\x75\x39\x81\xd6\x73\x64\xd9\xfc\x06\xa3\xeb\xb4\xe2\x37\x11\x56\xbc\x8b\x6b\x01\x6c\x1b\x75\xb2\xf7\x5f\x07\xb9\x64\xcc\x4e\x05\xc5\x76\xad\x5f\x7a\x0b\x4c\xa5\x11\xcd\x14\x70\x0d\xa8\xaa\x46\xf4\xaa\xbb\x92\x5c\x76\xdd\x70\xa6\xaa\x44\x7e\x46\xf8\x69\x13\x74\x46\x9d\xec\xbd\x3d\xc6\xb4\xef\x06\x77\xd5\x33\xda\x61\x4c\xeb\x41\x50\xdf\x75\x98\x57\x8d\xe8\x49\x0f\xd9\x10\xeb\xd3\xe4\xf9\x0b\xca\xbb\xaa\x01\x5b\x80\x91\xb3\xb6\xbd\xd5\x98\xc7\x0e\xc0\x10\x28\x7a\xa0\x7a\xe5\xd1\x28\x0e\xc2\x50\x1b\x33\xe5\xac\x7d\x08\xf8\xb7\xdc\x41\xf8\x15\xc6\xdc\xa7\x3c\xcc\x01\xe0\x02\x00\xcb\x03\x8f\xf3\x7f\x6d\x9c\xb1\x00\xa8\x04\x40\xdb\x6b\x02\xff\x5e\x89\xac\x10\xc7\xaf\x55\x9d\x65\x42\x09\x7f\xfa\x75\x03\x39\x9b\x6b\x92\x9b\xab\xb8\xf9\x76\x0c\x48\x55\x5d\xde\x56\x24\xc9\x0f\xce\xda\xdd\x40\xbf\x28\xad\x9e\x3b\xb3\x49\x79\x87\xbf\x36\x6a\x09\x40\x38\x57\xdc\x70\x5c\x01\x44\xa1\x59\xc3\xe6\x0f\x7b\x5d\x4d\x89\x2c\x76\xb5\x5e\xfc\xa0\x64\x37\xa0\x64\x35\x04\x06\xef\x42\xd5\x68\xfd\xb9\x12\xf9\xc6\xb3\xcd\x3d\x1a\x57\xb9\xe7\x89\x69\x47\xfa\xcf\xe1\xe0\xb6\xad\xa7\xf0\xb9\x09\x6e\xad\x7d\xf9\x7b\x7f\xb4\xeb\xeb\x7e\x7f\x7b\x1f\x82\x35\x50\x27\xa0\xf2\x9b\xd6\x67\x55\x23\x7a\xce\x83\xbe\xdd\x75\xed\xa1\x22\xeb\x1e\x2f\x0a\x35\x0c\xa6\xe7\x66\x71\x9d\xe4\x57\x42\xbd\xac\xea\xd1\x51\x20\x04\x2c\xe0\x9c\xb5\x7b\xb0\xec\x06\x0a\x84\xef\x95\xc8\xb7\xde\x49\x05\xe8\xb9\x4e\xb6\xc4\xea\xea\x23\xb4\x5a\x07\xca\xd0\x46\xf1\x7e\x92\xf4\x47\x47\x78\x59\xd5\xe5\x14\x65\x1c\xc6\x94\xc8\x72\x20\x2c\x6f\x82\x5c\xf3\xae\x7b\xae\x6b\x0f\x62\xcc\xbd\xb4\x5a\xc7\x10\xfe\xa8\x02\xa2\x44\x56\x5c\x33\x9e\x22\x49\xbf\x70\xb9\x9e\x54\x8d\xe8\x28\xb0\x0e\x04\xc5\x8d\x45\x05\x7e\xa4\x5b\x5c\xd7\x9e\x24\x4d\x0f\xd3\x6c\x3e\xad\x84\xd3\xc0\x58\xd5\x83\x14\x25\x72\xc6\x35\x9b\x3b\xc9\xb2\x05\x77\x25\xf9\x8b\x58\x7f\x84\x84\x8b\x20\x49\xd9\xc7\xde\x89\xcd\x1f\x25\x35\xfb\x80\xbf\x29\xc3\x7a\xde\xbb\x1c\x6c\xfc\x8f\x86\xc0\xb8\x12\x2e\xd2\x88\x26\x9c\x0d\x9f\x21\xcb\x8f\x90\xa6\x33\x5e\x18\x00\xeb\x68\x2e\x10\xc7\x47\x54\x5d\x16\x28\xc3\x3b\xee\xb7\xc6\x7f\x26\x1b\x46\x74\x1c\x0a\xcd\x61\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\xd4\xe7\x3c\x51\x7a\x03\x00\x00")) - saveAll18 = HexToBytes("saveAll18", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x7b\x03\x84\xfc\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x12\x00\x00\x00\x12\x08\x06\x00\x00\x00\x56\xce\x8e\x57\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0e\xc3\x00\x00\x0e\xc3\x01\xc7\x6f\xa8\x64\x00\x00\x03\x2d\x49\x44\x41\x54\x38\x8d\x95\x93\xcb\x6f\x5b\x55\x10\xc6\x7f\x67\xce\xbd\xbe\xbe\x76\xfc\x6a\x8c\xf3\x4e\x89\xa2\x94\xd2\x94\x82\x84\x88\x08\x34\x12\x8a\x8a\x78\x4a\x20\x21\x56\xec\x58\xc1\x82\x0d\xe2\x2f\x80\x3f\x81\x2d\x2b\x24\x36\x2c\xca\xaa\xbb\x08\xa9\xcb\x12\x21\x81\x08\x69\x03\x6d\x4d\x93\x26\xc1\x89\x63\x3b\x2f\xc7\xb1\xef\x3d\xc3\x22\x76\xb0\xba\x82\x4f\x3a\x47\xb3\x98\x99\x6f\xbe\x6f\xce\x01\x00\x44\x04\xb1\x67\x31\xe6\x3f\x1e\x44\x44\x7a\xb1\x07\x22\xe0\x5c\xe8\x65\x4a\x37\xae\x7f\x74\x73\xa0\x38\x38\xa8\x71\x14\x61\x8c\x01\x40\x7b\x97\x01\x94\x38\x56\x95\xc8\x25\xff\xb8\xbb\xfc\xed\xcf\xe5\xdb\x5f\x89\x88\x38\xe7\xd4\x03\xe7\x12\x92\xcc\x0d\xf2\xd4\x3b\x93\xd3\x57\x5e\x4d\x8d\x16\x34\x3e\x8d\x8c\xeb\xa7\xf6\x2c\x1a\x3b\xac\xb5\x78\xa9\x90\x54\x31\xef\x26\x9f\x7b\xfe\x4b\xef\x7b\x3f\x77\xa7\xbc\xf4\x85\x88\x18\x0b\xf0\xfe\xe2\xa7\x4b\x1f\x7c\xf2\xf9\x67\xbb\x1b\x5b\x9d\xcc\xd4\xb4\x49\x16\x4b\x3a\x3e\x5a\xd2\x42\xa9\xa8\x51\x3a\xaf\xc3\xf9\x9c\x96\x86\x8b\xba\x77\x7f\x5d\x9b\x95\xba\x36\x8f\x0e\xc9\xce\x8c\x47\xe3\x63\x33\xd7\x5b\x9b\x35\xb7\x55\xff\xeb\xb6\x00\x26\x57\x2a\x16\x26\x5e\xbc\x46\xf1\xe9\x31\x7b\x71\xe1\x15\xb9\xfa\xf6\x82\xcc\xbf\x37\x2f\xd9\x97\xe7\x65\xee\xad\x05\x61\xf3\x8e\xa4\x6c\x5d\x86\x2e\x4d\xc9\xec\x1b\x8b\x92\x68\x23\x7b\xab\x65\x9b\x99\x1a\xe1\xd2\x95\x97\x3e\x04\x10\x40\xe3\x28\xd2\x4e\xab\x45\xa7\x15\xd1\x69\x1e\x33\x11\xc0\xaf\x0f\x8e\x49\xbb\x36\xd4\x8f\xc9\x87\xf7\x68\xee\x95\xd9\xad\xb6\x30\xc4\xcc\xbe\xb9\x88\x34\x3b\x34\xab\x75\x9c\x27\x00\x46\x00\x23\x46\x0c\x18\x8c\x67\x98\x9d\x4c\xb3\x73\x0a\x41\x2a\x64\x7a\x34\x41\xb2\x10\x70\xb4\x5f\xa0\x76\x9a\x27\xb2\x3e\x1a\xc7\x18\xdf\x72\x61\x62\x8c\xf6\xd1\x09\xd6\x8a\x74\xb7\x06\xa8\x03\x03\x5e\x1c\xf1\xf0\xb7\x32\x55\x92\xcc\x5c\xf0\x29\xef\x81\xe7\x7b\xd4\xc6\xde\xa5\x41\x00\x95\x35\x8c\x9d\x40\x63\x87\x46\x31\x22\xa6\xb7\xd6\x6e\x23\x23\xa0\xca\xd0\xb3\x97\x79\xf4\xcb\x9f\x78\x9e\x65\x05\x45\x15\x70\x0e\x1b\x26\xc9\xb5\xf7\xc9\x5e\x9e\x21\x91\x49\x81\x53\x10\x03\xb1\xd2\x83\xf0\x04\x8c\x01\x45\xcf\x78\x0c\x60\x85\xf8\xa4\x85\x01\x6a\x8f\xb7\xf9\xfb\xee\x7d\xac\x6f\xcf\x27\xe9\xa1\x4f\x9a\x65\x6b\xf5\x1e\x2f\xdc\x98\x23\xcc\x66\x88\x3b\xf1\x39\x8d\x00\x0e\x48\x24\x03\x96\x7f\x58\xa2\x79\x30\x86\x11\x8b\xeb\x6b\x24\x3d\x69\xaa\x0e\x3f\xe1\x31\xfa\xcc\x45\x6a\xdb\x3b\x6c\xae\x95\xd9\xbc\x5b\x66\x7f\xa7\x4a\x90\x09\x78\xb0\xbc\x42\x7e\xa4\x40\x6e\xa8\x40\xdc\x8e\x91\x27\xb4\x78\xe7\x92\x00\x55\x68\xb7\x1c\xcd\xc6\x21\x47\xb5\x1a\xd6\xf3\x39\x39\x38\xa4\xfe\x78\x97\x6b\xaf\x2f\x10\x84\x49\x4e\x5b\x1d\x92\xa6\x5b\xe4\x40\xcf\x5c\x50\xaf\xbf\xab\x01\x7c\x2b\x5c\x7d\x6d\x8e\xb8\x1d\xf7\xbe\x17\x00\xc9\x4c\x88\x15\xb0\x46\xce\xdd\x11\xdf\xc3\x58\x6b\x00\xe3\x01\x38\x75\x4e\x5d\x8c\x5a\xdc\xfa\x56\x95\xc6\x66\x05\x3f\xe1\x9f\x65\x77\xab\xda\xad\x53\xb2\x23\x25\x62\xcf\x03\x75\x38\x88\x0f\xd7\x2b\xd2\xac\xd7\xea\xe7\x13\xf9\x7e\x20\x61\x3a\x8b\x92\x90\x8a\xc9\x8b\x9d\x2a\x12\xf5\x3b\xd9\x5d\xc8\x41\x3a\x4d\xe3\x78\x95\xe1\xd4\x80\x86\xe1\x80\x7f\xeb\xbb\xaf\x3f\xae\x52\xb9\xd9\xf3\x48\xd7\x7e\x5f\xfe\xd1\x7c\x23\x03\xb5\xed\xed\x83\x70\xe3\xa1\xd8\x20\x00\xe7\xfe\xd5\xdb\x9b\x4c\x84\xa3\x47\x1b\xba\xb3\xf2\x93\x77\xd8\x68\xec\x55\x5d\xe5\x56\xd3\x1d\xef\xd3\x7d\x9a\xfd\x16\xfd\x1f\xa8\x20\xd6\x81\x82\x73\xff\x00\xe8\x76\x54\x33\x9c\x50\x87\xe8\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\x9a\xd9\xe0\x4f\x7b\x03\x00\x00")) - searchEngine400x27 = HexToBytes("searchEngine400x27", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x00\x40\xff\xbf\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x01\x90\x00\x00\x00\x1b\x08\x06\x00\x00\x00\x52\xbf\xd9\x63\x00\x00\x00\x19\x74\x45\x58\x74\x53\x6f\x66\x74\x77\x61\x72\x65\x00\x41\x64\x6f\x62\x65\x20\x49\x6d\x61\x67\x65\x52\x65\x61\x64\x79\x71\xc9\x65\x3c\x00\x00\x5b\xc1\x49\x44\x41\x54\x78\xda\xec\xbd\x07\x90\x24\xd9\x79\x1e\xf8\x5e\xfa\xcc\xca\xf2\xde\x74\x77\xb5\x37\x33\xdd\xd3\xd3\x63\x77\x66\xd6\x2f\xd6\x63\x61\x8f\x04\x08\x12\xa4\x20\x11\x74\xa2\x78\x77\x71\x54\x30\x2e\x28\x89\x3c\x5d\x5c\xf0\x24\xf2\xe2\x22\x48\xdc\x89\x77\x20\x2f\x02\x24\x04\x90\x20\x41\x2e\xb0\xc0\x62\x17\x58\x3f\x66\xc7\xf6\x4c\x4f\x7b\xdf\x5d\x5d\xde\xdb\xf4\xf9\xee\x65\x56\xf5\xcc\x60\x49\x50\x22\x09\x06\xa5\x10\x6a\x51\x3d\x65\xb2\xd2\xbc\xf7\xff\xff\xf7\x7d\xff\xff\xbf\x04\x44\x08\x81\x74\x2a\x03\x32\xe9\x2c\x20\x49\x12\x7c\xf0\x01\x21\x04\xb2\x26\x03\xd5\x50\x01\xc4\xff\x11\x90\x00\x2c\xc9\x00\x84\xbf\xd3\x0c\x05\xd8\x2f\x80\xf5\x0f\xc2\xdb\xe2\xef\x68\xce\xde\xe6\xc1\x87\x61\x18\x20\x12\x0d\x83\xbe\x81\x04\xf8\xd1\xe3\x87\xff\x40\x26\x02\x85\x74\xd9\xfe\xf7\x47\x8f\x1f\x3d\xfe\xb1\x1f\x56\xcc\x68\x77\xda\x80\xa0\x21\x48\x0e\xf7\xff\x37\x73\xdd\x5b\x2b\x69\xf0\x07\xbf\xfd\x2d\x40\x09\x34\x90\x4c\x03\x08\x0a\x03\x24\x5e\x02\x82\x41\xe3\x41\x41\xa0\xa9\x01\xc0\x50\x10\xb8\x1c\x24\xd0\x1c\x3c\x30\x28\x12\x90\xb5\x36\xa0\x1a\x1d\x10\xa8\x87\x41\x31\x52\x01\xcd\x6c\x13\x98\x26\x05\x10\xc4\xdf\x29\x32\x00\x24\x0d\x18\x07\x03\x60\xd2\x0d\x0c\xc2\xda\x0d\x8e\xb3\x52\x07\x98\x32\x04\x86\x6e\x02\x40\x2b\xc0\x65\xe2\x78\x8c\xb7\x33\x80\x09\x64\x15\xe1\x9f\x40\x10\xcb\xf8\x01\xdb\x61\x81\x41\x77\x40\x2d\x5a\x07\x1a\x27\x01\x49\xa5\x00\xa3\x21\xc0\x10\x24\x50\x64\x1d\xc8\x92\x06\x58\x0e\x7f\xe6\x65\x81\x09\x01\xb0\xc2\x87\x1b\x10\xa0\x42\x48\x80\xd2\xf1\x67\xf8\xb5\x8a\xaf\x83\x46\x24\x60\x74\x02\xef\x4b\x06\x2d\x55\x05\xad\xbc\x04\x5e\xfc\xe4\x19\xf0\xcc\x4f\x3f\x0c\x28\xeb\xc2\xbf\xf2\xa5\xaf\x81\xdf\xfd\xed\xff\x00\x5c\x6e\xe7\x5f\x19\x14\xcd\xd0\xc0\x4c\xec\x28\x18\x0c\x0c\x01\x0a\x52\xa0\xa9\x37\xc1\x7c\xf6\x36\xd0\x35\x28\x0c\xf9\x8f\x1e\xd7\x01\x8c\x5b\x36\xc3\x52\x4c\x51\x53\xea\xb7\x96\x0b\x37\x6b\xb2\x2c\xe1\x81\x62\xac\x8f\xed\x7d\x34\xea\x4d\xf0\x73\xbf\xfc\x39\xf0\x3f\xff\x2f\xbf\xfa\x23\xef\xfa\x07\x78\x68\xaa\x0e\x5e\xfb\xd2\x7b\x40\xe9\x60\x90\x27\xe0\xdf\x05\x82\x80\x49\xe1\x99\x34\x48\x6c\xa0\xf0\xde\xbc\xd9\xec\xc0\x7a\x89\xe0\x8f\x06\xf9\x47\x8f\xff\xec\x07\x85\x03\xe3\xe6\xd2\x2e\x70\x07\x45\xf0\xab\x5f\xf8\xb9\xff\xf6\x08\x9d\xe5\x37\xd8\x67\xd0\x3d\x4f\x42\x0f\x80\xeb\xe1\x9f\xde\x77\x16\x20\xdc\xdb\x0a\x59\x6f\x7b\x3b\xc1\xaf\x31\x3e\x60\x2e\x4e\xe0\xaf\x29\x9a\xa1\x35\xc3\xd0\x11\x30\xd0\x83\xbb\xc3\x41\x1e\x00\x1d\x6f\x6b\x76\x8f\x42\x1e\x1e\x4d\x27\x0d\x93\x37\x09\x64\x9a\xf0\x83\x27\x07\x1e\x38\xb1\xbf\xff\x5c\x1f\x2a\x04\x55\x55\xf0\x93\xfd\x2b\x1b\x74\xd4\x0e\x18\xf0\x24\xc1\xf9\xfe\x73\xe0\xf2\xce\x25\xb0\x79\xb0\xef\x8f\xb9\x8f\xfc\xcc\xb1\x99\x91\x97\xc6\x86\xdd\x27\x83\x51\x42\xa0\x68\x04\x6a\x25\xa8\x67\xf7\xc1\x7c\xff\xd6\xc4\x2b\x8b\xbb\x37\xbe\xb8\x95\xb9\x9d\x31\xf0\xc5\x12\x04\x61\xef\x5b\xc7\xc7\xf8\xd1\xe3\x1f\xee\x61\xe8\x06\xd0\xf1\x93\xf8\x1b\x00\xc4\x9a\x8b\x9e\x19\xdb\xff\x21\xc2\xb0\xe7\x9e\x92\x39\xe0\x2c\xf4\x43\xc5\x5f\x71\x9a\xbc\xea\x36\x28\x0d\x53\x20\x6c\x79\x3a\xa9\x02\x03\x96\x4d\x5a\x93\xee\xff\xf6\xbf\x2a\x2e\x6c\x33\x3f\x03\x68\x36\x38\x3e\xc8\x90\x21\xfc\x21\x83\x22\xde\x5f\xf7\x38\x87\x00\x8c\x03\x00\x89\xdd\xda\x24\xac\x53\xf8\x6b\x3d\xd6\xde\xf2\xbf\xc2\x71\xb5\xb2\x16\x08\xfd\x60\xb5\xab\x41\x19\x4c\x74\x1e\x06\xd3\xed\xd3\x7f\xaf\xe3\x34\x2b\x2d\xb0\x71\x6b\x0b\x90\xd4\xf7\x67\x46\x0e\x49\x8e\x81\xd9\x37\xdd\x11\x81\x6b\x6f\xf4\xfb\x38\x0f\x81\xc3\x58\xec\x53\xf8\x5f\xe6\x1f\xd3\xf2\xe0\x03\x53\x0e\xbb\xa0\xf2\x80\x19\xa0\xfb\xe9\x83\x7b\x01\xdd\xda\xc6\xd4\x4c\x6c\x32\x08\x9a\xba\xde\xc7\x51\xc4\x18\xc3\x13\x4e\x28\x98\xd7\x09\xca\x38\x20\xb0\x6a\x20\x9b\x2a\xd0\x28\x13\x68\x88\xc2\xf6\x86\x78\x07\x20\xfc\x01\x86\x0a\x88\x24\x08\x48\x3a\x70\xe7\x49\xa8\x62\x39\x31\x9f\xcc\x85\xd3\xa9\x40\x1e\xfb\xbc\x66\xa3\x8c\x8e\xd5\x8a\xaa\x1a\x10\xff\x94\x42\x90\xb0\x52\x48\x24\xea\x42\x96\x82\x8f\xae\xc2\xef\x83\xa5\xbf\x25\x80\xfc\x4d\x0f\x86\x64\xc0\x72\x79\x1d\xbc\xb7\xf5\x2e\x3e\x82\xe7\x93\x1f\x7e\xf2\xa9\xdf\xfa\xd8\xa7\xbd\xc3\x63\x33\x12\xa0\x7d\x0d\xa0\xd7\xb1\x14\x6a\x91\x80\x77\x12\x14\x29\x90\xa7\x52\x2b\xce\x53\x97\xbe\xf5\xc2\x3f\x7f\xf5\xd5\xbe\x5f\xbb\xb8\xfa\xf2\x1f\x02\x64\xfc\xf0\xe0\xee\x47\x8f\xbf\x9f\x43\xb6\xeb\x58\x1e\x9b\x76\xf0\x54\x4d\x19\x30\x1d\x17\x88\x82\x51\x86\x34\xa9\xb8\x1e\x68\x0d\xc8\xb0\x91\x68\x35\x6b\x49\x04\x91\x9f\x67\x79\xc8\xd2\x42\x09\x52\xe4\x02\x36\xc8\x8b\x8d\x4e\xad\xf2\x37\x05\x8d\xff\x22\x03\x1d\x8e\xdc\x50\xa5\x41\xc8\x1c\x24\x14\x5f\xc5\x67\x42\x83\xc2\xc1\x47\x93\xe4\x4e\x59\xd5\xe4\x1f\x1a\x88\x58\xfb\xd1\x34\x1d\x04\x95\x61\x02\x84\xda\x1e\x03\x6a\x2c\x06\xac\x16\x5b\x0a\x34\x35\x4f\xdd\x81\x81\x84\x43\xa4\x4e\x81\x07\x98\x26\x3e\x0f\xa4\x6b\x7a\xa3\xad\x54\xe5\x7f\xe8\x50\x66\x42\xdd\x66\xb6\x04\x22\x6d\xf2\x6b\xbd\xfe\xbb\x5e\xba\x65\x03\x3c\x2b\x00\x86\x61\x7f\x20\x88\x58\xd7\x47\x60\x32\x4c\xfd\x3d\xcf\xbc\x9a\xaf\x81\xb7\xbe\xfa\x1e\x60\xf9\x2e\x12\x18\x9c\x0c\xe2\x57\x9e\x81\x7c\x31\xe2\x31\x28\xc5\x28\x4f\xcd\x37\x64\xef\x12\x18\xf9\xe6\x28\x26\x43\xbd\x63\xeb\x00\xc7\x25\x00\x22\x1f\xfb\xc7\x03\x10\xd3\x9a\x5f\xf3\x3e\x68\x58\x43\x6d\x76\x45\x89\x2d\x27\xf0\x1f\xfc\xba\x17\xb2\xf1\x17\x24\x26\x19\x96\xad\x6a\xba\x0e\x58\x81\x19\x1c\x9a\x08\x3f\x34\x3e\x17\x9b\xc4\x5f\x8a\x37\xbe\xbb\x93\xea\xc8\xca\x3b\x52\x3a\x0f\x5c\x84\x00\x9a\x3a\x04\x34\x0d\x43\x23\x3c\x9c\x1c\x63\xd9\xbe\x04\xcb\x7b\xdc\xa6\xce\xb8\x0d\x85\xb8\xde\x46\xf4\x77\x74\xfe\xb6\x43\x46\x05\x48\x6b\x28\x13\x3e\x00\x62\x91\x13\xa0\x4e\xf9\x62\xc3\x3e\xaf\xcb\xed\x71\x85\xa3\x22\x8b\x0c\x43\x58\x9d\xcf\x1a\xc5\x4c\x7b\x9b\x85\xe6\xae\x62\x22\x6b\xd8\xf0\x79\x41\x5b\xe0\xe8\x0f\xa8\x94\xff\x94\x58\xf9\x4f\xce\x31\x45\x52\xe0\xee\xce\x2d\xbe\x3f\x38\xfb\x4b\xbf\xf8\xb9\x0f\xff\x6f\x9f\xfc\x59\x9d\x66\xbc\x0d\x33\xb3\xce\xe9\xab\xef\x3a\x35\x45\x88\xc8\xeb\x17\xab\x94\x93\x93\xc9\x90\xa7\xca\x9e\x79\x46\x25\x3f\xf5\x6b\x5a\xb0\x7f\xe4\xe8\x1f\x80\x2f\x90\xc9\x8b\x4b\x5f\xff\xd7\x86\x69\xfc\x9d\x20\xe4\x7f\xf8\xf9\x5f\x03\x3b\xdb\xbb\xd8\x58\x19\xdb\x58\x69\x6c\xb4\x61\x35\x0a\xd6\x3b\x6b\xf8\x33\x02\x4b\x65\xca\xbe\xbc\x4e\x5b\x02\x9f\xf8\xd4\x4b\xe0\x73\x3f\xff\xd9\x1f\xa1\xc4\xdf\xa0\x3e\xf2\xe5\x2c\xe8\x48\x2d\xd0\xc1\x2c\x86\x6f\xf9\x98\x89\xbe\xbe\x01\x3d\xd6\x1c\xce\x98\x3b\x47\xb7\xf7\x57\x1f\x4e\x67\xf6\x8f\x14\x4a\xd9\x00\x56\x33\x4e\x9f\xdb\x8f\x26\x87\x67\xa4\x64\xff\xd8\x2b\x0c\x27\x94\x0e\x72\xfb\x97\x75\x43\xff\xe1\x33\xf7\x1f\x76\xb8\xb4\xd5\x45\xf7\xb5\x0e\x54\xe0\xca\x24\x41\x7f\x9f\xeb\x68\xcd\xb9\x77\x81\x22\xe8\x28\x4d\xb2\x69\x0c\x20\xdf\x4c\x17\xf6\xd3\x7f\xdf\x6b\xb1\xd4\x9e\xb5\x8f\x8e\xd1\x02\xee\x6c\x12\x8c\xf6\x47\xc7\xb3\xfa\xed\x0b\x78\xaf\x71\x96\x14\xee\x10\x3c\x2a\x1a\xa6\x16\x57\x75\x39\x88\xa3\x84\x0f\x83\x37\x44\x58\xd9\x91\x24\x85\xd9\x16\xad\x11\x04\x79\xad\x58\x2d\xbc\xd1\xee\xb4\xf4\x7f\x18\x85\x87\x03\x02\x26\xa4\x6c\xcb\x0d\x58\x8e\xa3\x58\x1f\xe1\xa0\x09\x5a\x6f\x76\x1a\xed\xb6\xd2\xba\x97\x3a\xf9\x5b\x29\x5d\xac\x58\x13\x91\x7e\x10\x64\xc3\x38\xd8\x18\x3f\x48\xf7\x7d\x20\x71\xf3\x77\x1c\x5f\x92\x00\x9c\x83\x05\x0c\xc7\x00\x48\xe1\x40\xbb\x17\x07\x66\x95\x4d\xa4\x27\xaf\x7c\x58\x72\x55\xa3\x89\xf2\xd4\x1f\xc7\x53\x67\xd7\x68\x37\xb8\x0f\x20\xf8\x94\x68\xd7\x3f\x76\x0a\xab\xa7\x92\xe0\xfd\xf4\x14\x56\x0b\xf8\x09\x69\x08\x91\x83\x80\x58\xa2\x91\x84\x6c\xe3\x2f\x8e\x8d\x04\x56\xc7\xba\x61\x8a\xa1\x88\xf3\x99\x33\x1f\x19\x3d\xef\xf2\x39\x78\x43\x55\x3b\xdb\xeb\x05\xa3\xa5\xab\xcb\x4e\x43\xac\xf0\x14\x0b\x64\x64\xd0\x6e\x0a\x9e\x7b\x58\x60\xa7\x47\x38\x4a\x60\xf0\x8f\x0d\x45\x46\xb4\xae\x82\x02\x22\x88\x3b\xbc\x63\x01\x83\xd3\x77\x1b\x6a\x55\x5f\x3e\xb1\x1d\x9d\x9b\x1c\x1e\xe1\x09\x2a\x42\xb3\x94\xe0\x70\x32\x50\x10\x18\x13\x52\x84\xb1\xbe\x94\xad\xb6\x1b\xca\x9a\x40\xba\xf6\x14\xb6\x63\xd4\x35\x13\x3a\x69\xc0\x06\x29\x42\x70\x61\x7b\xa6\x21\x69\xd5\x3f\xb4\x96\x01\x74\xac\xa9\x35\x8b\x81\xf4\xd4\x4a\x97\x7c\xa0\xbf\x05\x80\xe8\x86\xc6\xf5\x07\xa7\x7f\xe6\xf3\x9f\x79\xe1\xdf\xfe\xc4\x2f\xca\xb4\xc1\x90\xea\x9f\x7e\xc1\xab\x35\x3c\x13\xe5\x4e\x53\x91\x03\x73\xc9\x5a\xf4\xc3\xf8\x08\x9a\xc1\xa6\x33\x4d\xf1\xff\xfb\xfd\x35\xff\x43\x73\x07\xe2\xc3\x9f\x42\x58\x88\x4d\xfc\x2b\xf8\x85\x8f\xe5\xbf\x7b\xfd\x2b\x5f\x30\x2d\xa9\xf6\xb7\x7c\xdc\xbe\x75\x07\x2c\x2e\x2c\x03\x8e\xe3\x80\xa2\x2a\x60\x7a\x7c\xea\xc8\x4f\x3f\x7f\xe1\xa7\x43\xb5\x66\xf0\xe2\xf5\xcc\xef\xdc\x5c\xbb\xb9\x68\x62\xec\xac\x37\x1b\x60\xee\xd4\xb1\x1f\xa1\xc4\x0f\x0c\xaa\x04\xb6\x04\x1d\x03\x87\x0c\xca\xd9\x26\x11\x13\x86\xe2\x63\xc7\x46\xc6\x30\x45\x9e\xbe\xb8\x39\xff\xec\xc6\xe6\xca\xa9\x7a\xb3\x06\xbc\x9e\xe0\xe6\xc4\xc8\xf1\x37\x23\xa1\x44\xb9\x5c\x2d\xb8\xf7\xf3\xfb\x49\x8f\x27\xd4\x88\x70\xa2\x79\x2f\x77\xfa\x5f\xf6\x85\x02\x15\xeb\xf8\x76\x5d\x82\x04\x24\x58\xcd\x54\x60\x0c\xfa\x1d\xc5\xf0\xfa\x91\x85\x95\x6b\x9f\x9d\x1a\x98\x3e\x09\x1d\xce\x2f\x8a\x0e\xe7\x5b\x24\x41\x61\x35\xa6\x5b\x39\x66\x8b\x2f\x62\x76\x8e\x19\x23\x7e\x1a\x14\x66\x81\x56\x1a\xd0\xa4\x81\x61\xa2\xae\xfb\x43\xf4\x40\x1a\xa2\x07\x50\xf8\x65\xbd\xd4\x86\xa6\x61\x32\xaa\xaa\xc0\xb0\x9f\x0e\x1f\x44\x6f\x9e\xbb\x7c\xed\xbb\x3f\x37\x3b\x76\x6a\xcc\x04\xc5\xbb\xb5\xf6\x2d\x39\x9d\x4d\x05\x8b\xe5\x5c\xc0\x30\xcc\x00\xfe\x55\x4b\xc7\x3e\xef\x71\x7a\x8c\x89\xa1\xa3\xa9\xf1\xd1\x63\x29\x4c\x8e\x58\x49\x81\x7f\x67\x00\x81\xbd\x5c\x7b\xf7\x2a\x7a\xc9\x93\x1e\x88\x62\xc5\x05\xe8\xa6\x1b\x9c\x51\x7e\xcc\xa5\x8c\xef\x9d\x92\xb8\xca\x38\x09\xe9\x96\x57\x09\x5e\xd9\xcb\x6f\x6e\xc8\x72\xfb\x03\x52\x04\x1e\x66\xdf\x6c\x46\x6c\x90\x38\xb8\x99\x24\xb0\x68\xa9\x09\x4d\x40\xe2\xc0\x62\x65\xd9\xed\x1e\x19\xe2\x07\x1b\x83\x1d\xcc\x71\xa4\x21\x8c\x1f\x42\x28\x86\xb6\x74\x02\x78\x2a\x01\xbc\x19\xf3\x57\x82\x5b\x4f\xcb\xc7\x33\x9f\x1d\x38\x3a\x3e\x5d\x5c\x5b\x99\x50\xdf\xd2\x7e\x2f\x24\x4f\x5f\xa3\x24\x56\xb2\xcf\x1b\x53\x69\x2b\x6b\xf3\x8f\x05\x1c\xa6\xfd\x34\xac\xc1\x07\x86\x75\xde\x78\x1c\x34\x04\x9c\x2c\x41\x3c\xe2\x24\xe1\x69\xfc\x0d\xaf\xb7\xcc\x3f\x25\x54\xf9\x06\xb2\x8a\xe4\x8a\x06\x3a\xba\x3e\x40\x89\xca\x4f\x24\xa3\x9e\xf1\x56\xa5\x2d\xb5\x6b\x6d\x39\x3c\xe0\x87\x52\x43\x2b\xd7\xab\xed\x3b\xaa\xdb\xc4\x00\x4a\x02\x1f\x20\x2e\xbc\xe8\xa1\xcf\xe2\x29\xd7\x0e\x64\x5d\x35\x54\x19\x38\x21\x22\x1a\x32\x82\x97\x49\xfa\xce\xd8\x53\x93\x6f\x15\x5e\xbe\x4a\xf9\xa3\xdc\x13\x33\xc7\x93\x43\x89\x91\x00\x9e\x6e\x1c\xfc\xb1\x24\xa6\x28\xa8\xeb\x9a\x69\xbe\xf1\x27\x4b\xe9\xc5\xd5\xd4\xed\x68\xc0\x5f\x33\x19\x13\x68\x24\xc1\x4d\xd1\x30\x39\xcc\x93\xce\x61\x8e\xc4\xfb\x33\x34\xd6\x64\x74\x5d\x56\xd4\x8b\x32\xa1\x5e\x53\x99\x1a\xa0\x8c\x3a\x81\x2f\xc6\xf2\x07\x0c\x74\xb6\x27\x1c\x92\x2f\xca\xfc\x4d\x19\xec\xbe\xb7\x06\x68\xfe\xaf\xea\x3d\x1c\xf4\x49\x9a\x14\x4e\x3d\x76\xfa\xc2\x7f\xff\xd1\x8f\x6b\x9c\x52\xd6\xd5\x2f\x7d\xd5\xd7\x21\x8f\x4c\xa6\x38\x8e\x2c\x3b\x47\x5c\x65\xa9\x56\xd2\x15\xec\x79\x98\x2d\x08\xae\x38\xef\xf2\xfd\xc4\xe9\xf6\xe5\x6f\x88\x11\xf4\x95\x55\xef\x23\x9f\x86\x54\x7a\x7b\xfa\x37\xb3\xa5\x9d\xef\xbc\xf9\xde\x1b\x5b\x1f\xf9\x8d\x67\x80\x30\xe1\x01\x57\xf9\x3c\xe8\xa3\x34\x40\x03\x27\xd0\x09\x13\x38\xf0\xd3\x20\xac\xb4\x0a\x0d\x38\x6c\x7c\x5a\x47\x05\x08\x2b\x1f\x84\x71\xcf\xe9\x14\x2d\xa5\x41\xbb\x44\xcf\xd1\xcf\x7f\xe6\xfc\xef\x9f\xfd\x48\xeb\xd4\x13\xd4\x14\x78\xf2\xc6\xd8\xa9\x7f\xff\xbb\xee\x1f\xf3\xfb\x03\xb3\x5f\x7f\xfd\x8f\xff\x34\xb5\x52\xd7\xdf\xff\xd3\x03\xa0\xb3\x4d\x40\xe3\x9d\x6c\x97\x57\x40\xe4\xae\x0b\x0c\x1c\xef\x07\x19\xa6\x04\xea\x0a\x0b\x58\x2b\x1f\xcd\x2a\x80\xc6\x33\x70\x73\x7b\x08\x0c\x4c\x6c\x00\xb2\x64\x82\x10\x6b\x80\xaa\x41\xd9\x8c\x47\x95\x8b\xe0\xad\x25\x07\x38\x79\xba\x0f\x70\xb0\x09\xf8\x12\x0d\x84\x40\x0b\xff\xc6\x07\x24\xa3\x06\xb6\xef\x2e\x80\x8f\x7b\x5e\x04\xdf\x1b\xdf\xc2\x83\x17\x05\x2e\xc5\xaa\xef\xb4\x81\x83\x93\xc0\xda\x5e\x12\x9c\x78\x2a\x0a\x58\xf9\x16\x38\x98\xaf\x82\xa5\x3a\x01\x4e\x50\x73\x60\xe4\x5c\x07\x6e\xb4\xd2\x40\xaf\x70\xc0\x03\x54\x58\x67\x0c\xc0\x60\x46\x01\x74\x1d\x5a\xf9\x5a\x6b\x3e\x18\xc2\x96\xb1\xd8\x4b\x30\xa6\x13\x26\x24\xac\x54\x13\x22\x71\x64\xb1\x26\xab\x2b\x89\x81\x49\xc0\x7b\xb9\x54\x64\x27\x42\x7a\xe0\x80\xa9\x82\x82\x3d\x07\xff\xc6\xfc\x40\xc1\xdb\x7e\x87\xf7\x51\xc8\xe7\x89\x5a\xbe\xe1\x0e\xbb\x13\x63\x23\x33\x7d\x7d\xeb\x99\x9b\x17\x36\x36\x96\x5e\x2c\xd6\xf2\xce\x68\xb8\xff\xfa\xc3\x67\x9f\x7b\xd3\x25\xf8\x2b\xed\x66\x0b\x73\x19\x62\x7d\xe0\xc8\x50\x9d\xa2\x09\x17\x0e\x90\x1a\x56\x24\xdb\x41\x5f\x88\xc6\x2a\xf0\x1f\x86\x26\x7f\x1f\x75\xfb\xc1\xa4\xee\xde\xc6\x87\x45\xc8\x2e\x15\x42\xdd\xa0\x89\x19\x2a\x05\x41\xb1\x50\x83\xed\xb2\x14\xc6\x84\xe3\xa8\xa6\xe9\x41\x75\xaa\x58\x4f\x95\x6a\xe3\x9a\xa2\x8c\xe0\xa1\xc9\x61\xd9\xb0\x81\x55\x58\xc3\xc5\x7b\x00\xa2\x69\x82\x94\x69\x2c\x0e\x10\x6a\x70\x32\x60\x79\x05\x84\x77\x06\xd0\x8d\x8a\x0a\x74\xef\x1d\x10\x75\xbb\xb0\x9c\xc7\x63\x6a\x50\x36\x87\x24\xc9\x6e\x3d\xc3\xd4\x4d\x50\xc9\x37\x80\xd4\x56\x2c\x50\x38\x8a\x59\x7d\x24\xd4\xef\xef\x5c\x5b\x7a\xf3\x11\x45\xea\x8c\x2d\xac\xdd\x50\xf7\x32\x3b\x47\x55\x4d\xd5\x05\x41\x3c\xf0\x7b\x43\x57\xc3\x81\x58\xde\x29\xba\xb3\x04\x20\x54\xb7\xe8\xa9\x0a\x0e\x31\xd7\x29\x36\xb6\xa9\x22\xe8\x88\xba\xf0\x37\x2a\x3b\xf8\x03\x86\xc7\x20\x4d\x20\xb3\x32\xf6\x23\xca\x9e\x77\xcb\x44\x2c\x1c\x92\x30\x51\x50\x64\x0d\x87\x7c\x93\xe4\x34\xc2\x54\x8e\x1e\x4c\x5d\xda\x7f\xe5\x63\x94\x4e\x7c\x62\x64\x60\x32\xe3\x70\xb8\xd9\x80\x2b\x52\x29\x13\xb5\xb2\x83\xe4\xf0\x35\x99\x36\x58\x20\xc3\x62\xc3\x38\x3a\xd1\x08\x30\x3a\x09\xe2\xa9\x28\xac\xbb\x6a\x08\xc5\x11\xf4\x19\x3e\x50\x6e\x96\x80\xd6\xc6\x7e\xdb\x14\xf0\xb1\x20\xa0\x54\xd3\x1a\x0e\x68\x52\x06\x1e\x13\x12\x9b\x99\x9d\x9b\xc1\xb6\x4d\x41\x28\x36\x41\x1a\xae\x02\xf5\xeb\x18\x7a\xac\xa8\x0a\xbb\x1c\x84\x20\xa1\x95\xb5\xb1\x94\x18\x20\xac\x6b\xc6\x63\x6a\xbd\x86\x18\x99\x2c\x75\x66\xfd\xde\xfa\xd8\xf2\xc5\x5a\xa9\x01\x58\x43\x84\xa4\x4e\x9a\xd2\x16\xc7\x6a\x62\xf9\xbc\xfe\x68\xfd\xc5\xb1\x8f\x3c\x3f\x46\x94\x5a\xcd\xfe\x59\xd7\x87\xd2\xfc\xe6\xf0\xd6\xd2\xee\x17\x63\x1b\x67\x5e\x86\x34\x28\xc9\x5c\x1d\x51\x0c\x24\xe6\x5f\xc5\xbb\xe6\xba\x25\x86\x0f\x64\xd7\x1e\x48\x71\xfe\x67\x61\xc2\x5f\x6b\x89\x1f\xfc\x29\x16\x95\xa0\x9c\x6f\xa0\x30\xe5\xb4\xdc\xd0\x8a\x59\x58\x97\x2a\xb0\x0d\xf4\x93\xc7\x1d\xf4\x87\x8f\x32\xe6\x04\x6b\xa8\xfc\x25\xd3\x54\xd7\x2a\x01\xc1\xd7\xa1\xec\x31\x51\x19\x34\x79\xec\xe9\xe4\xcf\x4e\x1c\x89\x86\x19\x96\x6d\xe3\x09\x34\xb1\xa8\x80\xf5\x52\x07\x16\x53\xcd\x05\x1f\xed\xce\xba\x68\x11\x28\x08\x52\x2c\xd1\xf1\xf9\x71\x10\x73\xe3\x18\xa1\x1a\x1d\x4a\x25\x75\x62\x49\x32\xe5\xbb\xfe\xc0\x2d\x13\x50\xef\x1f\xbc\xbf\xa9\xb3\x14\x7c\xe6\x89\xe7\xfc\xd3\x04\x59\xea\xb4\x2b\x05\x9d\x66\xb1\xbe\x11\x01\xb1\x79\xd3\x30\x6e\xbe\xab\xae\xd2\x3e\x73\xe1\xfc\xd0\x31\x6d\x79\x71\x11\x18\x31\x07\x8e\xc0\x4e\xff\xd3\x91\x56\x22\x86\x15\x51\xa1\xdd\x51\x2b\xd8\x6e\x24\x2c\x2d\x3b\x7e\xb7\xbc\xd4\x51\xca\x40\x56\x3a\xce\x18\x03\xc9\x34\x80\x1d\x0c\x30\x2c\xcf\x20\x93\x50\xd1\x61\xb3\x0e\x95\xfd\x8d\x7d\xb0\xeb\x5a\x03\x94\x93\xe9\xc2\xe7\x83\x06\x6a\x1a\xfe\xfe\xf0\xe8\x0b\x4f\x3f\xe5\x1f\x73\x89\x35\xfd\x3b\x6f\xfa\x34\x62\xe2\x68\x5a\xf0\x32\x29\xc3\xd0\xd3\xcd\x62\xa3\xac\x2a\x72\xdb\xd0\x75\x8a\x20\x49\x17\x23\xc9\x61\xce\xe1\x30\x86\x5f\x9a\x82\xef\x7f\xa5\xc5\x8e\x9d\xc8\x38\xce\x3c\xd7\xf6\xdf\x99\x3f\xf7\x4f\xfe\xef\xef\xfc\xe6\xaf\xbf\x7b\xf1\x1d\x30\xfc\xd2\x11\xf0\xc7\x81\xbb\xe0\x2c\xdb\x01\x02\x88\x03\x99\xd4\x40\x84\xd1\x81\x4c\x13\xa0\xad\x08\xc0\x8d\xa5\x6a\xbb\x84\x87\x9d\xa4\x41\xa3\xd6\xb2\x14\x90\x95\x33\xc4\x0a\x0b\x4e\x4e\x4f\x91\xc3\x8d\x32\x07\xf6\xea\x00\x24\xfb\x6b\xe3\x01\x9f\xf3\x57\x3e\xf2\xcb\xbf\xf8\x79\x77\xd2\xf7\x5c\xea\x9d\xce\x67\xbf\xf9\x7b\x0b\x48\x1c\x92\x81\xe0\xa5\xc0\x77\xd7\xfe\x0c\x1c\x7f\xb5\x1f\x3c\xfe\xe2\xe3\xe0\x7d\xf7\x5d\xb0\xdd\x70\x03\xb7\x4a\x03\xc2\xd5\x00\x0e\xbc\xc3\x2f\xbe\xe7\x06\x8f\x3c\x7b\x15\xd0\x6b\x1a\x98\x76\x6a\x60\x5b\x67\x00\xc9\x60\x47\x94\x0f\xc0\x1f\x5d\x72\x81\xfc\xc7\x8e\x00\x27\x53\x86\xbe\xac\x03\x78\xfa\x0b\x50\x80\x7d\x40\x03\x25\xb4\xb7\x75\x1b\x0d\x79\x03\x60\xb3\xbd\x47\x52\x28\x42\xf9\x74\x19\x9a\x84\x04\x05\x51\x86\xa8\xbd\x03\x33\x0b\x4e\x48\x1b\x59\x42\x52\x4c\x18\xc3\x62\xb5\x43\xee\x11\xdb\xbb\x08\x73\x41\x19\x83\x04\x45\x60\x3f\x83\x9c\x69\x12\x94\xdd\xf5\x8c\x4d\x58\x07\xf8\x53\x3c\x1d\x76\x76\x08\x61\xbf\xc1\x20\x81\x0c\x82\xb4\xb3\x31\x04\xc4\xb1\x0d\xfb\x1c\xb2\xfa\xa7\xf1\xb7\x56\xf6\x14\x5a\xdb\x59\xee\x88\xfd\x8c\x20\xac\x26\x0e\x84\x07\xe7\x91\xe7\x19\xd8\x4b\x78\x43\xbb\xc8\x09\x7b\x1c\x11\x6f\x56\x29\xc9\x0c\xb9\xd4\x88\xb2\xac\x7f\x34\x39\xdc\x47\x2f\xac\xde\x39\xd3\xa8\x56\xcf\xbb\x5c\x5c\xfd\xdc\xf9\x67\x5e\x89\x87\x12\x1b\x3b\x5b\x07\xfd\x1b\x6b\xd7\x1e\xc1\x17\x95\x9f\x9c\x09\xc8\x73\xe7\xe9\x2d\x87\xc8\x1a\xa6\x69\x5a\xbb\x1b\x25\x09\x17\xf1\xb7\x96\x20\xf0\x9e\x30\xc0\x91\xc1\xd6\xf3\x36\x49\xbc\x47\x74\x8d\x2e\x20\xd9\xb1\x93\xb0\xce\xbc\x97\x39\xee\x76\xa6\x60\x23\xbd\xd7\x5d\x08\xed\xa2\x7e\x17\x2c\x30\x8c\x5a\x57\x85\x87\xd4\x0a\x0f\xc8\x2e\x44\xdb\x3f\xc2\x03\xa5\xef\x6c\x22\xe1\xcd\xd7\xea\xa7\xd2\xfb\xca\x53\x8c\x4e\xf8\xa2\x7d\xfc\x5b\x0b\x9b\x2b\x73\x11\x7f\xd4\x81\x01\x71\xc7\xeb\x07\xf9\x93\x47\x68\x9a\x65\x7d\x11\xec\x09\x40\x55\xa1\x75\x85\x58\x8b\x88\xc0\x62\x68\x44\x0b\x98\x49\x89\x40\x1a\x9a\x44\x2c\x86\x96\xb6\xae\xa3\x56\x83\x46\xa6\x21\x03\x8e\xe4\x11\x54\x34\x54\xce\xb7\xb0\xca\x91\x5d\x58\xd5\x9d\xc3\x18\xf1\x82\xcf\xe7\xc3\xa4\xb2\xb2\x58\x29\xe7\xcf\x25\x82\x7d\x28\x5f\xc9\x65\x66\x8e\x9c\x79\x67\x24\x39\xb5\x66\xc9\x80\x4e\xab\xcd\x13\x90\x54\x14\xdd\xd8\xf5\x46\xc3\xeb\xae\xa0\xbf\xbd\x94\x59\x6e\x47\x8a\x6e\xf5\x31\xea\xe3\x8c\xc1\x1a\xa4\xd5\x47\x83\x2c\x06\x01\xbb\x23\x85\xba\x59\xf2\x5e\x25\xc7\x1a\x35\x84\x8d\xa1\x5b\x77\xb7\x03\x31\x1e\x8e\xa6\xd8\x80\x38\x7c\x22\x9f\xe9\x45\x2d\xfc\x5e\xc1\x63\x44\x51\x1a\xac\x64\xd2\x42\x7a\x3f\x9d\x90\x5b\xad\x38\x29\xe8\x52\x4d\xc8\xfb\x72\xd9\xfc\xd4\xfe\xc1\xa6\x8b\xa2\xd9\xcc\xe4\xf8\x09\x5e\xf0\x07\x5d\x8c\x37\x88\x28\x48\x5a\x06\x83\x6d\xcb\xae\x68\x58\x86\x05\x0c\x6b\xe8\xf1\x1b\x35\x4c\x43\x96\x74\x9a\x98\x3d\x11\x2a\x36\x40\xde\xcf\x03\x0e\x59\x71\x01\x03\x97\x15\xfb\x45\xbb\x90\xdb\xed\x2b\x42\x5d\xb6\x4d\x58\xfb\xc3\x06\xad\x44\x6a\xb0\x04\x2b\x70\xf9\xba\xb5\xa1\x65\xca\x96\xf9\x58\x44\x13\x76\x25\xb1\xd9\xeb\xf0\x23\xba\xd0\x09\xed\x7c\x20\xb0\x17\x0a\x58\xff\xb3\x8c\x82\xa4\x09\xc8\x4e\xc5\x90\x29\x01\x20\xa4\xb8\x63\xad\xa3\x07\x2f\x0d\x9f\x1f\xbe\x90\x10\x58\x43\xf1\x99\xb0\xdc\x24\x94\xbe\x89\xb1\xe1\x7a\x20\xff\xaf\xf6\x1c\x97\xa6\x5d\x66\xe4\x65\x30\x0e\x36\x0c\x5e\x33\x8b\x69\x60\xfb\xc1\xa1\x78\x84\xa8\x67\x7b\x3d\xf2\x05\x7a\x65\x88\x5e\xcb\x14\xf8\x80\x8c\x3b\x84\x1a\x4b\x94\x22\x78\x98\xb4\x81\x5d\x49\x04\xef\x8b\x51\x00\xbb\x74\xdc\xa6\x73\x24\x49\xa2\xd8\xc9\x84\xf5\xa1\xd6\x6c\x28\x1c\x9b\xcd\x3f\xf7\x61\x87\xf0\xe4\x28\x4d\x88\x84\x2c\xd9\xde\x49\x4a\xa4\xec\x1f\xe3\x6a\xb1\xa8\x97\x3a\xb8\x2b\x8f\x27\x13\xc1\x5f\x18\x1c\xee\x8f\xe6\x52\xd5\x56\xa3\x92\xa6\x0c\xa5\x65\x72\x82\x42\xac\xde\xee\x94\x34\xda\xb3\x34\xf4\xc4\x20\x85\x81\xdd\xea\x03\x36\x4a\x99\xfa\xd5\xaf\xd5\xcb\x68\x84\x34\xfd\x08\x2b\xb2\x3c\x64\xcb\xb9\x90\x7b\xc1\x1d\x0b\xee\xc6\x18\xc6\x94\xab\x12\x45\xd4\x0d\x6d\xe9\x46\xcb\x8c\xf6\xb1\xb4\x35\x1d\xe5\x9c\x8c\x3a\x0d\x98\x53\x69\x76\x31\x32\xd3\xb7\x23\x78\x39\x44\xeb\x24\x1c\x1d\x3e\x0e\x28\x51\x44\xe5\x9d\x72\xf1\xad\x6a\xd3\x71\x94\x94\x5d\x08\xe9\x6a\xda\x29\x36\xf7\x69\xae\x42\x01\x6f\x5b\x97\x57\xc8\xfe\x51\xaf\x6b\xea\xcc\x14\x94\xcb\x2d\xbd\x2d\x49\xba\xcb\xe7\x30\xe4\xa6\x62\x78\xc2\x4e\xb3\x5b\xe2\xc0\xec\x85\x42\x16\x83\x51\x80\xa2\x13\x76\xa1\xcd\xf2\x47\x02\x87\x32\xd3\x40\xb1\x91\xfe\xa1\x0b\x53\x47\x35\xd0\x6c\xb1\x46\x8e\x1d\xaf\x70\x02\x51\x86\x24\x91\xd2\x5a\xca\x0e\x06\x8f\xfd\x66\xb5\xda\x54\x64\x89\xa6\x68\x3a\xe8\x70\x3a\xad\xca\x24\x45\x0b\x0c\xe7\x39\x3d\x56\xbd\xfe\xbd\xac\xf0\xe2\xe7\x35\x30\x34\xe8\x7b\xf1\x48\xe2\xf4\x17\x60\x15\x66\x29\x1e\x33\x7a\x96\x03\x1c\x67\x02\x16\x58\xfd\xcb\x04\x60\x30\x78\x98\x34\x09\x34\xc8\x00\x06\x47\x4e\x8d\xb3\x52\x0b\x14\x88\x85\xfb\x80\xd7\xe5\x07\x8d\x76\x5d\xcd\x16\x2b\xf5\xaf\xfe\x79\x6a\xe1\x97\xff\x89\xf1\x98\x0b\x9b\xed\xfa\xfe\x10\xf5\xcc\x4f\x3d\xff\xcf\x32\x6b\x1b\xd2\xd8\xc8\x34\x15\xac\x2b\x51\xb5\xa6\x65\x44\x0f\x24\x69\xd1\x80\x47\x07\x27\x41\xe0\x51\x17\xd1\x1e\x6b\x82\x90\x20\x12\x22\x66\x91\x1c\x49\x40\x8a\x63\x09\x07\x0e\xb8\xff\xfa\xd8\x02\x70\xf9\x9d\x90\x3d\x61\x12\x02\x46\xf5\x49\x4c\x9a\x28\x86\x80\x0c\x79\x84\xf8\xf1\x5f\xc2\xca\x80\xae\x61\x9b\xc6\x0f\x52\xc6\x7f\x9c\x38\x54\x95\xe1\xf6\x56\x96\xf1\x4d\xcc\x3d\x77\x20\xc8\x47\x9e\x8e\x3b\x7e\x5f\x70\xd7\x6b\xba\x49\x70\x04\x41\x63\xbf\x63\x20\x4d\xa8\x84\xae\x15\xf1\x6b\x9e\x20\x92\x96\x59\x59\x00\x60\x62\x82\x6b\x99\x2a\x6d\x87\x3d\x64\x39\x8f\x01\x6c\x5d\x61\xfb\x9d\x89\xb0\xfe\xb2\xfc\x15\xda\x31\xb0\x57\x67\xeb\x86\x48\x64\xb9\x35\x7e\xdf\xdb\x18\x74\x15\x40\x57\x76\x74\x13\x05\x56\x70\xb1\x13\x0a\x72\xab\xeb\x87\x78\x7b\xb2\x6b\xd6\x36\x3f\x27\x9a\x75\x89\xdf\x5a\x6d\xc4\x37\xd7\xaa\x47\xfa\x13\x43\x68\xe3\x60\x53\x68\x56\x3b\x8f\xce\xcd\x9c\x29\x79\xa3\xc2\x5b\x0c\x4b\xd6\x8b\xc5\x7c\x4c\xf4\x0b\xdc\xb8\x77\xb8\xc4\x39\x58\x39\x31\xe8\x1b\x34\x19\x97\xaf\xa5\x77\x13\x08\x76\x80\x30\xba\x71\xad\xc7\xfd\x11\xb8\x9f\x39\xb9\x9f\x6c\x40\x87\x09\x90\x9e\xf3\x59\x99\x0f\x1c\xea\x4c\x0d\x8b\x65\xdd\xa4\xba\x3d\x27\xc8\xaa\xe3\x5b\x0e\x6d\x52\x2c\x2d\xe1\x78\xa3\x63\x2f\xc5\xdb\x18\x94\xa1\x9b\x96\xa3\xe8\x14\xc7\xb4\xf1\xf6\xa4\xa1\xe9\x0c\xde\xd8\x24\x49\x5a\x21\x59\x52\x02\x16\xb6\xda\xa1\x00\xe8\xa6\x6a\x32\x5a\x13\xf9\x0c\x0d\x79\x74\x53\x23\xf1\x17\x06\xcd\x90\xa5\x4c\xce\x54\x6b\x6d\xea\x34\x26\x52\xe3\x3e\x6f\xa0\x01\x78\xce\x5b\x6f\x76\xa6\x13\xc9\x31\xc4\x0a\xc2\x01\xeb\xf1\xa1\x0e\x64\x23\x6d\xb9\x1b\x53\x50\x6f\x05\x53\xd7\xbb\xf1\xd3\x83\x10\xe3\x21\x30\xab\xc7\xd3\x64\x12\x48\xc0\xfe\x20\xf4\x59\xe1\x9d\xc1\x64\xc6\x42\x42\x02\x79\xdb\x0a\x11\x62\x16\x86\xf7\x97\xd6\x9f\xd5\x5a\xd2\x74\x62\x6a\xf4\xf2\x41\x69\xed\xe1\x68\x20\x1e\x8b\xc7\x87\xaa\x47\x4e\x3f\xf6\x5a\xad\xd2\x96\xb6\xd3\xd9\x49\x5d\xd3\x68\xab\xb7\x9a\x62\xe8\x9a\x33\x1c\x68\xc3\xb1\xa1\x8a\x99\x88\x72\xd3\xb3\x47\xc3\x98\x58\xa3\xa5\x62\x39\x0a\x1b\x95\x7e\xab\x4e\x08\x1c\xce\x2a\xc9\x39\xea\x64\xbd\x19\x36\x91\xec\xb0\x3e\xc3\xd3\xdf\x31\x83\xde\x03\x43\x14\xea\xd8\x18\x48\x3b\xca\xdb\x01\x10\x1b\x96\xee\x05\x62\xe7\x34\x2f\x9b\x2a\xc7\xe2\x21\x65\xf0\xe7\xba\xaa\x1b\x8a\xae\xf8\xb5\x62\xf1\x1c\xd2\xa8\xa9\x0e\x30\xab\x4d\x00\x6e\x3f\xf9\xdc\xa7\xde\x6e\xb6\xea\xb7\x44\x97\xb7\x64\x46\x62\x29\xe8\x77\xfb\xd8\xb6\x1e\xa7\xca\xe5\x11\x43\x97\x39\x44\x50\x0a\xe1\xf2\xe4\x28\x59\x77\x00\x5d\xf2\x9a\x98\xc4\xe0\xe3\x63\xe7\x10\x0a\x86\xcf\x73\xa0\x52\x18\xb2\x2c\x3b\xc6\xf3\x4e\x76\xe3\xa7\x05\x01\x56\xc3\x10\x3a\x24\xf3\xb0\x3b\xe9\xf0\x30\xc1\x85\xbd\x1a\x74\x83\xaf\x45\x7a\x7a\x81\x16\x75\x83\xb2\x0d\x27\x18\x71\x6c\x4b\x3d\xd4\xd3\x08\xd9\xdf\x5b\x48\x04\x6d\x3d\x82\x10\x66\xc3\x3a\x5c\x57\x92\x2a\x9b\x3b\xed\x79\x26\xfa\xd8\x18\x96\x2c\xd4\xa5\x9b\x3a\x39\x33\x0e\x84\xe9\x24\xc8\xec\x95\x65\xd1\x00\xb4\xe3\x43\x9e\x4f\x1f\xdc\xd9\x99\x46\x19\xf2\xb7\x61\xbf\xe3\x32\x76\x64\xca\x36\x51\x6b\x71\x14\xb2\x91\xad\x3b\xcb\xdd\xb3\x41\x87\x9d\x88\x3d\x4f\xeb\xa6\xe5\xec\xcb\xb3\x4e\x84\xb0\xd5\xa6\x7d\x5d\x36\xae\x11\xc8\x4a\xe1\x59\xd1\x11\xf4\x80\xb2\xa7\x82\xed\xf7\xd6\x35\xdc\xcf\x0b\x40\xa3\x50\x6b\x08\x42\xbe\xf4\x89\x4f\xba\xe9\x87\x02\xf8\x3c\x1a\xcd\x96\xaa\xea\x80\xc2\xa3\x41\xd6\x08\x66\x97\x71\xd3\x07\x4a\x51\xe1\x29\x4d\x7d\xde\xe9\x6b\xf6\x97\xd3\xb7\x5a\xbc\xc3\x00\xfd\x49\x02\x39\x1c\x14\x51\xaa\x60\x56\x4d\x39\xde\x75\x47\xfd\x69\x03\x62\x72\xd1\xa5\x89\x84\x27\xe1\xcc\xb4\x8a\xe8\x1b\x77\x24\xd5\x81\x19\xab\xc9\x3a\xf9\x4e\xc8\x27\x9a\x84\x89\x28\x55\xd3\x48\xd2\xc9\x98\xee\xd1\xc8\xe5\x4c\xa1\x9c\x69\xd5\xf5\x20\xfe\xad\xd9\x6e\x33\x25\x17\x11\xdd\x67\x46\x28\x89\xa0\x20\x81\xfd\x05\x76\x08\x1d\xd0\x04\x03\xa4\xed\x8c\x53\xef\x34\x1c\x55\x86\xcd\xbc\x61\xb2\x7b\x5c\xc2\x0b\xdc\x7e\x97\x1a\x40\x14\xea\xcc\x2b\xc2\xe4\x09\x77\xf0\xc8\x69\x41\xa3\xc9\xa2\x6a\x86\x5d\x26\x49\xf9\xe1\xde\x72\x19\xac\x2f\x67\xc0\x04\x2f\x76\x15\x88\x35\xc8\xd8\xfd\x00\xab\x8f\x82\xb1\x10\x0f\x9a\xce\x0a\x68\x55\xf1\xce\x5b\x65\x16\x02\x23\xd1\x1f\x77\x27\x7c\x3e\x03\x5c\xbf\x41\x99\xed\xba\xa1\x46\x8f\x38\x8b\x72\xbd\x5d\xc2\x91\x75\x8f\x34\xcd\x8d\xe6\xfe\x76\xa1\x9c\xcf\xf3\x9e\x78\x5f\x12\x47\x3e\x07\xcd\xb0\x7e\xa5\x25\x07\xc4\xa8\x5b\x2e\xac\x7a\x55\xb3\x53\xa3\x7c\x7d\xd2\xcc\x53\xb1\x97\xce\xf8\x86\x1c\x7f\x99\x09\x65\xf8\x47\x31\x9f\x17\x1d\x1c\xd4\x4d\x1d\xb2\x86\x35\x2f\x98\xdd\xe0\x59\x60\x31\xf2\x62\x00\x21\x38\x0e\x53\x72\xda\x84\x9f\x1b\x7d\x06\xd4\x1a\x1d\x6a\x61\x65\x27\xd9\x97\xe0\x3e\x17\xf0\xd3\xd1\xb7\x57\x66\x14\x7f\xb2\x8f\x55\x45\x06\x78\x7d\x1e\x6c\xbf\x90\x2f\x2e\x5c\x7a\x6d\xfa\x51\xd6\x32\xba\x09\x68\x87\x5f\x44\x4c\x50\x09\x60\x3e\x69\xe2\x01\x2b\x11\xc3\x98\x02\x61\xee\x8f\x15\xb6\x8e\x23\x00\x61\xad\x73\x24\xfa\xc8\x0a\x34\x30\x12\x5b\xc9\x72\xc3\x24\x89\xae\xd5\x5b\x99\x23\xcc\xbf\x30\x7e\xe8\x2a\x9e\x36\xbb\x61\x09\x47\x37\xbc\xe7\xd5\xf5\xac\x23\x9d\xa3\x3e\xf2\xf8\xcf\x3c\xff\x19\x55\x33\xa9\xe5\x3b\xf3\x27\x7d\x44\xfe\x77\x30\xa0\xb6\x0d\x13\x72\x5d\x8b\xb2\xe9\x55\x17\x1c\x88\x2e\x3f\x81\x90\x26\x7b\x54\x85\xb0\x17\x69\x10\xf6\x87\x04\xb4\x2d\xd3\xfe\xcc\xe2\x60\x10\x5a\xe9\x11\x68\xa5\xe5\x0d\xd3\x42\x6f\xac\xe1\x19\x7c\x6d\xa4\xad\x0a\xa1\xad\x3c\x80\xdd\xdc\xd2\xb5\xda\x9e\xdf\xf5\x40\xa5\x57\xab\xb3\x98\xe4\x3d\x8f\xc5\x9b\xca\x92\x42\xef\x6e\x56\x63\x5b\xab\xf5\xd1\x5a\x59\x89\x8e\x4f\xf9\x37\x6e\xdf\xba\x9b\x54\x1a\x2a\x69\x2d\x1a\x45\x80\x09\x74\x24\x33\x20\xba\x62\xd0\xe9\xc6\xd4\x01\xd3\x43\xac\x24\xdd\x9a\x0a\xc5\x52\x99\xa9\x30\x0e\xaa\x6a\xb7\x66\xf4\xd8\x97\xb5\x73\xd3\x20\xb0\x12\x07\x0e\x53\xd7\x59\x4c\xdd\xad\x1a\x00\x96\x50\xa4\x46\xf2\x74\x03\x33\x46\x19\xf5\x1c\xd4\x0a\xf4\x48\x05\x82\x21\xe9\xee\x76\xa3\xe5\x95\x24\xc9\xd3\x3d\x6f\x12\x91\xdd\xcb\x57\x78\xaf\xb8\xcd\x07\xc4\x3d\x2c\xed\xa8\x56\xbe\x31\xd2\x6e\x36\x62\x34\xc3\x74\x1c\x4e\x77\x5a\x53\x15\xbe\xd5\x6c\x44\x68\x9a\xb3\x9a\xe0\x2b\x8c\xc8\x65\xf9\x80\x63\x1f\xff\x4e\x33\x3b\xa6\xaf\x53\x6e\xc6\x73\x99\xbd\x81\xdd\xed\xb5\x21\x27\xe7\x72\x46\x43\x71\xd9\xe1\xf7\xde\xee\xa8\xe2\xbe\xa4\xc0\x3e\x03\x90\x7c\xb4\xbf\x7f\x33\x57\x2b\xf5\x3b\x58\x31\xc4\x09\x7c\x83\x75\xb9\xd2\xd0\xe5\x95\x9b\x32\xeb\xc7\xe7\xcf\x99\x86\x0e\x7b\x9e\xaf\xe0\x4b\xd3\x7a\xe8\x84\x0e\xa9\x68\x77\x94\x09\x70\x0f\x17\x2d\x00\xc3\xd7\x56\x2f\xd5\x5d\x8d\x52\xed\xb8\xa6\xaa\x63\x0e\xc1\xa1\xf3\x4e\x5e\x69\x6c\x94\x8e\x8f\xc7\x47\x49\x4f\x28\x7a\x97\xa0\xd8\xaa\xa9\x35\x1c\x43\xc3\x83\x25\x41\xe0\x0d\x2c\xcf\x59\x1c\xce\x1c\x38\x24\x9e\x47\xc5\x72\x1f\x26\x7a\xd7\x54\x02\x34\x70\xc8\xf6\xa0\x5c\xf6\x6c\x3e\xbf\xfb\x54\xd8\x1b\x76\xd2\x42\xf3\xdb\x6d\xec\xd0\xbb\xa9\x8d\x51\x59\x6a\x25\x92\xf1\x61\xc2\xe3\x0e\xee\x82\x74\xed\xa2\xce\xf1\x97\x75\x8a\xcc\x13\x56\x5c\xc6\x82\x96\x32\x28\x17\x6d\x1a\x7d\xa6\xd2\x8e\xc9\x52\x3d\x86\xc7\x8b\x73\x08\xa2\x8e\x15\x46\x9e\x29\xd5\x1a\x72\xa1\xe4\x51\x65\xd5\x3d\x3c\x32\xba\x21\x92\xd0\x60\x74\x43\x08\xf2\x9e\x34\xf6\xb0\x4b\xed\x6a\xf5\x80\x2c\xb7\x18\x87\x64\x1c\x4f\x1d\xdc\x39\xef\xe2\xc4\xf3\x0e\xa7\xf7\xb2\x5e\x2c\x2d\xed\xe7\xb6\xa7\xf3\x85\xcc\x98\xdf\xe3\x77\x27\x22\x43\x0d\x8a\x65\xde\x03\xa5\xea\xbb\x1a\xc7\x2f\xda\xe1\x9d\xb0\xca\x20\xf8\xe8\x88\xc4\x01\xd0\x0c\x10\xd0\xf0\x21\xd2\x60\xb0\x2a\xc1\xe8\x85\x45\x10\x45\x15\x35\x1a\xe6\x30\xf8\x74\xb3\x8d\x56\xd6\x15\x12\xdd\xa0\x0d\x0f\x19\xbd\x45\x24\x20\xea\xd6\x6f\x8c\x6e\x1e\xcc\xaa\x1a\xd8\x80\x89\xc1\xc5\xa6\x18\x56\xc9\x99\x30\xb6\x96\xd7\x69\x72\x05\xb8\x12\x8f\x87\x4e\x8e\x3d\xfd\x42\x98\xba\xb3\x5a\x27\xc3\x3e\xc0\x34\xdb\x80\xd8\xcd\x80\x11\x97\x00\xa4\xd9\xa4\x51\xcb\xd4\x0c\x39\xd9\x3a\x96\xbe\xbc\xe3\xa3\x6f\xbb\x0a\x0d\x73\x95\x42\x26\x03\xdc\x3e\x37\xc2\x94\x16\xa8\xdd\x72\x30\xa4\x78\xec\x52\x94\x8a\x43\x79\x2f\xe5\x46\x82\x2e\x82\x60\x35\x6a\xa9\xa3\xae\x2a\x21\xad\xb0\x6d\xa7\xd1\x30\x73\x82\x76\xa1\x58\x21\x80\xc6\xe2\xc0\x40\xf1\x80\x36\x0c\xcc\x60\x0c\xcb\x17\x20\x40\xf7\x45\x8b\xb5\x17\xc5\x40\x90\xaf\xd5\x9e\x7a\x56\x84\xb3\x2c\x16\xb8\x8b\x0d\xd5\x34\x14\x93\x69\x59\x20\x84\x43\x7d\x46\xd6\xae\xc7\x2a\x9d\x4a\x31\x6f\x86\x7c\x7e\xd4\x77\xe4\x14\x34\x1a\x05\xc2\x6c\x55\x71\xb4\xed\x10\xc4\xfa\x5d\x05\x2e\x5e\xd2\xde\xf7\x05\xbd\x17\x8d\x66\x5b\x6f\xd7\xba\x2a\xdd\x42\x11\xb9\x5c\x8f\xc8\x3c\x33\x8e\x0f\x2c\x10\x2c\x5b\xd1\x1b\xad\xbd\x56\xbd\x99\x25\x18\x56\xb7\x63\x43\x37\xcc\x28\x8c\x4e\x6f\x97\x73\x6a\x86\x12\x18\x49\xf0\xf2\x9a\xce\x37\x80\x9a\xe9\xaa\x4a\xdb\xc2\x49\x8c\x86\x85\xb6\x50\x14\x9d\xd3\xc6\xdc\xac\x83\xcb\x95\x5a\xb0\x50\xda\xe2\xcb\x9d\xbc\xda\x94\xb0\xba\xc4\x6a\x56\x45\x1a\x59\x46\xd2\xf6\x92\x0c\xda\x72\xc3\x60\xe9\x9c\xbe\x78\xd9\xd4\x74\x2c\x87\x0e\xf2\x0d\x14\x9f\x1c\xef\x02\xc8\x65\xfa\x06\x7c\x69\xec\x53\x40\x1e\x18\x82\xe1\x11\x4c\x3e\xe8\x1c\x2c\x56\x05\xf3\x3b\xef\xfd\xbf\x7c\xbe\x94\xf1\xbb\x5d\x2c\x4b\xa8\x1a\xe0\x22\x7e\x2d\x90\x1c\xad\x19\x92\x64\x62\xf7\x57\x59\x9a\x56\x7c\x4e\xba\xa9\x43\x49\x52\xb5\x26\xc1\xaa\x35\x85\x30\xfc\x56\x32\xd4\x5a\x94\x80\x11\x1c\x9f\x04\xe4\x4d\x4d\x2a\x03\x8f\x13\xc1\xc8\x49\x36\x99\xbc\x20\x85\xb5\x36\x14\x69\x9b\x76\x12\x76\x14\xb1\x18\x39\x42\x58\xab\xda\x45\x44\x68\x75\xce\x5b\xc1\xd4\x36\x39\xab\x6b\x65\xf1\xe2\x72\x88\xe3\xcd\xcf\xfc\xd8\xc7\x87\x3f\x6e\x35\x42\x96\x9a\x08\x94\x89\x30\x30\xa4\x12\x90\x1b\x6d\x20\x37\x5b\xc0\x13\xf4\x3f\x46\xf1\xfa\x06\x9e\x4a\xde\xc0\x8c\xde\x6a\x21\x50\x2c\xb6\xd8\xb6\x9c\x8d\xb1\x60\x03\xa2\xae\xfc\xb7\xa2\x81\x1d\x06\xba\x01\xdf\x36\x1d\xc2\x2e\x0b\xda\x64\xc8\x96\xd3\xf7\x15\x80\x25\x21\xf0\x27\x7b\xfb\x79\x67\xbb\xa3\x3f\xfd\xe4\x47\x4e\x3e\x0f\xea\x79\xc8\x75\x2a\xc0\x3b\x34\x7c\xaa\xba\x4b\xfc\x46\x50\x2e\xff\x01\x2f\x52\x1d\x7c\xae\x6c\x77\xdf\xb6\x5e\xee\x45\x1d\xeb\x5c\x8c\xee\x71\xbb\xf4\xeb\xfe\xa2\x00\x74\xd8\x34\x64\x73\x1f\x84\xe5\x21\x6c\x35\xc9\x11\x3e\x96\x98\x32\x5b\x72\xdb\x41\x94\x2f\xd2\x0c\x54\xba\x91\xb8\x47\x77\xba\x2d\xe3\x88\x40\xe0\xbe\xbe\xbe\x57\x44\x3d\x54\x03\xb0\xcb\x89\xf0\xa3\x98\x2d\xbb\xf7\x96\xf7\xfa\x2b\x85\x6a\x14\x3b\x38\x59\xcd\x16\xa8\x63\xa3\x33\x7b\xdf\x78\xfd\xe5\xe0\x5f\xbc\xf6\x27\x7e\x8a\xa0\x9e\xc2\x20\x8e\xba\x58\x84\x80\xc0\x09\x60\x62\xf8\x68\x6b\x20\x31\x5c\x66\x79\x7a\x43\x10\x88\x35\x86\x05\x05\x7b\xa7\x26\xc9\x18\x2a\xe9\x97\x14\xd5\x5f\xa9\x95\x83\xa5\x72\x21\x88\x8f\x2d\x84\x7c\x11\xc3\xe1\x10\x4b\x0c\x47\xed\x09\x0e\x62\x83\xa4\x40\x53\x55\x74\x06\x22\xce\x27\xc9\x6a\x64\x37\xb5\x3d\x9c\xca\xec\x26\x0a\xc5\x9c\xbf\x23\x4b\x94\xd3\xe1\x32\x4f\x4f\x9f\x43\xa2\xc3\x5d\x35\xda\x8e\x9a\x56\x25\xf7\x49\xc4\x70\x7b\xfb\x7b\xa1\x74\x6a\xf7\xd1\xe9\x89\xb9\x5c\x29\xb5\xcb\x5f\xbf\x7d\x69\x0a\xff\x26\x3e\x18\x1f\x46\xc7\x26\x4f\x96\x1c\x2e\xf7\x62\x2d\x85\x65\x9e\x49\x68\xba\xa1\xc5\x97\xd7\x6e\x4d\x2f\x2c\x5e\x1f\x97\x54\xd9\x64\x69\x16\x26\x63\x43\xd4\x99\xd3\x8f\xe5\x65\x49\x95\xda\xf5\x46\x88\xc4\xf6\xe4\xf5\x7a\xda\xb7\x97\x17\x67\xc3\x5e\x8c\x43\x2c\x57\xa4\x28\x46\x52\xcb\x9d\x61\x59\x6d\x78\xb0\x6a\xf6\x1a\xc8\xe0\x70\xd8\x30\x28\x9a\x2a\x72\x5e\x7e\x9d\x60\x28\xe9\x81\xf4\x76\x2f\x75\x71\xbf\xaa\x6c\x05\x08\x5d\xd7\x61\xeb\x60\xbf\x5f\xaa\x94\x46\x0d\x55\xf6\xf4\x0f\x0d\x6d\x35\x9b\x99\x00\x0b\x88\x48\x24\x14\xaf\xd1\x4e\xc7\x2e\xb6\x05\x6f\xd0\xc7\xb8\x0b\xc5\x54\x68\x63\xe5\x20\x5a\xad\x15\x7c\x78\x9e\x9d\xe3\x83\x53\xd2\xc8\xd8\x91\xbf\x28\xac\xa7\xfb\x3b\x1d\x59\x4e\x46\x92\xde\xb5\xfd\x3b\xe3\xf5\x52\xf9\x78\xc4\xed\x6f\x6e\x6d\xde\xbe\x70\xe5\xd6\xdb\x93\xb2\x26\x93\x18\x74\xf4\x5a\xb5\xc0\x9e\x3b\xf6\x68\x92\x73\x88\xaa\x47\xa0\x76\x58\x07\xac\x2b\x6d\x85\x05\x1d\x2a\x84\x40\x67\x38\x5b\xdc\x9b\xde\xd9\x5d\x3f\xbe\x75\xb0\x1e\x36\x81\x41\xcf\x8d\x9f\xa6\x46\x07\xa6\xf6\x07\x13\xfe\xbf\xe8\xd4\xc3\x99\x4e\x53\x56\x87\x47\xe3\xfb\xeb\x5b\xf3\x2f\x25\xfc\xfd\x73\x6e\x7f\xe0\xab\xd8\x69\x76\x4b\xa9\x94\x3b\xec\x8e\x70\xa6\x8b\x1d\x5a\x5e\xb9\xf6\xc8\xd9\x99\x87\xfb\x9a\xf5\x42\xed\xfd\xf9\x77\x1f\xda\xcf\x6c\xf7\x51\x34\xdd\xe6\xb1\x01\x30\x73\xc4\x70\x2c\xdc\xe7\x11\x48\xb0\xd5\xe7\x85\x4b\x38\xf8\xb6\xa5\xba\x41\x2b\x79\x35\xa1\x02\x79\xb8\x21\x95\x87\xb2\x85\xd4\x98\x61\xe8\x51\xbf\x27\x04\xdc\x4e\x4f\x91\xa6\x98\xeb\x1c\x4d\xbd\xc3\x7a\x98\x2d\xdb\x70\x35\x6b\x2d\x0c\x36\x1f\x03\xd9\x8e\x69\x41\xb6\x6e\xb9\x21\xb2\x4b\x1f\xf8\x89\xff\xa8\x10\x19\x96\xc4\xb5\x42\x1c\x76\x60\x43\xef\x60\xdd\x8a\x25\x25\xcb\x98\x7b\xfb\xab\x46\x39\x97\xae\x88\x9b\x4f\xbe\x7c\xf0\x8d\xcb\x0e\xe7\xa9\x91\x71\x21\x16\x52\x99\xd5\x3d\x44\xe6\x0a\x80\xcc\x98\x80\x3d\x73\x14\x18\x61\x07\xbd\xf4\xcd\xcc\x9f\xf8\xb2\xc3\x2f\x5b\x4a\xb1\xe9\x45\x18\x32\x30\xa2\xb5\x64\x7c\x78\xcd\xbe\x93\x86\xc5\xc6\xe8\x8e\xb5\xc8\xce\xe2\x6d\x98\x62\x68\x84\x5d\x72\xb4\xdb\xbd\x71\x90\x68\xeb\x2a\x98\x9c\x8e\x83\x0e\xe3\x03\xd7\x6e\x1c\x80\xa4\xd8\x00\x9a\xd9\xc4\xd1\x8a\x01\x54\x99\x04\x55\x5e\x81\x22\xef\x41\x0c\xd6\x23\x12\x92\xb1\xa4\x60\xc1\xbd\x1c\x6c\x17\x48\xcc\x06\x02\x53\xe7\xdc\xd4\x6c\x46\x85\x6a\x5e\x37\x68\x59\x37\x88\x30\xc6\x8e\x08\x8e\x33\x17\x0d\x3d\x05\x4d\xfd\xb2\x92\xaa\x58\xc4\xa4\x9c\x4d\x11\x57\xbf\xfb\x95\xa6\x7f\xf6\x14\x0f\x45\x37\x69\xd4\x4a\x7a\x65\x7f\x5b\xc1\xea\x09\x7d\x5b\xee\x54\x65\x73\xc7\x76\x4c\x4b\x08\x23\x57\x85\xe4\x3a\x7e\xfa\x89\xd6\xd9\xd1\x24\x4f\xd1\x2a\x6a\x75\xf0\x00\x69\x73\x60\x79\xf3\xb6\x50\xae\x5c\x33\x2d\x38\x57\xac\x3a\x16\x38\x56\x9c\x22\x8e\xb6\x27\x00\xc5\xb6\x94\xba\x7b\xbb\x91\x72\xae\xa0\x55\xc8\x82\x36\x6d\x58\x6e\x8c\x87\x98\x31\xac\x76\x3a\xdd\x08\xba\x91\xa4\x93\x88\x1e\x48\xd0\xc8\x27\x26\xb5\x57\x16\xdb\x12\x5d\x6e\x19\x14\x43\x30\xba\x03\x66\x2a\xa0\x9c\xdf\xd6\x41\x13\x4b\x5b\x91\xa4\x50\xbd\x20\x23\x4f\x80\x03\x7e\x8f\x0b\x88\x84\xda\x05\x90\x61\xfd\x25\xf4\x6a\xfe\x1d\xe8\x34\x5e\x41\x97\x6a\x00\x70\x2d\x16\x9f\x58\x07\x55\x9b\x05\x2b\xfd\x62\x68\x9a\x61\x18\x1c\x0d\x16\xdf\xae\x32\xf0\x61\x95\x64\x5c\xb4\x15\xc9\xa0\x75\x9b\x02\xde\x15\x21\xfa\x66\x8e\x02\x89\xa6\x90\xc6\x8a\x90\x64\xf1\x80\x52\x94\x8d\xee\xc0\x2e\x8b\x19\x76\xce\x53\x96\x2d\x17\x34\x3a\x3c\x80\x0a\x06\x70\xca\xd2\x1c\x14\xb4\x09\x00\xe4\x19\x96\x90\x08\x8c\x79\x9a\xcd\x53\xec\x2a\x1c\x61\x7d\x83\xf1\x45\x95\x0d\xd8\x6c\x37\xb9\xdd\x74\xb5\x53\x28\x0c\x6a\x7e\x0f\x49\xeb\xa6\x1b\x0f\x92\x8c\x35\x2b\x0f\x4a\xa9\xbc\x69\x36\x37\x7e\x6b\x68\x92\xf9\x26\x24\x69\x3c\x34\x50\x31\xed\xfa\x33\xbc\x97\xf6\x41\x76\x59\x11\xc2\xae\x2a\xee\x0a\x0d\xd3\x56\xa3\x56\x38\x00\x10\x1d\xa6\x85\xec\x74\xa9\x65\xc1\x76\x44\xb6\x79\x93\x65\xff\xdb\x3b\x29\xc7\x5e\xa6\x71\xe1\xe7\x7f\x71\xe0\x05\xad\xb6\x03\x96\x8a\x0e\x20\xc6\x42\x80\xdf\xde\x02\xe4\xc4\x91\x89\xe2\xda\xca\x3f\x0d\x22\xe9\xf7\x79\x0f\xdb\x40\xba\xc1\xf5\xd4\xfa\x21\x6d\x85\xbd\xae\x6f\xa2\x57\xf3\x25\x0e\x3b\x4d\x0f\xd7\x91\x59\xa6\x57\xaf\xb6\xfd\xeb\xbb\x85\x01\x57\x70\xfa\x39\x7f\xdf\x98\xc0\x3a\x1d\xa0\xb9\x74\xd3\x10\x85\xe6\x6b\x08\x8f\xea\xbd\xd2\x9f\x7d\x4e\xf7\xc1\x02\x75\x9b\xce\x0f\x4b\xc9\xe8\x90\x3a\x43\xbb\x7b\xce\xb4\x14\x9e\xa0\x28\x8a\x07\x6f\xc4\xd0\x14\xd4\x53\x07\xfb\xee\x63\xc7\xa6\x33\x9f\xfe\xe8\xa7\xae\x6c\xec\x6d\x05\x3b\x52\x87\x25\x2c\xfc\xee\xa5\x1e\x3a\xed\x16\xbd\xb8\x35\x1f\xe2\x18\xbe\x3f\x1a\x8a\x12\x26\xc3\x14\x0c\xa4\x57\xb0\x27\x8a\x00\x72\xc1\x5c\xf1\xa0\x2f\x97\xcf\x8d\x2d\xac\xcf\x07\x1a\xed\x86\x7d\xb8\xf1\xe4\x14\x31\x3b\x7e\x6a\x00\x21\x86\xe5\x18\xba\xd2\xaa\xd4\x19\x92\x70\x04\x64\xb3\x13\xb8\x7c\xe3\xbd\x99\xad\xdd\xcd\x7e\x6b\x09\x6d\x34\x12\x2d\x8c\x25\x46\x6a\xe5\x6a\xc5\x5d\xae\x95\xa2\x1e\xb7\x5b\xa6\xa1\x46\xe6\x76\xf7\x26\x12\x91\x3e\x53\x53\x6a\x9e\x6a\xa3\x44\x14\x4b\x99\xd0\x8d\xc5\xcb\x91\xb6\xdc\x52\x8f\x4e\x4e\xac\x15\x4a\x79\xd7\x3b\xd7\xbe\xd3\x7f\xf6\xf8\x05\x62\x30\x39\x50\x6f\xb6\x5b\xd4\xdd\x95\x5b\x27\x72\xb9\x54\xec\xc8\xe4\xe4\xf6\xdc\xcc\xc9\x75\x49\x96\x18\x5d\xd7\xe8\x60\x40\x28\x94\x16\x53\x71\x1a\xe8\x9e\x44\xa2\xaf\xc2\x39\x14\x27\xde\x71\x5f\xd0\x17\xd2\x83\x41\x57\xce\xe5\xa4\x7d\xa9\xcc\xde\xf4\xc2\xf2\xfc\x40\xb1\x5c\xf0\x8e\x26\x26\x84\x78\x64\x10\xb9\x7c\xe2\xdd\x80\xe8\xa4\xbd\x41\x21\x6d\xeb\x0c\xa2\xb7\x10\xac\x9b\x8b\xb7\x59\x86\x9d\x93\x27\xa0\xd9\xac\xb7\xd8\xc2\xb6\x39\xce\xd2\x60\xc0\xe3\x72\xd0\x47\xa6\x87\x3a\xef\xdf\x79\x67\x86\xc1\x10\x55\x69\x14\xb5\x4a\x66\xe9\xc9\x9d\xfd\x6d\x7f\xb5\x5e\x61\x71\xe4\xd1\x42\xc1\x70\x7d\x60\x68\xb0\x96\x88\xc7\xb7\x87\x07\x87\x33\x9d\x8e\xe4\x6a\x6c\xe5\x3f\xee\x12\xbd\xc8\x13\xa3\x2b\xe9\x2b\x5b\xe7\x81\x0a\xe1\x5b\xd7\x5f\x73\xb6\xa4\xc6\xb1\xb3\x0f\x3d\xb4\x7a\x74\x6a\x66\xcf\xef\x0f\x34\xbe\xfd\xea\x37\x2e\xd4\x5b\xd5\xa1\x40\x22\x10\x49\x4e\x85\x8e\x22\xa0\xf4\x75\xaa\x5c\xb8\xd5\x6e\x85\x6e\xde\xba\x39\x7b\xe7\xce\xfc\x98\xc3\xe9\x28\x3f\xfd\xcc\x8b\xf3\x58\xe9\xb4\x17\xe7\xef\x3c\xa5\x99\xda\xa0\xd7\xeb\x9d\x8c\x0f\x04\x9b\x22\xef\x52\x01\xad\x4d\x2b\x8a\x34\x4d\xb2\x74\xc3\x17\x75\x1b\xbb\x3b\xbb\xcf\xe2\xf7\xd1\xe8\x60\x70\x6f\x79\xeb\xd6\x88\xa4\xb4\xe3\xb7\x56\xaf\xeb\x85\x72\x6e\xc6\xe7\xf7\xa5\x3f\xf1\xf1\xcf\xbc\x32\x32\x38\x96\x5a\xdd\x58\x1c\xc8\xec\xa5\x5f\x0c\x05\x63\xce\x48\xc8\x9d\xe8\x9f\x0a\x4c\x68\x92\x4e\x35\xa0\x36\x90\x6a\xa7\xc6\xd2\xe9\x83\xd3\x77\xee\xde\x9a\x48\x17\xf6\x29\x4b\x99\x84\xfd\x11\x78\xe1\xf8\x93\x94\xd3\xed\x1e\xf7\x85\x7d\xc6\xd8\xb1\xb8\x35\x84\x3a\xea\x05\x56\xc3\xce\x24\x75\x0b\x3a\xbd\xc2\x9a\x9d\x3d\x34\xbb\x19\x26\xd3\xca\x34\xd9\xaf\x2d\xed\x61\xbd\x35\x90\x5d\x8f\x99\x3c\x96\x34\x6f\x2d\x2e\x96\x37\xef\xec\xae\xd7\xff\xa4\xfd\xe5\xf2\x41\xe9\xf1\xd3\x9f\x3c\xf7\x44\x74\xbc\x0f\xb3\x4b\xc5\x20\xca\x55\x60\x2c\x6f\x33\xcb\x2b\x07\xeb\x40\x61\xbf\xca\x3c\x6c\x02\x93\xab\x47\xe3\xda\x08\x30\xac\x74\x13\xde\xa9\xad\x71\xba\x3d\xb3\x38\xb6\x59\x29\xa8\xae\x90\xb7\x5e\x77\x8f\x6e\xda\xe7\xe6\xc4\xef\x72\x6d\xfc\xbe\x59\x45\xc9\x84\x05\x0e\x7e\xc4\x22\xbf\xed\x76\xa6\x0f\x00\xaf\x45\xdd\xac\xb3\xc3\x17\xc4\xd9\xa1\x0a\xa1\xc3\x4e\x8e\x6e\xcd\x18\x69\x4c\xa3\x39\x92\xe0\x08\x3e\x68\x77\xc5\x00\xeb\xa6\x4f\x04\x6f\x22\x7a\x45\x86\x60\x9d\x74\xfe\xa5\x27\xc1\x17\x08\x83\xe0\x48\x1c\x92\x28\x89\xf8\x46\xb9\xd9\xd8\x7c\xef\xa2\x19\xc4\x21\xab\x2e\xab\xdc\xb6\xc0\xf3\x19\x57\xd2\x4a\x56\x5a\xf5\x4d\x7c\xa2\x86\x55\xcd\x04\x48\x0f\xe0\x11\xd1\xf5\x7a\x07\x23\x80\xa6\x02\x4c\xda\x5c\x88\x32\x64\x1e\x9d\x98\x79\xc8\x98\x5f\x73\x91\x3a\x78\xcb\x35\x20\x2a\x9d\x56\x65\x38\x3d\xa7\x46\x45\x9f\x53\x32\x21\x14\x5a\xb3\x4a\xd8\x79\x53\x4a\xc4\x97\xe1\x0d\xc2\xeb\x4e\x43\x37\x0e\xc0\xd6\x15\x98\x18\x53\xab\x95\xbd\x76\x2c\x3c\xd1\x14\x58\xe0\xa1\x19\xba\xea\x77\x86\x38\xd1\xd3\xa2\xd8\xba\x7f\x6d\x02\x89\x38\xa2\xb5\xfb\x2e\x19\x15\x27\x46\x77\x5a\x44\x20\x88\x23\x09\xe0\x19\x48\x30\x26\x52\x75\xbd\x0b\x20\x22\xe2\xc1\x52\xf9\x36\xda\x51\xbe\x02\x98\x5d\x77\x2f\xdb\x62\x39\x0b\xad\xe1\x40\x5c\xcf\xe6\xdb\x0d\x03\x39\xe3\x51\xbf\x44\xec\x94\x6a\x82\x18\x0a\x71\xba\x6a\x60\x4d\x01\xbc\x15\x03\x86\x35\xff\x10\xcd\x0e\x32\x1c\x52\x34\x1f\x2d\x08\x02\xc5\xf2\x2c\xc5\x71\x94\x2a\xa9\xa4\x83\xac\x51\x8c\x8b\x02\xf9\x2c\xac\x2a\x79\x70\xe7\xcf\xdf\xd0\x6a\xec\xbe\xda\x4c\xc6\xf0\xa5\xf1\x4e\x20\x35\x08\xb8\xd1\xbe\x01\xcf\x2b\x73\x10\x4d\x1a\xa0\x83\xa1\x43\x22\x39\x48\xea\x2a\x04\x82\x01\x19\x86\x03\x8d\x3c\xd3\xde\xdd\xce\xa8\xff\xe6\x7f\xbd\xb8\xe4\xe5\xd9\x98\xb3\x3f\x3f\xf7\x63\xbf\xf0\x4f\x3f\xd4\xc8\xd7\x41\x2b\x57\xfe\xf7\xd1\xc1\xf1\x7f\xd7\x56\x79\x07\xa6\xea\x94\x35\x93\x34\xe6\x6e\x34\x4d\x13\x04\x0e\x63\xdd\xf5\x27\x24\x86\x23\xab\x93\xc8\x34\x48\x82\xa4\xf0\xd7\x8c\xbd\x46\x98\x42\x94\x7d\x67\x2f\xc3\x16\x3b\xb6\xc6\xc6\xd6\x4b\x74\xfb\x79\xac\x2f\x70\xb4\xd0\x34\xb8\x7b\x6d\x67\x60\x3b\x55\x6c\xed\xef\x07\x2a\x51\x37\xed\xa3\xdc\x21\x40\xf9\xc2\xa0\xb6\xb4\x03\x42\x51\x1f\x36\xad\x91\x89\xc2\xc6\xfe\xe7\xbc\xa2\xef\xb7\x38\xaf\x98\xc3\x06\x4b\x77\x19\xbb\x5d\x0f\x26\x50\x57\x26\x74\x2d\xb6\x6b\xb9\xc4\x61\xff\x07\x46\x35\x72\x63\x6d\xc5\xd9\xce\x96\xce\x0e\x26\xa7\x9e\x63\x02\x09\x8a\x13\x69\x50\xdd\x4b\x63\xd0\x15\x18\xe8\xf0\xe5\x00\x05\x39\x8c\x1a\x64\x37\xfb\xdc\xdd\x97\x5d\x4c\xb7\xa4\x35\x96\xd0\xf8\x92\x30\xbf\x31\xac\x92\x42\xaf\x79\xb3\x2b\x57\x0c\xcc\x5b\x48\xb7\x2e\x31\xce\x6a\x07\xca\x26\x0e\xe1\x26\x55\x6b\x69\xa1\x4b\xd7\x16\xbc\xc1\x60\xa0\x15\x8d\x8d\xd4\x05\x9e\xab\xdb\xce\x8b\x1f\x82\xe0\x90\xfc\x01\x7f\xeb\xea\xcd\x77\x47\xcb\xe5\xd2\x09\x8f\xd7\xcf\xf3\x58\x2f\x28\x0a\x39\xcc\x70\x3c\x7f\x7b\xe9\xea\x28\xa5\xd3\xe3\x91\xf0\x80\xec\x0b\x45\x96\xf1\x61\xdb\x2d\xa9\x09\xaf\x5e\x7f\x6f\x86\xdb\xe1\x5d\x33\x33\x27\x60\xa9\xa1\x84\x3a\x0d\xd4\xef\xf6\x03\xe2\xfa\xfc\xf5\x13\xb9\x42\x21\x3c\x38\x38\xb6\x7b\xec\xc8\x89\xcd\x80\x27\xd4\x72\x8a\x8e\xd6\xb5\x5b\x97\x4f\xf1\x94\x0b\x32\x3c\x9b\x3d\xc8\xe4\xfd\x9b\x6b\xfb\x53\x4e\x31\xbc\x57\xa8\x96\xbd\xd6\xd5\x6c\xec\xae\xc0\x64\xff\xf0\xfa\xcc\xd4\xec\xa6\x28\x88\x8d\x8e\xdc\x11\xdf\xbd\xf6\x4e\x07\x03\x4a\x53\xc3\x48\xb6\xb8\xb2\x30\x4b\x20\x2a\x71\xe2\xd8\x43\x77\xe3\x91\xd8\x26\x01\x8d\x62\xac\xcf\x5f\xd3\xf1\xf5\x6d\x6f\xef\x86\xd3\x07\xd9\x20\x9e\x03\x2a\x12\x0a\x54\x33\x07\x7b\x01\x37\xef\x15\x5d\x4e\x77\x49\x95\x25\xe3\xdb\x57\xde\x7c\x72\x69\x63\x29\xec\x70\x38\x6a\xd8\x46\x94\x74\x6e\x5f\x74\x0b\x3e\x9a\xc3\x26\xa7\xd4\x49\xb2\x65\x36\x68\xcb\x06\x1e\x6c\x02\x38\xc4\x69\xd8\x15\x7a\x28\x93\x2e\xbb\x33\xdb\xbb\xa1\x46\xad\xe2\x8c\x45\xa2\x35\xa9\x53\x81\x99\xfd\x54\x42\xd7\x74\x73\x63\x6f\x99\x12\x1c\xbc\x18\x8f\x44\x0f\xe6\x66\xa6\xf3\x18\xb8\xea\x1c\xc7\xb5\x02\x01\xb1\x4c\x91\x66\x3b\x9d\xd9\xe3\x17\xe6\x37\x8f\xe4\xb3\xd5\xe1\xb3\x67\x03\xeb\x0b\xb7\xdf\x8f\x03\x19\x04\x35\x2c\xeb\x03\x01\x77\xea\xf9\x13\x4f\xac\x90\x80\x41\x4a\xa9\x0e\x30\x1b\x21\x48\x93\x70\x70\x2c\x23\x31\xa4\x94\x5e\xbf\x75\xdd\xa9\xb6\xcd\xa8\xd3\xe7\xa1\xaf\xdf\xba\x7d\x3e\x9f\xcf\xc6\x8f\x4d\x8e\xdc\x3e\x76\x64\x76\xc9\x1f\x08\x34\x5f\x7f\xe7\xed\x39\x17\xef\xe1\x20\xd4\x6b\xa6\x52\x96\x0f\x36\xd6\xc6\x4f\x9e\x9a\xd9\x98\x5f\xbd\x3b\xe6\x15\xfd\xbc\x4b\x24\x36\xe5\xfa\x81\xb6\x76\xe7\xd6\x71\x9f\xc7\x8f\x34\x25\x57\xde\xde\x58\x9f\x75\x3b\x5c\x50\x33\x2a\xe5\x67\x9f\x38\xbb\x90\x88\x24\x33\xe5\x62\x5d\x00\x52\x89\xd5\xe4\x5a\xc0\x25\x78\x18\x9e\xd7\x32\xa4\x99\x81\xcb\xef\xad\xcc\x39\x84\x90\x6b\x75\x6f\x7b\x34\x93\xa9\x5c\x18\x49\x8c\x09\x8f\x3d\x74\x6a\x49\x33\x66\xb3\x38\x70\xca\x97\x6f\x5c\x3d\x36\xbf\x7c\x65\xe2\xf4\xec\x49\x1e\x1b\xac\x4f\x2b\xed\xf7\xc3\xee\x5d\x36\x0e\x0b\x04\xdd\x2a\x7d\xaf\x5c\x66\x1e\x52\x22\x13\x1e\xd6\xa1\x0e\xfb\x05\x6c\xe5\x47\xf6\x38\x3d\x0e\x57\xe8\xdc\xb4\xcb\x3c\x3a\x34\xa4\x2c\x2f\xef\x14\xb2\xeb\x37\x2e\x5e\xf9\x62\x51\x1d\x7b\xe2\xe4\xf9\xc4\xa9\xa3\x3e\xb2\x2d\x1b\x2b\x97\x16\xda\x5a\x2e\xfd\x17\x83\xc7\x5d\x0d\x93\x2d\x8e\xb8\xed\x2a\x8d\xdc\x4d\xf0\x02\xe2\x30\xc9\x64\xc3\x97\xdd\xa5\x08\xed\x2a\x8b\xfd\x1a\xdd\xbb\x65\x80\x5d\x82\xec\xae\xb1\xb7\xdb\xc2\xd8\x6e\xb9\xa3\x5b\x8b\xef\x95\xf8\xee\x75\xea\x76\x13\x03\x5d\xb5\xdf\x4b\x06\xd8\x8d\x65\x46\x69\x47\x6f\x6c\xb5\x3a\x46\x8c\xa7\x9d\x18\x3c\xe8\xb6\x64\xb2\xb7\x65\x52\xb9\xc1\x3b\x5e\x0b\x0d\x45\xaf\x61\x20\x77\x9a\x5d\x22\x69\x81\x8f\xc9\x6b\xee\xbb\xba\x6a\xea\xa0\xa1\x73\x62\x4b\x8a\xab\xb2\xda\x67\x4a\xa6\xc2\xb8\x5d\x25\x82\x67\xca\xc0\xcb\xaa\x26\x69\xf7\x65\x22\x7e\x23\xfd\xbe\xef\xe6\xb2\xb3\x76\x6c\x62\xa0\xce\x50\x06\x87\x28\x9d\x63\x49\x68\x4e\x8f\x4e\xab\x57\x36\x88\xaa\xa1\xbe\xd6\xdf\x37\x7c\xc5\xbb\xb6\xe4\xd1\x4e\x21\xa7\x83\xe2\x15\xc0\xb3\x46\xeb\x11\xd6\xbf\x15\x6e\x5e\x18\xbe\xaa\xdc\x72\x78\x06\x37\xd4\xa1\xa0\xd5\xb5\x07\x89\x6c\x25\xc3\xef\x67\x84\x96\xc8\xc7\x1b\x4e\x37\xa2\x06\xfd\xce\x88\x9b\xa7\x89\xa0\x1b\x76\xc2\x39\x52\xf7\x70\xec\x01\xaa\x39\x87\xde\xd2\x6b\x58\xcc\x21\x9d\x01\xa0\x15\x74\x11\xda\xf8\x90\xc9\x46\x19\xd4\xab\x81\x00\x80\x05\x0b\x10\x48\x01\x90\x90\x7f\xb0\x87\x06\xab\x2f\xa5\xb1\x73\x90\x5f\x49\xef\x24\x26\x8f\xce\xe9\xe4\xed\x6f\x6d\xfa\xc3\xb3\x71\x0f\x41\x68\x71\xac\x4d\x74\xac\x4d\x1c\xba\x81\x5a\x9c\xdb\xc7\x30\x86\xee\xc7\xd2\x37\xc1\xb0\x7c\x40\xf0\x39\x1c\xbb\xdf\xdd\x72\x9d\x9f\xea\x50\x52\xdb\x01\xf6\x76\xe4\xef\x15\xf3\xcb\xd7\x90\xfb\x34\x60\x8a\x86\x11\xe2\x0d\xd0\x6c\x74\x80\xd9\xf2\x80\xaf\x5f\x7a\x15\x9c\xc9\x9c\x02\x8d\x9f\x6e\x00\xdd\x1f\x03\x7b\x58\xa7\x10\xc5\x14\x20\xdc\x1a\x78\xfb\xfa\x9f\x80\x5c\x76\xbf\x85\xe7\x28\x5d\x6e\x54\x5e\x57\x0d\x3d\x84\xe6\x2f\x9d\x28\x67\x32\x9b\xc7\x4e\xcc\x1d\xa5\x77\x5a\xff\x61\x73\x7e\xb5\x7e\x20\x2b\xad\x29\x81\x07\xe1\x81\x08\x94\xa0\x0c\xb6\x0a\x39\xc8\x4a\x14\xec\x8b\xf7\xa3\x1d\x79\x17\x39\x4d\xd7\x6c\x7f\x72\xe4\x69\xa1\x44\x42\xc9\x25\xbf\x46\x8b\xcc\x8e\xb3\xe2\x2a\x2b\xb4\x46\xaa\x6e\x24\x62\xf6\x6a\xc1\xbd\x95\x99\x87\x5d\xfb\x25\x6d\x00\xa0\x19\x12\xa8\x65\x2d\xb7\xbb\xbf\xd9\xf8\x97\xbf\x96\xca\xfc\xfa\xaf\x3f\xfe\x33\x43\xd1\xab\xf1\xc6\x92\x0c\xfc\x91\x20\x68\xd6\x4d\xe0\x8b\x85\x01\x41\x92\xd3\xd9\x85\xdd\x5f\x80\x6b\xf9\x9f\x21\x28\xd2\xba\x35\x00\xf9\x81\x3e\xc0\xee\x1d\xa5\x90\x9d\x17\xc3\x9a\x88\xb2\x73\xc3\xfb\xb9\x3d\xe2\xf2\xb5\xb7\x26\xfd\xbc\xbf\x3d\x7a\xe6\x51\x4a\x8c\x7a\x81\x84\x25\xb7\xd6\x6a\x1b\xe5\xbd\xfc\xef\x76\x2a\xe2\x3b\xd8\x2a\xb9\x6e\xdb\x35\xb4\xc8\x0f\x86\x0d\x03\xb2\x1a\x0d\x19\x4d\x04\x65\x67\x1b\x76\x6a\x19\xc0\xf1\x1c\x3e\xac\x03\x9f\xb3\x66\x17\xe5\xb1\xc4\x83\x56\xc5\xb3\x52\x6a\x3a\xdb\x75\xf5\x0e\x50\xc9\x19\x2c\x06\xe3\x6d\x45\x72\x62\xc7\x22\x6b\xa5\x26\xb1\xbe\xbc\x6d\xa9\x32\x27\xa6\x67\x4e\x97\xe8\xae\x1d\x3f\x71\x7c\x21\x93\xcb\x79\xf6\x77\xf7\x06\x5c\xbc\x4b\xc2\x22\xed\x8d\x72\xbe\x93\x32\x90\xe6\xb8\xb9\xf8\x9d\xa3\x52\xb3\x31\x14\x0f\xf5\x9b\xb2\xaa\x68\xf5\x4e\x3d\x50\x28\xa4\x07\xf2\xe5\x3c\x23\xf0\x8e\x96\xdb\x1b\xbc\x62\x02\x76\x65\x6d\x69\xbd\xaf\x7f\xa0\x2f\xb3\xb0\xb4\x78\xd6\xc5\xfb\x3d\x0f\x9d\x1a\xfb\x6e\xd0\x1f\x5f\xc1\xe7\x4d\x76\x24\xd3\xbc\x76\xfb\xad\x59\x16\x52\xfd\xfe\xb0\xb3\xa4\x99\x70\x61\x7d\x6d\xff\xb8\xa6\x58\x86\x86\xb2\xd5\x5a\x7d\xba\x3f\x9c\x44\xc1\x70\xf0\x6d\x9a\xe4\x33\x77\x6e\xaf\x86\x09\x12\x49\x1e\x8f\x5b\x39\x3e\x7e\xfa\xba\xcb\xe5\x6c\x2c\x6f\xae\x0c\xeb\x2a\xe8\x1f\x1c\x18\x5c\x71\xb9\xc5\x2b\xfb\x07\x5b\x9d\x58\x3c\x98\xd2\x0c\x1e\x48\xb2\xe6\x6e\xb6\x3a\xc1\x76\xbb\xc3\x50\x24\xdd\x71\x7a\x1c\xd9\xcb\x17\xdf\x39\x3b\x1c\x9b\x30\x6a\xcd\x0a\x71\xf3\xca\x95\xb3\x2d\xb9\xd1\x7a\xea\xd1\x0f\xbd\x35\x9c\x1c\xc9\xae\x6d\xac\x0c\x55\x4b\xad\x08\x49\xc3\xac\xe0\xa4\x57\x10\x25\x15\x24\x1d\x28\xd0\x02\x79\xd8\x5b\xec\x81\xc0\xe1\x3a\x11\x8b\x4f\x60\xe6\xa7\x93\xb9\x42\xd1\x89\xcf\xd5\x67\x9a\x06\x35\x38\xd4\x97\xdd\x49\x6f\xc6\x62\x81\x7e\xb7\x2f\xe0\xdb\xf7\xfa\x9d\x77\x79\x8e\xd7\xac\x4c\x4d\xbb\xd9\x61\x35\xc5\xd0\x1c\x02\xa9\x2b\xba\x46\x29\x3a\x72\x95\x4a\x75\x6f\xb1\x54\x8d\xfb\xfc\xfe\x0e\x8e\xcd\xcd\xf9\xd5\x83\x13\xa3\x03\x53\x66\xa4\x2f\x70\xd3\xe5\x74\x1c\xac\xad\x6c\x0e\xec\x6d\xa7\x13\xe7\x1f\x39\x73\x6b\x63\x67\x33\x49\x03\x2e\x24\xb8\x84\x0d\x8c\xff\xe5\xcd\x8d\xec\xd0\xd8\xd4\x58\x65\x61\x65\x69\x8e\xa7\xdd\xb1\xf3\x17\xc6\xde\x8b\x86\x42\x9b\x96\x6d\xbd\x77\xed\xd2\x64\xfa\x20\x3d\x73\x6c\xec\x2c\x20\x59\xaa\x54\x69\x76\x28\x82\x72\x90\x56\xf2\xa6\x5a\x6d\x26\x46\xfb\x92\x2a\xe3\x12\xb7\x0f\x0e\x52\x9e\x4e\xc7\x74\xcf\x9d\x19\xbd\xb9\xba\xb7\x31\x10\xf0\xc4\xfc\x91\x68\x6c\x23\x91\x8c\xbd\x55\x29\x14\xdd\x6f\xbc\x71\xfd\x21\xbf\x2f\x5c\xe2\xbc\x2e\xb9\x58\xa8\x1f\xed\x0b\x0d\x4b\xac\xdb\xb3\xb2\x9b\x2e\x60\x1b\xf1\xfa\xae\xad\xcc\x8f\xad\xac\xae\x9f\x88\x78\x07\xf8\x74\x21\x25\x9b\xb0\xe5\xcf\xe4\xb3\x7d\xd9\x42\x4e\xc0\xd7\x87\xe6\xa6\x87\xe7\x3d\x91\xe8\x55\xca\xe7\x28\x18\x1e\x42\xc7\xba\x83\x04\xbd\x9a\x07\xbc\x7f\x1b\x28\x1b\x52\x48\x70\xaf\x67\x10\x7e\x7f\x57\x2d\xba\xaf\xd1\xbb\x90\x63\x55\x22\x49\x17\x21\x9a\xe1\xc1\x60\x7e\x65\xf5\x40\xda\xb8\x99\x52\xa4\x6f\x36\x77\x8b\xe5\xfa\x0b\x6c\x38\x34\x5c\xd9\xdd\xf9\xc6\xd4\xac\xe7\x22\xeb\x35\xa1\xa9\x5b\xa8\xa0\xf7\x00\xeb\x7e\xc7\xc1\xbd\xfb\x86\x74\x45\x87\x09\xee\xb7\x63\x99\xbd\x74\xa5\x69\xd3\x3e\x4b\xae\x74\x3b\x01\xd0\xfd\x85\x28\xb6\xe8\xe8\x76\x5f\x11\xdd\xeb\x39\xbc\xa9\x00\xbc\xb7\x8f\xee\xda\x08\x45\x04\xcb\x6b\xeb\x26\xfa\x4a\xb1\x3a\x13\xa4\x38\xa1\x45\x92\x25\xb3\x0f\xdc\x3d\x35\xac\xad\x08\xcc\x1e\xe6\x7a\x56\x53\x4d\x57\xf8\x74\x3b\x0b\x48\xb0\xb3\x02\x46\x0e\x32\xfa\x27\xd2\x53\x28\x21\xbb\x71\x7c\xc0\x76\xc8\x37\x8a\x35\xb1\x4c\xec\x44\x0e\xb8\xd5\x44\x10\xac\x8b\x11\xcc\x6e\xe6\x40\x51\xad\x48\x2f\x2f\xec\xdd\x9d\xcb\x46\x46\x67\x64\x97\x43\xd4\xb0\x51\xd2\x1e\xb7\xce\x3d\x3e\x39\x65\x7e\xf7\x4d\x49\xa0\xeb\x6f\x3e\x0c\xc1\x2b\xb7\xde\x6e\x3d\x54\x99\xd5\xa2\x5c\x44\x24\x45\x93\xd5\xd5\x23\x34\xb3\xce\x55\xe7\xfa\xdf\xbe\xcb\x7b\x53\x8e\x45\x2e\x62\x9a\xba\x4e\x01\xa7\x5c\xdf\x2a\x2c\x36\x8d\xda\xe0\x58\xc4\x88\x79\x59\x70\x77\xdd\xe1\x28\x38\xeb\x2c\x0f\xb0\xc8\x61\x51\x67\xd6\x41\x37\x57\x9a\xac\xbb\x00\x64\x89\xc3\x27\xc6\x52\x48\xa5\x59\x60\xba\x84\xae\x02\x39\x1c\xc1\xbf\xe6\xa1\x52\x24\x59\xdc\x4c\xad\x5c\x7f\xeb\xcd\x63\x1f\xfa\xdc\xaf\x70\xe2\xb8\x77\xd7\xb5\xfd\x66\xac\x6f\xf8\xe9\x51\x43\x2a\xb4\x19\x3c\x18\x01\x92\xa6\x24\x0e\x0a\x16\x61\x70\x61\x36\xec\x13\x02\x0e\x5f\x65\xbb\xee\x77\x14\x97\x3c\xa7\xfe\x05\x4d\x5e\xfa\x4b\x1e\xdc\x5a\xbd\xf5\xe5\x44\x1d\xa0\xba\x74\x07\xbc\xbf\xf4\x1d\x30\xe6\xfe\x3c\x78\xbb\xf5\x2d\xf0\xd4\xc4\x53\xe0\x97\x4e\x7d\x0e\xdc\x4a\xef\x80\xab\x1b\x5f\x07\xff\xe7\xaf\xbe\x0e\xf6\xbe\xb6\x08\x3c\x44\x06\xf0\x46\x00\xe8\x58\x26\xd1\x1c\x0f\x68\x8a\xd2\x3a\xed\x0e\x08\x91\x9e\x0c\x31\x48\xc8\x77\x36\x6f\x5e\xdf\xd9\xde\x28\xb5\xf4\x96\x0e\x31\x61\x94\x34\x2c\x30\xc6\x1f\x02\xe7\x07\x06\xc1\x4e\x6a\x0f\xbc\xfe\xe6\xcb\x96\x36\x06\x1d\xb9\xc9\xcc\x1e\x3b\xf5\xe3\x3f\xfe\x93\x3f\xfb\x3b\x62\xd0\x1f\x9a\x4f\x5f\x7a\xeb\xea\x9f\xbf\xf1\xf2\x85\x53\x8f\xff\x8b\x7e\x7e\x1a\xcb\xb0\xe6\xde\xbb\xdf\xfb\xe6\x97\x38\x67\xd0\xe8\x0f\x0f\x81\xae\x94\x35\xed\x3b\x61\x12\x78\x50\x96\x77\x6e\x82\x4c\x39\x5d\xe8\xb4\xda\xe9\x4a\x3d\x93\xfb\x97\xff\x53\xab\xf6\xef\x7e\xe7\xf9\x7f\x7e\x6c\xda\x37\xd0\xae\xe7\x41\xa9\xfe\x26\x90\xb8\x0f\x01\x87\xcf\x8b\xd5\xd0\xed\x77\x1b\x99\xea\x16\x41\x93\x7f\x65\x79\xc3\x83\xab\xc1\xad\x95\xe0\x4b\x1b\x37\xec\x3a\xf9\x4e\x61\x0b\x94\xaa\x05\xfe\xc2\xf4\x63\x2d\x48\x91\x2a\x1f\x70\x33\x52\xb5\x09\x5a\xe5\x9a\x4a\x19\x12\x5f\xd8\x69\x1d\x58\x4c\x8d\x24\x38\xb0\x93\xdd\x00\xc7\xce\xf5\x81\x78\x33\x0e\xf2\x37\xf2\xc0\xab\x24\xc1\xfc\xb1\x7d\x20\x67\x36\x41\x3c\x1e\x07\x82\xcb\x01\xac\x16\x26\x87\x40\x13\xbc\x48\x5b\xc5\x42\xe8\xf7\xd3\x50\x04\xe4\xb6\x61\xa0\x26\xe3\x60\x1c\x9d\x7a\x07\x56\x6b\x35\x80\xd9\xbc\xd5\x1d\xc5\xb2\x14\x1b\xf4\xba\x3d\x82\x37\xec\x2d\x66\x4a\xdb\x03\x77\x16\xaf\x3d\xcb\xd2\x3c\x3f\x31\x32\xfd\xe7\xc8\x00\xcb\x85\x5c\x3a\x46\x39\xa1\xb4\xb5\xb9\x32\xf8\xe8\xe9\xa7\xf4\xed\x83\xb5\x6a\xb5\x51\x55\x3d\x1e\x5f\xce\xef\x0f\x36\x4f\xce\x9e\x4e\x45\xc2\xf1\xb4\x28\xb8\x74\x59\x92\xc4\xc9\xf1\xfe\xb5\x62\x23\xeb\xd6\x24\x69\x78\xf6\xd8\xec\x8a\xcb\x2f\xbc\x2e\x75\x64\x57\x3a\xbf\x97\xb8\x78\xed\xbd\x53\x38\x56\x24\x1f\x99\xc3\xe3\x25\xd2\xeb\x86\x56\x97\xa4\x76\x5d\x18\x4e\x26\xf7\x75\x54\x06\x02\xcd\xf9\xc3\xa1\x70\xde\x1f\x14\x57\xaf\xbf\x3f\x3f\xd4\xa8\x37\x39\x41\x60\x03\x3b\xe5\x62\x60\x0f\xec\xba\xcf\x3e\x3c\x77\xbd\x54\xce\x8d\x8e\x26\x66\xa4\x50\xd8\x7b\x07\x00\xad\x34\x32\x3c\x28\xf3\x82\x23\xd0\xe9\xa8\x7d\x8a\x62\x44\xfb\x06\xfa\x72\x5b\xdb\x29\x33\x1c\x8c\x14\x15\x28\x11\xb2\x2c\xfb\x24\xb9\x63\xde\x59\xbd\xe1\xec\x4f\x0e\x2c\x4d\x8c\x4e\xae\x4a\x2d\x95\x97\x75\x95\xce\xe6\x0b\xe3\xc9\xc8\xa8\x11\x88\x06\xd6\x3d\x31\x6f\xd6\xe9\xa7\x5b\xb6\x37\xf7\xd2\x55\xbd\x85\x19\xdd\x12\x95\xf5\x96\x24\x80\x5c\xa8\x73\x0d\x39\x1d\x52\x74\xd2\x1b\x8e\x26\x9a\x62\xc8\x2d\xe5\xd6\xca\x83\x53\x03\xc7\xf4\x70\x32\xbc\x8b\xad\xb0\xd5\x6e\x4b\x34\x27\x70\x28\x1a\x08\x77\x64\x55\x16\xd3\xf9\xc2\xb0\xb6\x6f\x84\xc3\xb1\x48\xda\x19\x4c\xa4\x0d\xb0\x2b\x0c\x1f\x9d\xdc\x4c\xd7\x4b\x21\x91\xf7\xf9\xc2\xb1\x68\x3a\x32\x14\xdb\xb9\x7d\xf3\xae\x6f\x6b\x27\x1f\x1b\x19\x9b\xc8\xd3\x3e\xa7\x96\x5d\xae\x4e\x25\x42\x49\xc9\xdf\x17\x5b\xdc\x5c\xdf\x89\x30\xce\x28\x5d\x51\x54\x41\x6e\x83\xe1\xb9\xe3\xc7\x56\x3c\x7d\x81\x3b\xd5\x72\xc5\x7b\xed\xc6\x7b\x47\xae\x5d\xbb\x78\xe4\xd4\xd4\x19\x93\xa4\x68\xc4\x79\xfd\xbb\x7b\xfb\x39\x3e\x38\x30\x9e\x4e\x55\xaa\x5e\x9e\xf1\x78\x78\xa7\x2b\x8b\x1c\x81\xf4\x56\x6a\xf5\x98\x3b\x32\x58\x25\x7c\xc1\x5a\xfe\xee\xfc\xe3\xa3\xb1\x51\x39\x3e\x36\x71\xa3\x54\x6f\xb6\x6e\xde\x39\x98\x82\x86\x13\x8e\x9c\x3c\xb3\xbc\xb0\x78\xf9\xb8\x93\x0b\xf8\x5c\xe1\xf0\xfb\x6d\x28\x16\xd7\x77\x76\x27\x8e\x9e\x1a\xdc\xba\x32\xbf\x38\x36\xd5\x37\xc9\xea\x48\xaf\xdd\xde\xbc\xa3\xba\xbc\x81\x96\xc3\x1d\xc9\x9e\x3b\xf2\x50\x36\x91\x18\x4c\x7b\xdc\xfe\xb6\xae\x6a\x62\xa9\xc3\x79\x75\x36\xb9\xc3\xba\x84\x06\xd6\xbe\xb0\x77\x77\x8f\xde\xa2\x0c\x74\xaf\x9a\xd7\x0d\xd2\xa6\xcd\xf3\x7b\x49\xa0\x5e\x57\x13\xb2\x3f\xb7\xf3\xca\xdd\x9b\x80\x74\x5b\xbb\x08\x04\xfa\xcf\x4c\xd6\xa9\xf8\x41\xe1\xce\x3b\xb7\xf2\xfa\x8d\x95\xb4\x20\x1c\x24\x86\x4f\x0f\xbe\x8e\x06\x1d\x95\x0e\x0e\xce\xd0\xee\x75\x46\xbd\x6a\xa0\xd9\xd3\x3f\xa8\x9b\x3f\xeb\x2d\x0c\x45\x5d\xfd\x63\x05\x70\xfb\x84\x34\x45\xb3\xba\xd7\x28\xb9\xa1\x8a\x9c\xc8\x74\x30\x71\xd4\x7b\xb8\x83\x7a\x5a\xe3\x70\xc1\x51\xaf\xf5\xf7\xfe\x1d\x0f\xbb\xfa\xe9\x1e\x16\x41\xc2\x09\xc0\xd0\x71\xb4\x58\x2a\xb7\x96\x29\x46\x40\x41\xeb\x96\xb9\x92\xce\x97\x33\x6a\xa8\xe9\x80\x1d\x4a\x70\xb5\x45\x0f\xd4\xf1\x35\x92\x76\xe6\xae\xc3\x60\x29\x5e\x7b\x7a\xe5\xbc\x3e\xab\x4e\x3a\xda\x3e\x9d\x57\xf1\x99\x33\x32\x40\xfe\xb6\xa2\x7a\x73\x25\x79\x62\x67\x4b\xcf\x24\x57\xd0\xd2\xa0\x8f\x5c\xf4\x0c\x31\xa5\x93\x33\xca\xc5\xd4\xce\xea\xe6\x41\xd1\x3d\x55\xf5\xf8\x46\x14\x59\x71\x2a\x01\x3f\x74\x5c\x78\xf8\x44\xe7\xfa\xbc\x3a\xf7\x38\x79\x31\xac\x10\xaf\xee\x6e\x93\x23\x77\x56\x0b\x83\xed\x29\x87\x97\xf2\xb2\x04\x1c\x75\x92\x6b\x8e\xda\xf8\xf0\xdb\x65\xf6\xb4\x09\x16\x07\xe6\x20\xe6\x4c\xd0\xac\x95\x2a\x3b\x77\x6f\xde\x69\x67\xe8\x60\x44\x52\x14\xcf\xc4\x84\x5c\x3b\xb2\x4f\x54\xe7\xc9\x9a\xc3\x95\x74\x83\xf2\x2c\x16\x44\xaf\xa9\x0a\xa3\xe2\x39\xc9\x66\x51\x3b\x9e\x40\x0a\xed\xef\x02\xc8\xce\x99\x6d\xc0\x56\xf2\x00\x35\xa8\x6e\xc3\xe6\x83\x8b\x63\x08\x32\xdb\x94\x73\x77\x5f\xf9\xde\xed\xd7\x8f\x4e\xcf\x7e\xe2\x85\x9f\x32\x88\xff\xf8\x7b\x57\xa3\x9b\xdf\x36\xc8\xfe\x47\x46\x45\xc6\xc9\xfa\x74\x45\xd3\xac\xf6\x02\x1c\x00\x59\x48\x92\x8e\xfc\x62\x2e\xa0\x5d\xbe\x12\xfc\xc9\x5f\x51\xc9\xe2\x81\x13\xbc\xf1\xe7\xad\x6f\xae\xe5\xae\xbe\x7c\xaa\xf4\x49\xb0\xba\xf4\x1a\xd8\x22\x17\x81\x26\x9b\x40\xc4\x91\xc9\xe2\x21\x49\x7f\x3f\xc8\xbb\xb6\x61\xb8\x3e\x08\x6a\xbb\x07\x30\x48\x57\xa1\xdb\xc5\x40\x0e\xbb\xf2\x3f\xfb\xf4\x8f\x41\x96\xd6\xb1\x42\x82\x44\xb1\x90\x81\x13\xd4\x08\xe4\x4f\x33\xd2\x56\x7a\x5d\x76\xeb\x6e\x9e\x60\x4d\x7b\x1d\x85\x4e\xf0\xd6\x2a\x1b\x4c\x22\x6a\x70\x64\x24\x48\xbc\xf0\xe4\xe7\xc1\xc2\xca\x16\xf7\xee\xa5\xb5\x0b\x1f\xfd\xef\x3e\xfb\x7f\xf0\x41\x4f\x30\xbd\x70\xf3\xcf\x82\xce\xd2\x57\x10\x59\xe9\x93\x8c\xf6\x87\xcc\x8f\xf7\x3f\xd4\xf6\x04\xc1\xdc\x2b\x8d\x73\x93\xe1\xf2\x6f\x10\x8c\xce\xa1\xc3\xe4\x28\xd0\xed\xa8\x71\xfc\xc2\x11\x2c\x14\x8e\x58\x04\x08\xed\xee\xef\x9b\xdf\x79\xfb\x56\xee\x3f\xfe\xe1\xd6\x0d\xd7\x2f\x38\x13\x86\x23\x49\x6a\x58\xbf\xf9\xb5\x37\xc1\xf2\x0d\xf3\x0f\x07\xe2\x99\x2f\xb1\x63\x8e\x09\xec\x0d\xe4\xbd\xaa\x36\xfc\xc0\xe2\x25\x68\x00\xab\x33\x64\xee\xfc\x09\x9b\xd6\xb4\x6a\xd3\x9e\x2b\xf3\xb7\xa2\xed\x86\x2c\x6f\x5d\x7c\x77\xad\x51\x9a\x8c\x9b\x0d\x55\xd6\xcb\x7b\x5f\x1e\x18\xa5\x17\xfb\x49\x38\x66\xb7\xe5\x22\x09\x4e\xe8\x21\x20\x38\x0c\x44\x1b\x39\x48\x0d\x2a\xc0\x24\xde\x81\x4f\x9b\x34\x20\x4f\x8e\xf7\x02\x5d\x0d\xe2\x39\xb0\x7a\x11\xa0\x5d\xe3\xb1\x5a\xee\x5d\x50\xf7\x73\x81\xd8\xed\xe5\xed\x0b\x4b\x1b\x9b\xb3\x33\x13\xb3\xbb\x91\xbe\xbe\x0c\xcd\x10\x2d\xcb\x1f\x5b\xed\x8e\xbb\x54\x29\x87\x2e\xcf\x5f\x7b\x6a\x73\x7b\x75\xca\xeb\xf5\x36\x1f\x39\x75\xe1\x5b\x6e\x87\x33\x7b\xe5\xd2\xb5\x0f\xf3\x98\x86\x4c\x0f\x8e\x5f\xc3\x2a\xa0\xee\xe0\x84\xe0\x0b\x4f\x7e\xe4\x3d\x5e\x80\x77\xb1\x5d\x58\x5d\x2d\x4c\xb9\x56\xf3\x67\xb2\x7b\x8f\x74\x5a\xca\x74\xd0\x1f\xc8\x8f\x8d\xf5\x7d\x6d\x3b\x5b\x1e\xd9\xdc\x5f\x67\x62\x91\x98\xbb\x50\x25\x9e\x5d\xda\xb8\x1b\x5f\xdd\x5c\x8d\xd3\x0c\xdd\x48\x84\xfa\x35\x92\xa2\x4c\x86\x65\x76\xb7\x36\x0f\xa2\x9a\x6a\xd0\xc1\x68\xe4\x20\x5b\xd8\x49\x06\x3c\x11\x96\xe5\xb9\x6d\xcd\x44\x05\x97\xdf\x59\x83\x34\x15\x6a\xd6\x3b\x49\x59\x31\x03\xc1\xa0\x27\xaf\x98\x26\xc2\xec\xdf\x33\x96\x00\x1a\x20\x19\x93\xa0\x59\x4f\xa9\x54\x8a\xee\x2f\xad\x0c\xd7\xab\xf5\xe1\xa1\xc1\xb1\x54\x38\x16\xde\x27\x48\x16\x45\x12\xf1\xe2\x7e\x66\x2f\xc6\x33\x0e\xd1\x40\x86\x36\x79\x64\xe6\x66\x2c\xde\xb7\x75\xe3\xf2\xad\x63\xa3\xe3\xa3\xa9\xfd\xdd\xcd\x7e\x96\xe4\xfd\x4e\x97\xbb\x24\x78\x9d\x07\x42\x00\x73\x3d\x8e\xb2\xf2\xf1\x08\xdc\xc7\x0f\xd4\x6b\x72\xb0\xda\xb9\xad\x9b\x81\xc2\x52\xa9\xe9\xa9\x94\x1a\x21\x5d\x37\xd9\x78\x5f\x3c\x9b\x2d\x65\x3d\x8a\xa4\x78\x5c\x4e\x8f\xc2\x89\x42\x9d\x41\x3a\x85\xc5\x87\x58\xae\xe4\x3c\x57\x6f\xac\x45\xb6\xb7\x36\x63\x56\xbe\x7f\x72\xfc\x68\x21\x39\x9e\xcc\x6d\x6f\xed\x3b\x39\x5e\xd0\xbd\x41\x4f\x79\xf5\xca\xed\x33\x11\x57\xdc\x6a\x00\x59\x6f\xb5\xe5\x46\xbd\xd6\x8a\xf0\x9c\x43\x1d\x1c\x1b\xde\x5a\x5c\xbc\x36\xee\x64\xdd\x5e\x6f\x28\x70\x5b\x92\xf5\xca\xd6\xea\xde\xa9\x99\x13\xb3\x2b\xb9\xfc\xae\x6f\x63\x77\x85\x0a\x47\x62\x8e\xb5\xbd\xe5\xf3\xb7\x6e\x5f\x19\xca\xe6\x33\xa2\x3f\x18\x2e\x74\x09\x1c\x29\x63\x1f\xcc\xb6\xaa\x8d\x58\x7c\x3a\xb6\x7f\xe5\xca\xb5\xc7\xa3\x8e\x08\x21\x7a\xdd\x2b\xb5\x52\x99\x68\x94\xca\xde\x13\xa7\x4f\xdf\xc9\x1e\x6c\xf9\x05\x82\xf1\xb8\xbc\xde\x5d\x8a\xa1\xd6\xcb\xb9\x8c\x1b\x68\x0a\x3b\x3c\x32\xb6\xd1\x6c\x66\xc9\x4e\xb1\x74\x24\x36\x30\x51\x76\xf9\x7d\x57\x17\x6e\x2e\x0e\x56\x32\xe9\x7e\x42\x99\x58\x0d\x85\x22\x69\x1c\x28\xc3\x67\xe6\x1e\xd9\x7d\xd4\xff\xe1\x37\x48\x92\xd2\x71\x08\x24\x6a\xd5\xb2\xaf\x92\x4b\x0f\xee\x2c\xdc\x9e\xc6\x11\xd8\x91\x18\x1d\xfb\x0a\xa5\x86\x4c\x9e\xe6\xda\x06\xbc\xbf\xf8\xb4\x5b\xee\x20\xba\x3d\xc0\xbd\xf5\x3e\x56\x4b\x88\x55\x31\xec\xd6\x3f\xc8\x43\xd1\xd0\x4d\xac\xda\x50\x60\x3e\xb0\xf8\xaf\xdb\x4e\xe2\x0c\x4e\x2a\x33\x4f\x86\xd6\x3a\xb5\xe6\x56\xd0\x1f\x54\x28\x17\x83\x5a\xb2\x95\xae\x46\x46\xb7\x51\x1e\xf5\x56\x4b\xf7\x3a\x66\x2c\x50\xb1\x3e\xa7\x7a\xa0\x81\xd9\x91\xa6\x28\x4c\xbb\xd2\xe6\x3b\xd5\xb6\xa7\x9e\xaf\x09\x52\x43\xe5\x3c\x01\x9f\xd1\x3f\x13\x58\x26\x05\x12\x22\x1d\x75\xf1\xc7\x4a\x0e\x9b\xf7\x56\x85\xdc\xcf\xc2\xa1\x5e\xd9\x11\xdd\x6f\x5b\xb7\x3f\xe8\x76\xe8\x50\x91\x81\xa0\x9e\x5d\x2d\xf4\xa5\x76\xb4\x47\x34\x93\x1d\x30\xbc\x5e\x06\xaa\xa8\xa9\xec\x99\x5b\x03\x42\xe7\xae\x2f\xe9\x5e\x17\x63\xac\x62\xd2\x10\x89\x1e\x35\xc3\x57\x74\x2c\x34\x21\xc9\x20\xab\xd7\xb6\x9b\xdc\x43\x78\x7c\x8d\x98\x00\x5b\x31\x2d\x7a\xab\xdc\x0e\xac\x6f\x1a\x53\xfd\xd7\x89\xf5\x81\x10\x77\x37\x3e\xc1\xe6\x42\x1d\x23\x5f\xae\xe5\xee\xe6\xd3\xe6\x40\x7b\x37\x35\xa4\x90\x8c\x27\x4b\xf2\xd3\x17\x2f\x36\xdb\xe3\xa7\x85\xc5\xd1\x3e\xb0\xec\xda\x63\xb6\x4b\xd7\xd4\x50\x9a\x97\x63\x55\x3f\x0a\x98\x61\xc0\x2c\x3d\x46\x0e\xa0\x77\x69\x87\x7c\x15\x2e\x47\xa7\x51\xd1\xdf\x67\xa2\x93\x94\x9c\xcf\x1f\xa4\x6a\x79\x8d\xb6\x4a\xec\xc4\x99\x88\x5a\xeb\xdc\x22\xf4\x6d\x04\xf9\xd2\x71\x40\xba\x56\x11\x33\xb8\x1a\x51\x1a\x5c\x03\xc9\xb7\x17\x01\x88\x73\x00\x4c\x7a\x00\xf5\xfe\x67\xff\x08\x38\x5e\x5d\x07\xe6\x65\xcc\x5f\xd9\x0f\xde\x38\x0d\x54\x55\x55\x5b\x2a\xb7\x77\xd7\xde\xf8\xee\x19\xdd\x21\xe8\xe4\x4f\xfc\xb2\x41\xbe\xf3\xf5\xf7\x23\x0b\x5f\xdd\x75\x93\xfd\xc3\x4d\xc6\x67\xad\xfd\x00\x50\x6f\xca\xac\xb2\xbb\x27\xf6\xb3\xfb\xc2\x73\xbf\x6c\x12\x9a\xc6\x93\xff\xd7\xff\xde\x5c\xff\xda\x9b\x5f\xfb\xf9\x9c\xb2\x0f\x28\x7c\x56\x9f\x1a\xf8\x3c\xa8\xd3\x4f\x02\x92\x72\x81\x49\x71\x0c\xd4\x4c\x11\x6e\xd3\x75\x62\xd8\x1b\x82\x53\x83\x4f\xc3\xf4\xad\xb7\x88\x31\x27\x03\x19\x9f\x83\x60\x38\x0d\xd2\x8c\x4e\x30\x8c\x61\xa5\xf9\xe1\xd1\xe9\x20\x34\xa8\x1c\x61\xad\x68\x7a\x68\xc2\x09\x4d\xa8\x41\x5b\x2a\xd8\xad\x97\x2d\xa2\x47\x62\xec\xce\x2e\x6b\xb5\xfd\xfb\xf3\x85\xa8\xcf\xeb\x7b\xd2\x13\x0a\x07\xcb\x6b\x6b\xaf\x0f\x85\x0a\xff\xc6\xe9\xe5\xf5\xad\xdd\xd0\xec\xed\xe5\x37\x2e\x8b\xdf\x70\xf4\x09\xcf\x7c\x22\x41\x8c\x8c\x3f\x99\x10\xdf\xfb\x7f\x28\x7c\x3c\xcb\x9a\xad\x16\x5f\xbb\x98\x0f\x7b\xbd\xb0\x56\xb2\x09\x1f\x61\x78\xb0\x0f\x3a\x1c\x9a\xf6\xbd\x77\x36\xee\xbe\xfc\x75\x21\xfa\xe9\x9f\xa2\xcf\x19\x0c\x05\x0a\x2b\xe5\x3f\x1a\x8e\x90\x5f\x72\x7a\xb8\x7e\xc3\xd0\xc8\x6e\x0d\xfe\xc1\xe5\x72\xdd\x8e\xab\x6e\xcf\xa2\xdd\xbf\x0b\x54\x05\x92\xab\x5b\x39\xa7\xd4\x86\x8f\x3d\x79\x62\xf6\x59\x46\xa4\x58\x84\x23\xe2\xca\xdd\x77\xbf\xd6\x17\x74\x66\x86\xe6\xf8\x15\xa7\x4b\x8f\xe1\xdf\x0d\xf4\x60\xc8\x6a\x59\x03\x86\x89\xcf\x11\xaa\xc4\xbd\xc5\x66\xf8\x35\xb2\x5a\x58\x2c\x9b\x35\xbb\x09\x59\x59\x36\xe8\x5c\xa1\xed\x6a\x63\xa6\x2d\x38\x18\x19\xeb\x50\xb2\x3f\xe1\x70\x2d\xac\xe4\x12\x7f\xf1\xda\x97\x4f\x7b\xdd\x3e\x99\x63\x58\xbb\x7c\x58\x6b\xd6\xc8\x4a\xb5\xcc\xf2\x3c\xab\x9e\x3e\x71\x74\xfb\xf4\xf1\xe3\x4b\x56\x71\xed\xfd\xcb\xef\x3f\xa3\x6b\x2d\xbf\xc9\x1a\x6d\x97\x13\x93\xe9\xa0\x43\x79\xe7\xc6\xeb\x64\x3c\x95\x78\x12\x8f\xcc\xc3\x56\x97\x65\x5b\x6a\x12\xc5\x4a\x91\xb5\x02\xec\xcc\xd4\x44\x0a\x07\xb5\xb5\x4a\x39\x33\x32\x3d\x31\xa4\xe4\x8b\xa9\xcd\x57\xdf\xfd\xcb\x24\x1e\xce\xbe\x48\xc4\x5f\xfc\xe8\xf3\xcf\x5e\xa3\x29\xb6\xf3\xfa\x5b\x6f\x3f\x89\x0d\x5e\x8b\x24\x86\xa9\x7a\xbd\x9c\xf4\xf9\x45\x59\xf4\x92\xec\xe6\xfc\xfa\x68\xd0\x95\x20\x47\xf9\xc1\x56\x20\x42\x69\x4e\x6f\xac\xb6\x7c\xe7\x20\x50\xaf\xd5\xfd\x04\x89\x18\x8a\xd1\x14\xbf\xcf\x65\x62\xef\xaa\xbf\x7e\xf9\x9b\x7d\xe1\xf5\xe8\x4b\x6d\xb9\x6d\xe4\x8b\x19\x56\x10\x38\x6d\x6e\x76\x6e\x25\x9e\x0c\x2c\xde\xbd\xb5\x34\x8c\x4c\x9d\x73\x7b\x59\xe9\xed\x1b\x4b\xb3\x40\x46\x74\x72\x68\xe0\x6e\x24\x1e\x5d\xbf\xf8\xf6\x95\x63\xba\x6a\xb2\x0e\x17\xdd\xbe\xf5\xd6\xf5\xd3\x0e\xd2\x41\x25\x93\x43\x2d\x4e\x20\x2a\x24\xad\x35\xf0\xdc\xf5\x92\xdc\xc4\xbd\xbb\xa9\x76\xdb\xa1\xa1\xdd\x96\x50\x2b\xb7\xb8\xbd\x8d\x8c\xa3\x5a\x69\xba\xf0\x3c\xaa\xa2\xdb\x99\xbb\xb3\xb6\x32\xb8\xb2\xb5\x4c\x11\x56\x93\xe5\x3c\xf1\x44\xa5\x51\x41\xd5\x7a\x99\xc2\xca\xd9\x74\x7b\x7d\xe5\x91\xb1\x23\xb7\xa6\x26\x67\xb6\xbc\x3e\x7f\x7e\x7b\x2b\x15\x5a\x9c\x5f\x1b\x0d\x87\xc3\x99\x46\xb3\x25\x2d\x2f\x2f\x46\xc4\x69\x57\x1b\xcf\xfb\xf6\xf6\xda\x0e\x99\xdf\x2f\x07\x22\x91\x68\xbe\x25\x75\xda\xd7\xde\xbf\x34\x71\x62\xf2\x4c\x4b\x70\xf9\x6e\x2e\xdd\x59\x89\xb6\x5b\x32\x51\xc8\x57\xcc\x91\x89\xe9\x65\x0c\x4a\xc1\xaf\xbf\xfa\x55\x4c\x54\x50\x34\x18\x8a\xa5\x3f\xfa\xb1\x9f\x7e\xad\x5e\x2d\x86\x28\xc9\x78\x84\xc4\x60\xd0\x6c\x4a\x32\x81\x48\xbd\xd1\xaa\xd0\xeb\xeb\x4b\x7d\x4e\xcc\x6a\x19\x8e\xdf\x3a\x58\xde\x8a\x5b\x1d\xe9\x6e\x9f\xb3\x78\xe7\xca\xbb\x17\xd4\x5a\x8b\x3f\x3a\x73\xf2\xa0\x5d\x6b\xa2\xfc\x5e\x76\x18\xe8\x48\xe8\xeb\x8f\xa5\xde\xb8\xf4\xf2\x43\x9d\x4a\xdd\x33\x3b\x7b\xe6\x4d\xfc\x1d\x99\xdd\x4d\x8d\xe1\x50\x86\xd9\x79\xd3\x9d\x88\xf6\x15\x2f\xbe\xf7\x3d\xa3\x54\x2b\x1c\x65\x18\x66\xd4\xaa\x7c\xcb\x8a\x0c\x8a\x95\x3c\x23\x2b\x12\xdb\x17\x4b\xe6\xce\x9d\x79\xe2\x1d\x7f\xc8\xb7\xeb\x65\x49\x8d\x6c\xb4\x45\x3b\xe4\xde\x5f\x27\x01\x7b\x77\x89\xea\x35\x16\xde\x5f\xa0\x77\xcf\x5d\xec\x9e\x0e\x02\x1c\xae\x39\xb2\x6f\x1a\x7b\x98\xdf\xba\xbf\x8e\x15\xf9\x42\x61\x00\xf1\x13\xef\x9f\xbe\x7f\xcf\x72\x13\x1c\xe6\xbe\xe0\xe1\x52\xa5\x6e\x11\xd2\x06\x13\x0c\x1a\xa0\x92\xaf\xb8\x4b\xfb\x05\x8f\xd2\x56\xdc\x4a\x5b\x26\x24\xa9\xa5\x50\x9c\xfb\x34\xc9\x38\x07\x35\xde\x1f\x68\x94\x89\x57\x86\x3c\x8e\x3f\x43\x8c\x25\xe8\x6d\x21\xd4\x93\x2f\x3d\x00\x31\x7b\x7f\x40\x37\x11\x76\xf8\xbe\x27\x6c\xba\x0b\x5b\x49\x42\x2f\x6f\x57\xa2\xe9\xa5\xc6\xa7\xd4\x87\x66\x87\xb1\xe4\x86\xa8\x23\x53\xc0\x30\x28\x3a\xae\xcf\xa4\xeb\x9d\x0f\xa5\xaf\x17\xef\x0c\x86\x9b\xdf\x4d\x1c\x0f\xad\x8c\x9c\x1f\x7c\x83\xba\x9c\x32\xd6\x5f\xc9\x9f\xae\xcd\x18\x7e\x18\x60\x19\x5a\xa0\x6d\xe2\x42\x20\x68\x88\x88\x33\x8c\x30\x63\x16\x83\x0d\x6f\x61\x4c\x39\x99\xbd\x2b\x8d\x0e\xbc\xa7\x6c\x84\x12\xce\x65\x7f\xd2\x95\x8b\x24\x89\x8a\x5a\x55\x96\x6a\xa9\xa6\xa8\x78\x39\xce\xc4\xf1\xa5\xb9\x4f\x8b\x8e\x23\xce\x56\xf4\x88\xa1\x87\x65\x23\x35\xd2\x36\xd2\x95\x82\x2a\x34\x57\x0d\x7f\xae\xad\xfa\xdb\xac\xe1\xba\xb3\x8f\xc6\x0f\xf6\x08\x2e\x3e\xc0\xe4\xbd\x63\xbc\x1a\x99\x42\x8a\x2f\x69\x5a\x69\x5c\x48\xe1\xe3\x9f\xeb\x33\x5b\xc2\xbb\x6d\x6d\x75\x8a\x60\x0b\xe3\x90\xea\xdf\x25\x35\x42\x63\x4c\x36\x5b\x04\x5c\xd6\x6a\xce\x1c\x01\x14\xad\x70\x18\x90\xef\xdf\x12\xcb\xea\xeb\x3f\xbc\xb5\x30\x01\x49\xef\xa3\x27\x9e\xfd\xa5\xe1\xf8\xe8\xcf\x3e\xf1\xd9\xf3\xd4\xb5\x77\xb7\x51\x3e\xbb\x4d\x3d\xf6\x12\x0d\xce\xd6\x73\xd4\xc6\x6a\x56\x28\x97\xed\x0e\x58\xe0\x14\x0d\x30\xfc\x12\x20\x3d\x09\x06\x2e\xdf\xe0\xc0\x37\xfe\x12\xde\x2e\xd6\x3b\x9f\xf9\xe4\x47\x7f\x32\x63\xad\x18\x8c\x4b\x31\x18\xf0\x7b\xe1\xff\x18\xf0\x42\x8c\xc4\x04\x4d\x88\x90\x75\x7a\x21\x09\x69\x4c\x9c\x30\xea\x52\xf6\xea\x08\xa2\x63\xb5\x52\x91\x56\x00\x37\xed\x76\x5e\x12\xb3\x69\x1c\x23\x31\x2a\x77\xbb\xa3\xac\x85\xc8\x84\x6c\x2d\xdd\xee\xde\xdb\x83\x20\xba\x45\x6f\xcb\xde\x48\x7b\x91\x07\x84\x16\x5b\x2c\x4b\x29\x8f\x69\x36\xa9\xcc\xfa\xd6\x77\x42\x31\xff\x17\xf9\x68\x94\x30\x08\xe0\x3a\xfb\xd4\x48\x46\x26\xdf\x5d\xbc\x3a\xff\x9e\x7e\x9a\x14\x7e\x3c\x31\x10\x7f\xad\x20\xce\x12\x40\x06\x5c\x37\xf3\x6a\xaf\x0f\x27\xba\x06\x63\xbd\xb6\xe3\xb5\xbd\x56\x23\x32\x31\xd5\x1e\x6f\xdd\xce\xee\x6e\xed\x5e\x79\xf9\x5b\x8d\xfc\x50\xb2\x2f\xe3\x8b\x0d\x7c\xaf\xc5\x01\x5f\xbd\x83\xa9\x83\xed\x16\x56\x97\x73\xb7\xad\x1d\x76\xdb\x76\x0f\xef\xbd\x69\x17\xc0\xad\x2b\x33\x80\x81\xe7\x81\xf3\xec\x36\xb6\xeb\x6b\x99\x83\x3b\x47\x87\xfc\xb3\xc3\x71\x57\x60\x72\x22\x16\xf3\x0c\x44\xae\x01\x86\x0a\x36\x0c\x44\xf5\x7c\x88\xe8\x75\x75\x81\xde\x02\xc2\x7b\x1d\x5c\xbd\xae\xac\x6e\x71\xbd\xdb\x4f\x08\xaa\x9d\x86\x63\x75\xab\x36\x54\xcc\xd5\x23\x0c\x47\x29\x2e\x97\x52\xf7\xfa\x82\xe6\xf3\xcf\x7c\xfc\x56\x3a\x9f\xdd\xdd\xd8\x5a\x0f\xd7\xea\x75\xd1\x9a\xe1\x58\x3c\x21\x9d\x3a\x79\xb6\x96\xec\x4b\x94\xc2\x61\x77\xd1\x44\x52\xfb\xe6\xfb\x8b\x43\x1d\x45\xf7\x52\x2c\x47\x61\x39\xeb\x4e\x1d\x14\x86\x5e\x7a\xf6\xc5\xd5\xd5\xad\xcd\xca\xc6\xf6\x56\x58\xd3\x0c\xda\x4a\xf2\xf9\x42\x5e\xf9\xe8\xcc\x91\x6a\x22\x12\xad\x89\x1c\xdf\xd9\xdd\x4e\xc5\xf7\xf6\xd2\x9e\x44\x5f\xac\xf2\xd4\xc3\x4f\x6e\x3d\xfc\x90\xba\x67\x2f\x3a\xc3\x33\x48\x13\xb4\xda\xd6\x24\x21\x18\xf2\x57\x78\x37\x51\xd2\x4d\xcd\xd9\x6a\xb7\xc2\x2e\x97\xa3\xc2\xf1\x84\x33\x16\x8b\x48\xba\xaa\xa5\x04\x91\x34\xbc\x3e\xc2\xd9\x6c\x11\x22\x41\xe8\x51\x88\x34\x2f\x45\x21\x5a\xd7\x3b\xbe\x6a\x39\xab\x7c\xf4\x85\x17\x6f\xdf\x5c\x98\xaf\xed\xa5\x52\x21\x51\x14\x95\x27\x8e\x3e\x5e\x18\x1d\x19\x3d\x60\x18\xaa\xbe\x30\xbf\x92\xdc\xdf\xdd\x1f\xe2\x05\x41\x06\x84\xc9\x25\x62\xf1\x96\xa1\x99\x5b\x00\x1f\x1c\xe0\xe3\x89\xc1\xc4\xda\xd2\xed\xe5\xbe\x5a\xb9\x16\x70\x79\x5c\x4d\x6b\x0c\x07\xfa\x87\x4b\xf5\x5a\x55\x67\x45\x7e\x03\x2b\x9d\x96\xa2\xd9\x04\xd8\x5a\xa4\xd3\x85\x62\x74\x58\x18\xed\xae\x8e\xb7\xba\x75\x72\x99\x8a\x50\x48\x97\x3d\xaa\xa4\x31\x56\xa0\xa8\x54\xaa\xe0\xc8\x91\xe3\xcb\xd5\x5a\xcd\x51\x95\xeb\x14\x54\x21\x11\x49\x24\xf2\x53\x33\xb3\xf5\x68\x24\x51\xc2\x72\xaa\xe9\xf6\x79\xf3\xa4\x40\x95\x57\xe6\x57\xe2\x6b\x0b\xeb\x03\x9a\xaa\x53\x90\xa2\xea\x00\xd2\x5a\x30\x12\xdf\x27\x1d\x5c\x49\xd5\x51\x33\x73\x90\x1b\xd3\x0d\xd3\x45\x32\x74\xc9\x5a\x8c\xe0\x0f\xc6\x8a\x8e\x50\x70\xbb\x8d\x47\x05\x7f\x97\xa0\x28\x9a\x4c\xed\xa5\x86\xf0\xfc\x0a\x8f\x3e\xf2\x91\xab\xe7\xce\xcb\xb7\x2c\xb5\xec\xf7\x45\xaa\x9a\x21\xc3\xd4\xe6\xda\xa3\x71\x6f\x14\x09\x3e\xef\xd2\x41\x2a\xef\x6f\xcb\x1d\xca\xe1\x18\x56\x87\x47\x8e\x6c\x08\x7e\x6f\x4b\xd2\x0c\x2d\x9b\xc9\x0d\xd0\x1c\xd7\xb6\x1a\x14\x83\xa1\x44\xa5\x6c\xa6\x57\x58\xb7\x6b\x33\xb5\x97\x8d\x75\x5a\x72\x02\x2b\x43\x1d\x32\xb4\xe9\x72\x05\x14\x8a\xa0\x17\x45\xaf\x6f\x69\x79\x61\x6d\x00\x2b\x28\x16\x6b\x59\xb4\xbe\xbe\x35\x7a\xf2\xfc\x99\xeb\xd8\x96\x6a\xab\x6b\x8b\x23\xcd\x66\xdd\x6d\x19\x33\xc5\xb1\xfa\xf1\xb9\xf3\xd9\x70\x30\x56\x4e\x26\x47\x76\xbc\x91\x60\xca\x15\xf1\xee\x03\x92\x26\x0d\xcb\x86\x1f\xe0\x51\xf0\x01\xaa\xfe\xc0\x9d\x5b\x7a\xcb\x13\x7b\x70\xfd\xc0\x9b\x2e\xe5\x7a\x50\xcd\xc3\xfb\xa9\xa4\xc3\x04\x93\xfd\x7f\x4b\x40\x98\xbd\x9b\x70\x75\x35\x82\xd9\xad\x69\xf7\x22\x5a\x2f\x8f\x65\x82\x42\x16\x83\xea\xdd\x65\x1f\x90\x98\xe7\x9c\xf1\xc4\x84\x6b\x3a\x1c\x6e\x5c\xbc\xb9\xc0\x3b\xc3\xb3\xe5\x6a\xb6\x56\xaf\x74\x9c\x80\x71\x9c\x18\x52\xe1\x9f\x75\x1b\xf8\x0f\x97\x3d\xf6\x92\x54\xf6\x32\xd8\xee\x4d\x01\xec\x92\xbc\x79\xd8\xdc\x05\xbb\x1d\x64\xdd\x95\x5c\x38\xe4\x63\x5a\x57\x55\x5c\x6d\x7f\x20\xd0\xe2\x38\x83\xed\x68\x80\x31\xec\xfc\xa8\x69\x52\xd8\xb4\x7d\x9c\x03\x4c\x0b\x0f\xef\xed\x16\xa6\xca\x6f\xa7\x2f\xc6\x07\xf9\x6f\x8f\x9d\x0d\xbc\x9a\x48\x89\x57\xf3\x6b\xcd\xe1\xcc\x86\x34\x50\xa6\x5b\x51\xdd\xcb\x38\x54\x11\x10\x1d\x16\x9f\x04\x09\x21\x8b\x83\xb3\x41\x03\xb3\x3c\x6c\x3a\x85\x3a\x9a\x95\x6f\x55\xc3\xe5\x8d\xce\x8d\xc0\xb8\x2b\x15\x1a\x16\xe5\x90\x4f\xac\xf4\xee\xfb\x0b\x0c\xd5\x24\x54\xeb\x65\x87\xea\xae\x32\xe3\x29\x10\x1e\x64\xdb\x21\xc3\x6c\xc6\x2b\xda\x5e\xbb\xa2\x31\x0d\x0e\xa3\x41\xdd\x20\x1b\x55\x48\x11\x05\x02\x87\x4d\xec\x07\xba\xdd\x1a\x07\xda\x4d\x2c\xa3\x18\x04\xe3\x22\xa9\xe8\xdf\x82\x9a\x1c\x06\x54\x2e\x5a\x23\x84\x26\x89\xaf\x96\xba\x97\xa0\xff\xbe\x9b\x29\x5a\x35\x87\x53\xe7\xe6\x40\xab\xa4\x80\xb5\xcd\xf5\xc1\xc7\x4f\xbd\xf8\x85\x8f\x3f\x3a\xf5\x9c\x93\xc3\xef\xdf\x9a\x07\x9b\xfb\x07\xb7\xbe\xfc\xe5\x1b\xd7\xaf\xdd\x38\xf5\xd1\xf3\x0f\xbb\x23\xc3\x18\x80\xfe\x7f\xf6\xae\x3c\x46\x92\xf3\xaa\xbf\xaf\xee\xea\xea\xfb\x9c\xa3\x67\x66\x77\x66\x76\xf6\xf2\xb1\xeb\x3d\x1c\x2f\x89\x73\x9a\x38\xd8\x31\x31\x8a\xc8\x81\x45\x42\x12\x42\x12\x09\x12\x02\xe2\x8f\x80\x10\x58\x0a\x52\x84\x02\x08\x91\x08\x10\xe4\x0f\x14\xc2\x11\x08\x0e\x46\x4e\x4c\x1c\x1f\x38\xb6\xd7\x8e\x77\xed\x5d\xef\x78\xaf\x99\xd9\xb9\xcf\xbe\x8f\xba\xab\x3e\xde\x57\x55\x3d\x3d\xeb\x2b\x07\x4a\x62\x0b\xf7\xaa\xb7\xa7\xab\xbb\xeb\xf8\xea\xfb\xde\x7b\xbf\x77\xfc\xde\xae\x09\x37\xd0\xee\xba\xc5\xc3\x95\x45\x1e\x9e\xf9\x77\xa7\x76\x61\xd1\xfa\x5a\x79\xa2\xf8\x17\x27\x6e\xda\x57\xe1\x04\xa1\x2c\xf2\x3c\xb1\x79\x87\x34\x7c\x9f\xd3\xc4\x12\x67\xf3\x36\x29\x7a\x03\x41\x22\x6f\x80\x32\x09\x4f\x42\x86\x00\xfc\x1b\xd1\x86\x17\x4a\xf1\xb0\xd2\x9a\xf9\xb9\x82\x55\xcd\x46\x9f\xd5\xad\x07\x2d\x17\x42\xf7\x28\x53\xd1\x61\xf1\x17\x17\xe6\x56\x40\x28\xbc\x71\xc4\x06\x77\x5d\x9b\xc8\xe5\xba\xcf\x6a\xaa\x26\xf1\xf1\x8c\xdd\xb4\xd5\x61\xd4\x05\x52\x3c\x5f\x24\x37\xdf\x52\xe8\x9e\x9f\x7e\x76\x51\x4d\xca\x5f\xc0\x09\xdf\x6e\xfb\xca\x68\xe0\x86\x0b\x6b\x32\xc2\x8c\xac\x28\x15\x97\x84\x81\xf5\xb0\xea\x0f\xcf\x6d\xff\xa1\x9b\xb9\xa1\xb1\x6b\x96\x70\xc1\xcd\x25\x32\x59\x1b\x61\xe6\x70\xc7\xa7\x61\x39\x52\x80\x5b\xfc\xa8\xa6\x24\xa4\x26\xa1\x4c\xa1\x44\x5e\x91\x90\xe3\x99\x06\x65\x82\x03\xbb\x06\x48\xa2\x30\x69\x2e\x2f\x2d\xce\x3c\x3f\xbf\x58\xd9\xe8\x9a\xf9\xf1\x82\x36\xd5\xd1\xd3\xc7\x14\x49\x5b\x46\x21\x28\x44\x96\xd3\x36\x69\x2a\x47\xb6\xed\xb8\xa8\xfa\x23\xcc\x37\x86\x7e\xfe\x2e\xf5\x24\xc2\x21\x64\x96\x9b\x6d\x2f\xe7\x54\x2d\x79\x7d\x5d\x77\x38\xae\xe2\xc5\x62\x9a\x83\x02\xbc\x7b\xf4\xba\x9b\x16\xe3\x89\x18\x53\xc1\x08\x24\x5c\x1f\x75\xb7\x11\x4f\x8b\x75\x35\x29\x36\x4d\x93\xf2\x72\x3c\xdd\x15\xa5\x8e\x69\x9a\x8c\xf7\x85\x23\xd3\xcf\x2f\x94\x1b\x75\x43\x2b\x8f\x0e\xd4\x6e\x7b\xc7\xde\xe7\x59\x30\x19\x07\x0a\x61\x21\x71\x00\x1c\x73\x73\xbd\x12\x3f\xf9\xf8\x85\xc9\x7a\xa3\x93\xe5\x79\xde\x43\x4b\x5b\xa9\x54\x6a\xf1\x54\x32\x61\x3b\x8e\xaf\x34\x1a\x2d\xa9\x50\x8a\x2f\x1c\x39\xbe\x7f\xf9\xd7\x3e\xf8\xcb\x1b\xb5\x7a\x53\x39\xfd\xd4\xb9\x49\x46\x7f\x23\x8a\x60\x70\x44\x6f\xde\xfe\xf3\x6f\x7b\x9a\xb9\x8f\x04\xd9\x69\xf3\x02\xbb\x11\x9c\x2c\xc9\x02\xe5\x45\xce\x73\x4d\x47\x6d\xb7\x8c\x81\x53\x4f\x4d\xe7\xf2\x85\x7c\x67\xff\x9e\x7d\x1b\x6f\x3c\x76\xd3\x1c\xde\x25\x57\x56\xa0\xa3\xc4\xb9\xc6\xf4\xd9\x2b\x83\x1b\xab\x1b\x83\x3c\x4b\xb3\x13\x58\x0e\x42\x9d\xde\xfe\x0b\xef\x7c\x8a\x59\x24\x73\xb3\xf3\x89\xb5\x95\x75\x14\x90\x9c\x8c\x08\x4e\x37\xcc\x26\xf7\x9e\x3b\x6e\xff\x7e\x20\xa1\x44\xbf\xab\xa6\x79\x1b\xef\x56\x91\xa3\x11\x2f\xe1\xb6\xb9\x49\x42\xff\x05\x2a\x10\x56\x34\x66\x19\xd6\xb0\xe3\x7a\x43\xf8\x5e\x43\x4b\x85\x5c\xbc\x30\x73\x68\xc2\x1f\x5f\xbc\xf5\x1d\x77\x9e\xe5\x78\x8e\xf9\x4f\xfc\x4e\xab\x23\xe0\xc0\x51\xdb\x76\x6d\x41\xf3\xda\x72\x41\xaa\xdb\x96\x2d\xb4\x9b\xed\x31\xbc\x8f\x79\x51\x46\x1b\x83\xf7\xec\x44\x3e\x59\xb9\xeb\xc3\x9f\xb8\x87\x59\xef\xa8\xdc\x86\xf4\x56\x7b\x97\x28\x09\xc4\xf2\x2d\x27\x96\x4a\xd5\x7f\xf5\xa3\xbf\xfd\xcf\x96\x65\xf9\x67\x4f\x9f\x2d\x33\x4e\x3e\xbc\xc9\x31\x5c\x9b\xb9\xf9\xb9\x2b\x49\xc3\x30\x33\xa3\x63\x63\x6b\xe9\x6c\xb6\x6d\x3b\x76\xfc\xe4\x63\xf7\xbf\x99\x73\xfd\x21\x25\x93\x9e\xa6\xa2\xdc\x58\x9c\x5f\x3a\x2c\xc6\xd4\x05\x88\x6b\xeb\x77\x7c\xe0\x63\xf7\x34\x36\xab\x89\x33\x4f\x9e\xba\xd6\xb6\x9d\xb8\x9a\x8c\xd7\x5b\x8e\xd5\x7d\xd3\x2d\x77\x3c\xc2\xe6\xe1\xea\xf2\x4a\x6c\xfe\xca\xe2\x11\x9c\x08\x49\x5e\x96\xd6\x37\x9a\x0d\xe7\x96\x3b\xde\xf7\x6d\xb6\x18\x57\x16\x97\xe5\xad\x5a\x7d\x92\xf0\x42\x50\xa0\xb1\xb9\x55\x19\x7e\xec\xa1\x27\x94\xf2\xae\xd1\xc5\x37\xde\x74\xfb\x33\x92\x2c\xd9\x4c\x38\xe3\x47\x36\x08\x5c\x3b\x35\x5c\x5a\x89\xe5\x53\x75\x41\x95\x74\x03\x7f\xa0\x87\xc6\x52\x3f\x80\x1d\x2c\xee\x30\xcb\x0a\x7a\x69\xd2\x84\xd0\xab\x5c\xbd\x40\xfa\xf1\x05\x1a\x51\x64\xed\x8c\x85\xf7\xfc\x5b\x61\xce\x3d\xa5\xbd\x5e\x1a\x11\xca\x08\x21\x87\xdf\x2b\xea\x0b\x2d\x2b\x2e\x8c\x9f\x08\x02\xe7\xd7\x5a\x0d\x7e\x7e\x61\x61\x20\x97\xde\x7d\x7d\x6d\x75\x59\x1b\xce\x16\x47\xb9\xe1\x89\xcc\xc6\xc9\x53\xf7\x72\x07\xca\x13\x69\xdf\x3c\x39\x9a\xb7\xff\xa1\x4b\x14\xc1\x77\xbc\xb0\xe2\xbc\xbf\xcb\x1e\x73\xce\x0e\x67\x15\xa5\x3b\xd3\xf4\x42\xb2\xaf\xc0\xe6\xe4\xb4\xf1\xf4\x52\xee\xd4\xe6\xe3\xce\xa5\xe5\xb7\x1a\x63\x83\x31\x33\x4a\x06\xe7\x4d\x9b\x05\x3f\x5c\x5e\x56\x5d\xee\xf0\x9e\x84\xdd\x68\xdf\xda\x3d\xfd\xdc\xf8\x70\xd2\xfc\x46\xe1\x58\xe9\xcc\xf8\xde\x81\xa7\x86\x5b\xd6\xd3\xad\x75\x3d\x66\x55\xdd\xb8\xbd\xea\xa9\x2d\xb4\xf2\x2d\x9d\xaa\x32\x11\x7c\xd1\x27\x22\x1a\xe0\x2e\xc8\xa4\x29\xef\xe7\xdb\x32\x10\x43\xd3\xa8\xe7\x59\x06\xab\x75\xe3\xb7\x2b\xef\x23\x17\x21\x0d\xf5\x67\x30\x9b\x5d\xea\x71\x01\x1b\xb4\x0c\x34\x35\x48\xed\x34\x63\xbf\x09\xaa\x94\x59\xe7\x29\x33\x48\x6b\x16\x19\x2f\x86\x48\x18\x45\x09\x88\x12\x00\x3f\x01\xc4\x6c\x10\x7f\x6b\x9e\xda\x7e\x8a\x0b\x9c\x32\x3c\x95\xc3\x22\xcc\x17\x2a\x10\x56\x9d\xfc\xdc\x33\xcf\x83\x28\x4a\xbb\xde\x74\xc3\xad\x7f\x7e\xfb\x89\xbd\xef\x2a\x24\x74\x48\xe5\x13\xb0\x58\x31\x9d\x53\x67\x9e\xf8\xcc\xcc\xe6\xd3\x9b\xab\xff\x75\xf9\x81\xfb\x1e\x1e\xbd\x6e\xa0\x58\x9a\x1c\xc8\x67\x73\x4c\xa8\x34\x5a\xdd\xf5\xb5\xcd\xea\x69\x51\x70\x1f\xb8\x66\x6a\xf2\xa2\x55\x57\xc4\x85\xcd\xa6\xec\x21\x9a\x66\xee\x1b\x59\x54\x41\x91\x14\xee\x52\x75\x9d\x4c\xb8\x63\xa4\x59\xb6\x08\xd8\xa8\x2c\x44\x0f\x45\x25\x13\xbe\x52\x20\xa8\x99\x4e\x61\x74\xd7\x0c\xbb\x05\xa9\x47\x8c\x91\x80\xc9\x2c\x76\x5b\x84\xa0\x98\x92\xc8\x82\xcc\xb9\xac\x5a\x88\x73\xd1\xa0\x63\xb5\x60\xac\xb6\xc3\x0f\x4a\x5b\xd1\xf0\xc1\xf5\x2c\x90\x84\xa4\x99\x33\xcd\xc5\x66\xab\xd2\x7c\xfb\x6e\x63\xdf\xef\xaa\x0a\x77\xaf\x9a\x4d\x7e\x89\x13\x45\x4d\x40\x11\x7e\xe0\xc0\xa1\x2a\x93\xf0\x96\x69\x13\x6a\x58\x62\x18\x53\x23\x21\xeb\x54\xcf\xc2\x0f\xdc\x57\x11\x53\x53\x58\x88\xcd\x5c\x64\x90\x49\xa5\x83\xcf\x7c\xcb\xe2\x6c\x62\x99\x61\xfd\x4a\xa4\x68\xc2\x8e\x4e\x11\x72\x80\x88\x7a\x24\x7a\x8d\xf4\x50\x44\xf7\x40\x04\x25\x43\x76\xed\x49\x57\x73\xc5\xb1\x8d\x4a\xa5\x3a\xe7\xe4\xf2\xdf\x73\x99\xe4\x69\x07\xe0\xa7\x6f\x6f\x45\x4a\x22\xf0\xa7\xf4\x92\x54\x08\x7d\x11\xed\x14\x3b\x7d\x1c\x11\x23\x35\xb8\xeb\x72\xba\x4d\xdc\x46\xb5\x3e\x80\x82\x2f\xee\xdb\x9e\xa4\xeb\x3a\x5f\xa9\xea\xc2\xcc\xec\x86\xa8\x25\xb4\x7a\x3a\x97\xdd\x28\x96\x8b\xeb\xc5\xe1\x62\xcd\x51\x35\xb3\xe5\x32\xfe\x27\x87\x57\x32\xee\x9c\xca\xba\x2d\xd4\x9a\x83\x9e\x6d\x6b\x2c\xa6\xb3\xb0\xdc\x94\x97\x56\x3b\x05\x51\x9c\x8f\xcb\xaa\x8c\x96\x75\x72\x73\x78\x6c\x60\xb9\x34\x94\xab\x7a\x2a\x4d\x68\x79\xd3\xf2\xf9\x76\x9e\x5d\x7f\x3c\xa9\xd6\x55\x55\xea\xd4\x2a\xcd\x62\xbd\xd2\x1c\x91\x15\xa9\x19\xcb\x14\x16\xf8\x78\x62\x06\x55\xa2\xbf\xb8\x52\x99\xac\x35\x2c\x4f\x94\xb5\x9a\x9a\xc8\xac\x08\x5a\x62\x4e\x4a\x8a\x6d\x3f\x22\xf5\xd2\x4d\x26\xc8\x45\x2e\x9d\x2b\x91\x54\xc6\x12\x6a\x5b\xad\x51\x44\x3d\x2a\x8e\x9c\xbf\xb9\xd1\xf0\x3a\x5d\x0b\x0a\xa5\x74\x73\x68\x24\xbf\x56\x1a\xce\xd6\x3a\x6d\x8f\x74\x5a\xbe\xe6\x7b\x42\x8b\xb5\x33\x88\xc5\xe3\xb3\x92\x22\x4d\xa3\xc8\xaf\xd8\x96\xcb\x57\x36\xeb\x7b\x5d\x07\x3a\xec\x56\x48\x92\xbc\x8c\x46\xd6\x8c\x2f\x5a\xab\x28\xb0\x03\xaf\x89\xad\x3b\xa4\xdf\x85\x2b\xa2\x75\x8a\x6e\x21\x09\x4d\x62\x86\xca\x11\xa8\x88\x5d\x59\x16\x1b\xba\xc0\x23\xb2\xa5\x02\x2a\x40\xb8\x7c\x7e\x66\x70\x61\x76\x21\x2d\xa9\x52\x57\x4d\xa8\x8d\x64\x36\x59\xcf\x16\xd3\xb5\xfc\x40\xae\x9e\xcc\x25\x75\x25\x26\x73\x66\x5b\x8f\x0b\x08\xc3\x10\x66\xdb\xa2\x2c\xb5\xb3\xc5\x54\x3d\x51\x52\x2a\xa9\xa2\xaa\x1b\x0b\xad\x94\xd1\x6d\xef\xe6\x25\x84\x4c\xa2\x5c\x2b\x96\xb3\x2b\x99\x51\x6d\x31\x5d\xd4\xba\x7a\x9b\x13\x46\xcd\x41\x1d\x38\xc7\x6d\xd5\x9a\x25\xea\x01\x3f\x39\xb5\xa7\x96\x29\xa4\x4d\xbd\xd9\xca\xaf\x6d\x5e\xce\x9d\x7e\xe6\xb1\xa9\x56\x65\x73\xec\x9a\x83\xc7\xe6\x06\xc6\x27\x9f\xbc\x34\x3d\x33\x60\xb9\x8e\x35\x30\x32\xbe\xa8\x0d\x17\x57\x21\x19\xb7\x56\x2e\x5c\x9e\x6a\x34\x3b\xa2\xa0\xa8\x4d\x2d\x93\x59\x57\x87\x06\xd6\xa4\x3d\x63\x6b\xb6\x6e\x08\xd5\x8b\x97\xf7\xbb\xcc\x28\x53\xd5\x46\xa2\x54\x58\x88\xef\x2a\xcf\x2b\xfb\x77\xaf\xe2\xd9\xa2\x88\xf0\x73\xd9\x95\xd1\x74\x75\x79\x9d\x35\x50\x49\xe3\x02\x93\xda\x86\xa5\x9e\xbf\x70\x79\xf2\xf2\xdc\xfc\x10\x5e\x4b\x2b\x96\x4a\xae\x15\x76\x97\x67\x76\xdf\x70\x70\x4e\x19\x1b\x6a\x72\xa2\x40\x11\x49\x89\xb0\x83\xf1\x93\xf6\x38\xc0\xa3\x36\x7d\xbd\x2d\x91\x60\x0e\x78\x6d\xa2\xcf\x03\x0b\xb0\x17\xb8\xee\x49\x6c\xb2\xcd\x86\x18\x39\x18\x49\x44\x7f\x12\x54\x6d\xf9\x74\x9b\x8a\x6a\x9b\xaa\x2a\x62\x8b\xed\xc5\x4c\x22\x8b\x1c\x91\x9d\x5f\xaf\xad\x0b\x46\x47\xcf\x89\x7b\x87\x33\x62\xbb\x3e\xbf\xf6\xd0\xbd\x7f\x2f\x25\x62\x8e\x93\x70\x12\x09\xa3\xd1\x48\xec\x9b\x14\xaa\x15\xf7\x6d\x04\x5a\xf7\xf1\x2a\xef\x44\xf5\x21\xbd\x70\x47\x74\xf2\xd0\x4b\x4c\xee\xf1\x9b\xd3\x6d\xca\xc6\x40\xa3\xb1\x6f\x79\x68\x57\x72\xd6\xe8\xbe\xf8\x7d\xca\xf4\xca\xf2\xe6\xb3\xf5\x9f\x6b\x0c\x14\x76\xd3\x54\x22\xe9\xc8\x92\xe8\x84\xb5\xc3\x9e\x6f\xba\x0e\xc9\xa4\x5d\xee\xa6\xa3\x13\xce\xc9\x67\x3f\x51\xfd\xf6\xcc\x77\x86\x0e\x17\xef\xd7\xd2\xbc\x1e\x1f\x00\x23\x41\xf9\x2e\xe3\x50\x19\xa2\x7c\xc8\x9f\x12\xf8\xad\xc3\x12\x9a\x60\x2c\x78\x3f\xcc\x7a\x06\x94\x61\xe6\xb6\xdb\x2e\x42\x6d\x7e\x60\x82\x33\xd2\xbd\x1e\x8b\x44\x90\x33\xc0\x45\x7c\x19\x10\x51\x50\x87\x44\x17\x11\x43\x50\xc4\xc0\xe0\x12\xd8\xac\xf8\x50\x5f\x05\xaa\xa2\xf8\x45\xdd\x04\x54\xf6\x43\x3f\x3c\x25\x57\xa5\x08\x09\x2f\xa4\xaa\x44\x8b\x69\xf0\xc8\xbe\xb7\x7c\xfe\xf6\x13\x07\x7e\x71\x30\x63\x81\x9a\xd2\x60\x6e\x85\xc2\xec\x8a\xf5\x95\xeb\x26\x6e\xf8\x5e\x5c\x89\xc3\xea\xd6\xe2\xd2\x62\xe5\xcc\x77\x56\x1b\xa2\xcc\x5d\x46\x80\x2d\xca\x56\x3a\x99\x69\xad\x6e\xcc\xbb\xa2\x20\xc3\x95\xb5\x69\x76\x22\x16\xfe\x67\xb1\x8b\xb6\x1c\x0b\x6e\x98\x3a\x0a\xb7\xde\x7c\x27\x3c\xfa\xbd\x07\xe0\x4d\x1b\x9f\x86\xa5\xbb\x9a\x00\x15\x00\x2b\xd9\x06\x4b\x76\xc1\xe3\xd3\xc1\x19\x78\x08\x2a\x0e\x5d\x9c\x82\x7a\x6c\x06\xea\x25\x01\x6a\x50\x20\x7e\x6d\x83\x64\x34\x93\x31\x5e\x10\xa9\x90\x85\xef\x3f\xff\x30\xd9\x7f\x9c\xf9\xdf\xf6\x93\x8d\xf9\xa7\x49\xca\x4e\x92\x74\x79\x18\x88\x6b\x70\xad\xba\x49\x84\x64\x9c\x38\x96\x45\xce\x3e\xf5\xe4\x04\x11\x24\xe3\xe0\x27\x3f\x5e\xb0\x2e\xcc\x7c\xc4\x9e\x5d\xa8\x8b\xaa\xf8\x27\x84\xb5\x63\x40\xf4\xc2\x82\x45\x92\x20\x31\x92\x1f\x9c\x8a\x5e\x00\x69\x58\x05\x08\x6a\xad\x90\x60\x24\x24\x19\x89\x50\x49\xa0\x12\x7a\x28\x25\xc4\xda\x3d\xf7\x51\x44\xa9\x16\x29\x99\x00\xe3\x46\xeb\x21\x70\xad\xd1\x5e\x92\x3b\xde\x73\x9f\x15\x4c\xca\x11\xf3\x0e\xe1\xc2\xca\x78\x54\x92\xc3\xc5\x11\x46\xbc\xc5\x05\xad\xe7\xa3\x6a\x78\x1a\xf2\x3f\x70\xa1\xf1\xc6\x96\x06\x84\x45\x8e\x51\xba\x71\x40\x37\x48\x22\xbe\x2a\x12\x4a\x3e\xb6\xf3\xe2\xc8\x78\x55\x51\xd3\x2b\xb5\x8d\x4a\xae\xdd\x68\x66\x6c\xd3\x56\xd9\x79\x0a\x92\x68\xc5\x92\xf1\x56\x2a\x9b\x6d\x24\xf3\xe9\x36\x2a\x12\x93\xe3\x45\x9f\x35\x91\x61\x4f\x40\xd3\x24\x3f\x32\x6e\x70\x52\x12\xd7\xda\x66\xbe\xdb\xea\x24\x7d\xd7\x95\xd8\x51\x05\x51\xb2\x63\x5a\xac\x1d\x4f\xa7\x5a\xa9\x5c\xba\xa9\xa5\x12\x86\x28\x48\x5e\x3e\xe6\x54\x95\xf8\xc8\x46\xb7\xdd\xd6\xd8\x9c\x8d\x25\xe2\x5d\x41\xe0\x5d\x6d\x6d\x23\xaf\xa5\xb6\x16\xd1\x52\x35\xb3\x43\x23\xcb\x36\x97\x6f\x38\x38\x00\xa9\x12\xb9\x32\xac\xab\x2c\x05\x5c\x28\x95\x8b\xab\x62\x62\xb8\x62\x82\xe4\x30\x0a\xbf\xe0\x6a\x49\x17\x7c\xd5\xa5\x89\xd1\x41\x7d\x14\x95\x82\x96\xae\x2f\x99\xba\x1e\x47\xe1\xe4\x25\xd3\xf1\x66\xb6\x98\xa8\xe6\x0a\xa9\x96\xa6\x29\x0e\x22\x14\xdf\x73\x1d\x7e\x68\xbc\xb8\xc4\x70\x9f\xe7\x78\xe2\xc0\x48\x6e\x65\x64\x77\x61\x4b\x89\x89\x8e\xe4\xf2\xdc\xd8\x54\x71\x9e\xe3\xa9\x8f\x16\xb8\x9c\x2b\x24\xb7\x46\xc7\xd3\x6b\xaa\xea\x9a\x41\xaa\x27\xd9\xd9\x1e\x94\xf6\xb3\xae\xfd\x9d\x1b\x19\x60\xa7\x30\x54\x44\x78\xb0\x37\xe9\x6e\xa5\xe8\x8a\xc3\x2a\xed\x79\xe2\xc9\x8a\x68\xc4\xe2\x6a\x27\x99\x52\xdb\x89\xb4\xd6\x8d\x27\x63\x86\x12\x93\xf0\xbc\x58\x4b\x9e\x3a\xb0\x52\x04\x4d\xb4\xed\xa1\x21\xe5\x92\x40\x13\x2d\x51\x14\xec\xf2\x88\xb2\xa2\x42\xd3\xf0\xea\x5d\xaa\x50\xc3\x1c\x1a\x56\xae\xc8\x1c\x2a\x1b\x4d\xee\x8e\xec\x8a\x2f\xc7\xb9\x96\x07\xad\xae\xa4\xe2\x1e\xc6\xca\x88\x0c\x49\xe6\x52\x65\x1d\x36\x15\x3e\x1e\x93\x14\x2f\xff\xb5\xaf\xfe\xe5\x7b\xd0\x94\x4c\xe9\x66\x87\xcd\x2a\xfb\xba\x03\x87\xce\x1d\x3e\x7a\xf8\x69\x4e\x68\xaf\xaa\x9a\xd1\xd9\x7b\xb0\x38\x3b\x3c\x19\x5b\xca\x4a\x55\x1f\xec\x86\x30\x54\x82\x9a\x3b\x91\x3a\x63\x19\xb6\x9a\x1b\x4c\xad\x95\x92\x56\x87\xab\xcd\x0a\xbc\xed\x70\x85\x14\xd4\xcc\x72\xea\x8c\xe7\x7a\x42\x6e\x28\xb3\x9c\xd3\x68\xd3\x5d\x5f\x08\x38\xcb\xd2\x8a\xd7\x99\xd8\x53\x7a\x2e\x21\xfb\x9b\xed\x5a\x33\xe7\xd8\xae\xc2\xe4\x83\xc0\x0b\x8e\x1c\x93\xdb\x5a\x2a\x5e\x4f\x15\x72\xb5\xcc\x40\xbe\xa5\x02\xe2\xa5\xa5\x79\xc1\xdc\xa6\x57\x88\x1c\xc0\xd0\x0f\x5f\x84\xf4\x53\x91\x3f\x88\xd0\xde\xb6\xd0\x85\xd0\x73\x65\x71\x21\x9c\xe0\xa2\xb2\x5e\xe8\xf1\xf4\xf4\xcb\x67\x43\xc6\xb8\xe8\x37\xa4\x97\x5d\x05\x3b\x32\xa5\x22\x3e\xad\xc8\xfe\xa6\x61\xfe\x17\x93\x2b\x84\xc6\x40\x77\x12\x9a\x77\xa1\x73\xe9\x91\xbb\xe3\xf9\xf2\x70\xec\xe8\x1b\xde\x3a\xb4\x7f\xe2\x48\xa2\x54\x2c\xd6\x89\x44\x8c\xf9\x39\x9b\x9e\x3a\xff\xd7\x45\xce\x35\x68\x8a\xf8\xc4\xdf\xe6\xff\xec\x65\x82\x5d\xf5\x1a\x79\x02\x68\x2f\x35\x39\xba\xd6\xd0\x07\x84\x0f\x25\x41\xfc\xe4\x8d\xdc\xe3\x83\x9b\x8d\x33\x5b\xed\xad\x72\x77\x4b\xdb\xa5\xd3\xd4\xa8\x21\x08\x25\x47\x14\x13\x9c\xc3\xf1\xac\xb5\xa0\x88\x13\x5c\x54\x48\x9d\xe8\xb6\xdc\xba\xb8\x91\x4e\x5d\x4f\xba\xc9\x02\xf1\x98\xc3\x22\x6a\x83\x11\x0e\x25\x07\xdb\x3a\x24\x4c\xf2\xa0\xe0\x46\xb5\x33\xc1\x99\x04\x7e\xb4\xe0\x8c\xa8\x0d\x61\x13\x31\xb0\xc5\xa0\x9a\x93\xf5\x49\x71\x5d\x12\xa8\x3a\x1f\x3f\xb2\x2d\x8f\x41\x5b\x20\x1e\x42\x79\x46\x40\xe4\x0b\x0c\xa1\x10\x62\xfb\xe0\x2e\x03\x9d\xf3\x74\x44\x23\x22\x88\x06\x1a\x5e\xf8\xca\x50\xc9\x55\x0c\xc6\xd1\x1d\x11\xf0\xd6\x07\x4d\x62\xa2\xa8\x6f\xe1\xc8\xc1\xb7\xdc\xfd\xee\x13\x87\x3e\x38\x9a\x37\x21\x86\xca\xa3\xd2\x12\xe1\x9e\x07\xcf\x7d\x5d\x37\x8c\x4f\xef\x1d\xbb\x06\x4a\xd9\x51\xf0\x1c\xd3\x68\xb6\x3a\x06\x17\x73\xf0\xe0\x3c\x48\xb2\x0a\xf3\x1b\xe7\x61\x65\x7d\x3e\xec\xce\xe6\xbb\x57\xd1\x1f\xbb\xf8\x9e\x35\x23\x62\x3d\x29\x58\xd7\x2d\xd6\xde\xd6\xb5\x3d\x40\x93\x17\x1c\x46\x45\xce\x5a\xab\xb2\x2b\x64\x64\x70\x02\xe2\xb0\x16\x1f\x5c\xa5\x97\xa2\x60\xb0\x6b\x6f\x39\x34\xce\xc8\x1e\xf1\x92\xa5\x0c\x07\x17\xe6\xcf\xc0\x9e\x37\x67\xd0\xde\xcd\xc0\x06\xaa\xc9\xea\xe2\x1c\xfc\xeb\x3f\xfe\x3e\xfc\xdd\xdf\x7c\x19\x56\xcf\x96\xe0\xdc\xc9\xc7\x40\x32\x5b\xa8\x45\x37\x6a\x9e\x6d\xae\xce\x3d\xfa\x3f\xb3\xb9\xdb\xee\x98\xe0\x5b\xf6\xef\xd0\xf9\xf9\xef\x50\x97\xde\x8f\xb7\x41\x60\xfc\x86\xe7\xe7\x67\x09\x5a\x96\x50\xca\x14\xc1\xb1\x69\xd0\x91\x54\x24\xac\x8a\x3b\x88\x4b\x07\x23\x2e\x06\x37\x91\xd5\x07\xf2\x04\x76\x72\x08\xf6\x89\x2e\xfa\xc5\x1e\x2f\x20\x7e\x0e\x2c\x2c\xc6\x38\x87\xfb\x60\x2d\x60\xf2\xfb\x62\x64\xf3\x91\x2d\x4e\x11\x63\xa8\x3c\x4d\x22\x6b\x29\x42\x79\x95\xcc\xaf\xcd\x42\xab\x5d\x25\x82\xc8\x07\xba\x8b\xd5\x0e\xe2\xb4\x0f\x6d\xad\x20\x0d\x3d\x30\x1d\x48\x8f\x04\x94\xf6\xb8\xdf\x7a\x37\x52\xe2\xfb\x0d\x82\xc2\xd2\x5f\x62\x9b\x16\x6f\x74\xbb\x92\xeb\xba\x7c\x88\x30\x05\x4f\x69\xab\x8e\x5c\x95\x5d\x7e\x5e\xa0\xbd\x65\xba\x93\x28\x3c\x28\x42\x44\x74\xa7\x77\xbb\x82\x6d\x98\xa2\x17\x14\x57\x32\x03\x8e\xf7\x65\x45\x71\x94\x86\xe2\x0a\x2b\xa2\xdf\xaf\x93\x20\xb4\x9f\x8e\x12\xea\x55\x76\xcd\x7a\xa7\x23\x9a\x5d\x5d\xc4\x63\xfa\x6b\xcd\x55\x5b\x38\x2f\xf9\x4c\x3e\x38\x86\x21\x74\xdb\x5d\x16\x47\x20\x6b\xd5\x35\xfb\xfc\xe5\xcb\x5e\x58\x0d\xcf\xc6\x88\x85\x91\x6e\x84\x22\xcd\x93\x43\x63\x0e\x19\xda\x93\xe3\x2c\xfb\x8a\xc2\x51\x55\xd4\xbc\x2e\xe5\x6c\xdf\xa1\xad\xb4\x5f\x35\x28\xa9\x10\x93\xc5\x84\x59\x45\x0d\x71\x5d\x45\x88\x4b\x05\x89\x8a\xb8\x23\x5b\x74\xb7\x96\x5c\x9f\x0f\x09\x6c\x70\x8e\x29\x42\x2e\x5b\x12\x29\xe3\x05\xd4\x04\xd7\x6e\x53\xb7\x61\xea\x10\xa4\xef\x71\x41\x76\x6e\x10\xe9\x62\xc2\x8b\x0b\xf9\x8d\x19\x13\x42\xa0\xbe\xc3\x21\x0f\x91\x69\x22\xe6\x93\xa9\xc9\xc4\xc5\xe1\x41\x59\x0e\x5c\xa9\xf8\x99\x28\xf3\xbe\xaa\xe2\x98\xaa\x82\xcf\xb3\x24\x46\x62\xe2\x5e\x8c\x88\x63\x36\x5c\x6e\x5a\x1c\xb8\xe4\x41\x71\xd3\xdc\x5d\x78\x1e\x81\x31\xd5\xe2\x9e\x27\x8a\x5b\x01\x8e\x4c\x64\x7d\x92\x39\x2c\x57\xec\xfd\x39\x04\x38\x1c\x8d\xc5\x2c\x57\x10\xd6\xc2\x36\xbc\x8e\x2f\x2c\xae\xb7\x32\xb5\x85\x7a\xbe\x55\xd5\xf3\xae\x92\x92\x4a\xe5\x92\x5f\x1e\x2c\xac\x78\xae\xbf\x39\x32\x7c\x6d\x6d\xef\xe4\xf8\x4a\xa1\x90\x5e\x4e\x17\xba\x2b\x92\x6c\xb6\x26\x46\x55\x91\xe1\x5e\x55\x69\xba\x3c\xdf\x12\x19\xde\x1d\x9a\xa2\xd6\xc1\x11\x75\xce\xf3\x65\xa2\x28\x9e\x23\x2b\x73\x08\xc0\x21\xce\xb8\x05\xc6\x6f\xa0\x66\x77\x9f\x3a\xc3\xee\x9e\xaa\x59\x8e\x2c\x5f\x94\xf0\x37\x52\x58\x9f\x81\x67\x5f\x06\xc7\x3c\x0c\xab\x66\x57\xdb\x40\xc4\x1f\x98\xcd\x68\xe3\x50\x49\xe6\x5d\x45\xf5\xd1\x58\xac\xa2\xc4\xa9\xe2\xf2\xa0\xe2\x76\x4e\x52\x24\xf9\x19\xc3\x1f\xab\x02\xf7\x4d\xe8\x11\x6f\xd2\x7e\x28\x3a\xfa\x5e\x98\x69\xd5\x2b\xd0\xeb\xd9\xf3\x34\xf2\x14\x85\x26\x77\x48\x53\xdc\x0b\xb2\xb3\x77\x7e\x6f\x3f\x61\x41\x60\x7f\xbf\x81\xc9\x46\x7b\xc5\x7e\x24\xcc\x64\x0a\xe3\x29\x3e\x1a\x3f\x54\xde\x2d\x9a\x1b\xf3\xb6\xa7\xeb\xc5\x8f\x48\xc7\xde\xf9\x21\xa1\x98\xe4\xad\x56\xbd\xba\x71\xfa\xbb\x4f\xe9\x0b\xb3\x4f\x0c\xc5\x3b\xf7\x1d\x3c\x5c\x3c\xc7\x49\x84\xb3\x74\x9b\x44\x0c\x48\xbd\xba\x91\x90\x7a\x85\x84\xd5\xf2\xdb\x05\x86\x61\x1c\x26\x0c\xa2\x31\x9e\x37\x44\xb6\xac\x92\x1e\x35\x16\xca\x55\xb6\x72\x7d\x2a\x29\xa4\x36\x28\xaa\x9b\x46\xc7\x3e\x65\xeb\xeb\x42\xab\xee\x2b\x5d\x9d\xc4\x39\x57\x52\xec\x96\x13\x03\xc1\xeb\x68\x79\xb1\x2a\x8e\xca\x06\xfb\x45\x65\x59\xf2\x57\x66\x2c\x60\x69\x1d\x3c\xeb\x22\x49\x85\x20\x3e\x6f\x5b\x0e\xe3\xf6\x08\xed\x54\x2f\xca\x38\x70\x23\xa6\x61\xb4\x59\x0c\x0f\x4f\x4c\x94\xd1\x2a\x77\x21\x51\xcb\x02\x6f\x73\xb0\x95\x6d\x30\xbe\x7d\xd4\x53\x28\xc7\x14\x9f\xca\xb8\x8d\xe5\x1c\xb0\x9f\x3b\x0a\x80\xda\x61\xc3\x25\xe3\x3a\x46\x5d\x26\x21\xe2\x68\xfb\x28\x3b\xf1\xc3\x22\x05\x11\xc5\x9d\xe0\x85\x96\x2b\x93\x40\xc4\xdf\x29\xda\x42\xc9\x21\x4c\x4d\x4e\xc1\xc5\xd3\x57\x80\xf9\x53\x4b\x85\x91\x3b\x6f\xbd\xf1\xc8\x5d\x93\x83\x36\x48\x71\x0d\x5a\xba\x04\xf7\x3e\x78\xe5\xbe\xf5\xca\xea\x87\x8f\x1e\x38\x61\xb9\x9e\x85\x07\xb7\x21\x26\xaa\x90\x8e\xe3\x3c\xd3\x50\xcf\xf1\x7c\xd0\x29\xd0\xdf\xd1\x9d\xec\x85\xbd\x0d\xd8\x78\x26\x32\x1a\x8c\xee\x1b\x84\xc3\x6b\xd7\x43\xb6\x96\x03\x77\x2f\x5e\x6c\x93\x82\x19\x43\x64\x21\x32\x04\x12\x0f\xa6\x92\x87\x90\x29\x0d\x09\x46\x85\x07\x72\x8e\x83\x18\xcd\x80\x5f\xf2\x21\x1d\x0b\x10\x08\xa8\xf9\x1c\x1c\x3d\x72\x04\xca\x83\xbb\x51\x20\xaa\x40\x0e\xee\x05\x3f\xdb\x81\xdd\xed\x51\xc8\x8e\x14\x20\x83\x6b\xf3\xe1\x47\xbf\x02\x8a\x2a\x03\xa2\xa1\x0d\x9c\xc4\x4f\x7c\xf3\x4f\xef\xfe\xe3\xa3\x4f\x3f\x7b\x23\xae\xae\xc7\x12\x14\x1e\x17\x64\x19\x3c\xdb\x75\x45\x51\x82\x6f\x3d\x7e\x1f\xdc\x7c\xd3\x09\x78\xc3\xfe\xe3\xd0\xed\x18\xc1\x40\x31\x8b\xd3\xa3\x61\x4e\x07\x9b\x2d\x42\x5f\x81\xfc\xc8\x5d\x95\x7c\x1a\xca\x5a\xf6\x2a\x27\x14\x18\xbe\x31\x09\xca\x32\x40\x4c\xd0\xc0\x48\x77\x70\x5b\x16\x28\x9f\x80\xc7\x2f\x7c\x13\xa6\x2f\x3d\x0b\xa2\x28\xbe\xa8\x1b\xc1\x36\xa2\x7f\x89\x9e\x11\x41\xa7\x46\x5e\x84\x1b\xc7\xdf\x16\xbc\xd2\x5e\xdd\x2d\xa3\x5b\xe0\x24\x48\x25\xe5\xab\x3a\x4a\x04\xb3\x9e\x35\xdc\xb1\xdd\x97\xbc\x12\xf6\x4d\x11\x8f\xa3\xca\x8c\xbd\x24\xf1\xa2\x63\xb1\x89\x8a\x56\xc0\x55\xcd\x12\xc8\x4b\xb4\xa1\x53\x58\x9f\x89\xb4\x1a\x65\xfd\xe3\xf8\x19\x4e\xb4\x5d\x84\x64\x26\x13\x1a\x55\x01\x67\x9e\xdf\xab\xe5\x8a\x2a\x01\x3a\x41\xde\x8d\xdd\x75\xc0\x6f\xf8\x30\x52\xce\xc1\xba\xe8\x81\x7d\xc5\x05\x55\x68\x82\xe1\xae\x43\xca\xf4\x88\x10\x90\x41\xe6\x40\x60\xb9\x0a\x28\xbd\x93\x38\x86\x01\x88\x37\xf0\x0e\xea\x01\xb7\x59\xb0\x4b\x1e\x2d\xcb\x38\x2f\xd3\x40\xa2\x37\x28\x67\xd5\x29\x42\x63\xf6\x46\x08\xec\xc7\xae\xdd\x65\x0a\x2f\xc8\xf2\xa4\x1a\x23\x16\xb5\x89\x6a\x2b\xc4\x41\x83\x07\x50\x07\x21\xbc\x26\x0e\x03\x81\xae\x0d\x54\x62\x54\x90\x0a\xd0\x28\xaf\x22\xe0\xc8\x08\x7a\xd3\x32\xf6\x33\xe6\xe1\x67\x1e\x97\x5e\x14\xae\xd7\x5c\x89\xe9\xa6\x20\x9c\x04\xa1\x7f\x23\xa2\xc9\x09\xae\x99\xd1\x4a\xca\x61\xca\x70\xf0\xf3\x30\x7e\xc6\xac\xbc\xf5\x95\xb5\xd4\xea\xda\xc6\x1b\x71\x4e\xee\xc3\xf3\x2b\x02\xe9\x92\xf2\x3a\x99\x39\x34\xfe\xd6\x6f\xa0\x32\x6f\xa0\x82\xaf\x2e\x5d\x86\xd5\xf6\x96\x57\x41\x2d\x8a\x27\xab\xf2\x3d\xb6\x5c\x96\x2b\xeb\x6f\x73\xad\x45\x6c\xb3\x81\x2d\x44\x83\xf6\x00\xd0\x9f\x4e\xdb\x7d\x1d\x7a\x71\x06\xba\xcd\x8c\x16\x41\xe9\x08\x3a\xf4\xa3\x13\x91\x17\x8a\xd2\xbe\x23\xe7\xea\x19\x1b\xc0\x01\xb1\x1b\x07\x4d\x48\x52\x65\xca\x61\xb4\x24\x51\x52\x62\xc0\x1b\xbf\x83\x94\x87\xd2\xed\x8c\x9d\x88\x8c\x70\x47\x81\x5f\xdf\x6f\xb5\x1d\x85\xe0\x60\x87\xa5\xbf\xdd\x1f\x6f\x3b\x78\x05\xd0\x33\x6c\xfa\xc8\x84\xb1\x2a\xbb\x1e\xbd\x30\x7d\x89\x6e\xd5\x37\xb9\x67\x2e\x5e\xc0\xa9\x33\x77\x7f\xea\xec\xf4\x63\x56\xa7\xb9\xe5\x59\xee\x0a\x27\x08\x0b\xe5\xd2\xee\x7a\xb7\x38\x08\xe7\xa7\x37\x84\x5d\x63\xa3\xa4\x54\x1a\x43\xa1\x6b\x05\x71\x01\x1e\x42\x42\x5c\x0b\x05\x2a\xef\xf3\x14\x6d\x3c\x60\xb2\x10\x95\x3c\xcb\x06\xc2\xf5\x80\x73\x11\x27\x6d\xdd\xe9\x80\x37\xdf\xa4\x92\x27\x41\x23\xde\x0e\xda\xfe\xf2\x1d\x1c\x43\xc7\x86\x0d\xab\x06\xd9\xb4\x46\x15\x4b\x71\x1d\x6a\x9b\x7c\x92\x36\x34\x26\x69\xba\x2e\xd8\x1a\x0f\x46\x15\xd7\xee\xa2\x85\x47\xf2\x70\x9e\xab\xc0\x7a\x7d\x31\x12\x77\x1f\xe7\x5c\x07\x01\x3a\x6d\x0a\x10\xc7\xbf\x25\xd6\xe0\x8b\x4d\xcd\x18\xca\x25\xbc\x56\x45\xc7\xa9\x23\xf8\x61\x89\x00\x9e\x8b\xc7\x06\xd1\x6c\xc0\xa1\x0b\x47\x81\xb6\x29\xdc\x77\xeb\xa3\x90\xb7\x13\x60\x0a\x6e\x68\xe0\x45\x46\x2f\xcf\xc8\xc1\xd1\x86\x64\xc0\x82\xa5\x3a\x30\x9f\x09\xdb\x8f\xc0\x93\xa0\x30\x3f\xf0\xab\xf8\x91\x2b\xf7\x15\x44\x9e\xf0\xbe\xf7\xbe\x1f\xe6\x9f\x5f\x85\xfb\xff\xf3\xbb\x59\x44\x22\x19\x56\x5f\xae\xa6\xe2\xa8\x3c\x38\x78\xf4\x54\xfb\xc9\xc7\xcf\x3e\x78\xd7\x44\x79\x5c\x4f\xc4\x04\xb0\x6c\x37\xbc\x3f\x1e\x13\xb0\x2c\x3d\x2a\x6c\x60\xf4\x83\xba\x0d\xb2\x42\x9d\xc9\xc3\xbb\xe1\x5d\x1f\x3d\x11\x3c\x7f\xb8\xc7\x81\x97\xfd\xe4\xce\x8f\xdd\xb4\xe3\xdd\x44\xf0\xff\x67\xf0\x1f\x7b\x94\xb2\xb3\xf0\x87\xa8\x81\xd9\x29\x19\x78\xc6\xb8\x69\xba\xe5\x37\xaf\xdc\xf3\xb5\x2f\xff\x13\xae\xe2\xc0\xec\xbc\xaa\x4f\x38\xde\xf4\xcf\x7e\xee\x53\x70\xdb\xc7\xdf\xfe\x53\xeb\x5c\x76\xfc\xd0\x8d\x2f\xda\xf6\xee\x0f\xbd\xe1\xc7\xde\x9f\x6d\x3a\xf0\xf5\x2f\x7e\x0b\xd0\x6a\x82\x9e\x40\x78\x6d\xb4\x4a\x7c\xa9\x8d\x5d\xc4\x99\x6d\xd8\x62\x3a\x6a\x85\xf5\x1b\xe0\x51\x11\x52\x90\x87\x59\x6e\x43\x16\x14\x5c\xc8\x88\xca\xa9\xbd\x9d\x59\xd0\x6b\x2c\x01\x91\x89\x44\x76\x68\xb4\x1d\x5a\x2d\x92\x8c\x21\xef\x5d\x4f\x82\xe2\xab\xa2\xf6\x3b\xf9\x31\x7e\x62\x2f\x86\xc6\x0c\x43\x5c\x8c\xa2\x21\x34\x69\x43\xf8\x26\x6e\x4b\xb9\x5e\xcc\x97\xf0\xd1\x11\x7e\x50\xef\x6d\xda\x17\x7f\x2f\xd5\x67\x9a\xee\x6c\x54\xc4\x74\x15\x2a\xe8\x8b\x17\x97\x32\x9e\xeb\x5e\xc3\xf3\x9c\x81\x07\xaf\xb2\xac\xeb\x85\xb9\x95\xb5\x85\xd9\xe5\x79\x3c\xff\xef\xe3\x79\xcc\x5e\x7f\xf8\x3a\x57\x94\x14\x40\x74\xd0\xe7\xe7\xa4\xf4\xea\xa1\xa5\x7d\x29\xfc\x22\x65\x0f\x57\x37\x5c\x22\x3b\x6c\x14\x72\xd5\xd6\xab\xb5\x44\xaf\xd6\xf2\x65\x8d\x26\xd1\x01\x69\x7a\x08\xf6\xe6\x8f\xc1\xf1\xdf\x12\x7f\xe6\xd3\xac\xd5\x6c\xc3\xe7\x76\xff\x1e\xd4\xeb\x0d\x90\x65\x79\x1a\x2f\x7a\xda\x8f\xd2\x4d\x7b\xa4\xd8\xe7\x66\xcf\x05\x7d\x4e\xea\x6e\xdd\xfe\xdb\x2f\xfd\x15\x7c\xe0\x53\xb7\xfc\xc8\xc7\x59\x38\xb7\x08\xff\xf2\xf9\x7f\x03\x3f\x26\x43\xd2\x66\x26\xbe\x1f\x90\x35\x7a\xa6\x8f\xa0\xa0\xcb\xb2\x36\x70\xaa\x30\x8a\x14\x0f\xe7\x97\x8b\xca\x40\x05\x16\x4b\x63\xf6\x95\x2b\xb2\x70\x2f\x05\x01\xbf\x4b\x24\x0b\xe2\xa9\xd0\x53\xae\xe3\xf0\xe9\x0a\xca\x33\x5d\x00\x05\x15\x8d\x62\x72\xc1\xfc\x35\x24\xae\xc7\x99\x1f\xcc\x43\xd8\xa6\x6c\xed\xb5\x5a\xe6\x40\x57\xbb\x01\x14\x8e\xfc\x6a\xdb\x1e\x8a\xb0\x5b\x25\xed\x2b\x86\xed\x4c\x37\x1a\xf4\x99\xf1\xd8\x3a\x62\x79\x4d\xee\x8e\xcf\xb8\xde\xf2\xda\xe1\xf6\xd8\x19\x03\x11\x78\xa1\x5d\x6b\xad\x3d\xfb\x1f\x8f\x3c\xf0\xd5\x86\x71\xf3\x6d\x8e\x05\x67\x1f\x3d\xf5\xf0\x27\x67\x57\xce\xd7\xa7\x86\xa7\x50\x4a\x31\x4d\x10\x9e\x8c\x8b\xcb\xd7\x71\x59\xd7\x5c\x27\x9c\xbc\x2c\x7a\xe9\xfb\xf0\x6a\x68\x97\x5d\x28\xe6\xe1\xf3\x7f\xf6\x47\xb0\xa3\x45\x28\x33\x7d\x9b\x2f\xf7\x7d\xcb\xb4\xe0\xf8\x89\x63\xaf\xf9\xb6\xb5\x36\x5a\xc8\x16\x3e\xb9\xd7\x92\x02\x79\x59\xad\xc2\x87\x42\x5b\x80\x1d\x5e\xf4\xbe\xe0\xa7\x2f\x6a\x16\x47\x5f\xb1\x89\x1c\xfc\x50\x9f\xd2\x57\xde\x46\x76\x24\x0b\xfd\x1f\x15\x25\x79\xe5\xae\xbc\x41\xc5\x35\xaa\x2e\x03\x05\xcd\x69\xcf\xf3\xbb\x91\x8a\xaa\xe2\x73\x49\x94\xc4\x35\x9c\xdb\xad\x83\xd7\x1d\xf0\x07\x06\x07\xc0\xc1\x35\x18\x28\xbb\x9f\x58\xbf\xe1\x1f\x7d\xbf\x12\xaf\xc2\x79\xf5\x41\x58\x89\x9f\x84\xe3\xf0\xd9\x9f\xf9\x8c\x62\xde\x88\xbb\xbf\xf0\x07\xc1\x5a\x67\xf9\xff\xaf\xf4\x5d\xf6\x9d\x13\x6f\xba\xf1\xc7\x3a\x0e\x73\xdd\x5a\x86\xd5\x23\x2e\x0a\x03\xfa\x28\x86\x3c\xdc\x66\x19\x36\xd8\xf8\x34\x71\xff\x8c\x19\x98\x63\xb4\x20\x28\x47\x99\xd1\x67\xa1\xc5\xef\xf2\x36\x08\xf8\xb7\x6b\x31\x3f\x0b\xbf\x2d\xa4\x4d\x34\x62\x0c\x16\x38\x45\x83\xde\x64\xd9\xca\x26\xa2\x1d\x9b\xa1\xa1\x88\x50\x0b\x11\x08\x2f\x86\x08\xc4\x62\x7d\x95\x58\xac\x5b\x47\x74\xd4\x0e\x43\x06\x26\x3b\xb6\x2d\xe1\xf7\x9d\x20\x97\x87\xb2\xdf\xe3\x5f\x38\xaf\xc0\x67\xbd\xfa\x74\xfc\xbe\x18\x96\xd4\x39\x28\x3f\xe4\x4e\xd0\xc6\x3c\xf8\x9d\x64\xb3\x3c\x25\xe6\x8a\x13\x50\x17\x7a\xa1\x3b\x8b\xfa\xc1\xb5\xb8\x91\x17\x22\x50\x20\x36\x1a\xea\x1d\xbd\x5b\xe7\x79\xfe\xd4\xe9\xe9\x93\x8b\xcf\x5d\x3c\xf3\x45\x94\x43\x4b\x96\x63\x98\x1c\xee\xf8\xa1\xa7\xff\x1b\x1e\x7d\xe6\xa1\x1d\xc9\x15\x91\xa1\x43\xfa\x4b\xc2\xc3\x83\xb2\x38\x87\x63\x75\x5f\x34\xb0\xb8\x6f\x3c\x86\xf5\x53\x99\x2c\xe9\x4c\x0a\x7e\xe3\x37\x3f\x0a\xaf\x3f\x5e\x7f\xbc\x56\x1f\xcc\xf8\x29\x8f\x96\x4d\xcf\xf3\x2e\x10\x42\xe6\xa2\x95\xe6\xa0\x80\x72\x86\xca\x43\x34\x6a\xf3\x1c\x28\x8f\x57\xeb\x23\x0c\x5e\xf8\xaf\x8a\x73\x91\x24\x09\x3e\xf4\xeb\xbf\xf2\x13\x3f\x4e\x32\x9f\x84\xe3\xb7\x1f\x03\x41\x12\xb6\x11\x70\x60\xed\xdb\x2e\x4c\x38\x3a\xa4\x12\x0a\x48\x8e\x0c\x2e\x53\x08\x9a\x0f\x2a\x55\xc0\x69\xa3\xdc\x54\x50\x48\x33\x26\x73\x94\xc3\x3c\xa2\x16\x4e\x92\xb6\x15\xb7\xc3\x33\x14\x82\x46\x7a\x47\x80\x98\x84\x08\xc5\x25\xa1\x0b\x4b\x09\x9d\x8c\x8c\x79\x8f\xe3\x43\x2f\x1f\xfb\xae\x2f\x30\x05\xd3\x81\xd2\xbe\x02\x64\xfc\x14\x9c\x98\xba\x01\x62\x9e\x0c\x0e\x17\x16\x59\xf2\x6e\x98\xeb\xe3\xb3\x10\x28\x4b\xd5\x35\x82\x1c\xe7\x50\xa9\xa0\x92\x51\xf4\x10\x0c\x8c\x27\xf0\x6f\x57\x08\xdc\x58\x9c\xcf\x1a\xfe\xd1\x80\xde\x89\xfd\xc8\xc5\x79\x57\xde\x3f\xd8\x57\x20\x07\xaf\x3f\x00\xef\x7d\xff\x2f\x41\x2c\xa6\x56\x70\x4f\x95\x1e\xd7\x18\x89\xac\xf8\x30\x7a\xf4\xc2\xb4\xd1\x17\x38\xbd\x23\x42\xdb\x97\x7a\xe8\xba\x01\xd7\x1d\xbe\xf6\x75\xc9\xf0\xfa\xe3\xf5\xc7\x0f\x12\xbc\x2c\x48\x82\xeb\x6e\xff\x35\xfb\xd8\x5b\x37\x7a\xf6\xad\x5c\x2f\x5c\x8b\xbe\xef\xbf\xaa\xaf\x83\xf4\x3a\xfe\xfd\x3f\x7a\xe4\x86\xb2\xf0\xce\x8f\xbd\xe3\x55\x75\x4e\x7b\x60\xfc\x27\xba\xff\xff\x15\x60\x00\xcb\xbb\xa8\xac\x5c\xc6\x15\x5b\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\xe5\x8b\xc8\x8c\x1f\x5c\x00\x00")) - searchEngine700x48 = HexToBytes("searchEngine700x48", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x1a\x40\xe5\xbf\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x02\xbc\x00\x00\x00\x30\x08\x06\x00\x00\x00\xf3\x57\xa9\xc9\x00\x00\x00\x19\x74\x45\x58\x74\x53\x6f\x66\x74\x77\x61\x72\x65\x00\x41\x64\x6f\x62\x65\x20\x49\x6d\x61\x67\x65\x52\x65\x61\x64\x79\x71\xc9\x65\x3c\x00\x00\xd2\x2a\x49\x44\x41\x54\x78\xda\xec\xbd\x07\x9c\x65\x47\x79\x27\xfa\x55\x9d\x7c\xce\xcd\xf7\x76\x4e\xd3\x71\xf2\x8c\x34\x33\x9a\x51\x42\x01\x21\x04\x02\x01\x0f\x58\x1b\x13\x1e\x66\x9f\x0d\x5e\x1b\x1b\x2f\x4e\x6b\x7b\xbd\xfe\xb1\x3f\xc7\x7d\x5e\xbc\xec\xe2\x7d\xc6\xf6\x9a\xb5\x8d\x0d\x5e\x6c\x63\x13\x16\x90\x10\xc9\x48\x68\x14\x66\x46\x33\xa3\xc9\xd3\xdd\xd3\xb9\xfb\xf6\xcd\xe9\xc4\xaa\xf7\xd5\x39\xf7\x76\xf7\x28\x60\x92\x31\x5a\xba\xa4\x33\x7d\xc3\xb9\x75\xea\xd4\xf9\xea\xfb\xfe\x5f\x2c\xc2\x39\x87\xed\xb6\xdd\xb6\xdb\x76\xdb\x6e\xdb\x6d\xbb\x6d\xb7\xed\xf6\xad\xb7\xf7\xbd\xfb\x7f\x86\x7f\x09\x1e\x01\x1e\x25\xa9\x05\x71\xdb\x04\xdd\x51\xa0\x6e\xd5\x81\x49\x0c\x0c\x5f\x01\xca\x28\x50\x25\x00\xcf\x27\xd0\xc4\x13\x39\xe5\xa0\x4b\x12\x98\x0a\x80\xac\x49\xe0\xe9\x1a\xf8\x94\x86\xfd\x80\x44\x41\x5a\xab\x01\xf8\x4d\x7c\x4f\xa1\x7f\xb1\x17\xdc\x14\x87\xc5\xe4\x32\xe8\xa0\x40\x79\xae\x0e\xbe\xed\x41\xac\x37\x0d\x8d\x16\x07\xb9\xd5\x04\x09\x18\x30\x8a\xd7\x91\xf1\x3a\x01\x7e\x96\x32\x40\x1a\x88\x81\x2f\x13\x60\x01\x0b\xc7\xc8\x09\x01\xb5\xe9\x40\xc0\x5d\x1c\x03\x81\x54\x4b\x81\x26\x8e\xda\xd6\x5a\x60\x70\x02\x26\x93\x40\x22\x14\x3c\xa2\x80\x8c\xe3\x13\xbf\x6a\xb9\xf8\x2f\xfe\x4f\x71\x4c\x4c\x0d\xa0\x6f\x29\x0b\x66\x5d\x07\x46\x18\x10\x4e\xb1\xff\x1a\x04\x71\x1f\x0a\xe9\x06\xa8\xba\x0f\x41\x1d\xa0\x8a\xa3\x31\x25\x02\x04\x6f\x54\xc2\xdf\x29\xb2\x04\xae\xe3\x83\x6d\xe3\xf7\x38\x36\x82\xd8\x53\x37\x64\x90\x12\x2a\x76\x1c\xde\x31\xf8\x04\x3f\xc3\xf1\x55\x3c\x80\xdd\x92\x02\x97\xe4\x3a\x10\x1f\xa7\x22\x10\x63\x91\xc1\x43\xb8\xca\x18\x03\x1f\x7f\x4b\x71\x9e\x74\x1f\xe7\x8a\x8b\x79\x27\x60\x43\x0b\x34\x23\x80\x62\xd1\x07\x0f\xe7\xd4\xa8\x38\x10\x8b\x1b\xf0\xab\x7f\xfe\x13\x1b\xcf\x49\xee\xbc\xd8\xd9\x7f\xc3\x8b\x8a\xc0\x2e\x2e\x9d\xda\x5e\x65\xdb\xed\x9f\xb5\x7d\xe8\x97\x3f\xba\x3d\x09\xdb\x6d\xbb\x6d\xb7\x7f\x91\xf6\xa5\x87\xbe\x1c\xfe\xfd\xd8\x93\x1f\xda\x9e\x8c\x17\x55\x13\x20\x11\x01\x19\x82\x47\xf1\x37\x42\xaf\xcf\x3a\x83\x91\xf0\x3c\xd2\x46\xc9\x84\x44\x7f\x39\x3c\xeb\xf4\xb6\x41\x32\xfc\x1a\xfb\xe3\x84\x7d\x4b\x23\x11\xbf\x63\x8c\x23\xb6\x24\xdb\x96\xcd\xad\x80\xf7\xdb\x6d\xbf\x72\xef\xbf\x7b\xde\xcf\xd7\x52\x35\xf8\x93\x8f\xff\x81\x24\xae\x71\xc7\xb1\x97\x77\x8d\xc8\x13\x37\x07\x4c\xde\xd1\x50\xbd\x0c\x09\x24\x45\x26\xc4\x96\x55\xb2\x16\xa3\xda\xd5\x24\xc8\x5f\xff\xcf\x0f\xfd\x76\x69\xfb\x71\x6c\xb7\xed\xb6\xdd\xb6\xdb\x76\xdb\x6e\xdb\xed\xc5\x0b\x77\xa3\x26\x71\x1a\xbe\x0e\xb1\x26\x27\x10\x41\x5c\x01\x80\xf9\x26\x1a\xbd\x0e\xe0\x76\x90\xef\x96\xc6\xf0\x5c\x0a\xc2\xf4\x19\x5a\x87\x03\xc9\x0b\x2f\x40\xf1\xbc\xc0\x67\x40\x68\xf4\x1b\xce\xf0\x35\xf6\x8b\xc0\x36\x7a\x8f\x78\x1b\xbb\xd3\x7c\xce\x78\x22\xa6\x7b\xad\xc0\x0f\x3c\x61\xa5\xc5\xef\x48\xc0\x37\x07\xf9\x0d\xee\x81\xb5\x0f\x7c\x2d\xf3\xc8\x06\xfb\xac\x8f\x7f\x00\x01\xef\xf3\xb5\xdf\x7a\xe8\x77\x04\xd0\xd5\x76\x8e\xee\xe9\x1f\xef\xb9\xe1\x75\x00\xb1\x57\x34\xb8\xbc\xdf\x8c\x4b\xd9\x6e\x8b\x4a\x32\x5e\xd5\xc3\xe7\xd6\x6a\x82\x5f\xae\x07\x2b\x35\xc6\x1e\x7b\xeb\xab\x7f\xe6\x13\x49\x55\xfa\xe4\x1f\xfc\xdd\xef\xd7\xb7\x97\xcc\x76\xdb\x6e\xdb\x6d\xbb\x6d\xb7\x1f\xe4\xf6\xae\xe6\xb6\x65\xf7\xc5\x0a\x78\xc5\x21\x2c\xbc\x01\x89\xde\x09\xb8\x1b\x59\x68\xaf\x07\xc5\x11\xce\x15\xdf\xf2\x0d\x0b\xef\x73\x00\xaf\x12\x41\x4c\x8a\x00\x5a\x84\x46\x88\x30\x54\x42\x44\x88\x02\x07\x99\xd2\xe8\x77\x2c\xb4\x16\x6b\x8c\xf1\x14\x63\x7e\x97\x6e\xa9\x96\xaa\xd3\x4a\x9d\x78\x8b\xf1\x4c\xcc\xf1\xca\x0d\xb0\x3d\x1f\x94\x00\x81\x71\xd9\x41\xa0\x8c\xfd\x68\xed\xcb\x0b\x4b\x74\x3b\x74\x01\x31\x34\x38\x8c\x5b\x1a\x05\x5d\xa1\x24\x25\x01\x4f\x63\xd7\x9a\x82\x68\x9a\x11\xee\xe2\x29\x65\xbc\x5a\x05\xff\xd6\x10\xc8\x3b\x08\xc2\x39\x0d\x24\x04\xe2\xe4\x85\xe7\x83\x6f\x00\x6c\xf2\x2f\x0d\x94\xbf\xab\x80\x17\x81\xae\xe8\xcf\x1a\x4a\x0d\xf6\xdc\x34\xf1\xaa\x7f\x1f\x18\xfa\x5b\x87\x87\x08\x99\xd8\xc5\x61\x68\x22\x80\x54\x92\x41\x3c\x4e\x40\x51\x39\x02\x5e\x02\xf5\x2a\xc8\xc5\x92\x3f\x38\x73\x95\xbc\x71\xf6\x9c\xf4\xc6\xc5\x05\x08\xde\x72\xcf\x7b\x7f\xcf\xec\x6a\xfc\xfa\x1f\x7f\xec\x43\xce\xf6\xd2\xd9\x6e\x3f\x48\x6d\xea\x1f\x7e\x84\x54\x87\xa7\xd5\xda\xc0\x5c\x7f\xa0\x3a\xdd\xbe\xde\xca\xe1\x11\xdf\x7a\x8e\xe4\x6a\x15\x12\x48\x2b\x34\x90\x67\xdd\x58\x75\xdb\x2b\xb2\xdd\xb6\xdb\x76\xfb\xae\xb6\x3f\xfe\xa5\x3f\xfb\x8e\x7e\x3f\xf1\xa9\xb7\xff\x93\xe7\xdc\x7d\xee\xff\x6c\xb0\xdb\x01\x92\x61\x70\x83\x30\xba\xb2\x67\x83\xc0\x28\x3c\x81\x12\xb2\x11\xd6\xf0\x1c\xeb\xae\x00\xb6\x8c\x85\x31\xb7\x91\x51\x98\x42\x80\x40\x35\x0c\x73\x10\x20\x95\x05\x40\x64\x84\xa5\x84\x18\x88\x78\x27\x24\x4a\xf6\xe8\x31\xad\x97\x52\xaa\xe3\xaf\x6c\xdd\x80\x13\x36\x04\xd7\xca\x2b\xab\xbc\xe5\x7a\xa0\x71\x19\xd4\x9a\x0f\x2e\xf6\x09\x52\x7b\x9c\x6d\x20\xca\x81\xe7\x54\x80\xd4\x90\x22\xf7\xa6\x24\xb5\x3b\x21\x53\x39\x41\xb9\x89\x08\x38\x21\xe2\x69\x97\x64\x89\x97\x18\x47\x3c\x1c\x9c\x72\x54\x27\xff\xfa\x47\x6e\x71\x4e\x0e\x5c\xe3\x4f\xef\x3e\x0b\xdc\x42\x6c\xb7\x66\xe2\xe8\xa4\xc8\x04\x8c\xa0\xda\x73\x39\x41\x74\xac\x18\x9a\x44\x15\x45\x52\x25\xfc\x43\x29\x11\xf8\x50\xe6\x51\xf8\xae\xb8\x0f\x17\xff\xda\xf8\xaa\x89\x77\xee\xbf\x28\x00\xef\xb2\xd6\x84\x0f\x7f\xfa\xbf\x0a\xa3\xbb\x89\x47\xf6\x65\x47\x5f\xf3\x56\x53\x1e\xfd\x8f\x3b\xa6\x08\xbd\xfb\xbe\x00\x26\x0f\xa0\xee\x91\x64\xd1\xdc\xfa\xd1\x83\x25\x38\xd9\x42\xb9\x88\xe1\xd1\x8b\xc7\x9e\xbb\xf0\xf1\x95\x38\xbd\xf0\x34\x91\xbe\xf4\x39\xe9\x97\x66\xaf\x98\x3f\xf7\xce\xfb\xdf\xfb\xaf\xfe\xe8\x7f\xbf\xff\xef\xb7\xd9\xcf\x76\xfb\x01\x00\xba\x74\xe1\xd6\x2f\xf5\x4d\xdf\xf7\xf7\x7b\x98\xe2\xa5\x99\xe4\xd3\x17\x3a\x17\x81\x70\x12\xff\x88\x63\x4a\x72\xb4\x2f\x05\x9a\xb3\xb6\x3d\x83\xdb\x6d\xbb\x6d\xb7\xef\x55\x43\x40\x2b\x90\x99\xb4\x05\x3f\x78\x57\x1e\xf8\xb3\x60\x7b\x66\x3a\xa0\x37\xb2\x68\xd2\x10\xd4\x46\x21\x0c\x04\xe8\x75\xe6\xcd\x10\xf0\xb5\xb9\x7c\x3b\x7c\xb7\x1d\xfe\x40\xae\x47\xcf\x11\x74\x8a\x92\xdd\xf0\x2c\x26\x05\x51\x1f\xe1\xe7\x24\x25\x6b\x72\x7f\x6f\x56\x3d\x38\x3e\x9e\xda\xd3\x3d\x94\x90\x53\x69\x83\xcf\x5d\x29\xb0\xe9\x8b\x6b\x41\x2c\xd0\xeb\x15\xad\xe8\x15\x57\x97\xc1\x24\x1a\x24\xa9\x01\x36\x97\x42\x00\x8e\x07\xc5\x1e\xb4\x18\x25\xc3\x71\x19\xfa\x0e\xc4\xa5\x91\x2e\x35\xa6\xf5\x2b\xb2\x9a\x90\x40\xa6\xbe\x0f\x46\xe0\x72\x05\xaf\xb7\x20\x49\x50\x74\x85\x57\x5e\x9e\x4b\xb4\xc8\x55\xa6\xd2\xaa\xda\xd2\x78\xf9\xe0\x2a\xb8\x8a\x0d\x44\x13\x63\x31\x70\x48\x5c\xf2\x99\x9f\x4c\xc7\x0d\xcd\xcc\x99\xe9\x2c\xa3\x66\x32\xa6\xd1\x98\x29\xc7\x25\x99\x5a\x76\xcb\x27\xf5\x52\x2b\xa8\x95\x5a\x7e\xa5\xd1\x5a\x23\x2e\x59\x32\x24\x70\x02\xbc\xad\x96\xb0\x50\x8b\xa9\xda\x82\x48\xc9\xf7\x23\xe0\x45\xb0\x2b\xb7\x05\xf0\xe0\xfd\x37\xbf\xed\x77\x2d\x2d\x77\xdf\x6b\xdf\x14\xc0\xe1\x57\x78\x0c\x14\x9c\x83\x2a\xde\x45\x5d\x18\xdb\x03\x90\x58\x4d\x5a\x3c\xa3\xb0\x99\x8b\x32\x8b\x27\x09\x24\xd2\x12\xf4\xed\x90\x41\xe9\xc7\x7b\x4b\x33\xbe\xeb\x6e\xe2\xef\xba\x99\x91\xc7\xff\xb7\x24\x7f\xf2\xe3\xd2\x27\xde\xf2\xd2\xf7\x7e\xf0\x2f\xbf\xf8\xfe\x9f\xde\x5e\x42\xdb\xed\xc5\xd8\x2e\x4c\x9f\x7d\x0e\x23\x14\x19\xa6\xae\xe7\x40\xd3\x6e\xc0\x3b\xe6\xfe\x48\x9a\xbb\xe3\xc1\x11\x04\xba\xbb\xb7\x5a\x72\x57\xf3\x0b\x53\xb5\x7a\x79\xb8\x52\x2b\x4e\xb1\x20\x98\x42\xf6\x01\x31\x2b\x01\xc9\x78\x1a\x2c\x3d\x76\x49\x52\xd4\x53\x78\x3c\x8a\x60\xf7\xa5\x78\xfa\x17\xf0\x3a\xeb\xdb\xb3\xfd\x9d\x09\xa8\x96\xdd\x84\x37\x5d\xfe\x2f\x64\xe5\xc6\xe3\x89\x46\xcf\xe2\x11\x54\x3c\x32\x9c\x32\x29\x64\xbc\x81\x54\x24\x9c\x3e\x7e\x69\xe9\x6c\xd9\xf7\xbd\xef\x9b\x71\xfb\x81\x0f\x95\x7a\x19\xe9\xe8\x43\x14\xe9\x68\x87\x67\xd5\x77\xb6\x15\xa2\x70\xcc\x92\xa7\x3e\x31\xf6\xf9\xd7\x55\x51\x99\xea\x0d\x34\xbb\x17\x85\xaf\x11\xa8\x76\x1a\xe9\xc6\xfa\x46\xfd\x52\x5f\x29\x11\x46\xaf\xcc\x16\x2e\x5c\x6d\xb4\x1a\x2f\xca\x67\x2a\x5c\xbe\x12\x95\x80\x08\x97\x2f\xa2\x8b\x80\x05\x42\x20\x6f\x24\x01\x7d\x2f\xda\xae\xb1\x7d\xff\xa7\x2e\x19\x21\xf3\xfb\x9c\xd4\xfa\x78\x2b\xbb\x2a\x25\xae\x4d\x5d\x41\x10\xbc\x88\xa0\xd7\xdb\xe6\x26\xd7\xfb\xec\xf9\x0b\x78\xf0\xf9\x16\x50\xd7\x49\x58\x6b\x5b\x78\x37\x71\xf1\x16\x7a\x15\x80\x37\xc4\xb9\x94\x01\xf3\x02\x43\xd5\x95\xa1\xf1\x7d\x3d\xb7\x8f\xee\xea\xdb\xb3\xfb\xf0\x00\xe9\xdb\x91\x64\x66\x4a\x63\xf9\xd9\x52\x30\x3f\x93\x47\x39\x03\x4b\xc0\xd4\x6b\x09\x2f\xe1\x23\xe5\x83\xa9\x48\xe1\x58\x78\x10\x76\x6e\xa8\x84\x0c\xf4\x51\xba\xe7\x66\x4b\x1b\xe9\x96\x39\xc9\xc8\x1a\x91\x70\xd1\x04\x78\x36\x38\x36\x30\xe4\x2d\x4a\x68\x9f\x26\x70\xb9\xe9\xc2\x02\x28\xcb\x3c\xb0\x8e\x73\xda\xcc\x4b\x36\xc0\x7f\x7d\xe5\x5f\x41\x2e\x13\x07\x56\xe4\x32\xe7\x2c\x6e\x7b\x5e\xbf\x16\xa7\xe9\x6c\xc6\x4a\x0d\x0c\xa4\xa4\xa1\xb1\xae\x98\xa9\xa9\xcc\x4c\x9b\x2c\x91\xd1\x03\x49\x86\x60\x69\xb6\xc0\x9e\x7c\x74\x06\x82\x3c\x2f\x5b\x3c\x33\xef\x92\x6a\x49\x21\xbe\xdf\x12\x97\xe4\x91\x06\x25\xb1\x48\x95\xf2\x19\x22\x72\xa4\x32\x17\xa1\xb9\x19\x69\x06\x61\xcc\x47\x14\x78\xf1\x3c\xc9\x7d\xdf\x23\xc0\x2b\xa2\x4b\xb2\x78\xec\xb8\xff\xd8\x8f\x7e\xa0\x27\x97\x3a\xfa\x8e\xf7\x78\xbc\x6b\x37\x72\x17\x27\x2a\xd0\x41\x92\x0e\x3d\xfe\x57\x24\x58\xa8\xe6\x9c\x9b\xde\x72\x67\xf3\x0b\x27\x96\xe5\x73\x0f\x2d\xaa\x56\x4a\x01\xe2\xda\x54\x27\x15\x79\x78\x38\x20\x47\x5f\x6a\xb1\xb1\x3b\x64\x42\x74\x06\x47\xdf\x10\xf8\x43\x13\x5c\xfa\xf0\x7f\x93\xde\xfd\xc3\x77\xff\xdb\xdc\x5f\x7f\xe9\xf7\x7f\xe4\x7b\x45\xac\xdf\xed\x6a\x15\xdb\xd5\x24\xb6\x5b\xa4\x90\x33\xf0\x10\x2c\x15\xe7\x6a\x64\x8f\x7f\x87\xdc\xb3\x2f\x31\x78\x65\xe7\xdf\xed\x63\xe6\x26\xf8\x38\x7b\xe1\x89\x97\x95\xab\x85\x97\x3a\x4e\xcb\xcc\x17\x51\x7b\xf6\xbc\xf0\x77\x94\x88\x92\x2e\x32\x0c\xf7\x8f\xc2\x48\xff\xf8\x54\x32\x9e\x99\xd2\x35\xc3\x54\x74\xf3\x0b\xf8\xb3\x6e\x3c\xb6\x01\xef\x77\xd0\x02\x64\xee\xab\xc5\x15\xa8\xf5\xcf\x69\x8d\xbe\x85\x97\x06\x8a\xab\x5d\x27\x9c\xa4\x20\x83\x4c\xfd\xa8\x44\xe9\x83\xfe\xf7\x11\x3d\x55\x1b\x95\x10\xec\x2e\xde\xfc\x95\x71\x3b\x5d\x38\xfc\xec\x31\xfb\x52\xeb\xbe\x4b\xaf\xfd\xd6\x2b\x8d\x30\xd9\x4b\xe3\x9f\x9b\x86\xfa\x46\x03\x54\xa6\x66\x5f\x4c\x6b\x4c\x28\x24\x01\xfe\xd5\x55\x1d\x4c\xd5\x02\x5d\xd3\xc3\xef\x5c\xcf\x05\xdb\x69\x81\x87\xcf\x1a\xb6\x4b\x71\x7e\xfb\x73\xfc\x89\xbd\x72\x81\x2e\xf6\x4b\x43\xcd\xdb\x9f\xee\xff\x7b\xab\xd1\x68\x4d\xed\xbf\xed\xc6\xaf\xea\xc5\xae\x01\x04\xbd\x4f\xe1\x29\x0e\xbc\x48\x13\x9a\xbe\x9b\x0a\xb4\xb0\xee\x8a\x90\x86\x10\xab\x91\x28\xbc\x61\x03\xe1\xc2\x66\xe8\x03\xbe\x55\xc3\xb3\x88\x00\x4b\x02\xd0\x91\x4d\x16\x13\xa6\x89\x75\x62\x0e\x48\x14\xb7\x4b\x79\x57\x2a\x6d\xde\xba\x6f\x4f\xff\x91\x5d\x47\x06\x52\x99\xbe\x24\x6b\xd5\xdc\x60\xf9\x6a\x91\x14\xf3\x35\x98\xbf\x5a\x84\x6b\x33\x05\xee\xd2\x60\x0e\x18\x29\x26\xfc\x18\x04\x8a\x07\x1e\x3e\x16\xd1\x93\xcf\xa1\xc7\x20\x70\xf8\x0e\x53\x99\xdc\xad\x51\xa2\x49\x04\x2c\x85\x40\xd5\x03\x2e\x07\x0e\x62\x32\x17\x2a\x1e\x83\xb8\xc4\x11\xc2\x11\x72\xde\x97\xf9\x29\x49\x59\x47\x8c\xfb\x8f\x16\x85\x7c\x53\xad\xe0\x62\x42\xb8\x4c\x88\x89\x6b\x29\x39\x32\xd6\xb5\x3b\xdd\x65\xa4\xdd\x3d\x81\xa1\xcb\x8a\xac\xc7\x14\x8e\xc0\x99\xd5\x4b\xcd\xa0\x49\xf1\x57\x6b\x55\x50\x4d\x19\x8a\x6b\x0d\x98\xbd\xbc\xee\x94\xab\xb5\x45\xad\x69\x4d\xa3\x4c\x6b\x31\x4b\x65\x0d\x84\xa0\x6e\x08\xc9\x23\x44\x1b\x97\x40\x93\x09\x68\x59\x84\x82\x2a\x05\x5f\xa3\x80\x50\x9c\x30\x47\x84\x29\x03\x8a\xd0\x68\xce\xbc\x10\x5c\x02\x81\xad\xb5\x27\x3a\xca\x05\xe3\x9d\xaa\x16\xb0\x51\xee\xec\xbb\x01\x78\xe5\x36\xd8\x9d\xb8\xef\xe8\x5b\xfe\x63\x7f\x5f\xfa\xe8\xbb\xfe\xbd\xcf\x63\xbd\x3c\xe0\x75\x80\xca\x6c\x99\x9e\x3f\x6b\x78\xb9\xfb\xef\x5f\x3b\x51\x5a\x55\x2e\xfc\xcd\x53\x56\x65\x7f\x66\x3d\x71\x6b\x9a\xdf\x7e\x74\xb7\x14\xf8\x9c\x04\xb6\xab\xd4\x97\xaa\xda\xf4\xc9\x15\xe3\xa9\xdf\x9b\x36\xf7\x7d\xba\x2a\xbd\xfe\xa7\xe3\x3c\x31\x02\xb4\xef\x20\x0b\xde\xf5\x2b\x9c\xfe\xf1\x6f\x2a\x6f\x7a\xcb\xcb\x7e\xb6\xf8\x97\x5f\xf8\x2f\x3f\xf5\xfd\x40\xcc\xff\xcf\x0f\xbd\x5b\x7d\xdd\xa7\x5f\xe6\x3f\xd0\x7c\x1d\xdb\x66\x7f\xdb\xed\x9b\x61\x7e\x41\x10\x40\x1e\xd7\x43\x92\x77\xcb\x7b\xcd\x7d\xc9\xae\xbd\xda\x61\x48\xd7\x53\x82\x80\x1a\xad\xba\x79\x65\xfa\xec\x3d\xab\xf9\x85\x7b\x8a\x95\x75\x70\x50\x30\x3b\xc8\x74\xfc\xe0\xb9\x1e\xc2\xca\xa5\xd3\x70\xe5\xda\x25\x98\xda\xb1\x1b\xa6\x46\xf7\x0e\x66\x75\x11\x45\x04\xe9\xed\x59\xfe\xce\x9e\x4f\x0b\x81\xd0\x7b\x0a\x1f\x23\xb3\xf7\x7c\xe6\xb0\x00\xbb\xe7\xaf\x9e\x9e\x42\x4d\xfe\x47\x87\xfb\x46\x4d\x82\xca\x86\xa4\x68\xff\x99\xa2\xc2\x31\x3a\x38\x99\x46\x00\x58\xfa\x7e\x18\xb3\xed\xda\x30\xb3\x78\x15\x10\xec\xf6\x37\x7a\x96\x42\xb0\xfb\xc8\x13\x0f\x3e\x30\x3e\x38\x79\x8f\x65\x26\x40\x51\xf5\xff\xae\x1b\xd6\x25\xf1\x79\xb3\x59\xcb\x16\x4a\xab\x37\x0a\xd0\xd7\x68\x54\x0e\xaa\x8a\x36\x24\xac\x9f\x0e\xf6\x21\x0e\x21\x68\x05\x40\x8c\x5b\x49\x88\xc7\x92\x60\xe8\xd6\xd7\x75\x33\xfe\xd7\x6d\x65\xea\x45\x01\x78\x05\xd8\xad\x37\x6b\xf0\xd6\xe9\x0f\x92\xb5\x03\x4f\x26\xea\xbd\x8b\x37\x30\xc5\x4d\x33\xd9\xd7\x43\x8b\x75\x40\x4f\x2e\x54\xa7\xd7\xea\xcd\x6a\xb8\x1e\xb7\xdb\xb7\xde\x44\x28\xc3\x49\x78\x38\x1b\x4b\xaa\x77\x96\xf6\x1d\x2f\x4b\xae\xf9\xf3\x37\xdf\x77\x4b\xf7\xb9\x2f\x9d\x7c\x65\xef\x8e\xe2\x7b\x51\xc9\xba\xad\xfb\xd4\x6d\x27\x41\x94\x60\xfd\x1e\xc5\x64\x7e\x3f\x5a\x77\x99\x08\x61\x68\x03\x5c\x11\xd2\xc0\xdb\xe5\xc7\xda\x9f\xa0\x42\x86\xd8\x92\x43\x2f\xc2\xb5\x6e\x04\x8e\x5d\x78\x8a\x09\x2e\xac\xe8\x94\x9d\x6b\xa9\xa4\x12\x59\x74\x19\x48\x0b\xa5\x10\xb0\x89\x80\x57\xc9\x97\xa0\xe5\x3b\xbb\x40\x66\xf7\x8c\x8f\x76\xef\xef\x1d\x48\xb0\xc5\x2b\x45\xf6\xf8\x17\xae\x40\xad\xd0\x0a\xe1\x60\xb2\xcb\xe2\xbe\xe7\x33\xe6\x91\x75\x4e\xf9\x7c\x45\xae\x33\x22\xca\x9f\xa9\xe1\x78\x08\xe5\x90\xd5\x29\x79\xc9\x41\x53\x1a\x1e\x37\x28\x7f\xb4\x1e\xc0\x98\x46\xb9\xe3\x50\x52\x77\x1d\x18\x27\x2e\x2c\xf9\x08\x80\x25\x0a\x86\x04\xfc\x74\x83\xc1\x09\x22\xaf\xef\x7f\xe5\xe1\xaf\x5d\x7d\xea\xe2\x8a\xd7\x72\xa0\x5c\x06\x81\x76\x87\x76\xdd\x38\xbc\xf7\xc6\x97\x0e\x67\x07\xc6\xb2\x92\x86\x9f\x78\x0c\xff\x73\x18\x63\x0e\x83\x46\xcd\xe1\x8d\xaa\x0d\x0c\x81\x6c\xab\xe1\xf3\xc5\x99\x22\x3f\xf7\xd4\x52\xa3\xd2\xb0\xcf\x25\x12\xea\x62\xa4\x0a\x08\xf0\x4e\x42\x18\x19\xf0\x40\x46\x90\x9c\xee\x51\xc0\x9a\xd2\x25\x23\x26\x11\xa5\x4b\x91\xb8\x17\x30\x36\x25\x59\xa2\x36\xb0\xdf\x10\xa5\x7d\x3d\xe6\x2e\xb9\x2c\xb8\xe6\x11\xaf\x44\xa0\x25\xd8\x20\x1e\x82\xce\x78\x18\xdb\xdc\x79\x06\x7c\xab\xf5\xfc\xbb\x03\x78\x85\xf5\x39\x85\xc7\xe8\x9d\x37\xbe\xf2\x1d\xd9\x78\xf7\xdd\x6f\xfe\x71\x97\xc7\xba\x59\x00\x4d\xfc\xd4\x02\x3e\x17\x1c\xac\xfe\xe9\xef\x5f\xd6\xf6\x95\xca\xfe\xd0\x1d\x13\x6b\x32\x34\x93\xa6\x57\x6b\xf0\xa6\xe6\x8b\x48\x65\x11\xe2\x42\x75\x49\x4e\xed\x4b\x4b\x5d\x87\xb2\x4a\x6b\x65\xa7\x75\xf6\xa3\x27\xd3\xbf\xf5\xce\x69\xf3\xc7\x7f\xdd\x64\xe3\xb7\xca\x24\x3b\xc6\xd9\x9b\x7f\xd6\xa3\x7f\xf2\x5b\xf2\x4f\xbe\xe3\x81\xf7\x1c\xff\xf0\xa7\x3e\xf0\xe7\xff\x42\x74\x2c\xe6\x49\x98\x0a\xf4\x98\xea\xfc\xc2\xa5\x5f\xfd\xe4\x8d\x7f\xec\xbf\xfb\xd8\x42\x29\xa8\xce\xcd\xaa\x3f\xfa\xe1\xbf\xff\xc0\xc3\xdb\xec\x70\xbb\x3d\x1f\x30\x59\xb9\x5a\x08\x3d\x35\x31\x9e\xb6\x76\x0c\x8d\xed\xc8\x8c\x98\x53\x60\x7a\xe1\x2a\x3c\x71\xf6\x91\x97\x95\xcb\xeb\xaf\x6e\xd9\x0d\x28\x56\x0a\xd0\xb4\xed\x50\x70\x1b\xba\x59\x98\x1a\x9c\xfc\x7a\x57\xb6\x77\x6e\xef\xe4\x0d\x97\x3a\xfd\x3d\x79\xe6\xd1\x1b\x50\x60\xe7\x70\xe5\x88\x58\xaf\xb9\xf6\xc7\xf9\xed\x99\xfe\xe6\xdb\xf2\xd5\x75\xda\xe6\x5f\x2a\x44\x1e\x2a\xf1\x3a\xf8\xac\xfe\x41\xd8\x49\x87\x04\xc0\x83\x73\x17\x4f\x3c\x70\x74\xff\xad\xa6\x70\x81\xb3\xc0\x05\x82\x60\x97\xfe\xf3\x14\xb4\xf9\x56\xc6\x2d\x6d\x19\x77\x38\x98\x23\xf2\x2b\xb8\x1d\x2f\xdd\x28\x5e\x7f\xf9\xb1\xcf\xbd\x6c\x65\xed\xda\x3d\x93\xc3\xbb\xc2\xf3\x9b\x8d\xca\x4f\xae\xe5\x17\x42\x10\xd8\x68\xd5\xa0\x58\x5e\x07\xa1\x50\x75\x14\x29\xe1\xe2\x17\x1e\x04\x01\xfe\x22\x43\x08\x01\x4d\x55\x21\x97\xce\xc1\xa1\xbd\xb7\xc2\x80\x19\x7f\x51\xad\x33\x61\xbd\x15\x60\x77\xe5\xd0\x63\xbd\xf5\xfe\xf9\xdb\x99\x40\x08\x5b\x2d\xd6\x32\xbc\x74\x30\x31\xf6\xc5\xab\xee\xb9\xb5\x20\x68\x6d\x2f\x84\x6f\xa3\x9d\xf4\x1e\x8e\xc7\xa4\xd4\x31\xb5\x8b\x65\x57\xca\xd5\xd7\x4d\xde\xb0\xbb\xc7\x8a\x27\xe0\x8e\xb7\xdf\x9f\x3e\xf5\x99\x47\x3f\x5c\x4a\x9e\xfc\x45\x79\xa7\x95\xb0\x56\x86\xce\x6a\x95\xac\x50\x94\x7e\x20\x43\x1c\x3a\x16\xde\x30\x94\x97\x5c\x5f\x9e\x00\x81\x6e\xb7\xca\xa5\xa3\x29\x99\xdc\xa8\xcb\x64\x88\x00\x4d\x34\x39\x6f\x34\x81\x3f\x45\x6d\x77\xc9\x72\xdd\x8a\x38\xcf\x6d\x05\x40\x3c\x5c\xab\x32\x11\x1e\x0b\x84\xae\xcd\x5b\x10\x89\xde\x6b\x5a\xb4\x9f\x34\x49\x70\xfe\xe4\x22\xf1\x5c\xc6\x13\x69\x0d\x76\x1e\xea\x86\xbe\x1d\x5d\x90\xee\x4f\xd2\x13\x0f\x5f\x62\x97\x4e\xae\x5e\x40\x00\xb8\x58\x97\x6d\x90\x2c\x29\x4a\x26\x23\x44\xb7\x38\x3d\x74\xc4\x92\x46\x6e\x4e\x48\x7c\xc5\xe3\xd0\x25\x03\xc9\xc8\x94\x9f\xad\xbb\xbc\x8b\xb9\x50\x42\xce\x18\x20\x1f\xc8\xa2\x0c\x7a\xaa\xe8\xc3\x83\x95\x60\x61\x68\x67\xf2\xf8\xed\x77\xef\x5a\x78\xe2\xd3\x5f\x07\x7b\xd9\xb1\x62\x3b\xa4\x1b\x0c\x6a\xed\x4f\x77\x19\x64\xfd\x5a\x85\x97\x96\x1a\x4c\x92\x24\x2e\x6b\x14\x14\x4d\x06\x19\xc7\x6b\xc4\x54\xe8\x1a\x4a\x81\xaa\xca\x30\xfb\xcc\x9a\x3f\x73\xae\xb0\x5a\xaf\x38\x17\xa9\x46\xd6\xdb\x29\x7a\x50\xb3\x1a\xed\x19\x01\x23\x23\x93\xc1\x7d\xa6\x94\x4e\xab\x54\xd1\x80\x06\x3b\x4d\x1a\xa8\x84\x0b\xc6\x14\x50\x9f\x04\x10\x88\x9a\x6c\x01\xe1\x3a\x97\xcf\x62\x07\xab\x5c\x27\xba\xef\xbb\x12\xe7\xdc\xd3\x3c\x2e\x40\x6d\xbc\xa9\x81\x2b\xf3\x8d\x28\x90\x8d\x28\x91\xef\x82\x85\x57\xf4\x20\x4c\x4b\x43\x7d\xb9\x81\x03\x69\x6b\xd7\xdb\xee\x7b\x95\x07\xbd\x03\x6e\xc0\xa7\x09\xbf\x7c\xaa\x20\x9d\xca\x4f\x34\xf5\x57\x1f\x5c\xb8\xed\xa7\xe3\x31\xb7\x52\xc5\xd1\x3a\x85\xf4\xed\x93\x4b\x6e\xc5\x03\xbf\x89\x8f\x37\x2a\xab\x41\xf1\x1f\x85\xd4\x89\xd6\xa2\xd4\xd0\xd3\xaa\x77\xec\xe7\x8f\xd9\x57\x3f\xd5\x9d\xfd\xe0\x2f\x1f\x4f\xfe\x9b\xdf\x32\x60\xea\x36\x99\x0c\xef\xe7\xfe\x7d\x3f\x1c\xc8\x9f\xfa\x0b\xf9\xff\xfb\xa9\xd7\xff\xfc\x67\xff\xe0\xef\x7e\xef\x7b\x2d\xe0\x3b\xe0\xbe\xff\x57\x7f\xfa\x0d\xef\xdd\x3d\x49\xdf\x7e\xe8\x66\x84\xec\x41\x8d\x54\x2a\x52\x22\xbf\xea\x7f\x41\x21\xef\x39\xf2\x47\x9f\xf8\xc0\x53\xff\xfa\xb5\xef\x49\xfd\xe9\x3f\x7c\xa0\xbc\xcd\x1a\xb7\xdb\x97\x1e\xfa\x32\x6d\xaf\x2f\x53\xe3\x66\x6a\x7c\x62\x62\x6f\x66\x4c\x8f\x0b\x4f\xcc\xc5\xe9\x33\x53\x8b\x4b\xd3\x3f\xcc\x39\xcb\x8a\xd0\x05\x1b\xb5\xeb\x20\x60\x30\x3c\x30\xfa\xf5\x5d\x13\x07\x1f\x1d\x1d\x9c\x9c\x7f\xbe\x3e\x8f\xec\xbf\xf5\xfa\xf8\x18\x4e\xea\xa8\x2c\x5f\xdd\x9e\xed\x6f\x1a\x34\x92\x36\xc8\x15\x68\x2e\xdd\x5e\xd7\x22\x7c\xc1\x4b\x8c\x28\xaa\x6f\x36\xb5\xab\x73\x17\x87\x6c\xa7\x39\xa4\xa9\x7a\x68\xfd\x44\x3e\x55\x30\x15\x4d\x3c\x8f\xfa\xa5\xd9\x73\xa5\x7f\xa1\x71\x4b\xed\x71\x26\xda\xe3\x16\xe3\x27\xb9\xf1\x78\x2c\x30\x5b\xd6\x72\x7e\x31\x7b\x75\xf6\xdc\xab\x07\x7b\x87\xa0\xde\xa8\xc2\x5a\x71\x05\xf2\x78\xac\xae\x2f\x85\xa0\x56\x78\x0d\x44\xbc\xef\xb3\x3d\xf9\x63\xc3\x53\x0f\xab\xaa\xde\x22\x24\xb2\x84\x1c\xd9\x77\xeb\xa3\x31\x2b\xd1\xdc\x72\xca\x8b\x22\x21\x52\xc8\x93\x72\xbd\x14\x85\xa4\xf4\x2c\xdd\x22\xc0\xee\xe9\xf3\x4f\xdc\x90\x4b\x66\x1e\xc8\xa6\xba\xb3\xb2\xac\x7e\x5a\x52\xb5\x2f\x88\x98\xf7\x1d\x03\xe3\xdb\x31\xef\xdf\x46\x5b\xff\xdb\x8c\x16\x93\xd4\x5d\xf1\x61\x18\x3b\x37\xf0\x95\xf4\x8e\x43\x37\x1e\x4b\xef\xe8\x87\xfa\xc2\x1a\xe8\x96\x01\x37\xbd\xee\x4e\x98\x3e\x71\xe1\x3f\x9d\x6e\x7c\xe1\x93\xe3\xbd\x3b\x03\xbd\xd8\xd5\xdd\x75\xe6\xe6\x1f\xc8\x10\x87\x70\xd3\x89\x8d\x8c\xb4\x28\x70\xc1\xe7\x60\x48\x1c\x6e\xea\x52\xe5\xc3\xc3\x2a\x3d\xd0\x45\x98\xa9\x73\x4e\x0a\xdc\x97\xa6\x81\xc7\x8b\xbe\xac\x97\x56\x73\xbe\xac\x88\x5d\xc9\x1c\x50\x95\x22\x22\x0f\x09\x15\x53\xa6\x4a\x94\xdc\x91\xdd\x65\xbd\x7a\xb0\x2f\x17\xcf\xf5\x9a\xcc\x4a\xe8\x60\xa5\x0d\xc8\xf5\xc5\xc1\x4a\x9a\x20\xab\x0a\xae\x01\x95\x2f\x4d\xaf\xf1\x6b\x17\x8b\xab\x95\x8a\x7d\x41\x4b\x48\xae\x8c\xba\x71\x5c\xca\x62\x1f\x1e\x78\x9c\xe9\xb2\xec\x76\x8d\x22\x72\x33\x11\x94\x8a\x62\x01\x43\x8a\xc2\x5c\xdf\x23\xfb\x24\x87\xeb\x94\x83\x82\xe0\xd0\xc1\xf1\xce\xb8\x12\x9c\xd3\x8d\xab\xb2\x49\xbe\x6e\x82\x5b\x38\xfe\xe0\x93\x50\x98\x5d\xd4\xbb\x7a\x06\x0e\x1f\x3b\x9c\xdc\x3f\x75\x54\x01\xa7\xb1\xce\x02\x5b\xe4\x11\x20\x20\x67\x78\x7f\xa8\xda\x38\x4d\x02\x36\xa3\xbc\xb2\x4a\xe0\xf4\xd7\x38\xcf\xaf\x30\x7b\x7d\xa9\x72\x35\xbf\x58\xbb\x68\xa5\x55\x27\x10\xbb\xb2\xb5\x21\xa4\x1c\x18\x22\x1e\x97\x2a\x84\x65\x0e\xc4\x5b\xfd\x77\xc4\x65\x1c\x25\x65\x4b\x4e\x00\x4b\x8e\x0f\xa2\xaa\x44\x86\x07\xdc\x63\x8c\x67\xa5\xd0\x2a\x0e\xcf\x54\x1c\xfe\x35\xae\x39\x36\x85\x9a\xee\x83\xad\x67\x94\xc0\x51\x19\xd0\x1a\x85\x84\xa7\xc0\xba\x24\x42\x9a\x38\x8e\x09\xef\x85\xf1\x17\xb0\xf0\xe2\xfb\xf7\xc2\x1b\x00\xfa\xbe\x25\x6b\x67\x0e\x8f\xc1\xfd\x63\x77\xbe\x6d\xf7\x6e\xa6\xdc\x74\xb3\xeb\xb3\x12\xe5\x34\x6b\xc3\x8a\x7e\x43\xf9\xc1\x8f\x2c\x69\x47\xe1\x5c\x6c\xe8\x55\x13\x97\x9b\x45\xe6\xb5\xd6\x1d\x97\x31\xbf\x15\x04\x01\xce\x3b\xf3\x45\xe2\x8e\xe8\x87\x52\xaa\x12\x04\xbb\xa8\x21\x98\xad\x42\x10\xf3\x9b\x2a\x8c\xbf\x6e\x38\x2f\x0a\x28\xff\xe9\xfb\x1e\x4f\xfd\xfc\x1f\xc6\x78\xd7\x38\x21\xb7\xbd\x82\x07\xcf\x3c\xce\xcd\xc5\x45\xf7\x57\xf1\x77\x3f\x0b\xed\x1b\xf9\x6d\xfc\xef\xbd\xbd\x3f\x03\x1f\x7d\xf3\x5f\xc2\x67\x51\x38\xd1\x7a\x1c\xc6\x7a\x97\x61\x08\x1f\x98\xeb\x0e\x40\x29\xad\x80\xd1\xaa\x40\x2a\x70\x41\x49\x5b\xe0\xa3\xc2\xd9\x6c\x51\x70\x03\x1d\x74\x43\x05\x8b\x39\xe0\xd6\x5b\x50\x6d\x20\x81\x22\xd1\x00\x65\xcf\x07\xee\x45\x31\x89\xe1\xb1\x81\xa9\x5b\x7b\x73\xe9\xd7\xa5\x73\xa8\x70\x30\x4a\x56\x16\x64\xe8\xe9\xf5\x40\xee\xe3\x30\x32\xe2\x3f\xa2\x4b\x7a\x9f\x2c\xf1\x9f\xfa\xa9\xb7\xfe\xd2\xdb\xff\xe0\x23\xbf\x3b\xd9\xe9\xe0\xd7\xee\xfe\x12\x68\x46\x03\x68\x97\x0d\xf1\xa4\x05\x5c\x76\xc0\x93\x6c\x48\x58\x31\xf8\xe5\xbf\x78\x27\xbc\x6b\xfa\xed\xf0\xde\x91\x9f\x83\x87\x5e\xfb\x10\x2c\x18\xb3\x90\x9d\x9e\x80\x93\x89\x2a\x50\x47\x83\x6e\x3c\x3c\xd4\x84\x98\xec\x23\x91\xba\xd0\xad\x7b\xf0\xf3\x7f\xf8\x2e\xd8\x75\xe4\x49\x78\xc9\x5d\x8f\x40\x7e\xb9\x1b\xe4\x2b\x4d\xd8\x15\x2b\x83\xd9\x9d\x86\xa5\xa6\x04\xab\x95\x26\x58\x71\x82\xe7\xa6\xc1\x71\x1a\xf0\xeb\xff\x4b\x6c\x0c\xf2\x34\xbc\xe2\x15\xeb\x70\xd3\x2d\x9f\x87\xe9\xe9\x41\x48\x2d\x4c\x40\x17\x5f\x02\x29\x33\x0d\x46\x77\x1f\x68\x41\x1f\xb8\xc5\x2a\x28\x06\x87\x73\x95\xc7\xe1\xaf\xfe\xe1\x43\x70\x96\x9e\x01\xfb\xde\x2a\xbc\xff\xf6\xbf\x86\xd5\xd3\xbb\xa1\x7f\xa8\x0f\xba\xc4\x1a\x9e\x2f\xe1\x82\xc6\x31\x19\x3e\xc8\x92\x0b\x83\xf1\x06\x7c\xea\xab\x37\xc0\x89\xca\x3d\xf0\xd0\x43\x1e\x2e\xbc\x87\xe1\xc3\xbf\xf1\x55\xb8\xb1\xbc\x1f\x3e\x7e\xed\xe3\x70\xa6\x9c\x23\x71\xf7\xdd\xf0\x1e\x6a\xc1\xfe\xd7\x05\xc0\x5e\x55\x26\x4f\x9c\x7b\x12\x4e\x9f\x70\x49\x8c\x0f\xc2\x14\xc5\x05\xee\x16\xc8\x3c\xb7\xc1\xe9\x89\x13\x0b\x0c\x50\x9a\x01\x69\x79\xe2\x3e\x34\xc2\x90\x01\xf8\xb8\xaa\xb4\x40\x14\x06\x54\x09\x41\xa2\x0e\xb8\xa8\x6e\x88\xba\x20\x32\x04\x22\x7b\x24\xac\xb9\x1d\x12\xb9\x10\xea\x26\x11\xb6\x9d\x00\xe7\x4b\xd0\xbc\x8a\xcb\x4a\x14\x00\xf7\x3d\x29\x2a\x00\x43\xda\x75\x01\xb7\x08\xcb\x2d\x0e\x90\xeb\x5c\x53\xdf\x4e\xac\x9f\xef\xfb\xa4\xd1\xa8\x4b\xc3\xc3\x23\x5a\xbd\x5e\x4b\xb8\xb6\xd7\x3d\xd2\x33\x36\x9e\x1e\xb5\xc2\xee\x8e\x9f\xfa\xf2\x5d\x8d\x7a\xf9\x15\xe2\xba\x02\xec\x8a\x98\xc2\x4c\xaa\xeb\xca\x0d\x7b\x6f\xf9\xdc\x50\xdf\xe8\x82\xe8\xa3\x5c\xaa\x76\x15\x8b\x85\x54\xa9\x50\x22\x8e\xe3\x5c\xd4\x75\xe3\xdc\xc8\xc8\x70\x39\x9d\x4d\x27\x70\x88\x56\x7b\x80\xa5\xc0\x0b\xd6\xb1\x9f\xd8\x58\xdf\xae\x17\x8b\xe9\xe3\xdb\x3e\x7b\xeb\x53\xea\xbc\x20\x1b\xef\x78\xfb\xfd\xd6\x95\x1b\x59\x58\x24\xca\x38\x95\x19\x88\x02\x92\x99\x54\x8f\x94\x5f\x5a\x8d\xd7\xca\x8d\x41\xdf\xf3\xc6\x90\x8e\xfa\x45\x4e\x04\xf2\x92\xa6\x9e\x54\x0a\xc2\x00\x33\x3b\x7f\xe9\x70\x3a\x91\x21\x02\xf0\x8a\x67\x24\x2b\xda\x71\x0e\x5c\xc1\x6b\x55\x73\x99\x21\xcd\x6b\x32\x6e\x49\x71\xde\x30\x11\x44\x3a\x1a\x8f\x95\x63\x90\x43\x81\xb1\x8e\xcc\x7c\x45\x73\x41\xcf\x94\x40\x4a\x36\xf8\xd0\x62\x2f\xdf\xfb\xf5\x43\xf0\xd9\x62\x1c\x3e\x41\x2e\xa0\x94\x79\x3f\xbc\xfc\xe0\xb1\x6f\x99\xa0\xda\x16\x69\x61\xd5\x15\xe1\x63\xc3\x78\x8c\x0a\xfe\x2b\x13\x59\xb6\x52\x86\x00\x6e\xf6\x53\x67\x1e\x79\x99\x88\x55\xed\xce\xf4\xc2\xd5\xf9\x8b\xb0\x9c\x5f\x82\xa6\xdd\x8a\x92\xb4\xda\x6d\xa8\x7f\xf4\xeb\x71\x2b\x51\xe8\xce\xf6\xce\xed\xd9\xe2\x35\x78\x81\x26\x8c\x0a\x57\x2f\xce\x3c\x33\xfb\x7d\xac\xb8\xc8\x6d\xe5\x45\x89\xc8\x41\x0f\x56\x0f\x9c\xee\x67\xaa\xa3\x9e\xbd\x74\x72\xea\xc9\xd3\x8f\xfc\xe8\xbe\xc9\x03\xa0\xab\xc8\x4f\x14\xed\xd5\x2a\xf2\x06\x4d\xb7\xc2\x98\xf7\x84\x3e\x5c\x90\x93\x12\x18\xf8\x8c\x0d\x57\x05\xea\xa3\xc6\xa3\xb8\xc0\xf1\x85\x48\x0a\xe2\x28\xc1\x79\x2b\x00\x55\x52\x90\x8f\x00\x34\x29\x23\x54\x75\x60\x6c\x7a\x88\x8c\x5e\x1e\x05\xd5\x53\xe1\xc2\xc4\x39\xbe\x70\x60\x89\x1c\x92\x8f\x40\x2e\xc8\x40\xc3\xa9\xc2\xa5\xfc\x65\x42\x9b\x28\x52\x5b\x62\x71\x96\xc0\x59\x8d\x83\xa6\x12\xd0\xdc\x8a\x08\x9e\x24\xb2\xab\x01\x23\x01\x71\x4d\x3b\xca\x4f\x42\xfe\x6e\xfb\x94\x18\x38\x7a\x05\x24\xb0\x45\xea\xbc\xe7\x80\xa1\xc9\x44\xd3\x4d\x58\x3e\xf6\x79\x20\x08\x03\x3e\xfa\x96\x80\xf8\x5c\x02\xa6\x51\x22\xc9\x62\xdb\x2c\x1f\x85\x3a\x7e\x85\x5c\x50\x51\x03\x24\x5f\x95\x23\x95\x83\xc7\xbc\x50\xbe\x93\x00\x79\xaa\xb0\x6c\x09\x99\x46\x28\x09\x42\xbe\x88\x7c\x10\xaf\x12\x06\x8b\x32\x9f\x44\x7c\x8f\x5c\xb7\x6e\x3a\xd4\xa2\x42\x72\x63\x85\x85\x56\xc9\x26\xa5\xf1\x6e\x75\x30\xa1\x2b\x2f\x99\x1b\x7d\xac\x96\x1a\x19\x7c\xef\xc4\xdd\x47\xa8\x9e\x8c\x43\x25\x87\x72\xe7\x89\x73\xb0\xe3\xf0\x24\x0a\x74\x05\x6e\x7f\xdb\x2b\x5f\xfb\xd8\xc7\xbf\x78\x67\x57\x7f\xe1\x57\x7c\xc9\x79\x79\x7c\x7d\xe8\x74\x3d\x37\x57\xb5\xad\x52\xb0\x75\x4d\x7f\xf8\xc7\xbf\x6b\xdc\x82\x7f\xfb\x5c\x88\x7f\xb7\xfa\xe7\xc3\xd1\x9c\x5d\x07\x1c\xc4\xaa\x15\x72\xea\x92\x9f\x1f\xb0\x28\xbd\x6b\xaf\xa9\xdc\xb8\xd3\x94\xd2\x3d\xc4\x97\x0d\xdf\x95\x10\x07\xf1\x19\x46\x69\x1e\x9f\x6e\x09\xe9\x50\x66\x6a\x30\x61\xb4\x34\xa1\xdb\x72\xe8\xe3\x85\x56\x59\x45\x54\x74\xe7\xfe\x23\x3b\xee\xbf\xe1\x25\x3b\x12\xd9\x6e\x33\x50\x15\x7c\xce\x01\xe5\x08\x30\xa9\x63\x3b\xd2\xec\x85\x22\xac\xce\xd5\x79\x71\xb5\xc6\x0b\x2b\x45\xbb\xb8\x52\xbd\x3a\x98\xcd\xae\x26\xcc\xb8\xac\xa0\x7c\xa4\x0e\xc2\x4a\x04\xa3\x15\x55\xf3\x1d\xd6\xc8\x9f\xb7\xeb\xbd\x39\x45\xa2\xa6\x8c\x7d\xf8\x8c\x2b\xbe\x03\xdd\x94\x93\x80\x12\x3e\xdf\x0a\xf8\x23\x05\xc7\xc9\x0f\xe7\x2e\x74\xed\xe8\x7f\x5a\x9a\xae\x94\xfd\x16\xa3\x97\x1f\x9a\x81\x4c\x57\x77\x52\x4b\xcb\x13\x89\x2c\xa1\x8d\x0a\x63\xae\x83\xb4\x28\x1c\x8d\x42\x04\x23\x20\x4d\xa4\x08\x88\x42\x04\x2e\xca\xe6\xf9\x8b\x36\x59\x98\x76\x8a\x17\x4e\x38\xd3\x89\x61\xf5\xea\xbe\xd7\x27\xd8\xe1\x7d\xb7\x13\xfa\x7e\x19\x1e\x7e\xea\x21\xf8\x14\xfb\x28\xbc\xf4\xe8\xcf\x86\x7b\x64\x80\xe4\x20\x0c\x6c\x80\x26\x8b\x22\xc2\x9c\x8f\x11\x8f\x17\x6c\x87\x13\x9f\x41\x85\x13\x52\xc7\xb5\x39\x43\x25\x56\x4b\xc6\x5d\xf9\xd8\x8e\xaa\x71\x71\xb9\xb6\xf2\xb5\x73\xfe\xe0\xe4\x80\xc0\x01\x12\x0f\x02\xa2\x96\x65\xee\xfa\x88\x91\x62\x2a\x98\x86\xc4\x5c\xa4\xf7\x00\x51\x2f\x4e\xc0\x77\x6c\xe1\xed\x00\xc0\xbe\x9e\x4c\xdf\x58\xc2\xe8\x39\x76\xf4\x98\x23\x42\x18\xa0\xb5\x82\x37\x79\x25\xe6\xdb\x87\x6e\x59\xb9\xf7\x77\x2a\xcc\x2b\x36\xec\xc6\x1a\xae\x67\xdb\xab\x07\x81\x2f\x8e\x66\xe0\xfb\xb6\xef\xba\x81\x58\x6c\x08\x7c\x15\x04\x2c\x3a\x95\xa8\x25\x2b\xaa\x23\xc9\x88\xea\x5a\x9c\xd5\x97\x81\x8c\xbd\x66\xac\x50\xbc\x5c\x50\xff\xf6\x03\x57\xac\x77\xbe\x3f\x09\x14\x55\xa1\x5b\x5f\x19\xc0\xc7\x3e\x28\xff\xe4\xbb\xde\xf0\x9e\xdf\xf9\xd0\xdf\x7e\x60\xe5\x7b\xc4\x5b\x69\xfb\x7e\x7b\xfc\x92\x63\xee\xdd\x1f\x98\x3d\xbd\x1c\x4e\x3e\x69\xc0\x57\x4e\xed\x80\x37\xbd\xea\x0a\x4e\x84\x0d\x53\x7b\x5d\xb0\x03\x7b\x2a\xbd\x73\xec\x2d\x93\x77\xef\x99\xf8\x85\x54\x8c\xff\xbf\x1f\xfc\x35\xf2\xcf\x82\x19\x38\xd9\xc0\x61\xbc\x83\xc9\xda\x07\xdf\x72\x84\xef\xc3\xd2\x25\xcd\x50\x26\xb8\x7e\xb8\xcb\x36\x08\x2f\x09\x82\x3f\x08\xb7\xd5\xf6\x58\xe8\x2d\x60\x08\x26\x03\x97\x84\x80\x5f\x43\xf9\x3f\x9c\x1d\x85\x35\xa9\x02\xae\xd6\x00\xc3\xd7\x49\x0a\x99\x36\x6a\x7a\x44\x13\x39\x9b\x86\x17\x86\x27\x71\x43\x94\x00\x44\xe6\xa9\xe8\xe4\xae\x63\xcb\x70\x54\xfa\x2c\xb9\xf0\xb0\x8f\x4c\xb5\x4a\xf6\x8c\x8c\x10\x3a\xe1\x92\x7f\x75\xd7\x9b\xc9\x9b\x90\x21\x9b\xec\x71\x68\x2a\x2e\x9d\x66\x14\xd4\x4b\x94\xec\x30\x15\xb2\xf3\xe5\x1a\x51\xf4\xaa\x08\xd9\xc7\x85\x63\x91\xbd\xdc\x42\x66\xcd\x40\x52\x1d\x22\x29\x0c\x5f\xaa\x84\x71\x14\x34\xa2\x78\x9f\x2c\x53\x11\x80\xc4\x59\x98\x70\x42\x45\xc0\x8f\x24\xe1\x38\x50\x81\x89\xb6\xd1\x0e\x04\x5d\xe3\x81\x48\x97\xb6\x08\x17\xdb\x7b\x73\xd1\x2f\xca\x06\xf1\x3b\xb1\x8f\x23\x32\xf9\x76\xee\x00\xe9\x6c\xe8\x28\xd8\x39\x6a\xd0\x24\xf4\x37\x70\x4a\xa2\x6d\x18\x21\x8a\xba\xea\xd4\x0a\x24\xe1\x69\xd1\x9c\x76\xbe\x0b\xaf\x4a\xa2\x7e\xf8\xa6\xbf\xca\x43\x4e\xd4\xac\xfb\xf2\xca\x92\x6d\xad\x2c\xda\xe9\xd2\x1a\xeb\x31\xa4\x9e\xde\xa1\xc9\x64\x53\xfc\xf8\x53\x9f\xff\xf4\x03\x71\x35\x35\x45\x51\xd9\x59\x58\x9d\x05\xd3\xd2\x9c\x23\x87\x6e\x7b\x68\xef\xce\xbd\x17\x43\x94\xb1\x9a\xdf\x3d\x3b\x3d\x3f\xbc\x9e\x2f\x0d\xe0\x68\x5a\x9a\x29\x2f\x0e\xf6\xeb\xf6\xe8\xa4\xe5\x4c\xed\x85\xb5\x74\xae\x25\xac\x25\x9d\x00\xc4\x44\xfb\xf8\x6e\x0a\x83\xef\x1e\x8e\xe5\xcf\x62\xfe\xcf\xb3\x6d\x26\x21\xcf\x3a\x33\xb4\x34\x46\x7c\xb0\x6d\x18\x81\xb0\xb2\x0f\xe9\x24\x20\x88\xa7\xda\xae\x48\x49\x48\xe8\xca\xa2\x84\x75\xaa\x52\x46\x0f\x14\xff\x43\xa2\x09\xbf\xc3\xe7\x1e\x3e\x46\x71\xae\xe7\x31\xb2\x78\xcd\x57\x4f\x9f\x20\x3d\xf3\xd3\x6c\xaa\x52\x0e\x76\xba\x0e\xeb\x47\x5a\xb1\x34\x45\x2b\x75\x0d\xaa\x27\x64\x93\xb9\xc5\xca\xea\x8d\x07\xa7\x0e\x6f\x18\x06\x62\x09\x6d\x41\xd7\xc1\xcc\xf4\x79\xf9\x9b\xc6\x68\x42\x54\x92\xa7\xb8\xa6\x44\xd6\xb4\xe7\xdb\xdc\x0e\x1a\xdc\x09\x80\x4f\xe1\x18\x28\xae\xa3\x86\x9d\xe4\xbe\x93\xe1\x7c\x80\xf1\xe5\xa3\x8f\xf3\x23\x5e\xc0\x8f\xf9\x14\x59\xdb\x3b\xb8\x54\x43\xb0\x82\xf7\x50\x97\xeb\xb8\x1e\x19\x6f\x94\xbb\x78\xa3\xce\xb1\x8f\x69\x48\xc6\xd2\x90\x32\xd2\x48\xd2\x15\x90\xf0\x3b\x56\xf1\xe1\xca\xec\x1a\xc8\x9a\xa9\x06\x81\x93\x46\xc6\x3e\x82\x77\xb6\x17\x6f\x6f\x02\x87\x96\x4b\xc6\xd3\x65\x3d\x27\x2f\xac\xe4\x17\xb3\xf9\xf5\xa5\x5b\x26\x47\x76\x82\x24\xc9\x61\x72\x96\x98\xb7\xde\xee\x81\x53\xe9\x64\x6e\xe1\xce\x63\xf7\x3d\xfc\x02\x7c\x1c\xaa\xd5\x5a\xe0\x3a\xee\x72\x22\x11\xaf\xaa\x9a\x2a\x62\xe1\xd6\xcf\xe7\x67\xd6\x3f\xff\xc8\xff\x82\x97\xaf\xdd\x01\xbf\xc2\x7f\x4d\x22\xed\xdd\x9f\x36\xb3\xcd\xf9\x75\x19\x37\x5b\xc1\x12\xd9\xe2\xd2\xed\x58\x72\xda\xaf\xc9\xe6\x13\x7d\xf6\x28\xa2\xd6\x30\x1b\x70\xfc\xd8\xe3\x70\x7e\xd7\x39\xb2\xf3\xea\x14\x64\x7a\x53\x90\xc7\xf5\x3e\xbd\xd2\x80\x44\x42\x43\x3c\x8b\x80\x8d\xd8\xe0\x37\x8a\x92\x39\x12\x53\x8b\x95\x6a\xac\x65\x37\xd3\x9e\xef\xc5\x04\x9f\x90\x88\xd4\xb4\xe5\x6a\xb7\xca\x89\xba\xb4\x3a\xbf\xc7\x75\x5d\x72\xe6\xd2\xd3\xb0\xb8\x7a\x0d\x76\x8d\x1d\x80\xa1\x81\x89\x15\x15\xd1\x07\xf3\x79\x2b\x26\xab\x86\xc8\xa7\xa1\xf8\xe0\x3c\x54\xb4\xc3\x90\x4b\xbf\xb3\x05\x2c\x8d\x36\x09\x60\x52\x68\xb9\x12\xa5\x34\x35\x51\xf1\xa1\x69\xc2\xb5\xae\x35\xb8\xdc\x2b\x42\x10\x09\xa8\x3e\x02\x94\x95\x18\x3f\x0e\x67\x10\x24\x07\x61\x6e\x8c\xac\x29\xc0\xf5\x48\x6a\x50\xd4\x91\x48\x80\x0a\xad\x28\x52\xa4\x53\x1c\x3b\xf6\x47\xaa\xc2\x3d\x8d\xbc\x4d\x16\x80\x94\x50\xbd\x41\x44\x68\x49\x43\x14\xad\xa2\x08\x47\xf1\x43\x26\xc9\xa4\x22\xf9\xf8\x89\x8d\xfc\x4b\x74\x84\x27\xca\x14\xc2\x82\x13\x82\x28\xf1\x45\xf8\xe3\xb6\x8e\xe7\x51\x35\x2a\x7b\x25\x6a\xba\x72\x99\xb0\x90\xcb\x8b\x7c\xfb\x90\x9b\xe1\x37\x01\x44\xeb\x44\x02\xc4\xcc\x24\xe2\x60\x92\xd8\xc4\x40\x70\xcc\x28\x46\x34\x3c\x21\x7a\x20\x24\xca\x8d\xea\xac\x59\x22\x76\x14\xf0\x2f\x40\x12\x95\xab\x97\xd2\x3e\x87\x06\x49\xe3\x5d\xa3\x77\x1d\xd3\xe4\xee\x18\xf8\x48\x6a\x5d\x08\x76\xe4\x3b\x0f\xc1\xdc\x93\xe7\x21\xd9\x93\x06\x59\x56\xe1\x9e\x1f\x7b\x4d\xe6\x89\x4f\x7c\xf5\x0f\x97\x72\xe7\x7f\x7b\xc4\x32\x7a\x4d\xb9\xff\x92\x34\xa9\x2f\x78\x09\xdb\xdb\xf2\xdc\xc5\x02\x15\x9c\x39\x24\x92\x90\xd9\xb6\x17\x5d\x7b\x63\xb2\x4d\xde\xc0\xb7\x32\x15\xc2\xb7\x5a\x4e\x23\x72\x7b\xb6\x6e\xfc\x3c\x28\xbe\x43\xc2\xe4\x59\x45\x14\x36\x2d\x80\x1b\x36\x8e\x30\xc6\x94\x6e\x12\xfb\xa6\x62\x4d\xda\xf5\xc6\x08\xdf\x3a\x1e\x72\x9d\xb6\x4d\x36\x4a\xf1\xfa\x6e\x40\x67\x2f\x2c\xec\x1b\x96\xe4\xbb\x0f\xeb\xea\xd8\xa4\xae\xaa\x16\x78\xc4\x6f\x21\xd8\x45\xc6\x23\x21\x51\x58\xc8\xa9\x6c\x54\x7c\x02\x83\x97\x76\xdd\xa7\x35\x65\x2d\x1e\x2a\x70\xd5\x95\x92\xe2\x5e\xf4\x6e\x3d\x76\xf7\xc4\x03\x47\x5e\xba\x33\x29\xa1\x50\x5c\x9e\x2d\xf3\x7a\xb5\x05\x6b\x0b\x75\x28\x2e\x57\x82\x5a\xa9\x41\x5d\xbb\xc5\x55\xc3\x0b\xc7\x5d\x58\xa3\x35\xa2\x68\x33\xfd\xb7\x8d\xb5\xb1\x5d\xbb\xb0\x01\xde\x63\x37\x07\x77\xe5\x84\xfc\xcc\xa9\x66\xc3\x2a\xb3\x60\x70\xaf\x46\xa4\x34\xc2\x5c\x17\x75\xa4\x0a\x93\xf9\x2a\x12\xfb\x8a\x95\x9c\x59\x52\xe0\xb2\x9a\x34\xaf\xe9\x46\xc2\x36\xf7\xc5\x43\x92\x43\x2e\xca\xc9\x93\x8b\xbc\xd4\xac\x3a\x4f\x3e\xd6\x8a\x0d\xf4\x2a\xc4\xf1\x18\x02\x66\x82\x8a\x19\x70\xd3\xa0\xdc\xb1\x39\x54\x69\x93\x30\x8b\xb9\xa4\xaa\xcf\xb5\x7c\xf5\xc2\x1d\x6f\x9f\x5c\x07\xae\x02\xea\x70\x70\xe2\xa9\x05\xa0\xf7\x13\xe8\x7b\xcd\x3e\xf8\x69\x38\x0c\xd1\x9e\x6f\x94\x9f\xfa\xf2\xe5\xc2\xa9\x3a\x8d\x69\x84\xa5\xc7\x10\x7f\xa8\x8e\x83\x74\xce\xc4\xa4\x06\xcb\xa8\x22\xce\x52\x6a\x5f\x72\xbd\xf2\x20\x68\x0d\xf5\xc1\xba\x9b\x6f\x5c\x81\x56\xdd\xd5\x14\xcb\x90\xf7\x1f\x1d\x55\x54\x2b\xe0\xd5\x6b\x15\xbf\x3c\xdf\xe2\xf1\x84\xce\x72\xbd\x09\x6e\xc4\xcc\xa0\x5a\x68\x70\xbf\xee\xb2\xfc\x4a\x83\x7f\x27\x80\x57\xb8\xd6\x84\x2a\x93\xdb\x39\x78\xf8\xf6\xe1\x51\x26\x4f\x8e\x23\xb4\x6e\x12\xde\x70\x95\xe0\x23\x7f\xea\x70\x23\xf7\xb9\xfe\x03\xef\xbe\xfb\x99\x20\xab\xe6\xed\x82\xdb\xf4\x3d\xb7\xc4\x02\xbf\x8c\x40\xb7\xe6\x7b\x5e\x0b\xff\xfa\xf8\x99\x20\x0f\x61\xdd\x35\x65\x59\x89\xb3\x20\xf0\x14\x4d\xe0\x7b\x2e\xb6\x0d\x91\x9c\xaa\x4c\xf7\xfc\xc8\x81\xf2\x63\xbf\xb9\xa2\x9d\xf9\xa2\x2f\x1d\xb8\x97\xd2\xbd\x07\x78\xd0\x37\xc2\x95\x52\x11\x5e\x83\xbf\xfd\xa3\xef\xa1\x41\x21\x8c\xdf\x5d\x6b\xad\xb6\xea\x05\x8e\xf3\x1c\xc0\xe1\x23\x2d\x28\x97\xe6\x21\x11\xf7\x50\xfb\xad\x41\x69\xdd\xd0\xee\x3d\xf4\x9a\x9f\x29\x5d\x9b\xb3\xfc\xf4\x4b\xa0\xe7\xf0\x4e\x78\xdf\x6f\xfc\x01\x5f\x38\x75\x39\x5e\x39\x03\xcf\xbb\x73\x9c\xe0\x2a\xb6\x27\xe2\xae\x03\x50\x3d\x25\x2a\x52\x2d\xa8\x36\x20\xe1\x6e\x27\xc8\x43\x21\xf0\xc4\xf6\x81\x11\xc2\x09\x0f\x7c\x8d\xec\x07\x68\x58\x5e\x44\xe0\xbc\xce\x1e\x2d\x64\x43\xfe\x20\x7f\x14\x21\x9e\x21\xd0\xd3\x0d\x83\xbc\xe1\x25\x6f\xc7\xbf\xa7\x61\x60\xc8\x21\x49\x37\x4d\xf6\xf6\x22\x00\x4d\xaf\x40\x4c\xf6\x89\x6c\xa5\x40\x36\x5d\xa2\x92\x3c\x91\x47\x02\x42\x14\x9f\x8c\xc5\x46\xe1\xbe\xd7\xfc\x02\xb9\xc6\x1e\x27\x0a\xe2\x86\xfb\x95\x7e\x22\xed\x14\x20\x77\x01\x17\x28\x23\x8a\x8a\xab\x94\xa2\x1c\x54\xf0\xaa\x0a\xa5\x32\x35\x40\x97\x5d\x42\xa5\x39\xe2\xf8\x62\x3c\x12\x99\xd8\x8b\x60\x55\x72\x91\x4f\x87\x2e\x0c\x1c\x26\x2a\x82\x78\x15\x44\xad\x24\x0a\xea\x17\x91\x42\x28\xa4\xc2\xc8\x41\xc1\xeb\x98\xb0\x38\x90\x70\x15\x40\x3b\x1d\x55\x38\x3c\x02\x1e\xe2\x1f\xda\xc6\x3c\xc0\x3a\xa7\xe0\x7b\x81\x1d\x08\x69\x6f\x5f\x03\x91\x00\x88\x5e\x8b\xd9\xa1\xe2\x1c\xca\xc2\x40\xfd\x90\x27\x89\xd4\x51\x1e\xf6\xc3\x23\xc1\x01\xed\xcd\x6f\x68\xc8\xf6\xc3\xf1\x08\xa6\xbf\x11\xfe\x13\x8d\x82\x6c\x70\xc0\x48\x6e\xb7\xd1\x2f\x08\x98\x25\xa0\x74\xd8\x11\xca\x2c\x1a\x04\x9c\x56\xcb\xae\x62\xd7\xea\xf1\x66\xa9\x91\x6d\x55\x9b\x7d\xdc\xa3\x5d\x13\x7b\xbb\x8b\x8a\xce\x8c\x4f\x3f\xf4\xf0\x6d\x99\x58\xd7\xce\xee\x4c\x1f\x14\x2b\x79\xc8\x75\xdd\xb0\x72\xf0\xe0\xe4\x23\x89\x78\xac\xee\x3a\x4e\xdf\xc2\xfc\x62\x6c\xe1\xda\x72\x0a\x95\x7e\x39\x9d\x91\xeb\x88\xf1\x1d\xd3\x52\xa0\xb7\xdf\x8c\x0f\x0c\x1a\xbd\xe9\xa4\x64\x9a\xea\x46\x22\x08\x7f\x1e\x9b\xe7\xb7\x88\x73\xc9\x3f\xfd\x9b\xe7\xe9\x9a\xf0\x8d\x3d\x73\x78\x07\xc7\x90\x8d\x4d\xe1\x37\x45\x10\xb4\xeb\x4c\x76\x26\xbd\xb3\xe3\x65\x9b\x54\x23\x60\x4a\xda\x02\x2c\x2a\x57\xb9\xb9\x1f\x4f\x47\xbd\xd8\x48\x69\xe6\x9d\x1e\xc5\xb9\x42\x56\x44\xda\x1c\x8f\x56\x4d\xb8\x55\x3c\xa3\x91\xfe\x17\x9d\x2a\xbe\x89\x0a\x60\xf2\x10\xf6\x72\xe6\x30\xd2\x2c\xf9\x09\xb7\xe9\x0d\xfb\x1e\x9b\x64\x3e\x1b\x45\xbe\xd3\x2d\x0c\x5f\x5d\xd9\x4c\xd1\x48\x82\x72\xfe\xca\x85\x09\xce\x82\x6c\x36\x95\x0b\x2f\x27\x2b\x74\x39\x99\x54\x2b\xb2\xc2\x83\x9d\x7b\x3c\x31\x9e\xb4\x40\xac\x24\x02\xe1\xa8\xb3\x73\x6e\x8a\xdd\x8f\xf0\xf2\x94\x46\x79\xd9\x49\x1c\x1c\xf3\xbd\xa8\xde\xbc\xd8\x9d\x88\xcb\xa1\x8b\x8d\x07\x2d\x16\x2a\xab\x01\x22\x5e\x0f\xd5\xc7\x40\xdc\x41\x05\x42\x22\x0a\x86\xc1\x75\x39\x47\x3a\xc0\x35\x6f\x80\xb0\xbc\x04\x08\xc0\x76\x0d\x69\x92\x3a\xb3\x16\x5b\x5b\x2a\x0f\x35\x6a\xad\xbd\xa8\x50\xed\xc1\xee\x87\xf1\x17\xf1\xde\xfe\xde\xaf\xe2\x0d\xc6\xcf\x5d\x39\x75\xb7\x69\x98\x74\xb0\x67\x24\x0c\x8d\xc9\xa6\xbb\x61\xcf\xee\x9b\xfe\x74\xc7\xe0\xe4\xd5\xf6\x6a\x12\x0a\x3b\xac\x2c\xaf\xe6\xf2\x6b\xf9\x3e\xbb\xd9\x8c\x35\x9b\x2d\x05\x35\xc6\x05\xe4\xb9\xe7\xe2\xb9\x6c\x8b\xf5\x77\x17\xb2\xc3\x03\xae\x90\xe4\xbb\xa6\xa6\x72\x7b\xef\xba\x1f\xb9\x4c\x40\x3e\x06\x57\xf1\x76\x71\xe1\xd0\x68\x9d\x89\x29\x15\x37\x11\x81\xad\x10\x45\x41\xc7\x4b\xc9\x37\xaa\x88\xb6\xd5\x4a\xa1\x1c\xb2\x68\x57\xa8\x70\x45\xb3\x48\x5f\x89\x6a\x94\x46\xf8\x66\x03\x7e\x84\xeb\x59\x94\x24\xea\x23\x7d\x6c\x10\x4a\x43\x8c\x14\x43\xad\x15\xa0\x7b\x77\x06\x84\x15\x27\x24\x14\x54\x4e\x9d\x4a\x4c\x85\x7c\x21\x26\x29\xa4\x57\xae\xd2\x01\xd4\x32\x85\xe5\x9b\x4a\x8a\x82\xfa\x65\xa5\x3c\xa0\x77\x25\x77\xef\x3e\xb2\xb0\x52\x58\xae\x39\x76\x33\xa5\x99\x89\xd9\x58\xa6\xeb\xa4\x95\xed\x2a\x89\x02\xfd\x24\x93\x36\x63\xa3\x74\x98\x6f\xe2\x95\xeb\xf7\x79\xe5\xcf\x75\xf4\x74\xfe\x0a\x33\xfb\xb3\xeb\xb9\x69\x5b\x2b\x4f\x91\x6f\xb0\x10\xc9\xe6\x09\x91\x1a\x16\xb1\xab\xce\x52\x08\xa9\x38\x82\x9b\xd7\x2d\x37\xda\xd9\x81\x2b\x5c\x44\x9b\x11\xa1\x74\xe3\x7d\x87\xf3\x47\x3c\x93\xf0\xf6\x27\x64\x43\xa5\x0c\x75\xc6\xa0\xf3\xb6\xed\xf9\x08\x1f\x14\xe9\x94\x83\x25\x9b\xdf\xb5\x01\x5e\x07\x69\xf2\x02\x37\xa4\x15\xe5\x46\x23\xa5\x0f\x5c\xb4\x4e\x4f\x1e\x18\xd9\x31\x34\xd9\xaa\x82\xf7\xb4\x0d\xb1\xb9\x05\xf0\x4c\x03\xe4\xdb\x6f\x84\xf4\xdd\x07\x61\xe1\xec\x1c\x34\xaf\xad\x42\x6e\xb4\x1f\xc6\x0f\xed\x82\xf2\x7a\xe9\x57\x9e\x79\xe2\xd1\x2f\x0e\xa6\x26\x25\x7d\x3e\xd9\x03\x83\xb1\x67\xbc\x64\xcb\x05\xde\x01\xa9\x1b\xc8\xb6\xcd\x48\x23\x80\xb6\x99\x79\x1f\x71\x85\x4e\xc5\xae\xb6\x37\x8e\x03\x74\xaa\x1e\x90\x0e\x2b\xbc\x1e\xc4\xc2\x16\x30\xfc\xec\xcf\xf9\x86\xe1\x7a\x33\xc7\xbf\xbd\x01\x1a\x0f\x95\xe8\xf6\x19\x8c\x6c\x38\x00\x23\xa5\x3b\xa2\xeb\x68\x11\x74\x76\x09\x26\xd0\x61\x32\x5b\xe3\xcc\xc4\x3f\x08\x4c\xd5\xca\x95\xea\x2d\x63\x06\x7b\xc9\xad\x71\x35\xd7\xaf\xa8\x54\x54\x0f\xa9\xb7\x5c\x2a\xcc\xf3\x42\x76\x29\x6d\x6c\x1d\x10\x8a\x28\x4f\x5d\x17\x4f\x35\x70\xc2\xd8\x73\xbe\x7a\x79\x71\x7f\x3c\x66\xbd\xac\x5e\x21\xd9\xe3\x0f\x4e\xfb\xe5\xb5\x0a\x69\x56\xeb\x38\x45\x0e\x18\x86\x4f\xe3\x09\xc2\xfa\xf7\x49\x30\x38\xa1\x12\xcd\x32\xc8\x53\xff\xe8\xb6\xd6\x96\xfc\xf3\xc9\xbe\x44\xde\xb7\xbd\xe7\xab\xe3\xce\x73\xbb\xad\xa2\xb4\x9c\xfd\xf2\x4c\xb1\x3e\x74\xcd\xf1\x7a\x34\x42\x4d\x09\x84\x77\x80\x57\x5a\x01\xcf\x27\x7b\xe3\x6b\xc3\xd9\x44\x5d\x95\x65\xe6\xbb\x0e\xed\xcc\x9e\x20\x42\x29\x17\xaf\xb1\x19\xff\x4c\xa3\x56\x3e\xa4\x0c\xab\xd6\x8e\x9d\xc2\x60\x45\xa0\x56\xe1\x64\x7d\xcd\x25\x0b\xab\x0e\xaf\x9f\x8c\x5d\xcb\x48\xf1\x25\xf9\x10\x9f\x1f\xb8\x31\x83\x5d\xd2\x50\x33\x43\x88\xc0\x75\x91\x60\x8d\x8b\x5c\xf0\x6e\x47\x18\xaa\x22\xc9\x0f\xbb\xee\x18\x6e\xcd\x9d\x98\xbe\xfa\x48\xc5\xcd\x9d\x43\xb8\x9c\xa0\x8a\xc4\x2c\xc5\x2b\xc5\xb5\x96\xd5\x9d\x6a\x78\x3e\x34\x8e\xa4\x53\xa1\x7d\x6e\x7d\xb5\xa8\x75\xf7\xca\xb1\x97\xbd\x76\x5c\x71\x7d\x9d\x59\xa6\xcc\x7b\x07\xbb\x02\x32\x91\x83\x4a\xb9\x15\xb8\x45\x9b\xbb\x2d\x0f\x4c\x53\x23\xa3\xa3\x19\x0e\x0a\x81\xb3\xc7\xaf\x7d\x47\x16\x5e\xa1\xbf\x66\x44\x0c\x99\x65\xf6\x1d\x9c\x9c\xc0\x07\x27\x38\x40\xa5\x4e\x93\x7b\x46\x5b\x87\xfe\xdd\x1d\x2b\xab\x5f\x79\x5a\x6d\xe5\x9b\x3e\x8d\xe9\x88\xf9\x99\x88\x67\x2d\x30\xc6\x0a\xc8\xb4\xca\x9e\xe3\x34\x9b\x8d\x86\x1f\xa0\x6a\x80\xc2\x46\x97\x65\xc9\x52\x54\xd5\x51\x7c\x2d\x32\x99\x11\xaa\xa0\xb6\xac\xda\x65\x47\x8b\x0f\x18\xcd\xae\x43\xa3\xcd\x13\x0f\x9f\x49\x1c\xb8\x37\xc1\x49\x92\xc3\xd8\x5e\x06\x8f\x7c\x5a\x7e\xe0\x27\x1f\xf8\xb9\x07\x7f\xf6\x8f\xfe\xef\xd9\x00\x61\xa0\xec\xcb\x21\x6d\x07\xed\xa5\xcf\xc2\xb5\xb4\x45\x74\x3e\x0f\x07\xe2\xcf\x52\x1a\xb7\x5a\x45\x9f\x13\x8e\x13\x05\xde\x0b\x5b\x8e\xff\x67\x7f\xef\x9c\xfd\x0f\xef\x5c\xdb\xb7\x38\xd3\x0b\x37\x1d\xa9\x80\xdf\x68\xc1\x67\xbf\xa0\x43\x6c\x6a\x07\xdc\xff\x33\xf7\xbe\x79\xf5\xf2\x0c\xbb\xf8\xe7\x9f\x76\x12\x13\xc3\xac\x51\xad\x7d\x8a\x7b\x6c\x77\xe0\xd1\x27\x02\x59\x58\x0a\x84\x25\x35\x92\x94\xa2\x9e\x46\xcb\x76\xe0\xc8\xf0\xed\xa0\x6a\x59\x72\xae\x7b\x06\x6c\xd9\x03\x55\x36\x08\xcb\xb8\xa4\xc7\xc0\x07\x13\xe7\x24\x81\xf8\x86\xa9\x0c\x67\x85\x13\x43\xa6\xc4\x94\x0d\xf8\xed\x5f\xfc\x24\x51\x62\x01\x31\xf4\x1c\x48\xdd\xa8\xfc\xdf\x60\x10\x55\x47\xf9\xa5\x52\x32\x2a\x64\xb1\x1c\x23\x8a\x41\x41\xa6\x61\x7e\x39\xb9\x57\xbd\x9b\xc8\xca\x35\x82\xf0\x16\x6f\x26\x41\x54\x49\x04\x80\x17\x48\x04\x17\x75\x61\xd2\x24\xa2\x50\xb2\xe7\xfb\x74\x65\xb5\xa2\xe4\xf3\x75\xad\x71\x3e\x33\x29\xa9\xbd\x6f\xa6\xcc\x7e\xe2\xb6\xfb\x82\xbf\x13\x11\xf8\x41\x28\xc0\x68\xdb\xcf\xe5\x93\x68\x9f\x18\x10\xcf\x11\x5c\x5f\xe8\xbc\x11\x6b\x16\x72\xbe\xd9\x0c\x11\x09\x9e\xef\x87\x96\x56\x08\xe5\x99\x60\x04\x41\x47\xc8\x11\xbc\x6c\xc7\x54\x2d\x78\x17\x8d\xea\x92\x60\x9f\x6d\x60\xd9\xb6\x08\x86\xd6\xda\xb6\x20\x25\xed\xc7\xda\xe1\x7f\x91\x10\x24\x9d\x08\x44\x80\x8d\xb2\xdd\x51\x0d\x6b\xca\x23\xe5\x36\xc2\x55\xa1\x32\xc5\x3b\x32\x66\xa3\xcf\x8e\x59\x87\x87\x28\xaa\x23\xcb\xa3\x31\x72\x68\x9b\x83\xa3\x3f\x64\x93\x35\x46\xd7\x6c\x8f\x8f\x06\x8c\xd3\x66\xc3\x55\x4b\x05\x3b\xb1\xb6\xda\xca\x95\x0a\xad\xbe\x7a\xcd\xee\xe9\xca\xf4\x73\x87\x29\xad\x93\xa7\xce\x0d\x5d\xbd\x3a\xbf\xfb\xe5\xb7\xbd\x16\x64\x49\x86\x54\x3a\x3d\xdf\xd5\x9f\xfc\x7a\x18\x1b\x57\x68\xc4\x0a\xa5\xbc\x83\xf3\x51\xcf\xf6\xf7\xda\xbe\x17\x28\x01\x63\xb2\x44\x69\x60\xc4\xf4\x86\x91\x8c\x11\x87\xc7\xd3\xab\x05\xd3\x92\x2a\xc2\xdf\xca\x3b\x73\xb0\xe1\xb7\x27\x70\x5d\x75\x96\x2d\xf0\xf3\x1b\xe2\x5d\xbe\xb5\xc4\x79\x5b\x02\x30\xf2\x2c\xe7\x41\x47\x98\xb4\x2d\xab\xbc\x6d\x29\x09\xf5\x13\xa1\xa5\xb4\x1d\x0e\x91\xcc\xee\x98\xbf\x43\x91\xd1\xde\x4b\x27\x94\x06\x94\x47\x48\xb4\xfd\x2b\x68\x3f\x4a\xde\xd9\x33\x28\xec\x89\xb7\xa1\x73\xf4\xb2\x53\x1b\x3d\x12\x74\x11\x44\x68\xef\x48\xdf\xb9\x5e\x5b\x0d\xc1\x2f\x25\x12\xd4\x48\xca\x6b\xf2\x1e\x3f\xf0\xe2\x1e\xf7\x94\x0d\x06\x47\xe5\xba\xa2\x49\xab\x44\x67\x8b\xcb\x0b\x0c\xe7\xb1\x31\x50\x6b\x3a\x38\xd1\x41\x06\x71\x94\x29\x82\x61\xb2\x3d\x43\x55\x3b\x30\xac\x4b\xb3\x73\xfb\x72\xe9\x3e\xa2\xc8\x51\x38\x83\xa2\x9b\xd3\x4e\xa0\x9b\x4c\x95\xf3\x97\xe7\xbb\x53\x6d\x23\x75\xe4\x38\x69\x93\x68\xfb\x06\x21\xc2\x22\x6d\x12\x11\xa4\xdf\x7e\x20\x8c\x6f\xa2\xfc\xf0\xbd\x50\xaf\x58\x5b\x85\x0b\x27\x9c\x84\x11\x7f\xe1\x7b\x0d\x0f\x3d\xc4\x8a\x21\xf9\x35\xf5\xba\x42\x6a\x66\x16\xea\x73\x93\xdc\x2f\xed\xe5\xc4\x19\x41\xa0\x9e\xb6\x0c\xab\xd9\xbb\x77\x47\xa3\xd9\xaa\x0f\x20\xb0\xbb\xf9\xe0\xe4\x8d\xd4\x30\x2c\x04\xe8\x2a\xf4\x0c\x8d\x3e\x98\xe9\x1b\x2a\xd7\x4a\xb5\xa1\xf9\x6b\x73\x3d\xf5\x5a\xcd\x44\x9e\x6b\x88\x12\x9b\x38\x66\x0f\x81\xae\xa3\x66\xd2\xeb\x8a\x69\x54\xcc\x5c\x96\xa5\x47\x77\xc4\x13\x23\x03\x9c\xa4\x92\x7e\x67\x55\xf8\xed\xac\x0f\x0d\xc7\x29\xad\x34\xd2\x7c\x7d\x79\x37\xe3\x76\x22\xb2\xac\xab\x0d\xae\x6b\x45\x3e\x3e\x76\x5e\x5a\xaf\x25\x68\xa9\x91\x63\x4e\xa5\x2f\x00\x3b\xb6\x49\x5a\x34\x20\xb2\x56\x86\xae\xd4\xac\xdf\x9b\x59\x17\x58\x2e\x62\x04\x6d\x55\xb2\x63\xa3\x0b\xd7\xdc\xe6\x62\x87\x90\xfc\x42\x95\x82\xb7\x0d\xfd\x6d\x8a\x63\xd1\x5c\xb9\x8e\x84\x68\xc9\xb2\x0b\xc5\x1e\x9b\xb1\x71\x9b\xb3\xe1\x20\x08\x72\xe2\x37\xb8\x5e\x8a\x4b\x95\xe2\xb5\xee\x1d\x83\xcd\xc1\xc9\xdd\x95\xb7\x4d\xee\xbe\x7e\xbb\x30\x44\x14\xac\xaf\xfb\x69\x94\x5c\xe1\x38\x71\x84\x44\x2a\xd9\x49\x5e\x58\xdb\xc5\xb8\x1b\x7d\x46\x94\x06\x57\x95\x12\x0c\xf6\x5f\xa4\x15\x3b\x4e\x6b\x2d\xbc\xb7\x7a\x77\x00\x4e\x6c\x83\x59\x01\xaa\xd1\x92\x52\x66\x99\xe4\x0c\xcb\x26\x0a\xf0\xc2\x62\xe6\xb9\xef\xf9\xa6\xd5\xe8\xd9\xe7\x91\xe7\x8a\xa8\x0d\xf0\xb4\x15\x88\xd3\x0e\x90\xdb\x00\x6d\x1d\xd4\x4e\x36\xac\x79\x6d\x17\x15\x6f\x03\xb5\x0e\xbb\xe8\x70\x8e\x88\x53\xf3\xb6\x1a\x29\x0c\x0b\xbc\x4d\xb5\xd1\x82\xe4\x6d\xf9\xc9\x59\xd1\x93\xe1\x62\x6b\xd8\x52\xa4\x81\x2b\xd9\xe3\x76\xef\xd4\x8e\x9b\x87\x8e\xec\xe6\xca\xd5\x59\x84\x49\x1c\x02\x59\x02\x2f\x19\x07\x5f\x96\xa1\x57\x65\x60\x1f\x9c\x80\x56\x57\x2a\x0c\x71\xe8\xdb\x3d\x0c\x89\xde\x0c\xf4\x8c\x0f\xdc\x7d\xfc\x6f\xbf\x7c\x28\x93\x4d\xbd\x4f\x5f\x4a\xef\xf0\x4d\xe3\x64\x38\xee\x28\xac\xf1\xfa\x1d\x76\xdb\x23\xda\xa2\x39\x6f\x02\xde\xeb\xe6\x8b\x5c\x57\xac\x96\x84\x16\x72\xba\xc9\x15\x69\x1b\xcb\x6f\x80\x78\xb2\x15\xcf\xf3\x2d\x0a\xc1\x16\x15\x39\x5c\xc4\x91\xb5\x96\x77\xea\xbd\x76\x58\x20\x8d\xa6\x93\xb7\xd9\x4e\xdb\x32\xcc\xb7\xee\x55\xb6\xa5\x95\xaa\x75\x75\x79\x7e\xf5\xd8\xed\x31\xfd\xb6\xa3\x09\x25\x91\x52\x88\xc0\xba\xc4\x73\x5d\x06\xbe\x17\x4a\x5e\x01\x76\x02\x2e\x1c\x39\x94\xb6\x88\x36\x8f\xd0\xf3\x0a\x0f\x5d\x98\x00\xf6\xd9\x6a\xd2\x52\xd5\x1b\x24\x23\xe8\xaf\x15\x96\x19\x38\x1e\x74\xf5\x30\x96\x3d\xa0\x40\xaa\x47\xe3\xf1\x84\x19\x58\x06\x52\x91\x2a\x09\x27\x2d\xbb\x74\xc2\x0d\xae\x4d\xbb\xd3\x54\x91\x4f\xc5\x7b\xe2\xcd\xf6\xba\x7a\x5e\xab\x47\xaa\x37\xd5\xc0\xe3\x02\xbe\xbc\x50\x2d\x37\x25\x11\xbe\x23\xa1\x0c\x37\x55\x39\xb0\x52\x16\x13\xc4\xe0\xbb\xde\xd6\xd8\xd7\xb0\x1f\x25\xa7\x78\x03\xb9\xee\x73\xcf\x9c\xac\xad\xb7\x1e\x75\x86\xce\x3d\x6d\x67\x34\x4b\x52\x71\x3a\x5a\x4d\xdf\xa9\x34\x19\x2f\x0e\x91\xdc\x1a\x7d\xb9\x12\x1a\xf8\xfc\x96\xbb\x69\x81\xea\x90\x2f\x8d\x44\x6b\x47\x23\xcb\x3f\x7a\x32\x26\xec\x7d\xba\x6e\x35\xb3\x47\xa7\x96\x97\x2e\x2d\xd2\x55\xdb\x97\xf5\x44\x3c\x18\xea\xcb\x86\x60\xc1\x40\x68\xe8\xe1\x78\xd8\x53\xba\x84\x20\x23\x91\x1a\x49\x18\xa9\xbe\x58\x60\x98\x8c\x98\xca\xbc\x57\xaf\xac\x81\xb3\x16\xe7\xe9\xee\x0c\x24\x6f\x48\x40\x65\xad\xc5\xa7\x9f\x59\x85\x67\x4e\x2d\x92\xb5\xf5\x0a\xf1\x10\x76\xbf\xf2\x3b\x04\xbc\x49\x53\xb7\x12\x71\xd3\x18\x18\x18\x10\xfe\x1e\x0e\xc5\xbc\xc4\x1e\xfe\x9c\x4d\xdd\xbd\x2d\x32\xf2\x86\x83\x33\x76\xd1\xad\x7a\x4d\xb7\x89\x54\x52\x41\x1a\x29\x22\xad\xe4\x7d\x3f\x28\xba\xb6\x53\x67\xcd\xba\xdd\xaa\x57\x05\xf9\x59\xae\x66\xa4\x34\xdd\x60\xa1\x86\x2e\xcb\x0a\x95\xa8\x41\x25\xc9\xc0\x87\x60\xf8\x36\x53\xfa\x0e\xf5\xd9\x0b\x7f\x73\x21\x56\x9b\xe1\x34\x31\x46\xc8\xc8\x18\xc0\xa3\x32\x3f\xd4\xf4\xd8\xa1\x3d\xb0\x7b\x36\xa7\x67\x61\xb9\x67\x19\x29\x89\x40\xda\x95\x43\x73\x9e\x45\x35\x50\x14\x49\x30\x6d\xe1\x3d\x04\x99\x44\x06\x8a\x48\xec\xd2\xf0\xbd\x88\xd3\x92\x85\xa8\x09\x3d\x44\xa8\x69\x21\x20\x25\x22\x9a\x19\x69\xe8\x9d\x3f\xf4\x13\xa1\x7b\x49\x45\xf5\xa0\xde\x68\x90\x87\x4f\x3c\x0c\xeb\xc5\xb5\x46\x2e\xd1\x93\xf8\xe2\x57\x3e\xff\x17\x49\xf5\x81\x1f\x7b\xcd\x3d\x95\xc9\x85\x8b\x0c\x9a\xa4\x1b\xd2\xbb\x87\x80\x0d\xde\x04\x71\xec\x53\xb7\x76\xd1\x0b\x0f\x3e\xce\x4e\xfd\xcd\x27\x5f\x6f\xf4\x6b\x4f\xe4\xd2\x83\x6c\xfc\x25\x2b\x69\x4a\x3d\x94\x13\x3e\x51\x8d\x66\xe8\x9a\xe2\xb2\xb8\x76\x0b\x7e\xf1\x2d\x6f\x23\xae\xec\x90\x39\xf9\x38\xc9\xe0\xc8\xba\x69\x8a\xf0\xdd\x2d\x04\xae\x38\x1c\x3c\x9f\xcb\x61\xac\x15\x51\x70\xa0\xb2\x88\x1f\x40\x14\x2b\x2b\x4d\x01\x16\xc3\x15\x27\x4c\xff\x54\x12\xeb\x90\x46\x71\xac\x6d\xa3\x0b\x0d\xdd\xf3\x2c\x74\xd7\x07\xcc\xc3\xd5\xa6\x85\xfe\x77\x01\x40\x85\x53\x3c\x02\x71\x2c\x94\x41\x02\x78\x22\xc8\x22\x08\x76\xcd\x4b\x57\x56\x32\xd5\x15\x69\xdf\x8d\x77\x1f\xfe\xb7\xc9\xf1\xbe\xcc\xd2\x95\xb9\x37\x3d\xfa\xc5\xe5\xb1\xdd\x07\xdc\xbf\xe2\x22\xc8\x27\x82\x97\x42\x67\x0b\xc5\x03\x6b\xe3\xc9\xf0\xc2\xa4\xad\x06\x77\x00\x2b\x8d\xfc\x64\x11\x07\xd9\x72\x5e\xe7\x33\xa9\xfd\x23\x31\xe2\xc8\xb2\x4a\x37\x6c\xdf\xc2\x4c\xdd\xe6\x54\x6d\xbd\x9a\xf0\x4d\xeb\x04\x85\x4d\xb0\xdb\xe1\x7d\xc2\xe0\x1b\x19\x64\x3b\x60\xb5\xbd\x71\x0b\x89\xfc\x63\xe1\x7b\xb2\x89\x4a\x36\x82\x76\x85\x75\x99\x6c\x49\xea\x0c\x0d\x2d\xc0\xc9\x75\x55\xc0\x43\xb0\xdc\x39\x67\xc3\x68\x12\xbe\x47\x81\x4b\x9c\x96\xab\x95\x9d\x4a\x7c\xbd\xda\xcc\x96\x6a\xbc\xab\xd6\xe2\xb9\xa6\x0b\x89\xc9\xee\xae\x25\x49\x33\x13\x33\x8b\x0b\x13\x12\x42\x58\x55\x45\xda\x94\x15\xc8\x0c\x25\xa7\x65\x55\x8e\x8b\xae\xe2\xa6\x09\xf1\x5c\x77\x7c\xd3\x87\xb8\xe9\x02\xc0\x77\x86\xac\x49\x86\x9e\x90\x4b\x6a\x42\x69\x50\x4a\x36\xbf\x23\x5b\xf7\xe7\xe9\xbc\xef\xf8\xe5\xda\xb1\xca\xd7\xe1\xe0\xb6\xb1\x7a\x6b\x38\x4c\x9b\xf9\x74\x7e\xc3\x37\x85\x6b\xc8\xfa\x61\x43\x00\x09\xcc\x41\x89\x57\xf3\x63\xcd\x4a\x33\x87\x8c\xdb\xe0\xb0\x61\x9e\xda\x10\x3b\x02\x93\x88\xdf\xc8\x8a\xd2\x34\xbb\xe3\x73\xb2\xae\x34\x23\x49\x12\xe9\x34\x41\xcb\x33\x1b\xeb\xb5\x21\xdf\xf7\x0c\x71\x2d\xa4\xe9\xa6\x9e\x30\xd7\x8c\x54\xac\xe0\xd6\x9c\x78\xb3\x58\xed\xf3\x84\x89\xb3\x3d\x08\x45\x56\x9b\xaa\x65\xae\x2b\x09\xbd\xac\xc4\xe4\xfa\xb3\x2c\x6e\xa1\x4c\x0a\xaa\x5e\xac\xb6\x5a\x1e\xf5\x88\xa3\x47\xe6\x37\x85\x2b\x9b\x28\x5e\x8c\xca\xf4\x38\xef\xc6\x95\xbf\x83\x99\x76\x99\xa9\x95\x7e\x2e\xdb\x59\x90\xb9\x25\x02\x72\x4c\x23\x66\x67\x47\xfa\x3c\x49\xa1\xe6\x5a\x7e\x65\xd7\xa1\x5d\x47\x69\x47\xa7\x89\x65\xb3\x8b\xf8\xd0\x4c\xb3\x27\x6d\x53\xcb\x48\xb7\x85\x62\xa8\xe5\x84\x06\x66\xd8\xcc\x08\xde\xa0\xab\xb6\xe9\x8c\xb6\x85\x22\xed\xc4\x8d\x77\x7c\xa4\xc2\x5c\x42\xdb\xd1\x52\xa1\xef\xa2\x3d\xbf\x34\xf2\x65\x74\x0a\x77\xfa\x9e\x58\xab\xb6\xc9\x29\xed\xe3\x92\x34\x8e\x8c\x63\x08\x24\x39\x0b\xc4\xd7\x7b\x87\x86\x17\xa8\xa1\xc7\x2f\x5f\x78\x72\x8f\x08\xc7\xeb\xce\xf5\x87\xd4\xaa\xc5\x12\x0b\xb9\x1d\x13\x33\x8c\xf3\xf8\xd5\xd9\xd9\x7e\xc7\xf5\x98\x64\x1a\xd5\x44\x22\x96\x4f\x58\x09\x3f\x91\x48\x31\x4d\x31\x7c\x2b\x61\x70\x45\x27\x31\x1c\xe1\x6e\xe4\x7e\x23\x50\x69\xac\x12\xcb\xbc\xd6\x86\x3b\x1d\x68\x04\x4a\x91\xc5\xdd\xf5\xf9\x43\x5c\x2c\xfe\x0e\x60\xe7\x6e\x1c\x50\x61\x90\x4e\x9f\xdf\x81\x20\xd7\x0c\xf8\x75\xfe\xe4\xb6\x96\xe3\x8b\xb8\xa9\x18\xcc\xd7\x07\xc9\x5a\x71\xd6\xcf\xa5\xae\x44\x66\x3b\xa1\xf7\x6e\xf8\x97\xdb\x68\xa2\x13\xc2\x42\x40\xa9\x7a\x09\xda\xf2\x73\xe0\x36\xba\x19\xb5\x2d\xe8\x10\x99\xe0\x12\x5c\x76\x24\x2a\x55\xa0\x59\xab\xd6\x56\xf2\x89\x56\xb9\xdc\xed\xb7\x9c\x5e\x16\xf8\x51\x59\x3e\x9f\x48\x83\x23\x3d\x8b\xbc\x25\x54\x6b\xee\x6f\xd0\xb1\x24\x97\x10\xc4\x16\x7c\x54\x32\x91\xeb\xbb\x50\x8b\x76\xac\xd7\x4b\x3c\x16\x94\x17\x0e\xa0\x2a\x2f\x75\xc2\x84\x02\xf0\x75\x70\x5b\x7d\xf4\xbc\x1b\xf3\xc9\x26\x80\x87\xb0\x7c\x69\xa7\x05\x22\x76\x29\x09\x4b\xcd\x83\xbc\x50\xbd\xea\xf4\x75\x5d\xfa\x26\xdd\x2b\xdf\xf2\xe7\x11\xea\x6f\x63\x2b\x22\xf1\x8d\x5d\xb8\x3a\x40\xb6\x0d\x66\x23\xcc\x16\x6e\x55\x25\x1c\x56\x7c\x33\x9c\xad\xa3\x64\x76\x88\x35\x84\xb1\x11\x93\x6b\xdb\x3b\xc3\x9f\x05\xa1\x5a\x16\x71\xc9\xd0\x6a\xc4\xb8\xe7\xda\xa4\xf5\x78\x35\x95\x59\x4f\x8f\x2d\x4d\x5d\x5a\x34\x32\xa9\x5f\x1d\xbf\xf3\x08\x38\xbd\x19\x0e\x33\x73\xa1\x52\x46\x11\x70\xc9\xa2\x42\x46\xd5\xe6\x85\x52\x19\x8c\x81\x6e\xd0\x46\x7b\x40\x4b\x98\xb0\xfe\xf8\x33\x90\x1e\xea\x82\x56\xb1\x09\x2f\xfb\xb1\x57\xc7\xbf\xfc\xe7\x9f\xfb\x3d\x6a\x78\xff\x06\x0a\xc9\x2a\xe7\xd1\x86\x20\x62\xd8\x54\x84\x62\x50\x21\xab\xda\xeb\x85\x44\x91\x16\x9b\x40\x35\xd2\xcc\x43\xe3\x85\x08\xb0\xc1\x79\x88\x18\x8d\x70\x09\x88\xbc\xf7\x68\x5d\x05\x61\xbd\x72\x08\xcf\x09\x01\xfc\x46\xba\x3e\x0d\xe5\x79\xb8\x01\x49\xe4\xee\x0b\xa3\x44\x44\x46\x87\xf8\x5c\xf4\xcd\xda\x26\x93\x8e\x20\x82\x70\x7d\xb3\x76\xb0\x14\x44\xd7\xe0\x6d\x0d\x81\x6d\x1a\x9f\xc9\xf3\x3c\x3b\xd7\x76\xc9\xea\x62\xfe\xe8\x11\x93\xdc\x72\x4b\x8c\xc6\x92\x12\xe1\x22\x8c\x30\x60\x38\x42\xdf\x0f\xbd\xb7\xcb\x4c\xe2\x29\x49\x20\x7e\x22\x9d\x77\x15\x56\x95\xec\xab\xa6\x62\x16\x11\x04\x85\xbd\xbb\xcb\x24\xab\xf7\xc9\x03\x37\xde\x49\xe8\xc4\x3e\x25\x50\x15\x2d\x8c\xfc\xf0\x1d\xe0\xf5\x1a\x90\x85\x19\x06\xb5\x75\x8f\xd7\x0b\x0e\x5f\xca\x3b\x50\xcd\xd3\x15\xc9\x8f\x1d\xef\xdd\x93\xcb\x63\x1f\xfc\x1b\xd1\x54\x79\xb1\x24\x43\xb5\xa5\x22\x8c\x54\x04\x4d\xc9\x09\xcb\x8e\xf7\x67\xdd\x17\x52\xce\x9e\xdd\xf6\x1d\x9a\x5a\xc5\x3f\xab\x8b\xa7\x97\x95\x5a\x21\x90\x50\xa4\x81\xaa\xa8\x6c\xc7\xee\x01\x17\x76\xc3\x0b\xee\xb4\x41\xb6\xd8\xde\x8d\xcf\xac\x5a\x45\xa5\xd4\x6f\x1f\x1c\xcc\x90\xde\x5e\xa2\xcc\xae\x38\xab\x4f\x5d\x59\xc7\x39\x5d\x19\xbf\x61\xd2\x0d\xe3\xc6\xfd\xeb\x8d\xf3\x28\x3d\x10\xfb\x78\x92\x81\xcf\xd7\xad\x05\xe0\x35\x39\xb3\x91\x06\xf4\x54\x13\x74\xa3\x4c\x16\x2f\xad\xf0\xf3\x4f\xc6\xf0\xa1\xe8\x7c\x65\xbe\xc8\xce\x9f\x98\x63\xb6\xc7\xb8\x96\x4c\x3e\xd7\xc2\xeb\x83\xfb\xcd\xc6\xb3\x86\x3b\x02\x77\xa5\x7a\x7b\xe2\x71\x6a\x26\xe3\x3c\xb4\x81\x36\xb9\xe5\x5f\x3a\x1f\x70\x72\xf2\x33\xdd\xea\x3b\xee\x5d\x57\xbb\xac\x55\xa4\x9f\x26\x12\x59\x0d\x41\x6c\x59\x42\xa6\x83\x7f\x0b\x1a\xb8\xc5\xfc\xca\x9c\x9d\x5f\x5e\x95\x4c\xd3\xb4\x62\xd9\x2e\x1f\x58\x5a\x15\x49\x6b\xb2\xa2\xda\x92\x22\x3b\x2c\x10\xfb\xd9\x31\x5f\xdc\x50\xac\x3f\xe5\xba\x72\xd2\x5f\x9e\x6d\xaa\x89\x31\x19\x72\x59\x0e\x46\x8c\xf7\xb7\x5a\x7c\xea\x77\x6e\xff\xef\x9a\x3b\xe2\xc2\x47\x86\x3e\x43\x12\xeb\x71\x38\xe2\xe9\x84\x59\x3e\x48\x6e\x0f\xb2\x30\x24\x56\xea\x82\x51\x16\x76\x4d\x99\xd8\x92\x44\x58\x89\x83\x46\x65\xa2\xe0\x63\xa6\x92\x4f\x94\x40\x04\x6a\xe3\x22\x89\x49\x24\x9d\xa0\x84\xca\x9c\x88\x92\x1a\xc2\xf5\x6e\xbb\x3e\x2d\xd7\xf2\x6a\xa9\xb2\x62\xec\x1a\x1b\x1f\x1b\xb8\xf9\xb6\x37\x1d\x39\x92\xfc\xe1\x58\x32\xf0\x3f\xff\x19\x2f\x7f\x49\x79\x2b\xb0\x1e\x0e\x89\xae\x38\x70\x35\x80\xb5\xd3\x97\x20\xb5\xa3\x07\xac\x6c\x12\xf6\xbc\xea\x66\x23\xb0\xbd\x8f\xee\x3b\xd8\xbc\x59\xd6\x3c\x5c\x1f\x4e\xe8\x8a\x0b\x71\xa8\x58\xdc\x9b\x9b\x0d\xe2\x51\x23\x66\xb8\xe2\xd4\x50\x24\x86\x11\x4d\x6d\x16\xe7\xbb\xf8\xc2\x15\x40\x0e\x81\x46\x5b\x26\x44\xae\xf4\x2d\x96\xd1\x0e\x07\x8c\xbc\x7f\x6d\xaf\x3e\xb4\xfb\x0a\x1d\xbb\x6d\xcb\x68\x28\x60\x28\xe1\x9d\xf8\xd5\x10\x58\xd1\xa8\x46\x2c\xa7\xc5\x72\x53\x9f\x99\x2b\xe4\xca\x79\x72\xf8\xf0\x5d\xf7\xfe\xc8\xce\x57\x1e\x4b\x34\xd7\xaa\xd0\xcc\xd5\xa0\xae\xc8\x3f\x79\xe6\xc9\x6b\x89\xbe\x41\xf6\x09\xb2\x61\x42\x20\xd7\x81\xc2\x4d\x30\x18\xdd\x5b\xf8\xa1\xd4\x01\x8e\x6d\x7f\x5b\x1b\xdf\xb6\x8d\x88\x11\x32\x0f\xff\x09\xb6\x84\x10\xd0\xe8\x34\x11\xd7\x11\xfe\xd7\x09\x30\x8b\x3a\xe0\xed\x17\x6d\x8b\x6e\x3b\x1e\x77\xa3\xff\x36\xd7\x22\xd0\x31\x79\xb4\x2f\xd8\x41\x73\x21\x70\xbe\x3e\xcd\x29\x8a\xf0\x6c\xfb\xd0\x36\xac\xc3\x9b\xc1\x64\x6d\x43\xc1\xe6\xfb\x8d\xbe\x3a\x9d\xb8\x6e\xa0\x54\x4a\x4d\x6b\x7d\xb9\x9a\x5e\x5f\xad\x76\x57\x4a\xf5\xac\xd3\x74\xe2\x41\xc0\x94\x58\x32\x2e\xb6\x2d\x57\xf3\xf9\xb5\xb4\xe7\xfb\x24\x5f\x58\x86\x9e\xae\x41\xa8\xae\xd5\xa7\x92\xbd\xa9\x67\xbe\xb1\xf4\x0b\xf9\x96\xe4\x3a\x5c\x6b\x56\xfd\x8c\xa2\x05\x75\x54\x0f\x97\x10\x98\xb9\x9b\x5c\x65\x73\x43\x9e\x0e\x92\x8d\x80\x2a\xce\x6a\x8b\xc5\x7c\x3b\x88\xfb\x8e\x67\x79\x81\xab\x5e\xb7\xe8\x65\xc5\x91\x75\xb5\x2e\x9b\x4a\x59\x52\xa5\xd6\x16\x6e\x44\x36\xc2\x9b\xdb\x26\x25\x5c\x48\xd4\xa9\xda\x5d\x7e\xd3\x4d\x7a\xcc\x91\x9f\x1d\xa4\xc9\xaf\x37\x2b\x87\x9f\x7a\x8e\x1b\xaf\x2d\x95\x27\x62\x83\x99\x8b\xa1\xe6\x15\xc6\xb7\x02\x6d\xac\x54\xc7\x3d\x16\x6e\xea\xd0\x8e\x71\x73\xe2\xf5\x75\x37\xe6\x96\x5a\x03\x6e\xe0\xa8\xed\x6b\x6f\x40\x68\xcf\x77\xe2\x5e\xd9\xb5\xa0\xc4\x87\xcd\x54\x6c\xde\xe8\x89\xaf\x90\x4e\x50\x68\x40\xa1\xb9\x5c\x1b\x6e\x34\x6b\x5d\x1d\x4b\xcc\x85\xb3\x27\xf6\xac\xaf\xae\x0c\x29\x44\xce\x88\xd0\x11\xb1\x3b\x9d\x6e\x1a\xd7\xcc\x5c\xea\x84\x90\x6f\x52\xc0\x24\xaf\xe5\x24\x51\xf0\x88\x0c\x42\x31\x27\xbc\xaf\xaf\x6f\x45\xd8\x29\x9e\x39\x7f\x6a\x0c\x17\x83\x9a\x8e\xa7\xc3\xdb\x53\x35\x7d\x49\xd1\xd4\x86\xa4\xca\x75\x25\xae\x35\x71\xa5\x48\x9d\x98\x09\xce\xa2\xf8\x9b\xb6\x0c\x8c\x62\x2c\x84\x59\x85\x6f\x6e\x2b\xca\x9f\xe5\x62\xe2\x5b\x1d\x9e\x1b\x61\x48\x5b\x44\x26\x21\x1b\x96\xba\xb0\x2c\x51\xc3\x91\x6a\x0b\xcb\x66\x6d\x69\x29\xed\x94\x4b\xd9\xc0\x6e\x59\xdc\xf7\x15\x01\x68\xba\xb2\x99\xbc\xd8\x0d\x69\x61\xe6\xfc\xf8\xe4\xd0\xae\xb0\x86\x6e\x68\x0d\x89\x25\xaf\x8a\xcf\x0b\xab\xeb\xbc\x37\xd5\x3d\x13\x8f\x27\x88\x69\x69\xb2\xa4\x75\x24\x76\x67\x2c\xb6\xa8\x62\xd9\x7e\xdd\x32\xa1\x55\x1d\x85\x46\xd9\xa7\x89\xd8\x9c\x18\x01\x0b\xf7\xad\xc0\x47\xbf\xda\x40\xa0\x6d\xf3\xcb\x97\x4f\x8f\x9a\x40\x5f\xd1\x95\xe9\x15\x63\x5e\x93\x13\xf1\x4f\x50\xd9\x96\x91\x81\x38\xb3\xb3\xe7\xf7\xd7\x1a\xd5\x64\x69\x7d\xf9\x88\x08\xa7\x10\x89\x73\x31\x2b\xe9\x28\x9a\xf1\xb8\x64\x18\xc7\xc1\x71\x7a\xb5\x46\xa5\x16\x58\xe6\x95\x50\x4d\x8c\x8a\x94\x46\x56\x35\x44\x26\x14\x85\xbf\xda\x94\x52\xdc\x6d\xee\x0a\xe4\x56\x32\xd2\x67\x45\x0a\x16\x6d\x42\xc7\x2b\xb0\x61\xcd\x04\x33\x4b\xc0\x5c\x77\x03\xb7\xde\x68\x71\xf0\x7d\xa1\x26\x20\xb3\x90\x82\xfd\xbb\x77\x3e\x9e\xe9\x49\xa0\xd0\x74\xae\xab\x0b\x80\x3c\x05\x67\x2d\x7e\x52\x2a\x97\x04\xb2\x0d\x3f\x95\x3c\x45\x52\xca\xf5\xfd\xbe\xdc\xb4\x2f\x5c\x3a\xb5\x27\xa1\x19\x6f\xec\x4e\xf7\x08\x14\xb9\x2c\x19\xd6\x5f\x10\xd9\x16\xd8\xa9\x89\xf7\x76\xa8\x56\xaf\xa4\x2b\xe5\xfc\x6d\x19\xbc\xb7\x9e\x2c\xd2\x94\x91\xb0\x15\xdd\x78\x84\xea\xda\x23\xc4\x75\xfa\xf5\x66\xb5\x16\x24\xe2\x17\xe0\xb9\xd6\xbe\x0d\x3d\x48\xf6\x14\x2a\xd7\xdc\x6e\xe2\x31\x01\xe4\x73\x81\xec\xc6\xb7\x2c\x1b\x5c\x1b\x4a\x95\x10\x79\x9d\x69\xf2\xbc\x9f\x90\xca\x5b\xc3\x55\x3b\x66\x59\xd2\x0e\xfe\xea\xf8\x98\x3b\xaa\x2a\xeb\x58\x74\x37\x42\xde\x49\x27\xd2\xaa\x4d\x85\x11\x72\xa0\x34\x62\xc8\x20\xca\xd0\x89\x22\xf8\xa1\x0a\x13\x8a\x80\xb6\xc5\xd7\x6f\x87\x02\x51\x2e\xe1\xc7\xf3\x17\xcf\xc9\x6b\xe7\xcb\xb1\x43\x13\x37\x34\xd7\xf3\xeb\x6f\xba\xeb\x75\x77\xea\x89\xde\x2c\xea\x32\x61\xfc\x16\x48\x86\x06\x2c\x6e\x01\x75\x5c\x48\xce\xcd\x83\x81\x94\x89\xa2\x1b\xa4\x0b\x97\x01\x0e\xed\x82\x91\x57\xdd\xc4\x57\xe7\xd6\xa1\xb6\x52\x82\xc6\x4a\x05\x69\xd3\xc8\xcb\x2d\xb5\xb9\x5e\x73\x5b\x8c\xe2\xf5\xd7\x0a\x82\x51\xe0\x15\x2d\xd4\xe3\x32\x90\xeb\x0d\x57\x1d\xd8\xc2\x39\x23\x7b\xa8\x1c\xbb\x84\x78\x14\x54\x53\x05\xae\x88\xfb\x74\x85\x4c\x11\x19\x52\xa1\xa9\x47\x24\x1a\x8a\xd8\xbd\x70\x6b\x2e\x11\xa9\xcc\xa5\x50\x6c\x88\x99\xa1\x32\x0d\xcd\xe8\x81\x88\x1b\x72\x19\x91\x35\xfc\x8d\x4a\xc2\x4c\xff\x30\x44\x47\xb8\x2c\x85\xd5\x28\xca\xde\x88\x58\xba\x50\xc9\x65\x26\xd8\x8a\x50\xee\xc5\xa5\x40\x8a\xd6\xb8\xf0\xd2\x08\x9d\x40\x54\x7b\xdd\x00\xbf\x2f\xa4\xb0\xac\xae\x96\xf7\xde\xa0\x4a\x87\xef\xd2\x14\x53\xc1\x9f\x37\x50\x00\x88\x6a\xb8\x57\x1b\x1e\xe9\x62\x01\x6d\xe0\x0c\x9f\x71\x29\x1c\xd3\x03\xa8\x70\x89\xcf\xb9\xd0\x72\xb8\x7d\x2e\xdd\x32\xab\xf5\xa5\x42\x08\x78\x57\x79\x2d\x36\x68\x04\x56\x77\x57\x8c\x33\x4f\x82\xcb\xe7\x5c\x5e\x5a\x65\xbc\x59\x0e\x70\x99\x70\xa6\x28\x84\x67\xba\x24\xde\xc0\xfb\xbb\xb6\xd4\x70\x53\xc5\xec\x69\x25\x47\x67\xec\x62\xe5\x1b\x16\x98\x6e\xcd\x95\x93\x2d\xe6\x8d\x2a\xdd\xb9\x1e\x70\x9d\x24\x69\xf9\xd4\xc1\x95\x50\x3e\x73\x6d\x19\x9a\xd5\xe5\x44\x57\x76\x4d\xd2\xb5\x6f\x18\x0f\xe7\x56\x5d\x89\xb7\x1c\x62\xf8\x5c\x54\x1b\xf0\xd5\x9c\x15\xc6\x65\xe3\xd8\xbf\xe9\x74\x8f\x7c\x5f\x25\x59\x19\x1d\xe9\x09\x7a\x73\x9a\x9e\x4d\x23\x41\x29\x2a\xef\xcd\x18\x6c\xbd\x64\x2c\xff\xe3\xd3\xd7\xe2\x13\x83\xf6\x73\x7e\xd9\x0d\x7e\x61\x36\x28\xfb\x85\x20\xd9\xd3\xc5\x68\xd3\x66\x7c\x69\xc9\x05\xdd\xa2\xac\x6f\x58\x0a\x16\x2e\x54\x82\x13\x5f\x59\x41\xc0\x47\x58\xba\x5b\x66\xb2\x26\x83\x86\x34\xaa\xc4\xac\xe7\x02\xde\x81\x81\x5d\xc4\x4a\xdb\xa0\xd7\xde\x07\x3f\x66\x4c\xc1\x2d\xf7\x22\x35\xbd\x71\x0d\x9e\x9c\x7d\x84\x3c\x73\x2a\x0e\xb1\xe0\x28\x3c\xf6\xd5\xdf\x90\x17\xca\x97\x4c\xc7\x73\x0d\xcb\x4c\x24\xc5\x06\x36\xba\x2e\x6c\xb7\x1c\x86\xc6\x9a\xd2\xcb\x7f\xeb\xde\xd5\xe9\xab\xe9\xa2\x42\x1b\x76\xd0\xf4\xc3\x7c\x20\x11\xed\x22\x09\x57\x1a\x10\x2f\x23\x53\xc7\x46\x09\xb7\xde\xb2\x99\xd9\x70\x42\x0a\xa2\x86\x16\xa8\xa6\x81\x4f\x51\xc3\xd5\xe2\x09\xe0\x27\xb6\x3d\x22\x22\x73\x08\xa5\x9d\x44\x0d\x1d\x88\x61\xf2\x72\xbe\x4a\x84\x56\x98\x4c\x71\x88\xc5\xc5\x3a\x91\x86\x83\x1f\xbf\xd4\x85\xb8\x95\x1c\x60\x16\x81\xc9\x40\xe4\xa9\x44\xb1\x9a\xc8\xcc\x43\x45\x2f\xc4\x4a\x7e\xb8\x36\xa0\x63\x6b\x94\xdc\x0e\x0a\xa2\x44\x24\x06\x08\x2a\x97\xc2\x77\xed\x38\xd1\x08\x21\xb6\x6c\x57\x6a\x5e\x2c\x26\x5b\x4b\xeb\xbd\x96\x32\xf2\xb2\x37\xfe\x48\xe2\x8d\xa6\xea\x6a\x28\x38\xb4\xff\xf0\x01\x6a\xfd\xd9\x9f\xcc\xc2\xc4\x1d\x07\x42\xe3\x64\x7d\x7e\x1d\xa4\x98\x01\x6e\xa9\x06\xb1\xde\x34\x2c\x3f\x39\x0d\xd9\x3d\x7d\xa9\xf5\x95\xcb\x47\x7b\x06\xf9\x6c\x14\x5f\xda\x76\x7f\x23\x6f\x0e\xda\xd8\x8a\x47\x71\xa0\x6d\xdf\x0c\xef\xb0\xb3\x36\x68\x65\x9b\xa6\xbc\x0d\xd0\x08\x6d\xe7\x27\x89\x2c\x50\x61\x42\x17\xe9\x80\xc7\x76\xa8\xe4\x86\x09\x72\xab\x6b\x7f\x03\x2a\xf2\xcd\x70\xcb\xf0\x3d\x4e\x33\xad\xd4\x1a\x5a\xa9\xb4\x96\x6e\x94\xf8\x81\xc9\xdd\x77\xbe\x7e\xdf\x1b\xee\xd5\x5b\x35\x1b\x44\x56\x70\xd7\x8e\x31\x90\x96\x16\x09\x55\xe8\xdb\x0a\x17\xae\xc4\xc7\xc7\xf9\xe7\xc4\x10\x48\x27\x73\x08\x36\x81\xf8\x86\x4d\x62\xcb\x46\x89\x7c\xd3\x53\x45\x36\x87\xd7\xbe\xff\xa0\xcd\x99\x37\xb3\x5b\xc8\xd6\x40\xb7\x4e\xb8\xfd\xa6\xa1\x75\xc3\xba\x11\xf6\x17\xd5\x48\x25\x2a\xf3\x29\x62\x93\x28\x4e\x3a\xb4\x40\x3f\x3b\x5b\xe1\x59\xee\xfd\x8e\x1f\x9f\xbe\x90\x16\xcb\xaf\xf7\x33\x12\x7e\x5d\xfa\x3f\xef\x64\x39\x84\xb7\x84\x9c\xb0\x59\x6b\x2a\xa5\xb5\xaa\x55\x58\x2e\xa6\x2b\xc5\x5a\xba\xd9\x72\x13\x2c\x60\xc2\xdd\xc0\xca\x4b\x6b\x86\x31\xd8\xed\x8e\x0f\x8e\xae\x9c\x3c\x73\x72\xf4\xb1\xa7\xff\x11\x76\x8f\xed\x17\x05\xfe\x07\x83\xe9\x60\xd0\x75\xed\x76\x40\xea\x26\xf0\x91\x24\x0a\xba\x66\x82\x65\xc4\x20\x95\x4a\x2f\x28\x8a\xd2\x34\xe2\xc6\x8c\x87\xe4\x65\x17\xe8\xa8\x6e\x91\x69\x54\x1e\xbd\xad\x8e\xd0\x0d\xc3\x0f\x82\x53\xdf\x81\x8c\xe7\xf1\xb4\xcf\x3d\x0d\x36\xed\x11\xd7\xa9\xcb\xb8\x0a\x14\xb7\x1a\x96\xb7\x4a\xeb\x86\x32\x27\x6b\xa4\xda\xf6\xd0\xb1\x4d\x49\x89\x9f\x78\x52\xcc\x6e\xfa\x7d\x1e\x8f\x76\x1e\x6b\x34\xaa\x5a\x3e\x9f\xef\x2d\x16\xd6\x27\xf1\x1c\x59\xec\x50\x26\x42\x5a\x44\x7c\x56\x2e\xd5\x0d\x96\x19\x0f\xb7\x73\xd5\x63\xe6\xd7\x64\x5d\x5e\x0b\x9a\xf5\x84\x6a\xca\x8b\xa1\xa8\x68\x90\x1e\xc7\x75\xc8\x6a\x7e\xc9\x9c\x9f\xbd\x7a\xcf\xe4\xc8\x1e\x40\x30\x79\x35\x96\x4c\x3c\x25\x9c\x5f\x95\x7a\x45\x5d\x5e\x9a\x1b\x5a\x5d\x5d\x3a\x20\xfa\x4a\x25\xb2\x90\x4c\xa6\xe6\x15\x55\x5b\x51\x4c\xfd\x8a\x5d\xae\xf5\xd3\xc5\x3c\x8a\x0c\x3f\xcf\x1d\xd0\x25\x5f\x1e\x66\x72\x20\xca\x23\x06\x17\x2f\x9f\x99\xb8\x7c\xf1\xe9\x63\x95\x46\x59\x54\xf4\x08\xdd\x9b\xbd\xb9\x7e\x18\x1b\x98\x80\x44\x22\x3d\xe2\x3a\x8e\x6b\xa6\xd3\x5f\x77\xab\xb6\x55\x2b\x56\x12\x76\xd3\x36\xc4\x33\x42\x42\xf6\x53\xf1\x64\xd5\xad\x3b\xf4\xea\x95\x73\xe3\xfd\xdd\x43\x61\xe2\x97\xc0\x59\xaa\xa6\xcd\xb8\x4d\x87\xe2\x4d\xd6\x6a\x8b\xeb\x32\x6f\x91\x18\x73\x78\x2a\xf0\xbd\xb4\x0f\xc2\x0a\x1d\x6d\x3b\x1c\x69\x92\x52\x4d\x31\x94\x6b\x92\x25\xe5\xdb\xfa\x07\xdf\x5a\x04\xa4\xe3\xad\xdf\xf4\xef\x11\xce\xae\x27\x4a\xbe\xd5\x97\xcd\x90\x49\x54\xcb\x15\xa5\x78\x6d\x49\xaf\xaf\x17\x52\x6e\xbd\x99\x08\x3c\x4f\x17\x31\xb1\xc9\x78\x26\x1f\x4b\xaa\xab\xf9\x95\x85\x44\xa5\xb0\x3a\x78\x6c\xe7\x51\x61\x09\x17\x31\xc4\x15\x45\x55\x4f\x05\x28\x09\x32\xf1\x18\x81\x78\x3b\x4a\x84\xd9\x4e\x10\x15\x1a\xe3\xf9\xb5\x85\x03\x7e\xe0\x69\x08\xf8\x53\x12\xa1\xfb\x0d\xdd\x02\x55\xd5\x2f\x18\xf1\xe4\xa7\xfc\x7a\x53\x2e\x5c\x9d\x43\x0d\x1d\xc1\x8c\x2c\x07\x19\xa9\x2b\x4d\x2d\x87\x36\x9a\x0d\xef\xc4\x89\xaf\xdc\x79\xf7\xd1\x57\x70\xf1\x6c\xbd\x00\x41\xb7\xcf\xf3\xd3\xd3\xa7\x6f\xbe\x32\x73\xf6\xa5\x85\x72\x21\x8c\x1d\x46\xbc\xcf\xe6\x96\x66\x60\xf7\xf8\x7e\xd8\x35\xb6\x5f\x01\xcf\xbd\xcd\xf7\xdc\x3e\x49\x33\x3e\x82\xf7\xa7\xf9\xb5\x56\x81\x6f\x68\x55\xd1\x32\xd6\x9a\x31\x24\x77\x7f\x9f\x67\x35\x46\xa2\xac\x4f\x68\xae\xac\xce\x1c\x69\xb5\x1a\xa9\x99\xf9\x8b\x2f\xa9\x37\x2b\x90\x46\x5a\xd8\xb5\x63\x2f\xa4\x92\xd9\x92\x2c\x29\x4f\x12\x45\xfd\xc7\x9d\x53\x3b\x50\x3e\x97\x16\x2b\x95\xaa\x81\xcc\x20\x9e\x8e\x27\x0b\x99\xee\xf8\x52\x7e\x6d\x31\xbd\xb0\x70\xe5\x4d\x7b\xc6\x0f\xf4\x8b\xb1\xa2\x1c\xfd\x9f\x54\x56\xae\x36\xaf\xcd\xa7\x0b\x85\x52\x05\x69\x95\x48\x8a\xcc\x86\xcc\xb1\xac\x9f\x75\xf4\x7a\xb5\x46\x9f\x3e\xf3\xe8\xfd\xf7\xdc\xfc\x4a\x2e\x9e\x3b\xde\x9b\x80\x46\xe5\xe9\x2b\x67\xef\x98\x9e\x3b\x77\x5f\xa1\xbc\x0e\xb6\x13\xde\x1b\x57\x97\x67\xc2\xe4\x37\xbc\x3f\x0d\x7c\xef\xee\xa0\xee\x0d\xe3\xbd\xfd\x09\x71\x03\x93\x37\x5a\xd5\x48\xed\xd9\x4c\xee\xa3\x8c\x72\xbd\x9c\x91\x24\xc3\x1f\x67\x4a\x6d\xd4\x57\xdb\x16\x63\xf1\xe0\xdd\xeb\xf3\x3a\x98\xa8\x2b\xc3\xa1\x07\x95\x90\x6e\xb9\xa4\x3e\x56\x27\xad\x05\x21\xb0\x04\x1d\x48\x92\xd8\x22\x59\x6c\x49\xce\xc3\x7a\xaa\xa1\x39\x80\x89\x04\x3e\x2a\x0c\x9c\xf8\xce\x41\x55\x4c\x16\x41\xe4\xd7\x3b\xfc\x49\x27\x12\x8b\x85\x36\x05\x5f\x24\x2d\x0b\x0b\xb0\x06\xe1\x1a\x15\x31\xe3\x28\x74\x41\x53\x7c\x6e\xd7\xed\x30\xa9\x4d\xd2\x11\xf6\x2a\xa8\x30\x55\x53\xf0\xd8\x89\x47\x0d\x2f\xef\x04\x71\x1e\xa3\xfb\xee\xee\xff\xc0\x33\x9f\xfc\xda\xff\xb8\x67\xa4\x1b\x12\xa9\x38\x98\x86\x0a\xfe\xcd\xfb\x42\x1e\xaa\xaf\x16\x81\xaf\x15\x01\x81\x18\x90\xe9\x05\x54\x87\x8a\xe0\x94\xeb\xe0\x9a\x06\x28\xfd\x5d\xd0\x83\xe3\xb8\xf2\x95\x13\x5e\xab\x54\xf9\x6f\x19\x36\x36\x7f\xec\xc1\x57\x85\xd6\xf7\x47\x6e\xfc\x5d\x81\x48\x11\x24\xe8\x10\xda\x3a\xfd\x88\x89\xf9\x0e\x83\xc0\x41\xbe\x22\xdc\xea\x22\xe3\x0f\x71\x01\x91\xc5\x1c\xe1\xe7\x22\xb1\x05\xe1\x04\xc5\xb5\x24\x21\x10\x14\xb7\xc9\x24\x51\x59\x03\xc2\x3a\x17\x22\xf8\x30\xb4\x6c\x4b\x61\x25\x0a\xe8\x1f\xcc\x40\x6a\xa4\x0b\xce\x5d\x2d\xc1\xe2\x95\x0a\xf4\xe4\x34\x50\x83\x06\x5e\xcb\x0d\x4d\xfa\xd5\xcc\x12\x0c\xaf\x0c\x83\x9a\x97\xe1\x1a\x5f\x00\xa7\x0b\xf1\x52\xa2\x07\x62\xb4\x1b\x99\x23\x21\x4e\xb0\x0e\x65\xbf\x89\xf7\x19\x03\xd9\x57\x81\x79\x3e\x28\xaa\x1c\x49\xe5\xe7\xa9\xe0\xd3\x20\x2c\xae\x00\x3f\xba\x5b\x57\xe3\x36\x12\xcd\xe3\x15\x3f\x18\x33\x28\x29\xa2\x2c\xbd\x68\x33\xda\xad\x71\x86\x38\x91\xe4\xe4\x80\x20\x5e\x25\xeb\xe2\x9e\x3d\xe7\x0a\xa5\xc1\x79\xb6\xee\x38\x2d\x88\xbc\x0f\x72\xb7\xbd\xb4\xe6\xf1\xe2\x43\xff\xc0\x73\xdd\x39\x85\x65\xd3\x84\x59\x1a\xe1\xd9\x71\x85\x25\xb2\x12\x4b\xa4\x08\x77\x1a\xdc\x5f\x7b\x24\xa8\x20\xc8\x7a\x98\xc8\xfe\x63\x2d\xdf\x69\xc2\xe2\x0b\x23\xcd\xfe\xc5\x84\xd5\xca\x34\x0f\x2b\x19\x7d\x3f\x3f\x38\x01\x5e\x6f\x9a\x29\xc7\xcf\x0a\x7a\xcd\xc0\xc8\xc4\x08\x54\x2a\xf5\xd6\xe9\x2b\x97\xeb\xa5\x99\x33\xc9\x44\x5f\xed\xf9\xd1\x2a\xcd\xf8\x84\xf7\x33\xd5\xcf\x79\x16\x4e\x13\x04\xbe\xbc\xee\xe4\x79\x99\xe7\x55\x06\xeb\x48\x92\x8d\xc0\x0b\x42\xba\xe0\xc8\x99\x8d\x26\xf2\x52\xa4\x5d\xd7\x62\x9b\xa1\xf2\x61\x38\x11\x12\xa4\xac\x90\x7a\x32\xcd\xe9\x6a\x09\x64\x4d\xe7\x20\x2a\x58\x0d\x76\xa5\x03\x64\x26\xfc\xd4\xd2\x7c\xac\x41\xfd\xc2\x70\x03\xea\x66\x00\x89\xf5\x0c\xae\x03\x09\x64\xe6\xdb\x4b\xcf\x90\xa0\x3a\xd7\x54\xcc\x14\x85\x3a\xf7\x79\x6b\x86\x07\x4b\xb3\x1a\x0b\x9a\x14\xd5\x38\x99\xc7\x0d\xe1\x0d\x47\x45\x29\x91\x02\x91\x42\x9f\xa1\xd7\xeb\x00\xf2\x4f\xc0\x4f\x90\xfb\x13\x77\xc1\x47\xf6\xbc\x06\x9e\x18\x7f\x9c\xcc\xea\x8f\xc3\xd3\x79\x13\xc8\xef\x33\x18\xe2\x2a\x19\xe8\x92\xa0\x9c\x3c\x09\xc4\x64\x32\x94\xa9\x2a\x0c\x25\x32\x55\x34\xb1\x08\x85\x57\x82\xe2\x32\x9e\x3d\x83\xb4\xee\xd6\x14\x6b\x7f\x32\x08\xaa\xa8\x1b\xb9\xc2\x4d\x11\xc6\xed\x09\x54\x86\x68\x1b\x1f\x94\xae\xfb\x46\x43\xe3\x7d\x49\x95\x69\x3c\x49\x1a\x9e\xc7\x64\x09\x19\x89\x14\x30\x81\xca\x69\x88\xa4\x3a\x71\xe4\x2c\xca\xdc\xc4\x8b\x50\x15\x15\x8a\x66\xc4\x24\x55\xc4\xc3\x8a\x1a\x42\x28\xab\x37\x8d\xcb\x40\xe4\x25\x89\xe0\x58\x4a\x3b\xa2\x9f\x0a\x56\x10\xf5\x44\x61\x6b\x10\x4f\x18\x06\x20\x92\xad\xc4\xf7\x82\x07\xf0\x4e\xbe\x05\x15\xb1\xa9\xa4\xcd\x8b\xc2\xef\x56\xd7\x0b\xfa\x95\x79\xaf\x6b\x71\xcd\x1d\xdc\x37\x14\x3f\xd2\x93\x6e\x98\x5f\x7e\xb4\x0b\x2a\x5e\x0a\x7e\x28\x76\x09\x72\xfa\x12\x9e\x79\x00\x0a\xf3\x79\xd0\x5a\x0e\x18\x69\x64\x02\x09\x13\x16\x9e\xbc\x04\x9e\xa8\x1d\x37\xb7\x8a\x00\x00\x40\xff\xbf\x0b\x27\xae\x56\x3c\x55\xd9\x08\x21\x6d\x03\x3f\xb2\x99\xbe\xd3\x66\x47\xb0\x91\xd2\x43\x3a\xbe\x3d\xb6\x99\x38\x45\x79\x27\x0d\xb4\x8d\x9a\x37\x32\x1b\x36\x2c\x72\x91\x79\x73\x23\x2e\x75\x23\x29\x7a\xc3\xc7\xcf\x49\x3b\x1c\x3f\x9a\xdf\xb0\x1f\xa1\x6f\xd4\x1a\x75\x6d\x6e\xb1\x9e\x59\x58\x90\xf6\x3d\xf0\x7f\x0d\xbf\x66\x64\xaa\xac\x1f\xff\xec\x09\xe8\x22\xb3\x20\x3b\x2b\xc0\xf5\x0c\x28\x3d\xc7\x20\xd9\x85\xf7\x0e\xe4\x75\x97\x2f\xce\xc8\x3b\x26\x8d\x07\x37\x21\x20\xeb\x80\xd8\x30\x86\x77\x03\x52\x92\x0d\x10\xbc\x65\x83\x99\xf6\xe7\x9b\xac\x98\xc2\x26\xe0\xdd\x4c\x78\xe5\xd7\x85\xb4\x6d\x04\xd9\x8a\xf0\x0c\xdb\x71\xe5\x46\xcb\x56\x9a\x2b\x74\x82\x0f\xf5\x1d\x4e\xe4\xba\x07\xf1\xc9\x3b\x73\xa7\x2e\x56\x77\x4e\x29\x7f\x4c\x69\x5b\x25\x87\x4d\x7b\x0b\xdf\x82\x74\x39\x7f\x16\x16\xee\x24\x9c\x73\x02\x5b\x73\x72\xf9\x16\xc4\xbb\x25\x4d\xa2\x13\xe3\xbb\xa9\xed\xba\x9e\x54\xad\xb6\xf4\x52\xd1\x8b\x57\xab\x7e\xaa\xd9\x62\x71\x04\x9b\x61\xda\xb4\xac\x48\x7e\xbe\x50\x56\xbb\xfb\xfb\xe0\xd6\x43\x77\x5e\x5a\x5d\x5f\x4f\x2c\x2c\xcd\x67\x9f\x3c\x77\x5c\xc4\x95\xe2\xa2\x94\xb6\x84\x33\x6e\x71\xa3\x88\xb4\x3f\x5c\xdc\xb9\x64\x17\xdf\x31\x38\x39\xd0\x93\xed\x07\xdf\x65\x3b\xcc\x98\x7a\x0a\xd7\xc2\xba\xdf\xa0\xbd\x86\x15\xcc\x74\x34\xa1\x76\x8e\x1e\x61\x9e\x14\x77\x6c\x0f\xc1\xa9\x17\xed\xab\x83\xb8\xf6\xea\xec\x95\xf1\x66\xab\x61\xae\x17\x0a\x23\xba\x66\x20\x58\x4a\x43\x2a\x9e\x81\x98\x15\xcb\xab\x9a\xb2\xa4\x1b\xea\x35\xa7\x16\xf4\xa1\xa0\x68\xa8\x2a\xa9\x0a\xa1\x1a\xe0\x72\xc4\xeb\x29\xcc\x55\x72\xbe\xc4\x45\xf6\x16\x54\x6b\x15\xf5\xfc\x95\x67\xf6\x96\xcb\xc5\x7e\xec\x2f\xdc\xc8\x00\x9f\x47\xb8\x89\x81\x60\xfc\x1a\x2e\xca\x23\xfb\x6e\x0d\x01\xaf\xa8\xf7\xda\xaa\x37\xa6\xe2\x4a\x7c\xcd\x6b\xb1\xa4\xef\x39\x05\x59\xd4\xad\x71\xd4\x94\x90\xb7\xe7\x2f\x9f\x19\x07\xd7\x17\x89\x8f\xc0\x7c\xd6\x87\x73\xa5\x3c\x73\xee\xc4\x8d\x4f\x9f\x7b\x62\xd4\x43\x81\x22\x5c\x95\x73\x08\x2e\x86\x7b\x77\x00\x82\xe2\xe1\x44\x2c\x39\x8c\x58\x6a\x40\x8b\x5b\xc7\xb9\x1f\x4c\xd4\x2a\x8d\x44\x4c\x8b\xe5\x98\x16\x50\xc7\xb1\xd5\xc7\x9e\x78\xf8\xa8\x5d\x6f\x74\x57\x1a\x55\x68\xd8\xf6\x86\x20\x9a\x41\xf0\xb5\x52\x58\x82\x89\xa1\x9d\xb0\x77\xcf\x91\x06\xa5\x52\xbc\x5e\x6f\xaa\xf8\x7d\x06\x27\xc7\x42\x72\x55\x62\xb1\x54\x33\x33\x90\xf6\x5b\x8e\x9d\xab\x94\xd6\x87\x76\xee\xbb\x4d\x12\xae\x4f\x89\x48\x9e\x99\x4c\x96\x91\xd3\xa5\x35\x3d\x5e\xf3\x6a\xce\xae\x80\x3b\x3a\x69\xfb\xb8\xa4\xd0\x4e\xd0\x61\x19\x21\xe1\xe6\x02\xce\x47\x15\xaa\x5d\x51\x4c\xa5\x12\xba\xee\x29\xd9\x9a\xa7\xd4\x81\x3a\x1b\xf5\x0a\x22\x5d\x6e\x6b\x94\xf4\x26\xb5\x0a\x6f\x80\xef\xd2\xa4\x66\x48\xfd\xb2\x2a\x8d\x49\x0a\xed\xc5\x0e\xe3\xe2\x39\x8f\xef\x1c\x2b\xeb\x96\x92\x5b\x3c\x7f\x75\xaf\xae\xeb\x34\x16\x4b\x84\x71\xe1\xb2\xa9\x5f\xd6\x2d\x2d\xd7\xa1\x56\xcf\x73\xb5\xa5\x85\x6b\x93\xbe\xef\xf1\x8b\x97\x4e\x1f\x16\xdb\x5a\xbb\x08\x4c\x1b\xad\x3a\x17\xa5\xf0\x14\xfc\xcd\xf8\xf0\x2e\xf7\xc0\x81\xa3\x73\x66\x42\xef\x6a\xb4\x1a\x84\xd4\x9c\xb4\x70\x79\x28\x54\xf2\xac\xb4\xd2\x45\x74\x22\x3f\x7d\xe9\xf8\x41\x42\x89\x25\x2b\x0a\xf8\xa2\xbc\x15\x85\xca\xec\xec\x33\xbf\x74\xfa\xe2\x53\x5a\xa5\x5e\xe5\xae\xe7\x6c\xd0\xb0\xef\x06\x70\x7e\xe6\x2c\xe4\xd2\x3d\xd0\xd7\x35\x20\x9e\xc5\xa4\x69\x28\x93\xa8\xd8\x54\x7b\xba\xe3\x55\x59\x91\x5b\x82\x6e\xdc\x96\xab\xf8\x35\x96\xe0\x2e\x9f\x0c\x24\x57\x53\x10\xf4\x5c\xb9\x7a\x7e\x4f\xa5\x50\xb8\xb5\x56\x2b\x69\x33\x4b\xd3\x50\x6f\x36\xc2\x1a\x1b\xe2\xb9\x66\x12\x19\xc8\xa6\xba\x72\x88\x00\x5f\x21\x53\x16\xd3\x13\xd6\x93\x23\x53\xc3\xd2\xb5\xe9\x6b\x2d\xd1\xdd\x9e\x5d\xbb\xd6\xcd\xa4\x9e\x5b\xba\x38\x7b\x93\x22\xcb\x43\x62\xca\x3d\x04\x4a\xba\xae\x0e\x9a\x71\xbd\x18\x10\x67\x5f\xad\xc9\x3c\x04\x90\x14\x05\x97\x17\xeb\x92\x7a\x88\xa9\xaa\x4f\x3d\xf3\xf4\x31\x2a\xee\x4d\x56\xa2\x3a\xc5\xc0\xf2\x33\xb3\x67\x7f\xfd\xcc\x85\xa7\xf4\x72\xbd\xc2\x5d\xd7\xdd\xb8\x37\x51\xf6\xe8\xdc\xf4\xd3\xd0\x95\xee\x86\xbe\xee\x01\xc1\xcb\x27\x0d\x85\x0c\xa2\x72\x60\x8d\xf4\xc7\xfa\xe2\x29\xb5\x11\x84\xb1\xdb\x38\xea\xa6\x02\xb5\xf9\xa0\xa7\xa6\xd5\xf7\x7a\x4a\xcb\x12\xce\x7b\x51\x1a\xf1\xc2\xe5\x33\xb7\x23\x98\x4f\xd7\xeb\xd5\x9b\x0c\x54\x12\x53\x09\xb1\x1e\xb3\x60\x98\xd6\x55\x54\x5a\xce\x48\x9a\xfa\x38\x58\xde\x4b\x72\x9a\xf6\x68\x3c\x6d\x2c\xb9\x61\xb6\xa3\xb0\x82\x87\x5e\x85\xb6\x13\x90\x87\x49\x8d\x82\x9a\x28\x89\x42\xe7\x3d\x2e\x8b\x2a\x4e\x3c\x4c\x12\x0c\x93\x29\x85\xcd\x48\xd8\x86\xf1\x9e\x84\x85\xc5\x47\x2e\xe9\x0a\x40\xee\x82\x8b\x20\x52\x16\xe5\xc9\x7c\x71\x82\x8f\x20\x0d\xd5\x37\xbb\x09\x32\x82\x05\xa9\x2e\x83\x23\xbb\x48\x7f\x0d\xae\xca\xba\x5b\xa1\x6b\xc5\xe3\xab\x5f\x9a\x4f\x9e\xbb\x3f\x37\xb4\x37\xfd\xaf\x3f\xfb\xdb\x1f\xf9\x99\xa3\x6f\xbc\xeb\x86\x9e\xc3\xfb\x11\x0f\xc4\x80\x36\x6c\xd0\x05\x38\x95\x14\xd0\xb1\x2f\xb5\x56\x07\xd4\x8a\x40\xb5\x9d\x10\x14\x33\x04\x1f\x17\x66\x17\x61\xe1\xd2\xcc\xdf\x0c\x7a\x53\x67\x12\xe7\x0f\x5c\x7e\xfc\x8e\x3f\x11\xf5\x22\x40\x67\x61\x62\x68\xb8\xbb\x00\x63\x0d\x28\x54\x48\x18\xdf\x1e\x84\x72\x11\x31\xb1\x22\x42\x26\x04\x1d\x3b\x38\x56\x21\x12\x65\x04\xf6\x08\xca\xe5\x30\x4d\x15\x3c\x9c\x02\x05\xaf\x4b\x44\x65\x1e\xbc\x07\x49\x58\x77\x51\x58\x7a\xb8\x34\x1d\x5c\x7e\x1e\x8e\x6d\x60\x32\x03\x53\xb7\xec\x83\x0b\x1f\xbf\x44\xe6\x2e\xd9\xd0\x35\x8a\xc0\xa9\x56\x43\xc0\x55\x03\xae\xea\xc4\x72\xfa\xa1\x16\xc3\xd5\x8c\x58\xd9\xf2\xbb\x51\xd8\x2a\x44\xb6\x45\x36\x7d\x99\x37\x89\x44\x5c\xa2\x86\x8a\x85\x8c\x2b\x5e\x52\x70\xb4\xaa\xd4\x71\xe4\x3c\x7f\x38\x0a\x83\xdd\x0a\x27\xdd\x9a\x0a\x64\x1e\x07\xb8\xe4\x72\x18\x37\x29\x24\xf0\x8b\x5d\x88\x08\x93\x08\x89\x2c\x7c\x66\x3b\x65\x26\xe8\x81\xcc\x23\x57\x74\xe3\xee\xd7\x34\x26\x37\xf8\x16\x15\x38\xc9\xb3\x4b\x41\x91\x7c\x71\x65\xb9\xa4\x71\x12\x0c\xee\x18\xb1\x48\x76\x08\xef\x15\xaf\xdf\xa8\x07\xde\xd3\x4f\xb9\x95\x4b\xa7\x5a\x0b\xab\x0b\xfe\xa3\x72\x5c\x7e\x9a\xa5\xbc\x7f\x7a\xd7\x57\xdf\xce\xb4\xba\x12\x63\xd5\xdd\xa3\xdc\x70\x3c\x50\x1b\x36\xf7\x6f\x3a\x80\x0a\xca\x3a\x25\xad\x26\xf0\xae\x5c\xca\xbb\x33\x79\x90\x9c\xbb\x9c\x53\xcf\xad\x1c\x77\xba\x63\xab\x5b\x7f\x1e\x34\x6c\x4b\xf7\xe4\xa3\xe5\x49\x69\x7c\x79\x37\x63\xad\x18\x62\x36\x54\x8f\x55\x9b\xf7\x1a\x45\xee\x64\xe7\xa1\x18\x5f\x26\x57\xa4\x80\x5e\x43\x94\xe8\xf9\x34\xaa\x42\x27\x37\x91\xcf\xcb\x28\x57\xb4\x4d\x61\x1c\xc8\x72\xc1\x5a\x58\x1a\xf0\x63\x31\xb9\x81\x60\x57\x44\x79\x6a\x8a\x42\xa8\xdb\x02\x3e\x31\x92\xa3\x2b\x4e\xb1\x61\x07\x15\x5c\x3b\x51\x46\x38\xaa\xa3\x48\x27\xb2\x2e\x8b\x9c\x0c\xc5\x73\xdc\xc0\x73\x97\x7d\x70\x53\x91\xff\x22\xac\x24\x81\x97\x33\x91\xde\x4c\x89\x81\x2a\x76\x67\x53\x2c\x70\xcb\xab\x10\x37\xae\x7f\x44\xf2\x07\xe0\x03\xfc\x37\x5b\x0b\xe4\x63\x73\xeb\xf0\xee\x67\xee\xe5\xc6\xd0\x39\x72\x76\x4a\x02\x7d\x62\x10\xa4\xa5\x55\xde\x5c\x28\x13\x5e\x8c\xa1\xc6\x15\x20\x68\x0c\xda\xe0\x31\xf0\x45\xd4\x8f\x88\x1b\x85\x04\xe1\xe7\x9e\xe1\x70\xf6\xd2\x25\xeb\xf6\xfd\xc3\x12\x6b\x7b\xa2\x3b\xfe\x65\x11\x41\x23\x2a\xb6\x59\xc8\x69\x62\x2c\x41\x98\xd3\x4d\x95\x15\xa0\x25\xec\x8f\x2b\x1a\x51\x2d\xb1\xad\x06\x8a\x18\x85\x8a\x16\x9e\x2d\xfe\x92\x28\x0d\x95\x88\xa0\x6a\x4d\x8f\x02\xc0\xc4\x46\xca\xc8\x77\x04\xbe\xf5\x54\xc3\xe0\x81\x88\x3d\x0a\x93\xb5\x45\x1a\xa1\x24\x2a\x17\x20\x4f\x64\xed\x24\x90\xc8\x81\xc5\xda\x47\x14\xb0\x2e\x45\x6e\x10\xa1\x31\x07\xd0\x4e\xcf\xe7\x51\x1d\x01\xce\xa2\xd0\xa1\xd0\x10\xdb\xa0\xb6\x5d\xd3\x3d\xcf\x36\x56\xaa\xf9\x6b\x66\xac\xef\xe0\x81\x5d\x05\x28\xd7\x9a\x02\x7c\x80\x9a\xce\x81\x6b\x07\xb0\x76\x66\x1a\x86\x6f\x9c\x00\x13\xb5\x93\xc2\xd5\x25\x68\x35\x1b\x50\x5d\xba\xf6\x3f\xf6\xdd\x24\x7f\x54\xd3\x90\xc2\xb9\xd3\xce\xbb\x09\xe7\x2a\xcc\xce\xe5\x7c\x23\x37\xa3\x53\xf0\x63\x4b\x14\x7d\x94\xd2\x23\x34\xf8\x48\x6e\x0b\x63\x2e\xa7\x8c\x6f\x8a\xd6\x8d\xc4\xd4\x36\x32\xdb\xb2\x89\x61\xfb\x9c\xcd\xd0\xca\x4d\x2b\x2c\xb9\x4e\xac\x22\xe7\x47\xb0\xdb\x50\xaf\x2d\xae\xa4\xf2\x0b\xc1\x0d\x2f\xbf\x6f\xe8\xfe\x7b\xde\x44\xcd\xfa\x9a\x07\xfd\x8f\x7e\x15\xca\xac\x07\x60\xf2\x4e\xd0\x16\x4e\x83\x35\xff\x20\xfc\xff\xac\xbd\x07\x94\x64\xd9\x59\x26\x78\xef\xf3\xf1\xe2\x85\xf7\x91\x91\xde\x56\x55\x66\x96\xe9\xaa\xea\xea\xae\x36\xd5\x2d\x21\x09\x81\x84\x0c\x08\x16\x24\xd0\xec\x30\xec\x98\xc5\xcd\xee\xec\x0e\xec\x9c\xb3\x0c\x73\x60\x61\x59\x0e\x7e\x18\xfc\x0c\x02\x34\x48\xa8\x85\xbc\xd4\x52\xab\x5d\x75\x79\x9f\x55\x59\xe9\x5d\x44\x66\x44\x64\x78\xf7\xfc\x7b\x77\xef\x7d\x61\xb3\xd5\x07\x58\xd8\xec\x13\x5d\x69\x22\x9e\xb9\xef\x9a\xef\xff\xef\xf7\x7f\x9f\x3c\xf6\x3d\xc0\x1b\xf0\x03\x78\x6c\xe2\x7b\x77\xd7\xb6\xec\xf1\x59\xf6\x5b\x60\xa0\x6c\x00\x74\x64\xa1\xba\x55\x01\x6f\x2b\x45\xe8\x5d\xd1\xd1\x54\x2b\x40\x83\xd9\xc9\xef\xa8\x4b\x18\xb8\x55\x72\x03\x72\x53\x66\xb2\xa5\xa2\xa7\x50\xac\x05\x25\xf7\xe2\xfb\x63\x52\x80\x8b\x4e\x8f\x90\x7e\x22\x0c\x9d\x99\x11\x1e\xfc\xe5\xd7\x7e\x78\xf6\x18\xfa\x8b\xb7\x4f\x45\x7d\x90\xdb\x95\x01\x80\x47\xcb\x42\x50\x5f\x8b\x17\x0d\xc8\xbb\x7d\x87\x0c\x6f\x67\x83\x70\x90\x03\x6b\x19\x1a\x85\xfb\x0a\x6b\xea\x4d\x97\x65\xca\x2e\x3c\x48\x38\x3c\x65\x93\x0e\x6c\xe1\x25\x08\x35\xea\x05\xb6\x90\xf3\xb2\xf1\x44\x54\xff\xe8\x7b\x3f\x78\x73\x69\x75\x69\x78\x2f\x9b\x09\x6e\x6c\x6d\xc4\x09\x00\xf9\xbb\xbe\x1a\xad\x06\xc8\x97\xb2\xe0\xd9\x27\xde\x05\x62\xe1\x24\xab\x34\xd4\x53\x94\x87\x7f\x03\xcf\xc0\x82\xa9\xd8\x78\x59\xb1\x65\x22\xc7\x84\xc7\x03\x6b\xe9\x42\xc2\xa4\x34\xbf\xf3\xb9\x66\x83\xcf\xe4\x32\xd3\x18\x5c\x8f\xe6\xcb\x07\x80\x80\x48\x22\x7d\x44\xc6\x94\xc0\xf1\xe0\xdc\xc2\x33\x40\xe4\xc5\x88\x66\xe9\x11\x0c\x38\xdd\xa2\x9b\x5b\x36\x35\x14\xc5\x08\x4b\x21\xf4\x0c\x45\xd6\x04\xca\x16\x23\x9c\x97\x54\xf0\x02\xf0\x68\xfd\xe1\xe8\xd2\xe3\xfb\x27\xc9\x73\x6a\xca\xb2\x93\xcd\x33\xed\xa3\x51\x33\x71\xeb\xda\x4c\xaf\x38\x60\x9a\x8c\x7a\x9f\xdf\x93\xe5\xf0\x2a\xd1\x6a\x35\x18\xb3\x21\xc7\x04\x17\xaf\xbb\xd8\xa0\x87\x66\x6d\x46\x6e\xd5\x25\x42\xd8\xc3\x73\x08\x79\x71\xbb\x5b\xab\xef\x5d\xdd\x78\xe0\x56\x54\x05\x83\x8a\x7e\x9b\xac\xed\x3e\x06\xb9\x42\x06\x3c\x83\xef\xdf\x6d\x79\x86\x18\x06\x4e\x8a\x92\xb0\xe3\x63\xd9\x14\xef\xb6\xad\x6a\xbd\xea\xbe\x7c\xed\xd5\xa7\x5c\x9c\xe8\x3e\x94\x2b\xce\xd2\x39\x3f\xb7\xb0\xf3\xc4\xe2\xf9\x0d\x4d\x57\x98\xbd\xfd\xdd\x08\xb9\x67\xaf\xe4\x35\x12\x89\xd0\x1e\x19\xfc\x5a\xa3\xec\xa5\x91\x29\xb2\x8e\x2e\x14\x40\x13\x23\x89\xb2\xc8\x23\x7a\x6d\xe3\xd1\x08\x06\x0f\xac\x4f\xf2\x39\xd9\x2f\x97\xdb\x75\xe8\x11\x69\x8b\x85\x9c\x65\x58\xf5\x71\x9a\x6d\x0f\xa1\xd5\xb5\x47\xe3\xaa\xae\xb2\x87\xd9\xdc\xcc\x50\x64\x84\xf5\x63\x20\xc6\xd0\x1c\x10\x3d\xe2\x9a\x37\xec\x79\xc8\x22\x3d\x15\x09\x08\x72\x97\x58\xd4\xd5\x77\xea\x6e\x52\xb4\x65\xa5\xba\x54\x5e\xaa\xaf\xff\xd4\x8d\x45\x3b\x41\x8c\xdc\x54\x78\xbb\x05\xfd\x55\x1e\xc7\xd6\x1c\x0c\x98\x1c\x91\xcd\xa4\x19\x9e\x75\x59\x93\xb3\x49\x4d\x90\x38\xd7\x4e\x66\x6d\x36\x16\x8e\x93\xe9\xd2\x49\x10\xe3\x39\x52\x52\x9a\xc5\xd3\xf9\xc3\x5c\x20\x9d\xde\x4d\xb5\x88\x7a\x4c\xb3\xdc\xb3\xaa\xee\xf6\x71\xc1\x25\x98\xcf\x9e\xbb\xb4\x22\xb9\x44\xfd\xcc\x99\xf3\x9b\xe4\xd4\xb6\x6d\xfb\x6a\x1b\xb9\x00\x03\x0d\x2f\xee\x2d\x4c\x24\x14\x51\x12\x93\x6e\x55\x96\x65\x6e\x7b\xef\xf1\xd9\x60\x20\x40\x37\x94\x0a\x28\xd5\xf3\xb8\x4f\x1e\x4c\x17\x2a\x39\xa0\x9a\x3a\x60\x70\x6f\x7f\xf1\xdd\xef\x5f\x9a\x18\x9b\x3c\x4c\x25\x87\x1d\x53\x8e\xff\xfc\x47\xbf\xfd\xdd\xd5\x56\xd1\x1d\x8b\xc4\x9c\xbc\x43\x38\x29\x45\x78\x17\xef\x1a\x99\x8b\x4c\xda\xb6\x49\xa4\x94\xf8\x46\x01\x05\x6c\x17\x15\x21\xdb\xd1\xe5\x4a\xcb\x7d\xed\xca\x5b\x67\x6b\xd5\x7a\xbc\x58\xc9\x3b\xfa\xc1\x6e\xaf\xbb\x79\xe1\xe2\xc5\x8d\xe7\x2f\xbe\xb0\xfc\xc6\x95\x57\x8f\xaf\x3e\x5c\x3e\x39\x37\x71\xc2\x19\x73\x9c\x40\x85\xc2\x71\x09\x7f\x36\x8c\x97\x15\x95\xc5\x81\x9c\x31\x35\x33\xe4\x81\x2c\x72\xe7\x4a\x7b\x4f\x2c\x8c\x9d\xa2\x74\x4b\x23\x5b\x7c\x7a\x6a\x22\x5a\xc2\x81\x67\x18\xdf\x5b\x98\x86\x16\x9e\xc0\x2c\x26\x1e\x8d\xcb\x91\x49\x17\x9e\xfe\x9a\xdc\x4e\x66\xf5\x19\xbf\xcf\x47\xd5\x70\x3b\x15\xaa\x59\xdc\xdf\xf6\x8f\x1f\x96\xb3\xb8\x8f\xeb\xce\xda\x70\xe9\xd2\x8b\xd7\x26\xc7\xa7\xf6\xc6\x86\xc7\x0b\x24\x7b\xf3\x7b\x7f\xf2\x5b\x9f\x28\x35\x0e\x7d\x64\x47\x98\x3c\x2c\x5f\x58\xf4\xf1\x02\x0f\x8f\x3d\x39\x3c\xe4\x92\x58\x15\x43\x6a\x50\x2f\x2a\x6c\x66\xa5\x31\x05\xa3\x6a\xcc\x8b\x58\x54\x2a\xd7\xfc\x9b\x1b\xeb\xe7\xf6\xf6\x76\x16\x72\xa5\x7d\x3c\x1e\x0d\x02\xae\x51\x7b\x3c\x0a\xe0\xc9\xc5\xe7\x80\x24\x4a\xd3\xc8\x32\xa7\xf1\x2a\x38\xe4\x8f\xf8\x5f\x13\xdc\xdc\xb9\x73\x2f\x4e\xde\x74\xc0\x95\xdd\x2b\xe2\x74\xb6\xea\x50\x97\x55\xd3\x9e\xef\x51\x7b\x7b\x9e\x14\x9e\xd9\x04\x3c\x76\xa8\xd2\x1d\x75\x12\xb2\xe6\x58\x76\x67\x8f\xb1\x4b\xf5\x75\x20\x79\x7b\x57\xc1\x26\x99\x50\xf2\x39\x42\xdb\xb5\x09\x72\x76\x32\x30\x24\x1d\xf4\x83\xf6\x29\xf0\xf0\xf1\x9a\xfd\xe6\xb5\x6b\xb9\xc7\x7b\x77\xb8\xd6\xbd\x99\xb1\x99\xe4\xdc\x57\x6f\xfd\xed\xab\xb7\x23\xd3\x3b\xff\xe2\x5d\x9f\x7c\x11\x70\x1e\x37\x00\x63\x09\xa7\x1f\x33\x77\x96\x71\x88\xed\xec\xa0\x02\xf6\xde\x63\x40\x4d\x8f\x82\x34\x5e\x2b\x1f\x5d\x5d\x7a\xe8\x71\xb9\x6e\x78\x24\xdf\x9e\x72\xea\xae\x77\x0c\x25\xda\x73\xb1\x85\x9c\xe0\x96\x5c\x23\xb9\x19\xca\xd1\x2b\x6a\x6f\xee\x3a\xb4\x0b\xaa\x4d\x0e\x22\x48\x9e\xbc\xdf\xc1\x1b\xa8\x53\xba\xec\x7c\xde\x19\x51\x64\xaf\xcf\x01\xc3\xa0\xcd\x45\x00\x5d\xb7\x1f\xe8\xe1\xc1\xd2\xdd\x0c\x7a\x70\x63\x1f\xb8\x18\x0a\xbc\x7b\x0e\x83\x61\xe5\x10\xff\x51\xc4\xd0\x49\x24\xf9\x60\xc4\x11\xed\x2b\x16\xdf\x3f\x4f\x84\x3b\x05\xe0\x6f\x2f\xa0\xbd\x6a\x5b\xce\x19\xbb\x1c\xe8\xd6\x80\xc1\x01\xaa\xfe\x51\xcc\x4b\x94\x95\x2c\x1a\xe8\xd6\xf0\x10\x9e\x34\xfc\x0c\x24\x4c\x5a\x3a\x80\xbf\x89\x30\xa4\x6c\x07\x51\x71\xfc\xc8\x71\x1c\x4b\x87\x69\x1b\x92\x8c\xc8\x4d\x8d\x82\x6b\x26\x75\x83\x72\x53\x37\x7d\x06\xe1\x86\x02\xa6\x2f\x10\xa2\x62\x90\x2f\xdc\xf6\x42\xa6\x54\x2b\xe9\xf3\xd7\xaf\xe9\x61\xfe\xbe\x81\xd7\x40\x5b\xad\x1c\x5a\xd5\x4a\x09\x6c\xfb\xfc\xf6\x4e\x38\x29\x56\x3b\x9b\x95\xd4\xdf\x27\xcf\x53\x4e\x68\x4d\xdc\x7a\x65\x33\x10\x92\x4a\x5e\x2f\xf2\xdd\x78\x08\xc5\x68\x00\xc2\x68\x08\xa1\x40\x88\xa6\xd7\x56\x91\xe5\x11\x78\xee\xd8\x89\x71\x43\xa7\x79\xd8\x6c\x5d\x85\x2c\x3c\xe8\xef\x54\x69\x51\xc5\x80\x43\xe9\x05\x84\x5a\x43\x14\x70\xe3\x68\x98\xc5\xd1\x8d\xc5\xd8\x6c\x03\xcf\xa7\xca\x98\xe6\x72\x6f\x58\xde\xe8\x32\x8e\x4f\x5b\xd4\x0a\x23\xb9\x9a\xa4\x14\xb4\x7d\x3f\x0c\x1a\x90\xba\xc3\xb0\xc8\x54\x81\x69\xe4\x85\x52\x7e\xcc\x18\x1a\x86\x4d\x8a\xa3\x28\x0c\x4a\x18\x9b\x94\x6a\x9b\xb4\xea\x82\xc1\x92\xd7\xdf\x0a\x89\x8c\x85\xb4\x02\x6b\x0a\x30\x58\x1c\x43\xae\x46\x04\x5f\xe2\xbe\x2d\xfb\xf6\x41\x9d\x31\x90\xee\xa9\x63\x3c\x28\x90\xc0\x08\x3a\x99\xca\x48\xa0\x4d\x69\xb1\x50\x77\x08\x98\x60\xa3\xd1\x3a\x0a\x78\x79\xc0\x83\x3b\x3b\x93\x68\x5d\xfb\x28\xf8\x67\x4e\xcb\xe0\x46\xbb\xff\x8e\x6d\x66\x74\x15\x0b\x5a\x6a\xbd\xae\x69\x24\xc3\xd5\xde\x26\x0f\x47\x19\x9b\xdb\xb6\x81\xa9\x59\x14\xf1\x9c\xb7\x1d\x6d\x53\x40\x39\xc5\x47\x90\x26\x71\x26\x2c\xe1\x78\xcc\x1b\x70\x43\xad\xc1\xd9\xb5\x9a\x08\x14\xbd\x8c\x78\xde\x03\xea\x16\x0f\x5d\xc0\x85\x3b\xae\x60\x23\x0a\x87\x51\x14\x49\xdc\xe2\xf8\x07\x87\x54\x16\x01\xd9\x8a\x02\x7d\xc1\xb6\x42\x06\xa9\x75\x93\x9b\x0e\x11\xe9\xa0\x52\x30\xea\x1c\xe5\x08\x71\x3b\x66\x04\x64\xb7\x87\xec\x51\xd2\x44\x7e\x8a\x26\x62\x99\x04\xe9\xb3\x50\xc0\xbf\xc0\x3f\x53\x3a\x34\x9c\x94\x2e\x61\x00\x11\xbf\x02\x87\xf7\xda\xd9\x54\xa7\x40\x9b\xc7\xe9\x0c\x27\x13\x42\xa5\xd6\xd0\x59\xba\xe5\x45\xb6\x12\xda\xdc\xb9\x75\xf7\xff\xfe\xa5\x1f\x7a\xee\x93\x3f\xa1\xfa\x7d\x94\x02\xae\xdf\xf0\xe8\x65\x66\x84\x4b\x09\x34\x98\x78\x6e\x11\xe0\xa8\x1c\x54\xb6\xb3\xa0\x55\xab\x83\x46\xee\xe0\xa5\x91\x29\xf9\x4f\x3d\x52\x40\x23\x5b\x51\xed\x12\x87\x76\x61\x56\xb7\xea\x0a\xa1\x8e\x80\x68\xbf\xf0\xa8\xc3\x75\xed\xe8\x22\xb6\x67\xb5\x1e\x07\xb5\x93\xbc\xed\xd0\x1d\x50\x9b\xcb\xda\x51\xfe\xeb\xbe\xaf\xb7\xef\xde\xa3\x4e\xa0\x9e\xd6\x6c\x27\x65\xd9\x7f\x2f\x7e\x4f\xb5\xd6\x60\x0f\x76\x73\xae\x74\xae\xe8\x1e\xf2\x4d\xcc\x3f\xf7\x21\x4a\x04\x6f\x02\xb0\x53\x35\x41\xcd\x0a\x00\xe9\xfb\xbe\x0f\xcc\x8c\x78\x30\x88\x39\x06\xea\x9f\xff\x2f\x40\x68\x6c\x03\xef\xf4\x49\x60\xe9\x06\x40\xd3\xe3\x1f\xdc\x5e\x4f\x9b\x13\xa7\xfc\x5f\x04\x83\x65\xe9\x7d\x4e\x42\x27\x83\xdd\xa7\x2b\xb4\x8b\x5f\x61\xef\xbd\x7d\xdb\x80\x7e\x69\x7b\x4f\x4d\x61\xa0\x80\x0c\xf7\x23\x3c\x49\xe0\x58\xd1\xb4\xa8\x83\x1c\x9a\xcd\x64\x55\x86\xb2\x43\xc7\x47\x9f\x3d\xc6\xa9\xf5\x26\x50\xaa\x0d\x20\x45\x03\x40\xc7\xd1\x7c\xf4\xe4\xb1\x31\x53\xdd\xa5\x59\x17\x54\xfb\x65\xb9\xa8\x2d\x4b\x36\x50\x1d\x3e\x60\x73\xde\x57\xe1\x01\x6f\x2f\xbb\x79\x07\x8d\xa1\x01\x60\xdc\x93\x22\x6d\xd2\x90\x6d\x2a\x10\xf7\x01\xd2\xef\xf1\xcb\x72\x04\x1c\xdb\xf5\x0f\x34\x6b\xda\x50\xdc\xdc\x49\xc7\x70\x1f\xa8\x8e\x8c\xa6\x9a\xa7\x17\xcf\x66\x4e\x2d\x9c\xcd\xe0\xcf\x3e\x18\x04\xfe\xe8\x1d\x64\x44\x6e\x3c\xb8\x3e\xb1\xbd\xb3\x19\x5b\xd9\x79\xe8\x23\xfc\x41\x52\xc3\x65\x98\x68\x98\x75\x09\xdb\x16\x0d\x63\x26\x30\x6a\x9a\x6c\xf2\x18\xef\x27\xa0\x0b\x31\x64\x92\x5f\x5a\xb9\x3f\x61\x69\x68\x86\x80\x36\x59\x93\xc9\x16\x2d\x72\x16\x15\x7c\x06\x92\xdd\x23\x80\xf2\xee\xe3\x6b\xe0\xf9\x73\xef\x23\xdb\xd6\xc0\x50\xcd\x51\x5f\x50\xdc\xc0\x57\x1b\xc4\x40\x43\x6d\x35\x64\x37\x0e\x75\xfd\x52\xc4\xed\xdc\xfc\x6b\x57\x5f\x3d\xb1\x97\xd9\x19\xb6\x30\xaa\x56\x9d\xcf\x9b\x4e\x03\x3e\x7b\xe1\xd9\x55\xbf\xc7\xa7\x1c\x9b\x9c\xcd\x92\xf7\xbd\x79\xf3\xad\x59\x5d\x36\x27\xba\x4d\x16\x08\xb8\x8b\xb8\xff\xf3\x9b\xeb\x99\x20\xbe\xbb\xb0\xe4\x16\x15\xef\x70\x80\xc3\x13\xa8\x2d\xcb\x0d\xc9\xc5\xb9\x60\xad\x41\x02\xc8\x0a\xb7\x95\x5e\xe5\x5a\x4a\x13\xf8\x7d\x5e\x79\x7e\xee\x44\xfa\xc2\xe9\x27\x1d\xe7\xb8\xab\x77\xae\x4d\xbe\x75\xf3\xca\xec\xe5\x3b\xdf\x04\xa7\x8e\x3d\x09\x04\x11\x63\x0a\x8c\xce\x31\x10\x05\x95\x7a\xd5\x73\xed\xc6\xab\xe7\x93\xe1\x21\xb1\x52\x2f\xe1\x80\x20\x2a\x9f\x3b\x73\x6e\x69\x2c\x35\x52\xec\x3c\x37\x7d\x7a\x6c\x78\x40\x8f\x06\x72\x7b\x3b\x5b\xc8\xd0\x9b\x01\x8e\x41\x38\x7c\x86\x0c\x06\x17\xe6\xe8\x58\x54\x91\x44\x9a\x3f\xc8\x6e\x0f\x4f\x0d\xcf\x42\x62\xde\x40\x3a\xa2\xd7\xef\x3a\x74\x0b\x4e\x7e\x89\x53\x9a\x2d\x71\x6d\x63\x6d\xf4\xc6\xad\xab\x93\x8e\x63\x19\x06\xea\x1c\xc3\x02\xb7\x20\x81\xa0\x23\x5f\x66\x81\x56\xbd\x3e\x1b\x0c\x0b\xfb\x2c\x84\xbc\xc4\x5a\x7e\x96\xa3\xb5\x6e\x6f\x1f\xe0\xc6\xf4\x37\x33\x60\x27\x3a\x1d\x0c\x0a\x3b\x71\x2f\x41\x29\xf8\x49\x88\x66\x4b\xf6\xe9\xf8\x65\xe9\xba\x1b\xda\x16\x8b\x67\x31\x38\x3e\x92\xca\xb9\xdd\xac\xb5\xb1\xb5\x96\x94\x9b\x0d\x77\xc2\x1f\x07\xd9\xc3\xb4\x93\xcd\x6c\x6d\x34\x17\xf2\x45\xbc\x12\xb4\xea\x40\x35\xb4\x9e\x85\xb0\x4b\x10\x8c\xe7\x9f\x79\x71\x8d\xfc\x7b\xf6\xd4\xf9\xed\x23\xbd\xda\xb4\xf1\x8a\x62\xea\xdb\x9b\x3b\x7c\x6e\xbf\x80\x8f\x29\xfb\x90\x45\x31\x73\x13\xb3\x5b\x08\x77\xde\x57\xbe\xfd\x8d\x79\x0c\xa6\x58\x81\x13\xc1\xfd\x95\x9b\x8e\x49\x0a\x6a\x57\xd7\x83\x4b\x17\x5f\x58\x7a\xfa\xa9\x67\xd6\x7a\xa5\xea\x56\xfb\xf7\xb1\x70\xac\xe2\xe1\xbd\x6e\x92\xa5\xa6\x19\xca\xe0\x58\x46\xc1\xc7\x42\xc5\x4c\x91\x2b\x1d\x56\x24\xa5\x66\xf9\x25\xc9\x27\xd1\x9c\x6d\x61\x20\x18\xbb\x7b\xfb\xd6\xd3\x78\x7c\xb3\x79\x0c\xa2\x49\xe0\x74\xe1\xfc\xc5\x07\x4f\x9d\x7b\x76\x85\x34\x86\xa1\x5a\x0c\x47\x0b\xa6\x4f\x0a\x40\xab\x0d\xd6\x48\xf1\x91\x6a\xa8\x36\x7f\x98\x29\x7a\x6b\xc5\x96\x10\x1e\x4f\x54\xf0\x75\x69\xeb\x1b\x6b\x31\xad\xa9\x78\x3c\x6e\x9f\x73\x49\x1e\xc9\xbd\x4e\x76\x4e\xab\x95\xaa\xb0\xb3\x76\x30\xa4\x28\x6a\x90\xdc\xdb\xf4\x98\x77\x55\x53\x91\xfe\xf2\x2b\x2f\x3f\x4d\x6a\x5e\x04\xce\x8d\xc7\xc4\x75\x44\xc6\x86\xdd\x91\xd6\x78\xea\xdc\x73\x37\x9f\x3a\xff\xdc\x83\x2e\xeb\x59\x91\x4d\x81\x1c\x34\xe2\x8f\x95\x3d\xa2\xcf\x4f\xdc\xeb\x30\x60\xd5\x90\x4d\xeb\xaa\x62\x31\x3b\x6b\x15\x1e\x07\x29\x9e\x66\x49\x16\x91\xce\x4c\x40\xce\x76\x28\x40\x37\xee\xbe\x75\x9a\x32\xe0\x53\x64\x3c\x12\x8b\x67\x12\x78\xd8\xed\x0c\x2d\x7e\x3e\x3a\x50\x55\x1d\xdc\x5a\x7a\x0b\xbc\x70\xe1\xfd\x84\x57\x0f\xf4\xba\x71\x5a\x90\x3c\x57\x35\x4d\x89\xaf\x3f\x2c\xbb\xbb\x92\x09\xa8\x2f\xc5\xd2\xc6\xb9\x03\x74\xec\x01\x25\xda\xf6\x6f\x6d\x84\x8e\x2a\xd6\x76\x64\xf9\xda\x0c\xdd\x01\xcd\xf6\x5e\xd1\x60\xf7\x93\x03\xa2\x5f\xed\x9f\x03\x52\x12\x3c\x7b\xfe\x5d\xf6\x4e\x6c\xbb\xb8\xb7\x9b\x06\x57\x76\xdf\x1a\x5b\x48\x2e\x36\x61\xa5\xfe\x1f\xbe\xf0\x7f\x7d\xe6\x97\xbf\xfb\xa7\xbe\x0f\xb7\xb3\x07\xa0\x52\x0d\xd8\x64\xbb\x37\x15\x07\xcc\xce\x3e\xa0\x59\x06\x94\x8a\x75\xb0\x7c\x7f\xab\x0e\x4d\xeb\xf3\x3e\x77\xea\x40\x1f\x52\xdc\x14\xe1\x27\x76\x37\xfb\x20\x02\x3d\x59\xe0\xce\x19\x49\xfd\x35\x8d\x3a\xd7\xd9\x01\xf4\x76\xe7\xe6\xa8\x9e\x3c\xa1\x53\x05\xd2\xad\xd3\xeb\x68\xc0\xf4\x73\x17\x6d\xee\x6d\x4f\xd5\xa5\x4b\x03\x77\xbe\x68\x04\x06\x5a\xa5\xdd\x02\x74\xb7\xf0\xaf\x3f\x56\x7b\x3c\x3d\xd0\xd6\xb0\x24\x94\x10\x34\xa0\x00\xf1\x76\x32\x43\xfb\x78\xf5\x96\x0b\x96\x6b\x6c\x04\xcf\x72\x5e\xdc\x49\xbd\x3c\x49\xa2\x93\x2a\x49\x80\xd7\x2f\xe0\xe4\xa1\x49\x06\x81\x00\x90\x07\x06\x45\x5d\xd6\xd9\x03\x37\x2b\x7d\xc5\x1d\x1f\x21\xea\x28\xcc\x77\x54\x78\x11\x25\x39\xd3\xb7\x69\x17\xaa\x07\xf9\x8a\xe1\x02\x25\xa2\xce\x87\x8c\xe8\x6c\xac\x19\xf1\xf0\x1d\xc9\x46\x44\x93\xdd\x32\x3c\x21\xd9\x7f\x1f\x6f\x16\x8d\x81\xa6\xf8\x70\x6b\x9d\xba\xfe\x20\xd6\x98\x99\xe0\xaa\xcf\x9e\x85\x4a\x26\x8b\xc4\x72\x1d\xba\x48\xca\x7d\x74\x08\x3a\xa1\x42\x4b\x06\xca\x48\x28\xc5\x6e\x68\xcf\x71\x0d\xf7\x15\x66\x5e\x22\x2e\x93\x70\x2c\xc6\x97\xb2\xf7\x72\x35\x4a\x2d\xc7\x5c\x2d\x16\x04\x05\x11\x2f\x71\x14\xd9\xa5\x73\xb6\xe7\xb5\x18\x0f\x6a\x7e\xd5\xad\x07\xd5\xd9\xe4\x5d\x24\xba\x65\x7d\x45\x8c\xc7\x0b\x30\xea\x69\xeb\x85\x80\x36\xbc\xe9\x28\x12\x22\x79\x79\x33\x83\xc7\x81\x88\xdc\x5c\xdc\xa2\x79\xd0\x6a\xb5\x80\xe4\x16\xc8\xee\x26\x6a\xba\xb8\xa0\x7a\x68\x1d\x32\x33\x53\x72\x42\xf1\x09\x0f\xe4\x92\xb4\xf5\x0c\x6d\x53\x6e\x1e\x96\x1b\xba\x90\xbc\x69\x53\x89\x25\x50\xa3\x4c\xa4\xf9\x15\x08\xe8\x92\x05\x78\x1c\x01\x59\x4e\x60\x84\x5f\x2c\x4d\x29\x61\x09\x85\x7c\xa3\x00\x15\xaa\xdf\xa9\xc3\xcb\xff\xc3\xf5\xe5\x09\xff\xc6\x2e\xd7\x0b\x55\xb9\x85\xb4\x46\x0b\xf2\x44\x04\x31\x9a\xc4\xc1\x49\xa3\xca\x6a\xe5\x86\xe0\x8a\x7b\x69\x3c\x77\xf0\x10\x52\x3c\xb1\xbd\xc2\xdd\xcd\x83\x71\xa9\x8c\x27\x65\xbd\xa4\x9b\x34\xe5\xf3\xaa\xa1\xf1\x14\xc5\x56\x7d\xa2\x6a\x20\xbf\x8b\xa6\x45\x9e\xe7\x78\x9a\xe3\x30\x3e\x65\x59\xbc\x10\xe3\xf9\x81\xa6\x18\x37\x44\xad\x74\x83\xa1\xd4\x3a\x13\x1d\x61\x9d\x85\xa8\x58\xc6\xcf\xa3\x01\xcb\x02\x4f\xad\x1e\x5c\x35\x6b\x77\xdd\x1a\x34\xd2\x5e\x10\x6b\x1e\x62\x74\x4f\x41\x3e\x2c\x00\xc2\x9e\x34\x5a\x18\xf6\x6b\x1c\x5e\xae\x54\xd8\x62\x65\xe8\x81\x3c\x48\xda\x71\x58\xf5\xb6\x00\x85\x21\x02\x47\x61\x54\x44\x39\xf8\x17\x12\x3b\x3d\xe2\x6b\x60\xe2\xd1\x66\x13\xd0\x0c\x39\x68\xa8\x71\xaa\xd6\x38\xb4\x6a\x8d\x32\xd4\x55\x18\xfd\xe2\x5b\x9f\xfd\x77\xdb\x4b\x67\x8f\x0b\x14\x1f\x58\x56\xef\x67\xde\xf3\x1c\xf7\xc9\xc4\xf4\x7b\x53\x3c\x7e\x40\xe5\x9d\x1c\x68\x56\x6a\xa0\x59\xae\xbd\x19\x9a\x18\xff\xdf\xf9\x48\x50\xaf\x1a\x90\x18\xe4\x38\xb4\x09\xd8\x55\x89\xe8\xab\xc6\x76\x54\x3c\xdb\x89\x70\xd4\x05\x7d\x24\x34\xa0\xa8\x8e\x62\x4b\xa7\x30\x8a\xea\xf1\x17\x60\x4f\xe1\x7a\x10\x28\xc3\x1e\x85\x01\xa2\x6e\x59\x57\x0f\x66\x76\xd9\xf8\x9d\x9e\xd6\x2f\xe9\x82\xf5\xd2\xae\xeb\xa0\xb4\xe9\x2b\x56\x4d\xa4\x54\x0a\x2b\xd7\xbe\xe2\x1e\x7e\xf7\x8f\x50\x6e\xfa\x65\x44\x6a\x5e\x40\x80\xa8\x23\x51\xc0\xe1\xf1\x12\x60\x64\xe3\x07\xca\x79\x5c\x20\x14\xc7\xc0\x2b\x7f\x08\xe0\xd4\xf0\x47\xd6\xef\x15\xb4\xb1\x8b\x0b\xff\xbd\xad\x88\x80\xa8\x6e\x12\xa2\xc7\xe5\xed\x14\xfe\xf6\x39\xbc\x1d\xce\x6e\x27\x9d\xdd\x49\x6d\xc3\x1e\xe0\xef\xa4\x26\xba\x9f\x21\x8d\xd4\xa8\x57\xb9\x42\x21\xef\x69\x36\x1a\x5c\xc8\xe6\xbf\xe7\xa3\x1f\x5a\xe0\x1f\xed\x45\xd9\x56\xa9\x0e\xbc\x89\x00\x70\x87\x7d\x38\xc8\x28\x83\xfc\xa3\x1d\xc0\x89\x02\x32\x64\x2f\x2b\x8e\x7a\x72\x3d\x2a\x44\xaf\xc8\xb9\x47\xf7\x18\xe0\x0b\x77\x2a\xf0\x60\x0f\x84\x1f\x29\xbe\xeb\x15\xdc\x77\xef\x0b\x1e\x71\x29\x74\x5a\xd9\xe4\x54\x0b\x08\xd0\xa0\x5d\x3a\x8e\x89\x2d\x0d\xea\x4d\x62\x6c\x48\x77\x94\x74\x68\xd5\x80\x22\x65\xdb\xc2\xe3\xd5\x1d\xef\x4e\xe6\x50\x0b\x06\xfd\xad\x44\x32\x51\x0b\x47\x42\x0a\x04\x6f\xe7\x4d\x1c\x49\x7c\x83\xa7\xce\x3f\xbf\x9d\x4c\x0c\xd7\x6f\xdd\xbc\x7a\x56\x25\x16\xb7\xf8\xf4\x02\x25\x40\x5a\xe0\xa0\x65\x19\x7c\xab\xa6\x47\x79\x56\xf2\x33\x6e\x1a\xa9\xaa\xc2\xbe\xf2\xfa\xd7\x4f\xc6\x02\xc9\x50\x32\x3a\x82\x83\x67\x1d\x2c\xcc\x9c\x01\x18\x57\xac\xe3\x49\x49\x4e\x24\x86\x72\xe4\xc8\xd5\x5a\x45\xfc\xdc\x97\xfe\xea\xb9\x74\x6e\xdb\xc9\xc6\x7a\x3c\x5e\x85\x08\xdd\xdb\x18\x18\x67\xb2\xe5\x04\x0b\x04\x69\x78\x32\xac\x92\x2b\x78\xe3\xea\x2b\x27\xca\xe5\x8a\x63\xb1\xdb\x30\x1a\x40\x70\x89\xc6\xb3\xa7\x2e\xac\xce\xcf\x2d\xa4\xbb\xb3\x81\xd5\x49\x7a\x54\x6b\x55\xdf\xe4\xd0\x31\xa7\x51\x04\x91\xcf\xe1\x25\xc8\x2c\x14\xab\xae\x74\xa6\x98\x64\x19\x46\x8d\x85\x84\x96\x39\x02\x2b\xb9\x6c\xce\xdf\x6c\xb5\xc4\x78\x68\x08\x14\x2a\x87\xc0\xc9\x14\xe2\x7b\x7b\xf2\xf4\x85\xd5\x53\xf3\x67\xb6\xc8\x61\x35\xbd\xcd\x5f\x3f\x33\x7f\x7e\xab\x54\xad\x89\x2b\xeb\x8f\x87\x57\x77\x1f\xc9\x93\x13\xa3\x59\x4d\x35\x81\xa2\xa9\xec\xd7\xbf\xfd\xf2\xe9\x91\xc4\x94\x48\x38\xc4\xf8\x3e\xe4\xc5\xf9\x85\x1b\x6e\x97\x28\x37\x6a\x0a\xa9\x51\x2a\x79\xbd\x62\x03\x77\x49\x17\xe9\x93\x06\x5e\x10\x4a\xa5\x92\xb0\xbf\x5f\x8c\x35\x6a\xaa\x4b\x55\x0d\x86\x38\x3d\x46\x82\x81\x06\x27\x30\x72\xb9\x58\x63\xf7\x33\x07\xe1\xe9\x73\x0b\x0e\x8f\x91\x04\xf5\x1c\x43\x67\xab\x95\x06\xf7\xe0\xd1\x83\xb9\x8d\xed\xf5\x11\x0c\xcc\xf1\x79\xfb\xce\x65\xa6\x61\x81\xcd\xbd\x15\x3c\xe7\xc4\x1d\xce\x2f\x43\xd3\x86\xae\x9a\x32\x7e\x59\xc5\x7d\x4b\x47\xe8\x3b\x77\x2b\xd0\x80\xbe\xeb\x3b\xc7\x54\xed\xca\x52\xc3\x30\xe9\x62\xa1\x2a\x64\xf6\x0f\xa5\x42\xb6\x28\x35\x1a\xb2\xa0\x93\x7a\x06\x1c\xba\xe1\xa0\xa0\x5a\x2b\xd7\xe0\xcd\xdb\x37\xc6\x38\x8a\x01\xb2\xdc\x02\xd7\xd3\x97\x49\x9b\x38\x59\xfc\xee\xd7\xd4\xf8\xf4\x01\x06\x9e\xd5\x85\x63\x27\x77\x04\x41\xe8\x55\x24\xd7\x4a\x15\xd2\xa7\x2d\x8c\xf6\x9b\x64\x5d\x69\xb4\x9a\x68\x3f\x9d\x0d\xe5\xb2\xe5\x68\xa3\xde\x0a\xe9\xba\x29\xa5\x62\xa9\xb2\x0d\xb5\xd6\xce\x66\xce\xfd\x78\x79\x69\x7c\x6c\x68\x0a\x83\xb5\x3a\x20\xdb\xfb\x84\xaf\x3d\x3b\x3d\xb7\xfd\xd4\xd9\xa7\x1f\x62\x00\xad\xd7\x0b\x25\x50\x29\x57\x85\x7a\xa9\x0e\x47\x67\x46\x14\x1c\x34\x71\x07\x99\xbd\xd8\xc8\xe2\x24\xb0\xf0\x9c\xe1\x12\x5c\xe9\x66\xb9\x84\x81\xac\xa1\xad\x3c\xc8\xc4\xd5\xa6\x15\x4c\x0d\x8d\x52\x1a\x6d\x69\xdb\xab\x3b\xb1\x07\x4b\x0f\x9f\x77\xf1\x22\xa8\x34\x8b\x20\xec\x0b\x54\x2e\x5d\xbc\x74\xc5\xe7\xf5\xb5\xd4\x7a\xd9\x19\x07\xb2\xaa\xb2\x77\xef\x5e\x9b\x5b\x9c\x3a\x87\xcf\x6d\x76\x60\x8c\x56\xd6\x1a\x45\x90\xde\xde\x4c\xe8\xaa\x06\xb9\xc9\x91\x9a\xd6\x2c\x51\x4b\x4b\x37\x66\x26\x71\xd0\xe2\x54\x63\x20\x82\x64\xc1\xbe\xde\x2c\x32\x9b\x8f\x1f\xfb\x6b\xe5\x7c\xc2\x30\x2c\x4f\x32\x9a\x2c\x0a\xa2\xaa\xe5\xf7\xb3\xa1\xcd\x8d\xe5\x99\xf1\xd4\xb4\x73\x6f\xa6\x69\x40\x8c\x26\xc0\xdc\xd4\xcc\xc6\xd3\x67\x2f\xdc\x11\x04\x97\x6e\xc8\x25\xbe\x5c\xaa\xb8\xaa\x85\x1a\x18\x9f\x1b\x53\xf0\x17\x57\x2c\x1e\x0c\xcf\x0c\x1d\x23\xe3\x85\x20\xe5\xb4\xa9\x95\x71\x64\x68\xd6\xb7\xef\x3f\x1c\x57\x9b\x20\xe0\x76\x45\xc2\xac\x87\x41\x4a\x4d\xe6\xbf\xf9\xe6\x2b\x97\x86\x22\xe3\xf1\x44\x6c\xd4\x19\x8f\x8b\x33\x4f\x00\x97\x9b\xb9\x89\x2f\xaf\x91\x4a\x24\x1d\x07\xbb\x52\xb5\x2c\x7d\xfe\xab\x2f\x7d\x2c\x9d\xdd\x74\xa8\x0d\x1e\x49\x6a\xe1\x38\xd6\x47\xd1\xa8\xd1\xca\xe5\x62\x60\x00\xfb\x81\x7e\x3d\xe4\x3b\xd8\xba\x74\xb1\x6a\x5f\xde\x78\xc0\x50\x12\x0d\x3a\xbd\xa0\xc1\x8d\xbf\x9e\x8f\x11\x1c\xd0\x40\x83\x60\x50\x5c\x5b\xe2\x20\x9a\x1b\xf7\x51\xf1\x10\xad\xef\xec\x65\x0a\xeb\xfb\xb7\xf8\xe9\xec\xdc\x48\x70\xc8\xf5\xab\x9f\xfb\xe5\xbf\xfa\x81\x0b\x1f\x7a\x6e\x2a\x75\x66\x1a\xd0\x4f\x2d\xb6\xb5\x2c\x14\x03\x34\x31\xf0\xdd\xf8\xc6\x0d\x50\x38\xc8\x7c\x35\xe5\x4b\xd4\xd9\x54\x13\x47\x08\x30\xdc\xd9\xf5\x40\xa8\x3f\x05\x93\x52\x33\x74\xa4\x88\x73\x90\x39\xd6\xd5\x00\xeb\x92\xbf\xbb\x9b\x9a\xe0\xe8\xef\x06\x94\xbf\x3b\xb7\x4c\xa1\x3e\x74\x87\x3d\x6d\x9a\x9e\x65\x0a\xea\x1a\x4e\x74\xb5\x13\x07\x3f\xdb\x37\x8e\xe8\x88\xa2\xa1\x41\x4d\x5f\xd4\x35\x9f\x70\x36\x8e\x07\xca\x52\x18\x8a\xd5\x0c\xa5\xb1\x6a\x29\xd6\xb8\xce\xb8\x86\x5c\x34\xa9\x81\x6f\xd7\xc1\x23\x1b\x5a\x34\x62\x14\x0b\x52\xab\x3a\x45\x5d\x31\xe8\x03\xcd\x25\x7e\xd9\x7f\x3c\x55\xc5\x0f\x89\x6f\x1f\x86\x42\xbd\x23\xc3\x9e\x68\x11\x12\x43\x01\xd3\x05\x40\xa3\x5b\xd6\xe2\x70\x32\xb7\xf3\x3e\xdd\x34\x59\xa8\xd9\x44\xc2\x09\x58\x2e\x5a\xa3\x27\x52\xad\x3e\x60\x6f\xe7\xcf\x3a\xfb\xc0\x1d\xfc\x8c\xff\x3f\x65\x6c\x0a\x2b\xdb\x41\xc4\xb1\xf3\xb4\xa2\x32\x7a\xd0\x0f\xeb\xa9\x38\x32\x0e\xb2\x90\x97\x2d\x24\x98\x3a\x80\x3e\x1e\xda\x62\x12\xe1\xdb\x88\xa1\x9d\xd2\x33\x1b\x5f\xc8\xbe\x3e\xfd\x53\x2f\x66\x77\x21\x90\x13\xc3\xf6\xcd\xe4\x5a\xed\xc5\x9d\x80\xe5\x92\xdd\x3a\xc9\xf2\x92\x22\x54\x40\x13\x3a\x01\xd1\xb5\x12\x68\xd0\x3a\xc6\x52\x69\x49\x1e\x8e\x3c\x30\x05\x6e\xbb\xbc\xcc\x58\x5c\x16\x3c\x3f\x87\xef\x9c\xee\xaa\x79\x3a\x0d\xe6\x3e\x31\x63\x59\x7f\xfe\xa5\x5d\xdb\x2d\x09\xda\x54\x4a\x32\x24\x01\x34\x75\x0b\xb9\x13\x43\x40\xa4\x44\x58\xd9\x79\xd3\xc3\x1e\x7f\x4e\x7e\x32\x3e\x67\x5c\xff\xe2\xe7\x91\x48\xb1\xc0\x6b\x4a\x50\x0e\x9a\x20\xfb\x1c\x9e\xbe\x64\xc3\x15\xda\xb0\x0c\x51\xc3\x61\x51\xd1\x00\xa6\xa7\x23\x7c\x63\x21\xa8\x06\x44\xaa\x79\x7e\xc6\x26\xed\xe3\xba\xf7\xe8\x1f\xad\xc3\x6b\x39\x74\x7b\xfc\xaa\x35\xab\xcd\x5a\x43\xc9\xe7\xb2\xdc\xc8\xf8\x02\x00\xc3\x63\x10\xf8\xb9\x06\x9b\x7b\x90\xf5\xcc\x4c\xf9\xca\x7a\x0d\x62\xf8\x0f\xdc\x78\xde\xf1\x39\x92\xef\x4e\xa2\xc9\x66\x4d\xdb\x96\x34\x03\x18\x1a\xe2\x29\x0c\xc9\x5d\x3c\x6b\x79\x31\xb6\x0d\xe0\xae\xe1\x67\x38\xde\xc3\xb0\xac\x48\xd1\x8c\x40\xc0\x32\xeb\xa6\xe8\xdc\xfd\x9c\x10\x0b\x2b\x54\x70\xa2\x5d\x64\xbe\xbf\x03\xc9\x87\x1f\x79\xbd\xe0\x3e\x63\xd2\x76\xc1\x56\x40\xab\x8e\xc1\x59\x49\x07\x1e\xb2\xf5\x80\x7b\x86\x41\xd9\x40\xaf\x12\x1e\x91\x07\xac\x2a\x1b\xe0\xb3\xf7\xfe\x0c\x5c\x3a\x38\x0f\x3e\xcd\xfd\x35\xf8\x93\x1f\xff\x53\x50\xe1\xf3\x20\x99\x3d\x01\x32\x93\x3e\xa8\x1c\x2a\x80\xc2\xd1\x29\x14\x14\x7c\x10\x8b\x98\x25\x00\x51\xe0\xc1\x41\x76\x1b\xee\xdc\x59\x97\xf1\x1d\xd7\x35\x4a\xf3\x91\xee\x7a\xa3\xf9\xc6\x4d\xc3\x36\x63\xf8\x7e\x86\xfe\xdb\x67\xff\xf3\xaf\xd5\x4a\xa5\x4f\x5e\xf8\xe8\x7b\x4f\xd7\x0a\x65\x60\x6b\x2d\x50\xdd\xcd\xff\x08\x8b\xd8\x8a\x5e\x92\xf1\xb3\x25\xdd\x9c\x98\x33\xe0\x68\x94\xa2\x31\x88\xc6\x2f\xf2\x2f\xdb\x2e\x2a\x66\x39\x1c\x06\xba\x38\xa8\x33\xf8\x41\xa9\x26\x84\x3a\x05\x59\x9e\xc7\x60\x86\x71\xb2\xd3\x14\x11\x4d\xb1\xda\x3c\x5d\x86\x50\xb8\x58\xa7\x5e\x94\xd4\xa2\x76\x2a\xf0\x3a\x94\x5f\x34\x50\x10\xd6\xc9\x2c\x92\x7d\x2a\xe4\x50\x4f\x3a\x20\xdb\xd9\xa5\x32\xfa\xc5\x65\x44\x0d\x57\xc7\x0d\x67\x01\xd6\x32\x2d\xe1\xa0\xb9\xb5\xf4\xc7\xff\x55\x6e\x50\xdc\xf1\x0f\x3f\xf7\x41\x4e\xca\xed\xa8\xa0\xf0\x85\x6f\x03\xe3\xf4\x0c\x50\x37\x37\x80\x5d\xc7\x17\xb0\x70\x02\x58\x4a\x13\xe0\xd0\x04\x84\x93\x71\x50\xdc\xcf\x01\x7b\xcc\xfe\x1f\xb6\xdf\x7a\xa4\xc5\x17\x27\x3e\x45\xb1\x0e\xcb\x0c\x1c\x29\x4a\x43\xf6\x80\x5a\x64\x57\x2b\xe7\x68\xf9\x57\x5f\x00\xa1\x3d\xed\xda\x4e\xf8\x67\xf7\x4a\x2e\x0a\x95\x8a\xb4\xb1\xb9\xce\x57\x8a\x45\xbf\x08\x84\xaf\xe8\xd4\xd9\x8f\x06\x26\x58\xc0\xe3\xe6\xf5\x26\xc3\x80\xe6\x58\xa0\x54\x5b\x20\x34\x99\x00\xe9\xdb\x1b\xad\xc0\x74\xf2\x7a\x5d\x36\xfa\xe2\x8b\xa4\x1d\xba\xfb\xc9\xa8\xab\xbb\x8b\x60\x6f\x87\xb0\x2f\xbf\x0e\xfb\xbc\xe4\x0e\xf7\xb9\x27\x26\xd5\xb1\x5f\xea\x1a\x50\x80\x4e\x0e\x97\x50\x6c\x0c\x8b\x31\x2c\xaa\x05\x68\xd6\xa2\x18\xd6\x86\x14\x83\x03\x42\xdb\x6b\x59\x16\x6f\x18\xa4\xa8\xc9\xd9\x67\x23\xea\x78\xa0\xd9\x54\xf9\x42\xbe\xec\x5d\x5b\xdd\x4e\xf6\x8c\xc7\xda\x71\xaf\x89\x03\x42\x0b\xf7\x7d\x55\x14\xc5\xea\xec\xd4\x5c\x31\x18\xf3\x13\x4b\x39\xf8\x70\xe5\x51\x32\xe4\x8f\xa2\x26\xee\xe4\x34\x8d\xa3\x6a\x2e\x96\x51\x35\x64\xe4\x0f\x2a\x42\x34\x16\xa6\xf1\x6a\x81\xc7\xa2\xc2\x7e\xed\x5b\x2f\x9d\xe1\x29\xd6\x17\x0e\xc4\x10\xc7\x70\xc0\xed\xf1\x6c\xc6\x3c\x23\x2b\xe4\x22\x4b\x85\xfc\x08\xc9\x50\x1e\x96\xf3\xec\xed\x7b\xd7\x26\x39\x96\x43\x9b\xe9\x35\x40\x80\x4c\x24\x3e\xb4\x81\xc7\xa3\x59\x2c\x56\xa9\x4c\xa6\x12\x39\x31\x77\xa2\x4e\x8e\x7f\xfd\xce\x1b\xc7\x74\xd9\x4c\x85\xfd\x31\x1c\x20\xe7\xc1\xf8\x68\x32\xfb\xd4\xb9\x4b\xb7\xc9\x75\xcb\xaa\x0d\xca\x85\xaa\xe4\x11\x3d\x3a\x2b\xd2\xfa\xfa\xf6\x4a\x82\xa7\xc5\x90\xc0\xbb\x9d\x0c\x1c\x1e\xbe\xfb\x84\x1e\xb6\xba\x9e\xf1\x57\xeb\x9a\x44\xd1\x86\x10\x09\x0a\x32\xf9\xdd\xda\xce\x4e\x80\x63\x59\x0c\x14\x13\x40\xc5\x00\x12\x2f\xf2\xc6\x99\x85\x8b\xb7\xc3\xa1\x68\xa1\x25\x23\x80\x01\x36\x65\x98\x7a\x5d\x72\xb9\x2d\xd1\xe3\xf6\x3d\x75\xe6\x5d\xf7\x9e\x3e\xfd\xae\x7b\xdd\x27\xd3\x94\x6d\x70\xe3\xde\xad\x99\x88\x3f\xe9\x23\x59\x47\xc3\xd4\x8c\x64\x72\xea\x26\x42\x5c\x23\x73\x50\x64\x2b\x95\x72\x33\x1a\x09\xd6\x6c\x1b\x36\x58\x8e\x2d\x61\x10\x48\x61\xe0\xea\xc9\xe5\x4a\x62\xa5\xd2\x12\x5b\x8a\xc6\x99\x66\x5b\xd8\x1d\x9f\xb3\xac\x28\x26\xba\xb5\x74\x67\x98\xd4\xb5\x8a\xae\xf6\xfe\x1b\xc3\xc2\xbd\x62\xa9\x9a\xb8\xff\xf0\xee\xc2\x76\x66\x9d\x75\x32\xdb\x86\x01\x4e\xce\x9f\xda\x9c\x1e\x9f\xce\x26\xc2\xf1\xea\x6b\x57\xbf\xbd\x68\x6a\xf6\x08\x01\xce\xb6\x8d\xe7\x1e\xaf\x77\xc3\x46\x06\xc0\xb7\xd6\x44\xd0\x18\x50\x6b\x1e\x48\xf0\xc2\xa3\xb6\xc8\x6f\x37\x67\x82\xed\x7a\x1b\x68\xda\x1a\xee\x53\x15\x41\xd7\x6a\x92\x65\x29\x18\xb4\xeb\x2c\x91\x1f\x4c\x44\xe3\x95\x70\x82\xc5\x71\x75\x41\xcc\x66\xd3\xc9\xf9\xa9\xd3\xa0\xd1\xaa\x3a\xe7\x88\x84\x83\xb5\xe9\x89\xc9\x7d\x81\x17\x8c\xd3\xf3\x0b\x3b\x83\x28\xda\xd0\x5b\x74\xa3\xd1\xa4\x48\x1a\xc0\x1f\xe2\xf3\x91\x28\x5f\xa1\x29\xda\x6e\x36\x54\xbe\x5c\xa9\x84\x54\xa5\xec\x37\x8d\x96\x0f\x20\xdd\x85\xa7\x19\x7a\x6a\x26\x9e\xe7\x59\x03\xdc\x7f\x74\x63\x66\x38\x3e\x0a\xe2\xc1\x38\x28\xd1\x34\x18\x4e\x45\xb7\x67\x26\xc7\xb7\x63\x91\x68\xa5\x6d\x64\x71\xe0\x5d\x79\xb4\x39\x4a\x76\x0e\x9e\xbe\x70\x76\x9d\xe7\x75\x70\x67\xe9\xee\x78\x2a\x36\xca\x12\x4b\x53\xb2\xb3\x10\x4b\xf0\xab\xf8\xf7\x76\x21\x97\xe1\x6b\x85\x42\x72\x62\x7c\xca\xf0\x47\x50\xe3\x20\xb7\x17\x7c\xf4\xe8\xd1\xf3\x84\xe7\x4b\xe8\x04\xc7\x67\xa6\xd3\x17\x9f\x5c\xbc\x4a\x1a\xa1\x9c\x2f\xba\x83\x31\x6f\x8b\xb4\xc7\x37\x5e\xfb\xe6\x59\x9e\xe1\x24\xbf\xc7\xe7\x70\xba\xf0\x94\x6a\x44\x22\xa8\xa2\x69\x2d\x5a\x69\x95\xe3\xf1\x70\xa8\x10\x1f\x86\x9a\xa2\xd6\xd9\x5c\x3e\x33\x3c\x73\xe6\x84\xe3\x70\x81\xa7\xd2\x72\x22\x0e\xcb\x8a\x5c\xa7\x5a\xf5\x7c\x8c\x67\x0c\x17\x6e\x44\x7a\x71\x3e\xbe\x1f\xf0\xeb\xf6\x9b\x37\x6f\x1e\x1b\x1d\x1a\x03\x89\x70\x02\x94\x6a\x0c\x18\x1b\x0b\x6f\x1c\x9b\x1e\x5f\x4b\x25\x22\x65\x72\x0d\xd9\x4c\xd6\xf7\xf0\xc1\xd6\x84\xa1\x1b\xf0\x99\x8b\x67\x1e\xfb\xc2\x06\x7a\xfd\xea\xbd\xe9\xd1\xc4\x38\x49\xcb\x38\xe5\x69\xe3\x93\xc2\x43\x51\x34\x71\x40\x55\xb0\x6c\x55\x9d\x48\xcd\xa5\x08\x2d\xda\x6a\xca\x0d\xfe\x0b\xdf\xfc\xea\x7b\x68\xe8\x0e\xc5\x23\x71\x20\xf2\x3c\xf0\x44\x85\xa5\x78\xd2\xe7\x8c\x9f\xad\xed\xf2\x74\xae\xb0\xb1\x98\x2b\x66\xf9\xb7\x6e\xdc\x5d\xc0\xe3\x11\xec\x1c\xac\x82\xb1\xe4\x34\x98\x9e\x0e\x3e\x88\xc4\x2c\x2a\x18\x34\x9b\xb3\xb3\x3a\x73\x44\xf0\x03\xf5\x36\x99\x50\x3f\xaf\xd0\x95\x8f\x3d\x52\x20\xd9\x91\x14\xef\xfc\x6c\xc3\xbe\x78\x48\xef\x18\x70\x40\x42\x0e\xf6\x80\x72\x5f\x4f\x1a\xf4\x7d\x41\x50\x17\xe4\x09\xd6\xe2\xf1\x64\xe5\xf1\x06\x63\x6f\xae\xad\xea\xe0\x20\x16\x1d\xf5\x8f\x7c\x7b\xf9\x5b\xdf\xba\xb7\xbd\xbc\xfb\xfd\x27\x7e\xe0\x12\xd9\x48\x01\x70\x6e\x1c\x1c\x5e\x5b\x06\x99\xdd\xf5\xcb\x8b\x23\x91\xe5\xa1\x13\xfa\x1e\xe2\x0c\xa6\x97\x87\xed\xa1\x73\x08\x8e\x16\x77\xc2\xc1\xbf\x0f\xe8\xd6\xf5\x78\x6d\xa8\x67\xbd\xd8\xbb\x5d\xd8\x97\x51\xec\xd9\xa8\x41\x34\xb0\x6b\xd6\x15\x56\x74\xee\xd8\x06\xf0\x88\xab\x3c\xe8\xde\x1b\x7a\x3b\x61\xad\xf3\x06\xbb\x57\xf7\xdc\x05\xde\x68\xf0\x5a\xda\x07\x6b\xdf\x97\x15\x04\xfa\x21\xc5\xae\x1f\xee\x99\xee\x57\x64\xf5\xe9\x39\xc8\x82\x31\x3c\xce\x78\x88\x28\xd5\x32\xa9\xa2\x81\xd0\x9e\x0e\x6b\x5b\x14\xb7\xa3\xfb\x5d\x6f\x9d\x9c\xe7\x1f\xd9\xe8\xb0\x4d\xcd\x1e\x28\x5a\xee\x0a\xc9\xf5\xdc\x77\x3a\xdb\xd0\xa4\xb6\xa2\xf5\xa0\x11\xd5\x55\x75\xca\x04\x54\x5c\xe7\x50\x10\xf7\x43\x06\xe3\x04\x03\x36\xad\x26\x9d\x3d\x2c\x79\x54\xfe\xc0\x0c\xb0\x69\x30\xea\xae\x50\x12\x6f\xdb\xa8\x2f\x4d\x49\x36\x66\x58\x2f\xab\x1a\xa3\xd1\x6b\x5c\xb9\x29\x5b\x3c\x73\xc2\x08\xba\x7c\x9e\xfd\x0c\xd2\xbc\x3e\x40\x14\x1f\x4c\x1d\x2f\x65\x1a\x8d\xd1\x19\x7e\x8e\x93\xa3\xc0\xf2\x12\x1d\x2d\xe5\xc2\x1f\xff\xdc\xff\xf4\xc6\x0f\xff\xeb\x5f\x2a\x6e\x40\x36\xe3\xa9\xd3\xaf\x25\x96\xf4\x8b\xf9\x93\x4d\x8f\x15\x80\x50\x72\x61\xd0\xab\xe1\x2b\x36\x10\x64\x2c\x0a\x79\x68\xde\x6e\x8e\x51\x76\xce\x25\x07\x30\x9e\x5a\x88\xaf\x67\x59\xf8\x45\x39\xad\x9e\x1a\x37\xda\xca\xa9\x1d\x10\x4e\x74\x58\x9e\xbd\xd0\xf2\xbd\x75\x7d\xab\x69\x68\x13\xf2\xd8\x90\xa8\xb3\x3c\xc9\x26\xe0\xbb\xf3\x20\x29\x05\x7d\xf5\x6f\xdd\x3c\x6c\xbc\x30\xa9\x7b\xf3\x48\xad\xb1\x90\x14\x61\x23\x6f\x93\x05\x16\xa1\x90\x1e\x6f\x71\xee\x43\x93\x77\x15\x80\x0a\x30\x6c\x32\x04\x87\xe2\x42\xb6\xf9\x1d\x6d\x68\xaa\xaa\x02\x42\xfc\xb3\x9e\x18\xff\x47\x03\x5e\xdb\x21\x97\xb4\xbd\x6a\xcd\xa6\x9e\x7f\xb8\xbe\x31\x3a\xf2\xd4\x53\xf8\x34\x7e\x9b\x3a\xf9\x24\x87\xbe\xf6\xfa\xa6\x77\xe2\xbb\x66\x25\x56\xe2\xf1\x1c\xaa\xf9\xda\x4c\x1b\xa7\x90\x88\xc6\x60\xc6\x85\x5b\x5d\xc6\x30\xd0\xe4\x38\x96\x90\x1d\x78\x47\x93\x04\x42\x1f\x01\xbc\xf8\xe5\x65\x58\xce\xcd\x30\x8c\x8b\xf5\x0a\xac\x59\xb3\xc5\xdc\xb5\x1d\xf1\x23\x3f\x22\x22\xc8\xe1\xd6\x69\x51\x60\x63\x19\xe3\x64\xb7\xf5\xd5\x3f\xfe\xe2\xef\x3c\xfc\x85\x0f\xff\x24\xd1\xd4\x05\x3c\xcb\x00\x7c\x3c\x87\xcc\xee\x58\xe3\x72\x1c\xa0\x70\xc3\x21\x52\xf0\xc8\x90\x2d\x30\xcb\x71\x35\x20\x01\x06\xd1\x3c\x6d\x90\xda\x54\x4d\x07\x14\x65\x38\xf2\x2b\x0e\x55\x98\x72\x64\xb4\x10\x8e\xac\xc1\x7f\xfb\x9b\xdf\xee\xa9\x78\x80\xb6\xc0\x4d\xb1\x5b\x98\x05\xda\x1e\xf3\xe4\xfe\x53\x9f\x7d\xf9\x53\xbf\xdf\xac\xd7\x9f\x9f\x3b\x7b\xfa\x3d\xa8\xd6\xa8\x8c\x8f\xb8\xd1\xc2\x67\x63\xad\x3f\xff\xc0\x2b\x60\x3b\x17\x06\xd1\x6d\x00\x27\xf8\x43\x20\x26\x43\x00\x8a\x14\xd4\xa1\x06\x10\xd1\xfa\xa5\xbc\x60\xb7\xb1\x0f\xe5\x4a\x15\xbe\x60\x3d\x07\x82\xa7\xa2\x20\x1d\x49\x53\x1b\xab\x6b\xf4\xfe\x4a\x9a\x4d\x05\x46\xa6\xbc\x94\x3f\x06\xe3\xd4\xa5\xe3\xf7\x26\xcc\xbd\xf1\xec\x43\x3d\x08\xde\x0c\x06\xbd\x65\x12\x0f\x1b\x3c\x4b\x14\x0e\x88\x13\x1b\x29\xdf\x25\x9a\xc2\x6d\xbd\xc0\x76\x31\x5a\xc7\x35\x8c\x72\xf4\x7f\xda\x1c\x41\xda\xb1\xe8\x75\xb4\x55\xc8\xa3\xc0\x81\xa4\xa2\x68\x14\xa3\x53\x75\x5b\xb3\x1a\x72\xad\x39\x56\xd5\x1f\x35\x7e\xf3\xff\x69\xc9\x00\x9e\xfb\xf8\x13\xdf\xc7\xb9\x97\x5f\xce\x00\xe5\xfe\x2e\x18\x89\xdb\xa0\x35\x2b\x81\xbd\xbd\x22\xf0\x46\x26\xf1\x09\x1b\x80\x71\x71\x20\x32\x94\x00\x28\x83\x07\x79\xc2\xfc\x64\xfa\x8d\x87\x5b\x9e\xb8\xef\x2f\xfe\x31\x3e\xb6\x47\x8a\x7a\xde\x96\xba\xc0\xc0\x04\x1e\xec\xac\x4b\xbb\xab\x2b\xba\xa9\x1b\xd2\xf0\xe4\x99\x29\xff\x70\x84\x4e\x2c\x8c\x80\x66\xb1\x0e\xca\xd9\x32\xee\x8d\xba\x03\x76\x1f\xfc\xcd\x1b\xe4\x93\x3f\xdb\xca\x14\xef\xb5\xeb\xde\x10\x18\x28\x08\x6f\xbb\x66\xe1\x50\x98\x6c\xcd\x5b\x8e\x8a\x11\xd5\xae\x0d\xc4\x6d\x67\xe0\x20\x07\xaf\xef\x90\xb5\x70\xcf\xc4\x51\x24\x0e\x56\x9c\x8c\x8f\x65\x1a\x7d\x6a\x34\xd9\x0d\x20\x43\xd5\x71\x7e\x6b\x27\xd6\x6d\x7c\x1c\xc3\x30\xa8\x56\x53\x76\xd5\x2b\xad\xb0\x52\xd7\x53\x86\x62\x8d\x5a\x86\x15\xb3\x4d\xdb\x8f\x17\x7c\x57\x3b\x5e\x41\xd4\x3b\xe9\x8e\x21\x62\xb4\x83\x10\x8b\xc8\xa4\x45\x36\x6a\x29\xdb\x4e\x85\xc7\xb6\x59\x9e\x3b\x68\x54\x65\x70\xf9\xc6\xcb\x97\x90\xa9\x85\xbd\x01\xc9\xa8\x37\xea\x20\x14\x8a\xdd\x33\x54\xf0\xb0\x52\x28\x33\xb4\xcd\xf2\xaa\xac\x2b\x2b\x9b\x0f\x26\x97\x96\x6f\x62\x50\xc0\xba\x13\xc9\x09\xb3\x5c\x2d\x39\x5b\x43\xf8\xb8\xa3\x0d\xa5\x3e\x4a\xf8\x88\x8d\x66\x0d\xb4\xe4\x26\x90\x35\x95\x14\x43\x99\x38\xf0\x02\x41\x7f\xb4\x31\x36\x7a\xec\x26\x27\x78\x77\x5a\x0d\x83\x7a\xf4\x60\x6d\x2c\x1e\x4c\x14\x19\x51\x48\xef\x64\xd2\xa1\xc3\x7c\x76\x74\x71\xfa\x8c\xa9\xa8\x32\x88\xc7\xc7\x6e\x45\xa2\x43\x4b\x9a\x86\xc0\x41\x26\x17\x61\x71\xf8\x16\x19\x0a\xaf\x93\xad\xc6\xf5\xad\xf5\xe4\xdd\xfb\x57\x4e\x5e\x3c\xf3\x2e\xb3\xb3\xd5\xad\x33\xbc\x70\x47\x56\x34\x3a\x9f\x2d\x4c\xdb\x16\xd2\x91\x65\x23\xc9\xe3\xdd\xb3\x6c\xbb\x92\x39\xd8\x5d\xc4\x0b\xbb\xe9\x12\x44\x62\x17\x0d\x66\x67\x4e\xbc\xc4\x0b\x42\xbd\x5e\xab\xbb\x1f\x2f\xaf\x8c\x99\x96\xd1\xf2\xf8\xdc\x5a\x85\x65\x14\x51\x74\xdb\x3e\xbf\x8f\x09\x04\x02\x8a\xdc\x68\x89\x6e\xaf\xa8\x54\x6a\x65\xef\x5e\x7a\x6d\xfc\xe2\x99\x77\x5b\x24\xbb\x1b\x88\x44\xee\xfb\x02\xee\xed\x46\xbd\xc9\x1d\x16\x33\x66\x28\xe2\xcd\x06\xe2\x4c\xc9\xef\xe3\x14\x5b\x67\x02\xaa\x02\x7d\x2e\x41\x60\x78\x8e\xc2\xeb\x85\xe1\xb0\x00\xf1\xa3\x37\x08\x07\x2a\x12\xf3\xe5\x19\x1e\xc9\x5b\x7b\xeb\x51\x96\x65\x9c\x28\xcb\xc4\xc0\x56\xd1\x75\x7f\x7a\x7f\x7b\x7c\x2b\xb3\x0a\x0d\xd3\x42\x33\x53\x33\x5b\x4f\x9f\x7d\xfa\x21\xbe\x4e\xe2\xdf\x09\x55\x55\xe1\xd2\x07\xe9\xf8\x13\xc7\x9f\x76\xa2\x24\x1c\xb0\xb7\x82\x11\xdf\x63\xf2\x58\x79\x37\xda\x37\x49\xd9\x7c\x67\xc5\x06\x76\x3f\x75\x06\x8f\xa6\x77\x3b\x33\xff\xa0\xcc\x06\x5e\xd4\x0c\x0b\x56\x6b\x3a\x55\xa9\x68\x7c\xbd\xa1\x89\x8a\x6a\x09\xf8\x12\x28\x22\x15\x9d\x4a\x0d\x17\x74\xdc\x75\xef\x2d\x3f\x1a\x1d\x4e\x8c\x03\x22\x11\xe6\xc2\x20\xfd\xec\xd9\xb3\xaf\x05\xfc\x81\x5a\xf7\xf0\x44\xf3\xb3\x54\x28\x8b\xa5\x62\xc5\x25\xcb\x32\xcd\x73\xbc\x12\x8f\x44\x5b\x81\x50\x98\x36\x2d\x98\xca\x66\x41\xaa\x7d\x1d\xbc\x5e\xad\xd6\xf1\xf9\xec\x80\xa2\x22\x51\x37\x21\x93\x8a\x0f\x15\xa5\xb0\xbf\x76\x58\xae\xb8\xb7\xb6\xf7\xc6\x9f\x3a\xf5\x82\x73\xd8\x54\x72\xf4\x70\x7a\x76\xc2\x31\x0c\x38\x38\xa8\x88\x9b\x9b\xbb\xc9\x5c\xf6\x30\x4e\xee\x69\x28\x3e\x94\xa5\x25\x9f\x52\xae\xaa\xdc\xd2\xa3\xb5\xb9\x73\x27\x9e\x21\xfd\x0c\xf1\x2e\x3e\x6f\x00\xb1\x51\x2b\xc9\xe0\xde\x83\xfc\x50\xc0\x1b\xa2\x19\x5f\x28\x5d\xac\xa8\x38\x40\xbb\xfc\xfc\x13\xc7\x2e\xe2\x6b\xd5\x41\x24\x12\xdd\x1c\x1e\x1b\xba\x5d\xc7\x2b\x4b\x66\x23\x1f\x4f\x4d\xc6\xb2\x75\x19\xa0\xd7\xaf\xbc\x76\x72\x37\x9d\x1b\x3e\x3f\xff\x0c\x29\x26\x72\x8a\x24\x59\x81\xcd\x55\x5b\x02\xca\xec\x55\x7c\x8a\xce\x01\x4f\x60\xb4\x58\x69\xba\xec\xeb\xb7\xef\x4d\x4a\xae\x20\x0e\x38\x5c\x4e\xfd\x03\x23\x88\xbb\xe5\xa6\x68\xef\xa7\xab\x62\xa9\x46\xbb\x0d\x03\xb2\xc9\x68\x3c\x0f\xbd\xd1\xf2\x7a\xba\x2c\xad\xae\x65\xa6\x70\x20\xe5\xdc\x5b\x32\x31\x96\x9d\x9a\x9d\xbc\x42\xda\x7f\x65\xa3\x22\x6d\x6f\xec\x0c\xe5\x73\x05\x52\x1c\x80\x86\x62\xc3\x69\x95\x89\x34\x2b\xfb\x0a\x7f\xfb\xde\xd6\xfc\xf9\xf9\x67\x71\xf0\x63\x61\x40\xcd\x67\x6b\xb2\x0f\xb7\x93\x66\x3f\x7e\x54\x8f\x4d\x4f\x4c\x03\xbb\xea\x52\x1f\xad\x2e\x8d\xdc\xb9\x7f\xf3\x2c\x4b\x31\x9e\xd1\x44\x0c\x95\x2a\x15\x1c\xe8\xca\x20\x7b\x88\xe6\x6f\x3f\x68\xcc\x3b\xe3\xb1\x85\xc7\x63\xab\x81\xc7\x23\xa1\x9d\x40\xb2\x3b\x00\x42\x81\x44\x7d\x7a\xfa\xf8\x2d\x8a\x0f\x6d\x15\xaa\xb8\x59\x04\x76\xb7\xf2\x10\x12\xf1\xe3\xfe\x5e\x54\xdf\x28\xad\x5f\xe9\xdb\xfd\x19\x0e\x48\xf7\xc2\x9e\xeb\x79\x7b\x41\x78\x1b\x61\xab\x27\x0b\xdd\xeb\xa4\x60\x40\x85\xf1\x08\xc4\xfc\x4e\x97\x32\x3e\x60\xa5\xc6\x42\x65\xc0\x14\x94\xdd\xed\x7c\xfd\xf6\xce\xd2\xd0\x54\x74\xd6\x76\x1b\x85\x5f\x7e\xeb\xb7\x3e\xfb\xf3\x4f\xfe\xf8\x07\x80\xba\xdd\x00\xbb\xb7\x97\x0e\x82\x12\x7d\x59\x88\x70\xeb\x0d\xcd\xd0\x91\x46\x81\x8e\x27\xd4\xdb\x7d\x82\x51\xbf\x64\x18\xbd\xcd\x13\xaa\x27\x47\x87\xfa\x90\x78\xd0\x9f\x0f\xbd\xad\x54\x05\xa1\xbe\x08\x4f\x77\xe3\xbc\x5b\xb9\xd1\xbe\x67\xaa\x8f\xa7\x7b\xef\x73\x20\x6b\x5f\x43\x08\x75\x1d\xe3\x41\xa7\x9c\xfd\x48\x9d\x49\x67\x6f\x16\x76\xb2\xbc\x1d\x1a\x64\x5b\xbf\x18\x7f\xc5\xa7\x51\xf9\xc0\x45\x5f\x5d\xdf\x85\xb5\x5b\x4d\x63\x72\x8b\xa6\x02\x2c\x32\x29\xd5\xb0\xe4\x1a\x60\x2a\x16\x8f\xf6\x62\x11\x73\xeb\xe4\x4c\xa5\x34\x78\xdd\xe8\x88\x0e\x11\x42\x47\x6a\x6e\xf0\x77\x2d\x99\xa5\x1f\xdc\xd7\x66\xac\x8a\xf8\xee\x7a\xc4\x9e\x38\x9c\xb0\x29\x25\x8c\xc1\x15\x63\x5b\xc0\xc2\x90\x17\x2f\xf0\x5c\xcb\xd2\x84\xba\xd9\x92\x4a\xd4\xa1\x6f\xa3\x9a\x49\x28\x52\x5a\x0c\x59\x7b\xa9\x8b\x6a\x9d\xa0\x6a\xbb\x9b\xdd\x8f\x01\x1d\xff\x7c\xeb\xce\xd5\x56\x06\xad\xe9\xa7\x9a\x73\x93\x93\x90\xb6\x20\xa7\xb6\x80\xee\x97\x6c\xa6\xa5\xe1\x35\x52\x03\x74\x34\x84\x84\xa1\x08\xe4\x59\x2b\xf9\x51\xf4\x91\x73\xf4\xfd\xab\xaf\xcd\x9c\xf7\xc9\xf6\x31\xb0\xbb\x73\x97\xd6\x3d\x55\x6a\x31\x3b\x5d\x4d\xa5\xe3\x08\x85\xe2\x21\xe4\x12\x39\x44\xcb\x36\xe0\x0c\x0a\xf8\x91\x00\x5b\x51\x08\x0e\x2e\x34\x25\x9d\xd3\x4f\x8c\x3e\xaa\xf0\xfc\xbd\xd2\x9a\xe0\x67\xf0\xbc\x8d\x57\x46\x87\x2b\x4e\x39\xd3\xa3\x0d\xac\x1a\xbf\xb7\xbf\x89\xd7\xba\x61\x23\x12\xf5\xe8\x5e\x1f\xc2\x53\x20\x08\x45\x86\x69\x6e\xfd\x80\x35\x2f\x8c\x69\xf1\x7d\x6f\x6d\x23\x57\x8d\x9a\xe3\x6e\x40\xc9\x08\xf8\x9b\x1c\x2a\x8f\x1a\xa8\x34\xa5\x71\xbe\x12\x5e\x73\x4c\x68\xd9\xa6\x05\x74\xaa\x6d\xa3\xad\x53\x08\x59\x82\x80\xcc\x6a\x9d\x14\x44\xfd\x93\x9c\xd6\x08\xe0\xad\x11\x20\xb8\x97\x79\x74\x2b\xe1\x9f\x7c\xff\xf6\x2e\xcd\x8c\x2f\x9a\xe6\x53\xcf\x73\xf6\x95\xd7\x0e\xf9\xf5\x2f\x3f\x8a\x9e\xf8\xf8\xbc\x6c\x2a\x94\x07\xb6\xed\x3f\x49\x08\xe4\xe8\xf7\xe2\x07\xa9\x41\x9a\x36\x69\x47\x0e\x8f\x66\xf1\x22\x29\xe2\xa5\x5e\xc2\xdf\x7b\x28\x8a\xc6\x80\x97\xf1\x60\xe0\xeb\x72\x05\x28\x6e\xe9\x4f\x1e\xf8\xe2\xbe\x22\xfb\xe4\x77\xfb\x9d\x2c\xc6\xd6\x2a\xa4\x33\x1b\x44\x88\xd1\xfc\xbc\xb3\xb2\xf2\x1a\x60\x5d\x22\xa8\xa8\x65\x50\x96\x0b\x20\xa8\xfb\x41\x98\x8d\x81\x2f\x3f\xfe\x2a\xa8\xd1\x0a\xf8\xfe\x13\x3f\x08\x12\x6b\x12\x08\xbb\xc2\x24\xe3\x05\xf6\xe1\x21\xf8\xe5\xcf\xff\x2a\xf8\xc8\x0f\xbe\x0b\xfc\xd0\xff\xf9\x71\xf0\x99\x57\x5c\xa0\xae\x5d\x01\x12\xbf\x07\xbc\x8a\x48\x0a\xa0\x1d\xc7\x98\x77\x00\xf9\xfa\xdb\x78\xcc\x66\x07\xf4\x86\xbf\x76\xed\x0b\xbf\x57\x28\xa6\x7f\xf1\xd6\xc6\x9d\x8d\x5e\x15\xf6\x9f\x1c\x85\x36\x3f\x9b\xf8\xd7\xce\x28\x34\x49\x61\x9c\x89\xc0\x1f\x7e\xe6\x37\x7a\x6f\x78\x15\xbc\x0c\xc0\x5b\x6d\x75\x17\xe2\x5e\xf7\xa1\x0f\xfc\xf0\xa5\xb0\x27\xfe\xef\xa7\x2f\x9d\x1e\x32\x74\x33\x5c\x18\xc9\x83\xe5\x37\x56\x26\x13\x42\xea\x83\x66\xdd\x1c\xc3\x31\xd8\xff\xea\xd2\x38\xee\xdf\xfc\xc9\x27\xf4\x5f\xff\xd1\x4f\x41\x22\x91\x62\xe0\xff\x34\x53\x76\xc0\x3e\x63\x31\x80\x27\x95\xa5\x2c\x05\x74\x4b\x77\x8a\xc5\x89\xb7\xb9\x66\x31\x90\xc2\x11\x1c\x43\xd4\xac\x04\x04\x30\xd4\x07\xdb\x2b\x1b\x14\xee\x67\x07\x8a\xd6\xca\x9b\x96\x39\x55\xa9\x14\x2b\xbf\xf2\x9f\xd4\xe6\xbf\xff\x3f\x9e\xfd\x89\x17\x3f\xc1\x79\xb2\x0f\x20\x70\x47\x20\x60\xdd\x16\xf0\x5c\x7f\x0d\xdc\xbf\x62\x81\xe1\x73\x33\x80\xb5\x1b\x00\x0a\x34\x18\x9a\x19\x05\xc2\x3e\x6e\xc3\x07\x59\xab\xb5\x51\xd8\x79\x27\xf3\xf2\x7f\xca\xd7\x4b\x57\x3f\x4b\x1f\xd6\x0e\xbd\xf8\xda\x84\x85\xe1\x53\x0b\xc5\x5a\x61\xd3\x15\x0a\xcc\x5b\xa6\xc5\x7b\x43\x12\x89\x78\x41\xa3\xd8\x00\xfb\x4b\xdb\x60\xe2\x64\x18\xdc\xff\xe6\x76\x09\x96\xb5\xad\x77\x20\xe2\x20\xb2\xcd\x59\x6c\x55\x80\x3f\xe4\x05\x12\xe7\x01\x6a\xad\x09\x5a\xb8\x8f\x4c\xef\x24\xc1\x99\xfb\x4f\x83\xaf\xbf\xd7\x02\xb7\x87\xb7\x01\xb5\xf5\x16\xb8\x7b\xf3\xeb\x60\x6a\x7a\x18\xce\x1e\x7b\x0a\x9f\x23\x42\x80\x2f\xbe\xe7\x3a\x64\x6d\x52\xb1\x2d\x40\x8e\x22\x19\x66\x52\x70\x09\x28\xce\xcd\x02\x4d\x51\x59\x60\x28\x22\x34\xf5\x10\x67\x33\xc9\x88\x2f\x3c\x22\x48\xac\x88\x17\x3b\x2f\x06\x9b\x9e\xae\xb1\x52\x9b\xb3\x02\xbb\x81\x13\x83\xfb\xbe\x1b\x4f\x75\x7e\x7c\xa0\xa0\xdf\x1b\x2a\x4f\x4e\x8e\xdf\xf7\xc5\xdc\x05\x32\xbd\x7e\xf5\xdb\x9f\xfb\x18\x9e\xc4\x66\xbc\x92\xcf\x6c\xca\x75\x18\xf0\x87\x36\x87\x92\xa3\x2f\x91\xc3\xec\x6e\x6c\x4d\x9f\x3a\x77\x72\xfd\xb0\x94\x0b\xbc\xfa\xd6\xd7\x2e\x49\x82\x0b\x1c\x3f\x7e\xde\x6c\xb4\xea\x60\x79\xe3\x3e\xd0\x0c\xc3\x99\xf7\x0d\xcb\x72\x38\x91\x64\x02\x20\x54\x19\xb2\xb0\x8e\x0f\x4f\xac\x8c\x0f\x4f\xef\xcc\x4e\xce\xdf\x6f\x67\xb1\x4d\xd0\xa8\xd6\x25\x16\x51\x76\xc4\xef\xdf\x65\xa1\x59\xbc\xf7\xe0\x8d\x4b\x0b\x13\xa7\x6d\xa2\x61\xeb\xf3\xfa\xd7\xfc\x21\xff\x6b\xa4\x6b\x1f\xee\x95\x93\x93\x13\xd1\xd5\x8e\x38\x2f\xf8\xc6\xeb\x5f\x79\xd7\xc1\xc1\xde\xc2\x93\x0b\xcf\xd8\x24\x4b\x45\xb2\x9d\x82\xc8\xaf\x48\x22\x6a\xec\xa7\x0b\x41\x88\x74\x86\x63\x90\xe5\x71\x7b\xea\xc9\x31\x31\x23\x2b\x2d\xbe\x5e\x2b\x24\x4e\x4f\x9f\x46\x2c\xc3\x22\x49\x12\x37\x03\x41\x3e\x8f\xc1\x85\xff\xc1\xbd\x47\x0b\x96\x69\xdb\x02\xcf\xa8\xc0\x94\xdd\x18\xd8\x89\x8d\x6a\x39\xb0\xb7\xb5\x15\xb6\x4c\x24\x3d\x71\xea\xd4\x92\x10\x71\xd5\x1e\x3c\xbe\x39\x37\x37\xb1\x88\x08\xcd\x02\xcf\x09\x8d\xc4\x50\xf0\x0e\x59\x1f\x64\xb9\x50\x4f\x0d\x89\xe5\x70\xc8\x5b\x17\x59\xbf\x47\xab\xc2\x51\x3c\x2a\xc8\x98\x82\x2e\x89\x83\x13\xd3\xe3\xca\xe1\x61\xd9\x50\x5a\x8a\x53\xe2\x1d\xf4\xfb\xca\x52\x48\x28\x97\xab\x65\x4f\xb9\x52\xf2\x8f\x26\xc7\x9d\x2c\xba\xa6\x2b\xa0\x50\xc9\x07\x72\xc5\x7d\x10\xf0\x05\x4a\x4f\x9f\xbf\x78\x33\x1a\x8d\x57\xc8\x2d\xd7\x8a\x2d\xc9\x17\x76\xb7\x96\x56\x97\x26\x23\x81\x04\xe3\x16\x3d\x88\x14\xde\xe1\xf6\x79\x8c\xa3\x24\x9d\xe3\x61\xd9\xe5\x63\x4a\xa8\x4f\x20\xef\x09\xb1\x22\xd8\x17\x8a\x1e\xe0\xec\x52\xdd\x12\xa1\x8e\xf8\x34\x31\xe6\x60\xf4\xaa\x2e\x28\x26\x2d\xe9\x16\x25\x21\x48\xf3\xc4\x7f\x3b\x18\x0c\x36\x12\x53\xc9\xb2\xa2\x2a\xec\xf6\xce\xf6\xd8\x53\x8b\x97\x30\xe8\x72\x01\x51\x92\x6a\xe1\x78\xb2\x46\x68\x05\xd5\x6a\x4d\x50\x14\x95\x52\x64\x85\xa0\x7b\x2b\x1a\x0c\xb7\x26\xe6\xe6\x34\x5e\x60\xbb\x52\x73\xf4\xdb\x18\xeb\x5c\x30\x31\x42\xaf\x6f\xe6\x25\x0b\xd1\x02\xe1\x53\x0d\x8d\x8f\x17\x29\x41\x04\x77\xae\xbe\x3e\x33\x3a\x34\xe5\xc8\xcd\x91\xc0\x22\x31\x9e\x5c\xa3\xdd\x22\x06\x9a\x07\xc2\xfa\xca\x66\x42\x91\x35\x1f\xcd\x0a\x78\x66\xc7\x41\xcb\xa9\xf9\x03\x46\x12\xed\x3b\x77\x6f\xcc\x8c\x0d\x4d\x33\x0c\xcb\x39\xed\x12\x4c\x45\x57\x38\x8f\x84\xd2\xd9\xa2\x4f\x35\xe9\x68\x7c\x74\x74\x8f\xf5\x78\xd0\x6b\xd7\xdf\x5c\x9c\x19\x5b\x60\x71\x10\x84\xe3\x4b\xa6\x92\x9c\x1e\xba\xe9\x2c\xea\x15\x4d\x1c\x3d\x39\x43\x84\x95\xd0\x17\xbe\xf4\x99\x67\xd2\x7b\x5b\x23\xc3\xd1\x11\xe0\xf5\x04\x7a\x84\x4a\xc6\xed\x2e\x42\x77\xc0\x2a\x37\xf6\x3c\xb4\xe0\xd5\x43\xc3\xe3\x65\x20\x0a\xe6\xee\x41\x76\x78\x72\x78\xb6\x1d\xee\x13\xfe\x6e\x32\xb5\x8a\x68\xc6\xca\x1c\x6e\x04\x4c\xe8\xe2\x48\x90\x1f\x9f\x3c\x76\x60\x09\x01\xf3\xe6\xc3\x37\x8e\x8f\xa6\x66\x7a\xf7\x16\x1e\x1d\x7d\x80\x7f\x6f\xa7\x77\x33\xae\x8d\xc7\xbb\x49\x5d\xd1\x82\x36\xed\xb6\x08\xbd\x65\x6c\xfe\xe4\xae\x25\x48\xe6\xf5\x9b\xd7\x4e\x8f\x26\x67\x58\x9a\x69\xdf\x9b\x3b\x96\xbc\x67\xbb\x82\x66\x36\x9f\x16\x65\xdb\x1d\x73\x25\x53\x1b\xc5\xf2\xa1\xf7\x9b\x6f\x7c\xf3\x05\x37\x1e\x8f\x73\xb3\x0b\x0e\x67\x77\xe5\xe1\x15\x3c\x37\x9b\x4e\xca\x95\x70\xbf\xc9\x9c\xe5\x04\x49\x44\x09\x84\xa2\xd0\xf4\xd4\xc9\xcd\x89\x89\x63\xfb\x33\xc7\x4e\x2e\x77\x81\x0f\xcd\xf2\x4d\x23\x10\xa6\xa8\xa8\x47\xb5\x8f\x14\x0e\x38\x5b\x56\x68\x20\xe7\x08\xfa\x1a\x33\x08\x80\x23\x92\x6f\x1d\xf0\x08\xfb\x4e\xde\xdd\x04\xe8\x80\xbb\x77\x2f\xc1\x0a\xdb\x65\xd1\x3d\xc0\x45\xc1\xa3\xca\x7a\x70\xc0\xef\x45\x08\xe1\x68\x3a\x31\xa6\x48\x23\xc5\xd6\xe3\x87\xab\xf5\xe5\xb5\xb5\xe1\xa9\xdc\x9c\x2f\x31\xe6\xf9\xc5\x37\x7f\xe7\x33\x1f\xe3\x3d\x52\xc2\x23\x81\x4f\x87\xe3\x13\x9b\xec\x24\x57\x43\x5d\x48\xd7\x4f\x45\x23\xd4\xf7\xc4\xe8\xa1\xd2\x6e\xf5\x70\x97\x7b\xdc\xa1\xd8\x0e\xd4\x69\xf7\xd8\xcc\x5d\x13\xb6\xb7\xff\xb9\xbf\x02\x75\x5c\x73\x40\xc7\xeb\xab\xe3\x30\xde\x09\x16\xba\x6a\xc6\x03\x2a\x29\xbd\x0d\xb7\x8e\xaf\x66\x9f\x2c\x41\xa1\x7e\x60\xd0\x75\xff\xeb\xd8\x58\xa1\xb6\x45\x5d\x8f\x84\xd0\xbe\x15\x29\x81\xd4\x39\x9f\x75\x6f\x65\x39\xbd\xb2\x57\x6f\xb9\xc6\x93\xc7\x89\xd0\xa1\x31\xee\xb3\x9a\xd1\x38\xa5\x90\x37\x35\x1d\x4b\xc5\xb6\x4d\x13\xec\x53\xe5\x1c\xdd\xa2\x9e\xc6\x27\xec\x9c\xc6\x86\x54\x26\xed\x4d\x14\x0a\xe9\x4b\x70\xd2\x3e\xbe\xb3\x88\x50\x63\x08\x59\xbc\xcd\xda\x1c\xc0\x6b\x3d\xc5\x38\x1f\xd1\x0c\x9b\x55\xa0\xe5\xab\x55\x4d\xf1\xf0\xd0\x8e\xe7\x2a\xf2\x6c\x34\x47\x65\x0a\x5f\xa6\xb7\xdc\x2e\x94\x19\x3a\x65\x95\x7d\x23\x8e\xd8\xb2\x93\xcf\xbf\xf8\x5e\x90\x7f\xf0\x7a\xf6\xcd\xdc\xed\x66\xc6\x0c\x47\xc6\x9b\xc3\xb1\x51\x1a\x9a\x78\x48\xdb\x40\x13\x25\x48\xd5\x1b\xc8\xb6\x30\xf4\x4d\xa4\x40\x64\x5a\x9f\x40\x1b\x8f\xe5\xfa\x1a\xb8\x71\xfc\xbd\xba\x3c\x32\x09\xb2\xf7\xbf\x20\x35\xc4\x43\x90\x9a\x36\xc4\x13\xdb\x86\xec\x6d\x86\x55\xc0\xe1\x13\xd1\x12\x0d\x39\x05\xd8\x3e\x3c\xfd\x52\x5e\x88\xf2\x4f\xd4\x38\xcb\x6b\xcd\x8e\x2d\x01\x96\x3a\xd0\x57\x16\x3f\x08\x74\x22\xb7\xe7\xa8\x66\x39\x05\x8b\x64\x43\x1a\xd5\x6e\xde\x2b\x9b\xa8\x65\x26\x5b\x29\xe0\xd7\x3c\x6e\xd8\x94\xdc\x6c\x54\xe6\x82\x3b\x6b\x57\x72\x51\x71\x54\x5d\xd4\x91\xba\xd4\xa8\x32\x3e\x3c\xef\x8a\x2a\x0d\x44\x17\x0f\x9a\x33\x06\xdd\x5c\xd3\xb8\xc8\x3e\xad\x08\x1a\x46\x47\x74\xdb\xdd\xcd\x95\xcd\xa3\xe6\xe8\x28\x50\x63\x61\x28\x94\x8a\xe8\x9f\x0a\x78\xc9\x96\x56\x73\x3b\xbf\x91\x9d\x1d\xa9\xdc\xbf\x75\x4b\x3a\x39\x3e\x6b\x02\xce\x6f\x53\x1f\xfe\xb8\xcb\xfa\x83\xdf\xb8\x1b\x08\x4e\x06\xd5\xf8\x53\x89\x5c\x6b\x1f\xf8\x30\x82\x27\x72\x81\x64\x85\x92\xda\x80\x91\x31\xa9\x76\x7a\x83\x64\xbf\x04\x8a\xf8\x9b\x53\xb4\x48\xe4\x61\x28\x96\x75\xbb\x93\x2c\x97\xbb\x92\xf3\x67\x5f\x7b\x24\xfd\xd4\xaf\x7b\x10\x6c\x9b\xd5\x83\xcb\x2f\x3b\xc2\xd1\x7f\xfd\x67\x2f\xfd\x3e\x59\x74\xc1\x13\x57\x9e\x02\x7f\x29\xfe\x0e\x78\xeb\xf6\xe7\x81\x5c\xaf\x82\x1f\x9b\xff\x31\xf0\x44\xec\x3c\xa8\x16\x2a\x60\xdb\xb7\x8b\x7b\x5e\x0b\x9c\x10\xc7\xc1\xcf\x5d\xf8\xb7\xa0\x20\x19\xe0\x57\x0f\xff\x02\x2c\x7d\xee\x1e\xf8\x5e\xe6\x22\x48\x9e\x8c\x03\xf6\x32\x0d\x6c\x9e\xd4\xc8\x35\x80\x60\x90\x64\x1b\x83\x23\x83\xbf\xb7\x39\x08\xd8\x2d\x75\xb2\xbf\x64\x72\x36\x31\xd8\x6d\xfe\x5d\xc9\x4d\x3c\x8d\x03\xd9\x55\x07\x2d\xb2\xc2\x1d\xa2\x77\x32\xf3\x20\xca\xc8\x89\x77\xbf\xfb\x03\xef\x3b\x36\xb7\xf8\x2b\xe1\xa9\x94\x8b\xc3\x80\x6e\xff\xb5\xfb\x80\x93\x78\xf5\xee\xf2\x2d\xea\xeb\x97\xbf\xf4\xb9\x0f\x3e\xff\xfd\x27\x62\xbe\xf8\x9e\x1e\xe2\xbf\xf6\x1b\xbf\xf7\x72\x84\x59\x06\x4d\x83\x52\x7f\xf4\x0f\xff\xe6\xb7\x9c\x03\x7d\xe2\xc3\x3f\xed\x20\xf3\xb6\x48\x10\x06\x3a\x2c\x0d\xba\x6b\x1c\xa0\x0d\xe4\x18\xc1\xe3\x9f\x3f\xf5\xf9\xdf\x1a\x04\xf3\x84\x1b\x94\xee\xce\x9c\xbb\x85\x25\xf4\x2b\xbf\x84\xfe\x8b\xaa\x3d\xfd\x63\x17\xde\xc5\x45\xdf\xfa\x12\x05\xa2\x49\x08\x8e\x2d\xea\x80\x63\xbe\x0d\x1e\x6f\x72\x20\x34\x85\x81\xae\x60\x02\x43\x33\xc0\xf6\xab\xf7\x3f\x2b\x97\xaa\x7f\x60\x05\xdc\xe8\xef\x77\xd7\xfc\xbb\xbf\x06\xae\x6b\xf0\x00\x8e\x70\xc6\x56\x6e\xed\xe0\x85\xd8\xfb\x2e\x28\xe5\x0a\xeb\x4e\x04\x1c\xad\x55\x96\xa1\x40\x20\x15\x06\xd9\x6a\x13\xec\x2d\xe5\x2b\xa7\x9f\xf6\x7c\x7e\x7f\xcf\x90\xb2\x45\xe3\x48\x59\xa6\x69\xb1\x78\x4d\x94\xc0\xef\x7f\xf9\x97\xc1\xcf\xff\xfa\x4f\x83\x1f\x38\xf7\x71\xf0\xea\xaf\x7e\x0b\x3c\x3a\x58\x01\x25\x97\x0c\xd6\x82\x87\x40\xc3\xf3\x80\x5b\x93\x31\xbc\xf0\xc3\xef\x79\xfe\x7b\xa0\x5b\x92\x20\x2b\x04\x20\x5e\x90\x21\xd9\x49\x61\x70\xec\xc6\xe3\x9e\x2a\x7a\x38\xc8\x88\x14\xa4\x38\x88\x9b\x97\xf0\xbf\x19\xc2\x11\xa5\x1a\xb5\x96\x5e\x5c\xa9\xd7\x10\x45\x2f\x20\xc1\x22\x3c\x42\x6d\x02\x80\x82\xd1\x30\x0f\x5b\x0d\xd9\xac\x35\x6a\x5a\xa5\x51\xd6\x88\x6b\x3a\x44\x24\xd0\x83\x1e\x37\x2f\x85\x45\xc1\x25\xf9\xfc\x5e\xcd\x97\x90\xca\xe4\x5a\x33\xd9\x9d\x91\xdb\xf7\x2e\x7f\x80\xa6\xe8\x04\x71\x01\x22\xd9\xa0\x68\x38\xb9\x35\x7f\xe2\xdc\x5f\x91\x87\xf7\xf8\xe1\xe3\x11\x55\x91\x87\xf1\x58\xd9\xd2\x0d\x59\x22\xe3\x88\x48\x98\x85\xfc\x11\x47\xb7\x57\x56\x9b\x00\x03\x61\x27\x1b\x36\x35\x31\x73\x1f\x83\xd6\x2a\x61\xbf\x0c\x27\xc7\x76\x87\x12\x23\x79\xd8\x93\xe8\x24\xbe\x82\xed\x64\x4f\x62\xd4\xaf\x25\x47\xcf\xde\x21\xcd\x7d\x58\x29\x84\xab\xb5\xe2\xa8\x47\xf2\x3a\x3b\x25\x9e\x80\x70\x9b\x77\x41\x67\x50\x8c\x1e\x0b\x91\x9d\x0e\xf6\xea\xad\xb7\xce\xde\x5d\xba\x7f\x46\xd3\x55\xde\x2b\x7a\x80\xc7\xd9\x6e\x6e\x67\x92\xbc\x7e\xd7\x0e\x87\x9b\xa8\x50\x38\x4c\x76\x4c\x93\x40\x34\x12\x2a\x31\x2c\x64\x57\x97\x1f\xcf\x05\xbc\x01\x48\x2c\x70\x09\x00\xf0\x07\xa5\x35\xbc\xee\x73\xd5\x72\x45\xc2\xff\x2a\x0c\x4f\x5b\x14\xe1\xd2\x1b\xb6\xd7\x30\x2d\xd1\xd0\x2d\x1c\xec\xd8\x1e\x8e\x15\xcc\xd8\x68\xa8\x22\xab\x8a\x74\x70\x70\x30\x39\xf9\xc4\x3c\x24\x00\x5b\x94\xf8\x0d\x1c\x41\xb0\x24\x2b\x8c\xef\x4d\xe6\x39\xd1\x0f\x10\x9d\x92\x89\x81\x05\x91\xc1\x31\x69\x4e\x6e\x68\xd3\x04\x4c\x7a\xfc\xae\x65\x7f\x28\x68\x96\x2a\x75\x96\xb0\x7c\x46\xc7\xc7\x0b\x34\xcf\x0b\xeb\x7b\x5b\x93\x3c\xcf\xc3\x70\x20\x0a\x2a\xf5\x22\x20\x41\x83\xa2\xc9\x60\x72\x7c\x3a\x73\xf1\xe2\x73\x57\x9d\x21\x9b\x2b\x06\x33\xdb\xd9\xf8\x99\xa7\x17\xd7\x65\x55\x76\xaf\xad\xaf\x1e\x7f\x72\xf1\x79\x47\x56\x0d\x07\x9c\xad\x68\x2a\x9a\x26\x22\xa0\xe1\x94\x54\x61\x5d\x34\x0f\x8f\xd8\x3e\x0f\x62\x5f\x08\x06\xd8\xf5\xa8\xeb\xed\xd4\xa5\x37\xe0\x7b\x85\x16\xd5\x12\x4c\x7c\xb9\x26\x42\x3e\x04\x68\x37\xc4\x08\x8b\xc1\x4b\xda\xe8\xf8\x68\x81\xec\xac\x3c\x5c\xba\x39\xca\x32\x1c\xeb\xf3\x38\x82\x1c\x40\x0a\x7b\xf6\x69\x81\x75\xac\x80\x59\x4e\x50\x42\xe1\x88\xe9\xf1\x79\x2c\x96\xa7\x8f\x0c\xa2\xbd\xad\xed\x31\x5d\x35\xfc\x46\xcb\x18\xc3\xed\xe9\xf0\x8e\x63\x13\xb1\x57\x7d\x41\x5f\xc5\x25\x8a\x50\x55\x75\xda\xe7\xf1\xca\x43\x33\xb1\x22\x06\xd5\xdc\xfe\xfe\x5e\xea\xc9\x13\xcf\x3a\x57\xe8\xf6\x4a\xf9\x40\x2c\x98\x33\x31\x5a\x6b\xaa\x4d\x9d\x66\x39\x83\xa2\x4c\xa2\xe4\x88\xe6\xe6\x66\x76\xfc\x09\x6f\x63\xff\x20\x13\xd8\x5c\x7b\x3c\x4b\x32\xc2\x04\x20\xb8\xfd\xde\xb4\x3f\x1c\xce\xc9\x8d\x16\xbd\xb1\xba\x33\x86\x9f\x0b\x1f\x4a\x46\xcb\xc4\xfa\x63\x6f\x77\x7b\x78\xe4\xe4\x8b\x88\x63\x78\x1c\x50\xfb\x96\xf0\x44\x45\x98\x9f\x48\x0c\x72\xf5\xed\x9d\xb5\xc4\x6b\xdf\xfe\xda\xf9\x72\xa5\xec\x61\x69\x1a\xb5\x8b\xc8\xfa\x34\x7a\x6f\x24\xba\x82\xbb\xae\x59\xad\x34\xbc\xc9\xa1\xe1\x7d\x31\x2c\xe1\x73\xef\x85\x9b\xb5\x4a\x30\x38\x1b\x71\x50\x0f\x2f\xb9\xb7\x19\x5e\x68\x55\xcb\x55\xae\x56\xae\x86\x31\x46\xa1\x3d\x5e\x5f\x3d\x39\x9d\xd8\x57\x94\x16\x97\x3f\xd8\x1e\xbd\x30\xff\x9c\x83\x36\x5c\x1e\xcf\x41\x20\x1e\xdb\x33\x4d\xc3\xaa\xb7\x1a\x88\xe3\x59\xcd\x36\x4c\xc7\x28\x65\x66\x76\x6e\x35\x34\x12\x2c\xa7\xd3\x5b\x91\xf4\xe6\xf2\xfc\xc5\xd3\x2f\x3a\x73\x9c\xcb\xef\xdb\x0c\x0d\xc5\xb6\x5a\xcd\x16\xbb\xb3\xbe\x3e\xce\xb3\x02\xcd\xbb\x58\xcd\x20\x5b\x8a\x64\xb3\x10\x77\xe6\x90\x3f\xdc\x19\x8f\x0d\x70\x58\xce\x3b\xe3\x71\x76\x66\xf1\x91\xe4\xf1\xd5\xc9\x9b\x46\x47\x26\xd3\x89\xa1\xb1\x43\xf0\x1d\xa2\x74\x04\x08\x18\x42\x3d\x9d\x9d\x0f\x08\xf4\x0d\x31\x1e\xae\xa1\x8e\x3c\x8f\x6d\x77\x2d\x65\x60\x8f\x71\xda\x4b\x89\x76\x11\x24\x04\x83\x3a\x77\xe8\x88\x3c\xcd\x20\x7d\xa6\x6b\x7c\xdd\xfb\xb5\xdd\x27\x3c\x38\x42\x22\xf6\x60\xa6\xb7\xef\xb2\xd3\x4d\xc2\xd2\x08\x05\x47\x43\xf2\x9c\x18\x6c\x41\x6e\xa9\xb9\xb6\xba\x19\x93\x97\x47\x7d\x78\x9e\xf9\xcb\x82\xbc\xef\x8b\x84\x67\x57\x3d\xa7\x82\x1b\x36\xd3\xdf\xb0\x87\x7d\x65\x76\xc7\x01\x69\xb0\xa2\xba\xeb\x8a\xdc\x75\x3c\x86\x1d\x43\xb8\x01\xbd\x9c\xbe\x9a\x0e\xea\x57\xd8\xf5\x44\xae\xed\x2e\x62\x86\xc0\xd4\x4d\x68\xe1\x68\xd1\x90\x6d\x56\x0a\x73\x32\x40\x10\xf4\x09\x0f\xb0\x63\xae\xd1\x61\x28\xd8\x5d\x44\xdc\x69\x24\xd4\x1d\x9b\x47\x6e\xbd\x27\x73\xd4\x69\x2a\x84\xfa\x24\x63\x30\x60\x5f\xd9\x35\x54\x47\xbc\x08\xec\x93\xcf\x06\xc8\x92\xdf\x1c\x5c\x0b\xeb\x05\x9d\x97\x2b\x26\xa7\x37\x75\x86\x66\x6c\xdb\x1d\x65\x15\xc6\x25\x98\x0c\xcf\x5a\x1c\x87\xba\x1c\x8a\x01\xa9\x23\xa2\x52\x45\x18\x4d\x74\x52\xb5\xec\xe1\xd6\x04\x84\xb5\x14\x42\x5e\x43\x00\x01\x4b\x44\x64\xee\x77\x78\x50\x24\x14\xa2\x9c\x8a\x3f\xdb\x08\xdb\x94\xe1\x31\xb8\xa2\xa9\xf9\x8b\x75\xc3\x1b\xda\x43\x23\xc1\x7d\x2a\x57\xbb\xc9\xae\xf8\x56\xa9\x6d\x69\x08\xb6\xa4\x14\x34\x79\x11\xda\xd3\xcf\x02\x39\x5e\x41\x8f\xb3\xcb\xf9\x4c\xf9\x6e\x69\x47\xf1\x05\x52\x72\x22\x30\xca\x00\x9b\x21\xd9\x5a\xdd\xe7\x81\x06\xc6\x11\xda\x48\x14\x49\xb5\xc2\x71\x76\xad\x82\xca\xaf\xc7\xae\x86\xde\x53\x33\x4e\x7f\xcc\x68\xed\xec\xb1\x9b\xbc\xe1\x29\xcb\xf7\x1a\xe1\xba\xa1\x0d\x2b\x67\x2c\xaf\x1c\xa5\x38\xb2\x0b\xcd\x92\x17\xa2\xf1\x42\x27\x82\xdc\xf1\x16\x32\x39\x30\x36\x7e\x1b\x08\x37\x5e\x36\x56\x5f\xf8\x08\x55\xef\x15\x50\x76\x1a\xe8\x3d\xdf\x65\xb6\xae\xbf\x54\xd8\xe3\xaa\x0d\x4d\xf3\x4b\x1e\xd3\x23\x51\x75\x8f\xee\x9a\x9f\xc6\xbd\x71\x6a\xcf\x72\xd7\x92\xa5\xdd\xcf\x65\xfd\xcd\x8f\x40\xd6\x0a\x78\x90\x5f\xe1\x91\x11\x34\x50\x71\x52\x63\x7c\x25\x9b\xb8\xaa\x58\x82\xe3\xfb\x87\x00\xdf\x6c\x21\x7b\x73\x03\x28\x13\x53\x08\x4f\x8a\xdf\x99\xe1\xb5\xfe\xe1\xb8\xc4\xec\x00\x5e\x02\xfa\xfc\xeb\xb9\x2b\x5f\x96\xee\x7e\xcf\xc9\xf9\x13\x16\x73\xec\x9c\x61\xce\x9e\xa5\xa8\x0f\x7c\x14\xa2\x2f\xfc\xee\x1b\xb1\x27\x99\x77\xa1\xe8\xb9\x70\x51\x29\xd2\x8c\xd1\xd2\x44\x0a\x50\x1a\xc6\x5b\x3a\x11\xe4\xef\xd4\x51\x92\x59\x19\x43\x07\x8a\x23\xf3\x08\xe7\xe1\x39\x21\x00\xf8\xdc\xf5\x42\xf0\xce\xef\xbd\x11\xfc\xa1\x7f\xc5\x82\xb1\x33\x04\x2b\xdb\xf0\xfe\x9b\x90\x7a\x7c\x8b\x02\x29\x1f\xfb\x0b\x3d\x8b\xbb\x5b\xa7\xc1\xba\xf5\x4d\x20\x53\xd5\x23\xa4\x1c\x47\x70\x9c\x28\xfd\x1d\xd1\x60\x1d\x24\x3a\x39\x4e\xc6\x0e\xda\x33\x89\x2c\x0b\xb1\xfd\x33\xdb\x43\x1d\xe3\x28\xf0\xcf\x3f\xf6\x1f\x88\x10\x18\x10\x70\x30\x26\x20\x0b\xaa\x16\x03\x1a\x18\x50\x7f\xe3\x5b\x9f\x83\xbf\xcd\xfc\x2e\x08\xfe\x5c\x08\xe4\xcf\xe6\xe4\xbf\xf9\xf3\xcf\xaa\xbc\x87\x45\xf1\x46\x1c\xfa\x64\x2f\x53\x09\x96\x81\xcd\x69\x40\x2c\x06\x60\x4b\x17\xa1\x1e\xa4\x00\xef\xc3\x93\x6a\xbd\x05\x68\x41\x87\x3c\x51\x5a\x0b\x00\xf0\x33\xff\xe3\x4f\x13\x9e\x2e\x68\xd6\x1b\xf0\xd1\xf2\xb2\x7b\x23\xb3\x9d\x1a\x1e\x9a\x7c\xfe\x89\x93\x4f\xfd\xc7\xd0\xe4\x90\x0b\xb8\x68\xb0\x77\xeb\x71\xd5\xd2\xcc\x83\x4a\xad\xfa\xb7\x92\xdb\xe5\xb7\x50\x68\xdc\x6e\x99\x2f\xb8\x4e\x06\x5b\xf4\xf4\xb1\x9f\x70\x9d\x99\x01\xd6\x0b\x06\xa8\xfc\xd1\x67\x3f\xf1\xb3\xff\xfc\x7f\x0e\xb6\xa7\x0b\xbb\x5f\x00\x85\x8e\x7a\xb0\xf6\xf3\x3a\x10\xfc\xe4\x27\x7f\x0a\x0c\x98\xd0\x02\xdd\xd0\xe1\xda\xf6\x9a\xbc\xb9\xbb\x55\xac\x35\xaa\xbe\x62\x73\xfb\xe0\xbf\xff\xd7\x91\x6b\x89\xf8\xd4\x07\xcf\xbe\xcf\x04\x99\x65\x08\x3e\xf5\xa5\x17\xc1\xf3\xe7\x97\xc0\x85\xd8\x37\xc0\x8d\xf5\xf7\x81\xf0\x64\x12\x5c\xf9\xe3\x2f\x7e\x51\x6e\x95\xfe\x97\xf0\x38\x29\x5b\xb4\x43\xe0\x9f\xf8\xf5\x53\xff\xec\x27\x8f\xfc\x2c\x2b\x32\xb5\xb4\xb2\xe4\xdb\x3b\xd8\x93\x5a\x8a\x0c\x85\x80\x6b\xe8\xce\x57\xbe\xfd\xea\xc5\x70\xe0\x5d\x52\x32\x04\x0c\xc3\x02\xf5\xbd\xbc\x72\xf8\x60\xab\x50\xca\x65\x7f\x5e\x6e\x05\xab\xbc\xdb\x16\x02\xfe\xa3\x35\x98\x96\x65\xe2\xf9\xa0\x0a\xfe\xe5\xc7\x7e\x1c\xd0\x18\xb0\xff\x6d\xfa\x25\xd8\x0a\xb7\xa0\x14\xf0\x80\x1a\x5f\x87\x37\x17\xdf\x80\xa2\x06\xe0\x2c\xfe\x18\x95\x14\xf1\x88\x10\x9c\xc2\x5c\x9a\x32\x30\xde\xc0\xff\xf2\x54\x5b\xfe\x03\x4f\x72\x96\xa9\x40\xd4\x68\x73\xa3\x75\xd8\xe3\xff\x3a\xb5\x85\x7e\xbf\x37\x5c\x33\xea\xc9\x42\xa5\x10\x28\x95\xf2\xc7\x66\xa7\x4e\x5c\xe3\xbc\x14\xe4\x3c\x12\x08\x00\x09\x8c\x82\xa1\x8e\xea\x14\x1c\x74\x4c\x75\x04\xbe\xcb\xd5\x42\x6a\x75\x63\x69\x71\x7b\x67\xf5\x49\x72\x58\xcb\xb6\x20\xb1\x20\x1e\x1f\x99\x59\x7b\xe2\xd4\x85\x2f\xe1\x69\xdc\xf3\xf8\xd1\xea\x68\x26\x9d\x59\x20\x6a\x39\xf5\x42\x79\x64\x2c\x35\x52\x9e\x3f\xb6\x70\x3b\x9d\xde\x3e\x2b\x62\x10\x19\xf0\x85\xc0\xe4\xf4\xd4\xa7\x05\x9e\x3b\xec\x9b\x13\x0f\x2a\x21\x5b\x42\xc7\xdd\x8c\x2f\x97\xeb\xf3\x78\x12\x9d\x27\x64\x24\x96\xa7\xae\x04\x23\x1e\x87\x5f\xb8\xb3\xb7\x31\x46\xf4\x8e\x2b\x8d\x12\x0e\x6a\x5c\x44\xea\x8b\xc1\xc8\x86\x69\x36\x5b\xde\xdd\xcc\xee\xd4\x9d\x07\xb7\xce\x54\x1b\x35\x5e\x73\xe4\x87\xa0\xa3\x5d\x4a\x39\xba\x27\x10\xd0\x0c\x5d\xe7\x79\x2e\x53\x2d\x37\xf9\x5c\xb6\x38\x64\x3b\xee\x82\x94\x11\x0e\x87\x0e\x0d\x1c\x6f\x61\xb0\x9a\x1c\x4f\xcd\xb6\x6d\x77\x69\xa6\x2e\x88\xae\x03\x4d\x33\x6d\x55\x57\xcb\x6e\x8f\xdb\xc4\xef\x67\x89\x2b\x31\x06\xba\xa2\xa6\xdb\x12\xc6\x57\x22\x99\x14\x3d\x7e\x6f\x89\xb0\xa6\x33\xf9\x6c\x08\x9f\x97\x23\x4f\x82\xe8\xce\xb2\x02\x5b\xc2\x01\x06\xa0\x79\x86\x04\xd2\x38\xa4\x75\x5c\xa5\x60\xab\x25\x4b\x85\x5c\xe9\x84\xa5\x81\x29\xc2\x9b\x12\x44\x21\x2f\x05\xa5\x65\x7f\x38\xd8\x44\x1b\x7b\x84\x3b\x02\x43\xf1\x50\x9d\xa4\xb5\x1e\xaf\x3e\x9e\x10\x05\x37\x20\x19\x63\x59\x69\xaf\x4d\x13\x13\x53\x9b\x27\x4f\x9d\x71\xda\x63\x79\x79\x35\xb5\xb9\xb2\x3d\x76\xfe\xc9\x27\x97\xc9\x35\xdc\x7f\x78\x7f\x4c\x74\x79\x58\xc9\xe5\x71\x78\x9c\x9e\xa0\x77\x9b\x6c\x60\xf1\x12\x8b\x23\x31\x4e\x1d\x58\xa2\xe1\x80\x64\x33\xec\x6e\x93\x76\x6d\xff\xda\xf6\x2c\x54\x7f\x54\x42\x87\xce\x40\xd7\x6a\x0a\x57\xaf\xc8\x62\xab\xa1\xb8\x35\xdd\x20\x24\x3c\x72\xbd\x56\x24\x1e\xa9\x13\xe0\xbc\xb9\xb1\xe6\xe8\x32\x33\x74\xdb\x3c\x59\xf4\x88\x87\xe4\xb3\x89\xa1\x98\xfa\xf6\x4d\x95\x46\xa3\xee\xde\xde\xda\x4c\x2c\x2f\x2d\x9d\x20\x99\x4c\x59\x6d\x39\x2d\x44\x9c\xd0\x66\x67\xe6\xf7\x45\x8f\xab\x52\x29\x57\xf9\x7a\xad\xe1\x27\x1f\x1c\x1e\x49\xe5\x21\x45\xdb\x2b\xab\xcb\x49\x81\x71\x31\x38\x48\x44\x24\x6b\xef\x8b\x04\x36\x89\x17\x98\x6e\x28\xb2\xae\xdb\x41\xfc\x5c\x18\x62\x58\xc3\xd2\x9c\x3d\x3c\x3e\x9a\x27\x42\x2a\x57\xaf\xbc\xb1\x30\x37\x71\x92\xc8\xf2\x38\x85\x7d\xd1\x91\xd4\x6d\xfc\xf8\x8d\xd5\xe5\xad\x84\xae\x9a\x7c\x38\x1c\x29\x52\x0c\xa3\xae\xaf\xaf\x24\x5a\xad\x16\x5b\xae\x15\x81\x57\x22\x6a\x0a\x50\xc5\xef\x33\x37\xd7\x1f\xcf\x6c\x6e\x3c\x1e\x23\x80\x97\x14\xe0\x91\xf3\x92\x85\xa6\xde\xac\xb4\xd3\x72\x04\xd0\x0b\x7c\x91\x66\xd9\x56\x31\x57\xf0\xb4\xea\x2d\xf7\xfc\xfc\xe2\x32\x1e\x86\x06\x0e\x02\x26\x13\xe1\x21\x44\xfa\x44\x07\x6c\x6f\xd2\x14\x65\x64\xd3\xfb\x11\xdb\xb2\x88\xa0\x1c\x1a\x4a\x0d\xed\x62\x90\xa5\x2d\x3f\xba\x3d\x89\xef\x8d\xc5\x60\xd4\xb9\x37\x6f\x28\xb8\x84\xc1\x9f\xa6\x6a\x6a\xd3\xd2\xb5\xa8\xa5\xeb\x34\xb1\x5f\x67\x29\x4a\xc7\x03\x6c\x8f\x54\xdb\x5d\xbf\xfc\xcd\xb3\xc7\x27\x4f\x3a\xb2\x7e\x4e\xb1\x63\x2a\x75\x19\x99\xa6\xb9\xf1\xe0\xf1\xb0\xd6\x90\x03\x8a\x2d\x73\xc5\xdd\xbc\x67\x28\x91\x3a\x58\x58\x3c\x77\x6b\x67\x6d\xf9\x09\x62\xe8\x41\x8c\x53\xa6\x17\x4f\x7e\x9a\x97\xa4\xc3\x41\xbb\xd5\x1e\xe9\xd4\x6c\xaf\xba\x06\x1e\x8f\x95\x83\xec\x02\x30\xec\x05\xdc\x23\x7c\x82\xcf\x73\xd9\x1d\x0d\xdf\xd0\x2b\x75\xc9\x3f\x1c\x3e\x44\x5d\xd3\x43\x04\xbf\xc3\xc3\xb9\x9b\xe4\x44\xed\xd2\x8d\x0e\xf6\xb3\x3b\xd6\xc2\xfd\xbd\xff\xb6\x11\x60\x3b\xc5\x61\xb7\xd5\xf1\x7b\xc8\xd8\xf9\xb8\x05\x8f\x68\x8e\x77\xf3\xc7\x5d\xf6\x6f\x4f\xbe\xa1\xbb\xdb\xdf\xa1\xcf\x72\x42\x4c\x1f\x9d\xe3\x54\xd6\x15\xaa\x99\x8a\xce\xd8\x71\xb7\x36\xe9\x3a\x4b\x89\x51\x49\x96\x75\xcb\x82\x7a\x27\xe3\x4c\x75\xb7\xec\xed\xb6\x3f\x68\x17\xff\xc2\xde\x82\xd5\x07\xc4\xb0\x2b\x27\x34\x50\x11\xd2\x05\x95\x68\x20\xdb\x4c\x39\x7a\x7a\x40\x55\x55\x0a\xc7\x2b\x30\xb7\x5e\x8c\x1a\xb6\x0e\xb4\xb2\x3d\x06\x2c\x4a\x62\x59\xa1\x76\xec\x85\xe4\x8d\x5e\x2c\xd0\xd6\x72\xeb\xcd\xbd\x7d\x98\x8a\xfa\x32\x9f\x10\x20\x78\xb4\xe0\xb4\x43\xec\xed\x64\x8b\xdb\xea\x10\x03\x20\xb8\x5f\x40\xd7\x01\xc5\xdd\x72\x38\xd4\x31\x7a\x72\xd6\xe5\xf4\x83\x42\x40\x4d\x37\xa7\x0c\x93\x4e\x98\xbc\xcb\x67\xf3\x1c\x9e\xc7\x74\x8d\xa9\xca\x87\xad\xa6\x95\x6b\xaa\x81\xfc\xec\xac\x56\x4e\xce\xba\x65\x04\x7b\xbe\xf5\xed\x63\x13\xc9\x2d\xd1\xd2\x44\x16\xe8\x5a\xcb\x06\xb4\x0e\x9d\x19\x97\x21\x95\xf6\xf8\x29\x9b\x76\x47\xc0\xcd\x91\x70\x03\x18\x67\x50\x10\x07\x61\x94\xc0\xf2\x96\x8a\x67\xc5\x52\x50\x13\xab\x43\xda\xa8\xe7\xd0\x8a\xc5\x76\xc1\xac\x6f\x99\xda\x62\xd3\x76\x3a\x7c\x4c\x28\x06\x62\x8c\xc1\x7b\x01\x1a\xbb\x00\x6a\x81\x8c\xd6\x2c\x6e\x17\xf7\xca\xdb\xe5\x6d\x83\x66\x13\x80\xf3\x46\x15\x43\x0f\xb9\xf2\x79\x60\x0b\x02\x54\x53\x29\xaa\xd6\x50\x8f\xdd\xa9\xe6\xd5\xa1\x25\xee\x6e\x6a\x98\x33\x02\x5e\x22\x98\x5c\x28\x0c\x37\xec\x4a\xfd\x01\xc8\x36\xee\x69\x41\x0d\xc2\x64\x73\x58\x77\x57\x26\x28\x0f\xe0\xe8\xf6\x76\x26\x1e\x3c\x07\xc7\x2c\x53\x77\x81\xe8\xf8\x4d\x9a\x5b\xfb\xed\xc8\xd6\xec\x4f\x57\xb2\xce\x42\x4b\xd9\x3d\x26\xcb\xb3\x3f\xc2\x6a\x0f\xbf\x58\xcb\x1c\x96\x55\x51\x6f\xd6\x24\xc3\x0f\xd1\xf2\xdf\xb2\xec\xd9\x1f\xd3\x0d\xb7\xef\x40\x1f\xba\x6c\x55\xca\xd7\x55\xa9\xb1\x00\xb9\x72\x4a\x82\x50\xa3\x61\x7d\x92\x86\xa5\x8c\xc1\x86\x32\x94\x4d\x51\x3e\xa4\xba\x1c\x83\x46\xe4\xc9\x57\xa0\x2d\x1c\x02\xdb\xef\xe4\x13\xfb\x80\xf7\xd3\x1f\xff\x34\x98\xc4\xdf\x3c\x7e\xe5\x1f\xac\xd4\x40\x56\x06\x22\x47\x14\xdc\x4c\xaf\xa6\x53\xa1\xb9\x2f\x7e\xf5\xcb\xe3\x1f\x1c\x1e\xb6\x69\x29\x62\x81\x17\x3e\xcc\xda\xc0\x36\xa9\x2f\xfc\xfa\xd7\x93\xb3\x1f\x79\x52\x98\x78\xdf\x00\x00\x40\xff\xbf\xb1\x12\xef\x03\x0a\x29\xf4\x36\x14\x42\xe0\xb0\xec\x8e\x86\x2c\xd9\xd7\xa1\x19\x17\xcd\xb0\x6e\xc0\x58\x4d\x4a\x5c\xf9\xcc\x72\x60\xfb\xcb\xb7\xbd\xdf\xff\x43\x14\x78\xea\x45\xc6\x19\xa1\xf5\x3c\x05\xbf\xf6\x29\x06\xcf\x04\xf0\x17\x7f\xe7\xeb\xbf\xb6\xd2\xbb\x12\xbc\x7c\x6b\xad\x41\x59\x3c\xd5\x99\x6c\x25\xde\x03\x7d\x5c\x10\xe0\xc8\x08\xa3\x6b\x0b\x9a\x90\x4c\x9d\x16\x0c\x78\x7d\xe0\x13\xef\xff\x49\xe8\xc7\x61\xd2\xcb\x7f\xf6\x06\xf0\x34\x01\x9c\x63\x2b\x40\x60\x42\xd0\x35\xe4\x82\x34\x86\xde\x80\x45\xd0\x66\x6a\x90\xc8\x1c\x33\x18\xec\x38\x4c\x63\xa0\x60\xf0\xc3\xc1\x17\x5f\xfc\x24\x28\x70\xaf\x53\x55\x0d\xbf\xed\x3e\x05\x3f\xf2\xe4\x28\x24\x2a\x80\x88\x08\x48\x30\x4d\xc0\xd8\xc4\xbf\x93\x14\xab\xa9\xf8\x67\xc3\x79\x96\xa4\x68\xaa\xab\x47\x46\xd1\x8e\x66\x1a\xbe\x6d\xd9\xf9\xdd\x7e\x4e\xe1\x1a\xaa\x15\x6f\x99\xfc\xd4\x78\x7c\xe4\x83\xd1\xa9\x94\x07\xba\x59\x90\xbe\xbf\x5a\x2a\x6e\x2c\xff\x61\x2a\x41\x5f\x3d\xf5\x84\xbd\xdb\x6c\x05\x12\x8f\xd7\xf5\x89\xad\xfa\x75\x79\x42\x99\x9f\x15\xca\x59\x60\x95\x62\x40\x71\xfb\x81\xf1\x2f\x3e\x01\x94\x3f\xf8\xf3\xdd\x0f\xff\x40\xf3\xf9\xbe\xd9\x2b\xe8\x18\xb2\x75\x46\x1d\x84\x6d\xd5\x87\x4e\x30\xdb\x1d\x8f\xed\x02\xb1\xb6\x65\x9a\x65\x4d\x62\xd0\xeb\x93\xae\xdd\xdc\x71\xef\xed\x57\x43\x11\x9f\x0a\x5f\xf9\x82\x5e\x3c\xf5\x2c\x14\x17\x4e\x9b\x22\xdf\xf2\x83\xaf\x3d\x78\x01\x7c\xf8\xec\xe7\xc0\x33\x67\xae\x82\x4f\xfd\x26\xfb\xe6\xc5\x67\xea\xbf\x1b\x0c\x78\x27\xda\x2c\x8f\xff\x7f\xbe\x08\x31\xdf\xea\x24\x17\x4a\x39\x2e\x3c\x8d\x23\xb4\x95\x6d\x5a\xca\xe5\x94\x58\xba\x7c\xf9\x0b\x27\x46\x9e\xfb\xc1\xb7\xfe\xfa\xcf\x5f\x4a\x44\xa6\x4e\x32\x12\x6f\xd2\x4d\x65\x1d\xd8\x6c\xf8\xc9\x67\x90\x3c\x31\xa6\x35\xf1\x9d\x9d\x80\xdf\xe1\xef\xd9\xbe\x3e\x3c\x18\x70\x60\xa3\x63\x30\x59\x24\xd6\x93\x1d\x2f\x0f\x34\x20\xda\x60\x38\x1e\x64\x76\x47\x42\xc5\x79\x6a\x96\x0d\x06\xf4\x6d\x9c\xef\xf1\xa2\x4f\x9c\x35\xa1\x69\xda\x38\xc0\x66\x9c\xa9\x92\xa1\x21\x28\x6b\xd2\xa8\xd1\x02\x91\xfc\xfa\xda\xf1\x5b\x77\xef\x3c\x5f\xa9\xe4\xdf\x3d\x3e\x3c\xb1\x2f\x49\x62\xc6\xed\xe6\xf1\xbf\x42\x01\xf4\xf6\xd8\x00\x38\x2c\x94\x87\x4a\x95\x4a\xe4\xb0\x58\x48\x65\x73\xb9\x21\x52\x80\x64\x74\xa4\xa4\x88\x53\xcc\x85\x73\x4f\xbc\x71\x62\x76\xee\x31\xee\xe5\xde\xe5\x87\xeb\xc3\xb9\x6c\xe6\x38\x4d\x23\xa7\xd4\x95\x66\x5a\x1e\x51\xe4\xd5\x7a\xa3\x98\xb4\xf1\x02\x5d\xac\xe4\x40\x2a\x36\x0a\x6c\x4d\x3f\xc5\xb8\xd1\x0d\xfc\xf9\x23\xd6\x8c\xfb\x07\xf9\xc9\x5a\xa3\xe1\x2d\x14\x4b\x13\x9a\x6a\x44\x08\xc0\xeb\xbe\x86\x86\xc2\x65\x0a\xb8\x1c\x0d\x48\x17\xc7\x9a\xc4\x59\xea\xda\xbd\xd7\xc1\xc9\xb9\x73\x40\x3c\x14\x3f\x46\xd4\x09\x4a\xd5\x43\xb0\x9f\xdf\x03\x32\xfe\x9e\x14\x70\x85\x82\xa1\x02\xa1\x2a\x94\x4a\x85\xc9\x8e\xe0\x11\xe0\x78\x76\x93\x68\x60\xe7\xf2\x45\x09\xb7\x0d\x09\x62\x6d\x97\xcb\xd5\xf0\x86\xbd\x65\xcb\x42\xd6\x61\xe1\x70\x68\x66\x78\xd1\xe9\x7e\x2e\xb7\xb8\x8c\x1f\xb5\x8e\x28\x58\x89\xa6\x82\xd5\x56\x43\x93\x5a\x2d\xd5\xdf\xa8\xc9\x71\x0c\xa2\xdd\xf8\xfd\x0c\x19\x3a\x14\x8d\xa7\x34\x9a\xa9\x5a\x88\xd2\xf0\x73\xd1\x75\xd3\x40\x99\xfc\x2e\x70\x09\x44\xf4\x1e\x46\x19\x91\xdf\x75\x74\xa5\x75\x9d\xdf\xdb\xdd\x9e\x2d\x95\x4a\x43\xe5\x72\x31\x49\x5c\x96\xc8\x33\x8c\x45\x92\xa5\xd3\x53\x4f\x7c\x1b\x77\x29\xad\x90\x2b\x4b\xa4\x74\x36\x84\xc1\x97\xe0\x11\xaa\xe9\x83\x74\x48\x6e\x36\xdd\xb3\x63\xc7\x9c\x4c\x22\xe1\x6e\xa7\x86\x13\x1b\x73\xf3\x27\xae\x13\x5d\xff\x7b\x37\x1f\x4c\xef\xef\x1d\x8c\x86\x02\xe1\x72\x78\x28\x90\x6d\xb6\x64\xfe\xfe\xfd\xbb\xb3\x33\x23\xb3\xa8\x3b\x45\xbb\xdc\xae\x03\xa2\x5e\x2a\x78\xd8\xb4\x85\x80\x72\x34\x8f\xd5\x5f\x38\xdb\xb4\xbf\xde\x1a\xd6\x29\x96\xb4\x7b\xae\x80\x36\xb2\xa8\x66\x5d\x61\xab\xc5\xba\x50\x29\x37\x3c\x72\x4b\x75\x5b\xa6\xc9\x92\x2c\x57\x30\x14\xaa\xba\x43\xae\x56\x66\x3f\xe3\x3b\x3c\x3c\xf4\x05\x46\x83\x6d\x04\x82\x3f\xcd\x89\x5c\xcd\x6e\x67\xa9\x40\xf1\xb0\x10\xa9\x55\xaa\x3e\x62\x0e\x71\xff\xee\xed\x13\xd5\x7a\xd9\x91\xa1\x6b\xcb\x6d\x39\xe5\x22\x60\x74\x74\x22\x7f\xea\xec\xb9\x95\x91\x91\x89\x3c\xc9\x18\xee\xac\x67\xe2\xf8\x59\x11\xc3\x46\x03\x83\xea\x82\x6d\x22\x73\x7d\x7d\x2d\x11\x0b\x26\x9c\x73\xe0\x0e\x6e\x78\x02\x81\x1d\x8c\x97\xad\x83\xfd\xa2\x55\x2f\xb5\x24\x55\x36\x04\xcb\xb0\xa9\xf1\xe9\xb1\x4d\x0c\xf2\x6b\x6b\x6b\xab\x89\xc3\x83\x83\xd8\x6c\xe2\xb8\xd3\x8e\x6e\xbf\x6f\x1d\x83\x8d\x4a\x7e\xff\xd0\xb3\xbb\xb9\x37\x82\xcf\x8b\xa3\x22\xba\x69\x5a\xc8\x30\x2d\xdb\xc0\xfd\x0b\xdd\x79\x7c\x1d\x10\xc3\x0a\xd7\x81\xf8\xee\x3a\xee\xf7\x07\x85\xb4\x43\x01\x50\x74\x1d\x91\x20\x8a\x17\x5c\xfa\xe4\xe4\xdc\xa6\x56\xad\x1d\xa3\x1c\xd5\x05\x02\x78\xb9\x34\x3e\x81\x96\xdf\xcf\x25\x05\x9e\x6f\xf8\xc3\xde\x12\x89\xb8\xf6\xb6\xd7\xc7\xe6\x27\x16\x1d\xaa\x01\x45\xd3\x1a\xbe\xde\x55\xad\x25\x53\xd9\x9d\x4c\xc2\x22\x94\x75\x48\xeb\x91\x48\x30\x6f\x6b\x86\xbd\xb5\xf6\x78\x32\x1e\x4a\x38\xc5\x95\x78\x3e\xd6\x24\x9f\x6f\xcd\xd4\x74\x6b\x7f\x27\x0d\x5b\xe5\x7a\xc8\x50\x34\xc9\xc2\xa8\x64\x6c\x62\x6a\x8d\x77\xd1\x8d\x95\x47\xf7\x86\x2b\x85\xfc\xf0\xc2\xc8\x82\x03\x90\x45\x8f\xe7\x21\xcb\xb2\xd5\xec\xce\x81\x77\x77\x7d\x77\xce\xe1\xe0\x13\x9e\x9e\xa2\x32\xf8\xc2\xd1\x61\xfe\x20\x62\xe2\xf6\xc6\x11\xb8\x33\x1e\xd5\x4a\x63\x9e\x62\xd8\xcb\x34\xc3\x68\x83\xe3\x31\x9b\xde\x99\xae\xd7\xab\x3e\x7c\xec\x69\x4d\x53\x62\xce\x58\x64\x05\x47\x97\x77\x38\xe0\xc9\x91\x0a\x23\xd6\xc5\xd5\x2c\x55\x3f\x9a\xb8\x79\xbb\x8c\x39\xea\xec\x83\xf7\xd4\xca\xd1\x80\x57\x4f\x87\xd5\xe0\x88\xf4\x50\x9d\xd4\xaa\xdd\xd5\x45\x40\xa8\x9f\xef\x85\xe4\xc1\x75\x0a\xd6\x1c\xfe\xaf\xdd\x31\x7e\x1a\x8c\x9b\xfb\x85\xb6\xe8\x48\x68\xe5\x8f\x7b\x2c\x6f\x38\xd1\xc2\xb1\x01\x45\x24\xa5\x30\x10\x43\x1d\x43\x5e\xba\x6d\x4d\x44\xc0\xb8\x53\x2e\xd6\xcd\x9e\xc2\x76\x29\x16\x39\xb3\x0d\x41\x77\x81\xb4\x7b\x1e\x96\x9d\xc2\x61\xd4\x83\xda\xb0\x6b\x39\x8a\x0f\xa5\x29\x0a\x6d\x99\x16\x2c\xee\x1d\xfa\x95\xba\xe2\xd2\x2a\x6a\xd2\xd0\xcc\xb0\x6d\x90\xbb\xb3\x2a\x1c\x23\x58\x43\x8b\xd1\x9b\xf1\xc9\x18\xc1\x29\xb4\x73\x8e\xbe\x36\x43\x67\xec\xf4\xb9\x0f\x5d\x56\xc2\x80\xd6\x05\x3a\x42\x34\xee\x80\xe5\xbe\xa7\x52\xdb\x3e\xaa\x27\x8c\xd1\x2d\xd2\xe8\x67\x91\x7a\x92\x3f\x64\x3c\x6c\xbe\xba\x35\x53\x6f\x9a\xcf\x40\x0f\x8e\x54\x2d\xe4\xc5\x93\x22\x8b\xa2\x3e\xda\xc0\x20\x52\xc3\xd1\x1e\x6d\x34\x55\xae\xa0\x1d\xe4\x0f\xd4\x34\xda\xaa\x3d\xa0\x27\x52\xeb\xc9\x33\xee\x16\xe8\xce\x0e\xf8\x0a\xc5\xa4\xb5\xeb\x59\x0d\xdc\xa2\xf6\xac\x17\x5a\x41\xe4\x6e\x8c\x19\x88\x41\x0a\x90\x6c\x81\x78\x17\x98\x08\xa1\x3e\x7d\xaa\xc3\x00\x66\xf1\x8a\xc7\x5a\x02\x12\x39\x1e\x2a\x09\x85\x2a\xc4\x14\xae\x30\x61\x27\xe3\x1b\x20\x1e\xde\x01\xa5\xe6\x92\xbe\x56\x7d\x8c\xb6\x86\x2f\x79\x4b\x8c\x40\xd9\xbe\x49\xb7\xed\x9f\x44\x75\x12\x67\xa6\x1f\x57\x77\xea\xfb\xe5\x80\x98\x3f\x1c\xc1\x73\x42\xd4\x24\xae\x45\x2c\xc5\x62\x3c\x83\xe7\x24\x76\x3c\xb7\x42\x04\x62\xac\xcd\xe9\x45\xaf\x4a\x30\xda\xe4\xb4\x68\xa2\x29\x50\x6d\x55\xad\x5a\xf1\x9e\x9e\xad\xaf\x5a\x9e\xfc\xb6\x1e\x37\x05\x10\x6a\xa4\x68\xde\x8a\x00\xda\x94\x00\xa8\xc5\xf1\x5a\xb4\x40\x79\x01\x5d\x9d\x3b\xfc\x4b\x5a\x62\x42\xf6\xde\xa9\x4b\x9c\xe6\xcc\x85\x9d\x59\x75\xe2\x45\xbf\x3d\x09\x51\x13\xdf\x77\xf3\xf6\xab\x88\xe1\x6b\x10\xa8\xcd\xf6\x2a\xfd\xde\x0f\x49\xc6\x8d\xeb\xa0\x5e\x79\x4b\x75\x6f\x9e\x35\x59\x79\x84\x01\xc6\x28\x02\xfc\x34\xa2\x83\x19\x8a\x0a\x57\x42\x56\x83\x11\x41\x15\x1d\x02\xa1\x21\x23\x6d\x7b\x9b\xb8\x51\xe0\xe3\x2e\xf6\x01\xef\xd2\xc9\x25\xc7\x63\x14\xbc\xf2\x0f\xc6\x25\x7a\xa7\x78\x8b\x80\x5e\xcf\x83\x9d\x37\x2e\x4b\x4c\xe2\xbd\x7f\xf4\x7b\x36\xff\x33\xff\x1b\xee\x5f\xa2\x4d\xbd\xf0\x11\x1c\xec\x0d\xd9\xe8\xf3\x7f\x75\x39\xfc\xfa\xb5\x4d\x69\xf4\x85\xd9\x46\x6c\x21\x29\xf3\x3e\x51\x83\x34\x61\x70\x74\xe4\xf3\x0c\xc0\xe8\x15\x59\x48\xbf\x76\x20\xee\xbd\xb1\x26\x79\xed\x3c\xf7\xaf\xfe\xad\xcb\x9e\x39\x4b\xa6\x60\x13\xda\x59\x0e\xfc\xc5\xef\x30\xb0\xd9\x40\xaf\xfc\xcd\xe5\xdf\xfc\x85\x23\xa9\x66\x7c\x80\x1f\x1d\xff\x08\xf8\xc3\x1c\x0f\x2a\x8a\x80\xc7\xcb\x10\x68\x69\x65\xf8\xbe\x13\x2f\xc0\xac\xcd\x82\x83\x3c\x0b\x4d\xb1\x0e\xbd\xf8\x92\x02\x6e\x01\x46\x93\x14\x98\x3f\xf1\x04\x8e\x8e\x5a\x50\xab\xdc\x87\xc3\x61\x0e\x0a\xa4\x2c\x99\xa8\x16\x73\x2a\x24\x31\x17\x43\xfc\x88\x31\x16\x22\xa5\x8f\x14\x8d\x1f\x02\xc6\xaf\xac\xa3\x3a\x4f\xb4\xbd\x1b\x70\x88\x06\x8e\xb4\x30\x79\x0f\xec\xca\x87\xb5\x67\x1a\x92\x1d\x86\xce\x3a\x6b\x11\x1b\x0b\xbb\xe3\xa0\x46\x84\xb4\x69\x67\x2c\x1b\x84\x4e\x69\x12\xd2\x1e\x4b\xa8\x19\x70\x67\x5f\x96\xf6\xb3\xad\xa8\xa6\xc3\xf8\xd8\xb1\xe3\x33\x64\xa4\xd4\x72\x45\xa0\xec\x1c\x7e\x39\x3e\x04\xbf\x91\x1c\xf6\x56\x9a\x2d\x08\x78\x3e\xa8\xd3\x54\xdd\xd4\x8c\x26\xf3\xcd\xd7\x3e\xfd\xdb\xef\x7e\xee\x07\xfe\x8d\x07\xde\x67\x9a\xa9\x59\x60\x87\x43\xc0\x58\x38\xe1\xde\xde\xbc\xe3\x11\xbd\x50\xed\xcb\xfb\x76\x2a\xab\x1c\x91\x1e\xd8\x9d\x58\x9c\x1f\x20\xd5\xb3\xdf\x85\xa0\x2b\x89\x86\xf1\x89\xd7\x13\xb4\x13\x89\x96\xdc\x68\xd9\x8d\x7c\x65\x77\x25\x57\x3a\xc8\x09\xee\xe7\x3f\x3a\x3d\xcd\x8b\xef\x9d\xfb\x3a\xd8\xcc\x87\xc9\x76\x1e\xf8\xe2\x9f\xaa\x97\x17\x4e\x6b\xbf\xce\xbb\xbc\x8e\xd1\xce\x3b\x92\x17\xd0\xdb\xbc\x24\xfa\x34\xa9\x81\x3d\xbc\x81\x3a\xf5\x4e\x80\xaa\xaa\x06\x9d\x2b\xd4\x04\x59\x51\xb9\x56\x31\xf4\xec\xf1\x09\xf8\x2f\xc3\xfc\xec\xdd\xa1\xe3\x52\x3c\x9b\xd5\x5b\xef\xfd\xa0\x30\xf9\xf8\x81\x67\x64\x79\xf5\xe0\x2b\xa2\x25\xd2\x3e\xda\x67\x84\x67\xcd\xaf\x04\xfc\x5e\xd4\x68\xd2\xfe\x4e\x62\xad\x23\x7f\xd6\x01\xfc\x6d\xec\xdf\x89\xec\xd9\x76\x02\xe1\x48\xdd\x1c\xea\x28\x39\xb4\xe7\x58\x1b\xc0\xc1\x52\x60\xd8\xd9\x51\x74\xda\xc9\x30\x2c\x5a\x69\x19\xac\xdc\xd2\x79\x8c\xbe\x88\x5a\x36\xd9\x06\x35\x78\x17\x63\xd1\xac\x89\x23\x1e\x36\xb4\x78\xfc\x44\x65\x69\xe5\xa1\xb2\xb2\xf3\x48\xca\xe4\x77\x46\xc2\x81\xd8\x08\x91\x5e\x62\x19\xc6\x01\x55\xa4\xe3\x13\xd3\x09\x42\x57\x20\x42\xfb\xe4\x7b\x83\x14\xd3\x11\x85\x03\x8a\x02\x53\x13\x13\x7b\x4f\x9f\xbd\x70\xdf\xe7\xf5\x35\x09\xc7\x77\xf9\xe1\x6a\x62\x67\x6b\x7f\xda\xb1\x53\xeb\xc8\x56\x56\xab\xcd\x54\x34\x15\x36\x13\xf1\x78\x33\x5f\x38\xa4\x6f\x3e\x7a\x0b\xd4\x9a\x15\x62\x3b\xbb\x00\x76\xd1\x02\x29\x06\xb2\xed\x76\x8d\x88\xa6\xc9\xf8\x3c\x87\xa0\x8e\xcf\x47\xc0\x04\x39\x0f\xe5\x14\x7b\x72\xe0\x3d\x97\xbe\xeb\x72\x34\xe2\x6b\xc9\x2d\x39\xca\x71\x9c\x79\x7a\x7e\xbe\xb4\xb2\xb5\x9a\xcf\xec\x1f\x24\xae\xde\x7f\x9d\xf0\xc3\x9c\xb6\x33\xdb\x64\x2b\xdc\x47\xbc\xcd\xd3\x0b\x27\x1f\x9d\x5d\x38\xbd\x71\xf9\xd6\xb5\xe3\xc5\x52\x81\xaa\x36\xca\x20\xe0\x0d\x01\x8e\x73\x99\x0c\x0f\x7d\xcd\x66\x6d\x18\xaf\xaf\x2e\x92\x7d\x8b\xc5\x42\x0d\x4e\x84\xe2\xa3\xb5\x47\xa3\xba\xa1\xbb\x54\x7c\x2d\x3c\xc7\x63\xa0\xc8\x96\xf1\x7b\x3c\x82\x04\x33\xa2\x27\x62\xd5\x2a\x4d\x2b\x9f\xab\xe2\xb6\x55\x44\xbc\x04\x79\x11\x29\x66\x25\xf6\x3a\x0c\xa5\x58\x6d\x35\x7c\xd7\x50\x3c\xd5\x22\xbb\x11\x4b\xeb\xf7\x88\x8b\x18\x08\xfa\x22\x27\xf1\xbd\x9e\x94\x55\x19\x94\x6a\x05\x50\xc0\x81\xa0\x61\xe1\xf0\x16\xb7\x25\xc9\xf6\x1d\x9f\x9b\xdf\x38\xf7\xd4\x93\x37\xc9\x72\xbf\xb7\x93\x1e\xda\xdd\xd9\x9d\xc1\x5d\x81\x8a\x44\x83\x4d\x82\xc5\xd7\x36\x56\xa6\xa0\x33\xcd\x18\x8e\x69\x45\x24\x1a\xcb\xcc\x1e\x9f\xbb\x4b\x72\x2a\xf7\x6e\x3d\x18\x39\xc8\xe4\x86\xc9\x38\x0f\x45\x02\x4d\x02\x6c\xee\x3f\xbc\x35\xa3\x6a\x0a\x57\xaa\x16\x40\x14\x03\x42\xb2\x06\x08\x6e\xbe\x41\xb4\x30\x39\x91\x22\x48\x8d\x25\x5d\xad\x5b\xee\xdd\xe1\x9d\xc2\xae\x4b\x33\x45\x8a\x04\x7a\x60\xc1\x31\x74\xec\x76\x32\x48\xa4\xd3\x30\xe0\x65\xaa\x95\x86\xab\x55\x97\x25\x5d\xd5\x05\xd3\x44\x84\xf1\x6d\x05\x22\x81\x32\x9e\x31\xad\xad\xed\xcd\x30\x79\x7e\x3b\xd9\x2d\xdc\xde\x61\xe0\x71\x7b\x51\xe1\x4a\xee\x83\x44\xc3\x98\x64\x4c\xc9\x73\x68\x2a\x0d\xb2\x63\x43\xcc\x26\x90\xc3\x17\x25\x85\x74\xa2\xcb\x38\x7f\xea\xfc\xa3\xb9\x99\x13\x7b\xfe\x40\xa8\x4e\xae\x47\x6e\xaa\xd4\xc6\xea\x56\x78\x67\x73\x2f\x8e\x8f\x6d\xf3\x2e\x57\xd3\xed\x17\x8b\xf5\x7a\x83\x4f\xef\xec\xc4\x98\xa1\x09\x44\x8c\x40\x3c\x01\x7f\xc6\xd0\x6d\x55\xd7\x35\x39\x9f\x2e\x84\x9a\x35\xd9\xad\x13\x59\x37\x7c\x3d\xc1\x70\x38\x6b\x18\x48\xbb\x71\xfd\xcd\x63\x24\xa3\x42\x0a\x1c\x79\xce\x05\x7c\xe1\xc8\x1d\xd3\xb0\x8d\x8d\x95\xad\xb8\x65\x12\xca\x18\xa5\xd7\x6a\x0d\xa8\x54\x55\x30\x31\x3a\xb7\x37\x33\xbb\xf0\x78\x65\xe5\xc1\xb1\x6b\x4b\x57\x41\x47\x86\x91\x70\xcd\xbb\xa5\x3b\xe0\xdc\x93\xcf\x5d\x7f\xf6\xe2\x7b\xee\xbd\xf4\xd2\x9f\x7d\xef\x50\x28\x89\x88\xd5\xb1\x13\x5c\x78\xbc\x4e\x40\x55\xca\x97\xc2\x41\x7f\xa8\x88\x27\x72\xf3\xee\xfd\x1b\x93\xaa\xa2\xf0\xe4\xde\x43\xbe\x08\xf0\x87\xc3\xcb\xb8\x83\xc3\x62\xf6\xd0\xab\xc9\x1a\x8e\x70\x11\xe4\x5c\x9c\xec\x8f\x7a\xea\xad\x56\x53\xcc\x1e\xa4\x53\xae\x14\xe7\x28\x84\x78\xfc\xfe\x0c\xb1\xe5\x54\x70\x04\x58\x3b\x2c\x26\x0c\x45\x0d\x23\xcb\x14\xc9\xec\x1e\x4f\x44\xcb\xc4\xca\xe8\xee\xdd\x2b\x67\xc9\xc9\x71\x5b\x40\x9e\x17\x40\x38\x11\xbf\x8f\x47\x30\x9b\xde\xdc\x9e\xc1\x13\x03\x0f\x3a\xe2\x4f\xf5\x52\x25\x3c\x34\x12\xa9\xc4\x23\x89\x52\x21\xb7\x3f\x7a\x7d\xe9\xb2\xf3\x3c\xfc\xde\xe0\x22\xd8\x46\x8b\x86\xd9\x1f\x8f\xe4\xdc\x85\x72\xbe\x3d\x1e\xf1\x82\xd1\xe6\xd9\x53\x40\x20\xe3\xf1\xdd\x1f\xfa\x5a\x20\x18\xcc\x61\xe4\x68\x44\x03\xee\x16\xa5\xa9\x7c\x4f\x12\x0b\x1e\x31\x90\x1c\x98\x73\xa9\x4e\x0d\xec\x91\xcd\xbc\xb7\x79\xf7\xf5\x93\xb7\x47\x49\x02\x7d\x73\x4b\x04\x7b\x9a\xbe\x9d\x64\x72\x0f\x9d\x1e\x39\x69\x5f\x3b\x6b\x40\x27\xcd\x21\x9f\x31\xed\xee\x6d\x58\xed\xb7\xc1\xee\xe1\xec\x0e\x3d\xb5\x23\x2d\xdf\xd3\x82\x6c\x83\xeb\x1e\x07\x16\x76\x39\xc7\xb0\x27\xcc\x4e\x7e\xd6\x35\x8d\x22\xfd\xbe\xb0\x53\x08\x6b\x9a\xca\x62\x90\x1b\xd6\x1a\xd6\x38\x82\x56\xc9\xd2\x11\x71\x3f\xa8\x59\x50\x4f\xeb\xba\x2c\xb1\xd0\x73\x82\x12\x5d\xa9\x72\xc5\xf5\x33\xc5\xaf\x67\x0e\xc7\x27\xa5\x5f\x8a\x1e\x0b\x97\xfb\xfa\x0a\xdf\x61\xf8\xdd\x17\x78\x40\x03\x7f\xe8\xfd\xb9\x9d\x43\x1f\xa0\x4b\xa3\x5e\x66\x7d\x80\x0b\x31\x90\x6a\xef\xbe\xd3\x59\x35\xb6\xaf\x64\xc6\x8c\x7c\xe3\x12\x9c\x9b\x9a\x30\x9e\x98\x23\xc5\xa7\x34\x95\xab\x62\x9c\xa0\xe3\xcb\xb7\x20\x70\x8b\xd0\x74\xf9\x5d\xe2\x84\x39\x09\x9a\x91\xa9\xec\x5e\xed\x09\x65\xcb\x78\x98\x5e\xde\xba\x75\xe2\xb9\xf0\x8a\x6f\x18\x03\x4a\x7c\x16\x5f\x94\x51\x12\x67\x8e\x5d\x2d\xae\xd6\x11\x7b\x73\xf5\x7c\x5a\xe1\xbc\xf5\xb8\xcc\x98\x3c\x0e\x0e\x45\x9e\x62\x20\x6d\xb1\x36\x45\xda\xd8\xc1\xe6\x54\xd7\x45\x96\x68\x6b\x40\x06\x08\x94\x07\x09\x78\xed\x2b\x7b\x65\x6a\x7f\xd1\x40\x95\x04\x08\x46\xb6\xd1\x93\xf6\x96\x3e\xd5\xfa\x7a\x76\x93\x0b\x8a\x9b\x89\x39\x5f\x45\x8a\xb0\x8e\x3d\x5a\x6a\x2e\xac\x83\x39\x94\xc7\xcd\x9f\xcb\x3f\xaa\x71\xd5\xed\xaa\x47\xd7\x28\xce\xf0\x48\x78\x46\x86\x1c\x8e\xce\xa9\xea\x3e\x0a\xca\xe9\x64\x99\x7b\x9f\xa2\x76\x64\x99\x80\xe0\xa1\x51\xea\x59\x62\x8f\x06\x94\xd1\x8a\x51\xc8\xae\x29\x7c\x73\xd9\xf2\x9a\x1a\x15\x53\x25\x10\x69\x05\x30\xde\x93\x10\xac\xc5\x2d\xde\x02\xd6\xa8\x58\xa3\x5c\xd7\xbf\x6c\x64\x46\x92\x5c\x35\xb4\xc0\x58\x90\xea\xed\x49\x38\x1d\x6f\xf1\x39\x60\x3a\x74\x2f\x3c\xd4\x3a\x2e\x06\xe0\xfc\x05\x60\xbd\xf1\x69\xad\x31\x52\xd7\x85\xea\xa2\x29\x14\xf1\x2c\x5e\x1e\x03\x76\x65\x04\x32\xe1\x65\xd3\xb1\x55\xa1\x0c\x8e\x6c\x4a\x01\xb6\xd6\x02\x4c\x53\x7b\x9b\xf1\x04\x1e\x53\xd6\xff\xb7\x44\x1c\xea\xa8\x17\x10\xae\xa4\xf1\xec\xf9\xe7\x7f\xec\xd4\x89\x11\x7e\x7f\x5f\xb7\x7f\xed\x3f\xed\xc2\x9f\xfc\x77\x02\x70\x45\x4c\xea\xd8\x53\x10\x8c\x4d\xbb\xed\x6b\xaf\x15\xf9\xfb\x6f\x64\x85\x7b\xaf\x05\x0c\xda\xef\x37\x58\xc9\x65\xc1\xb6\x60\x31\x65\x36\x71\xb4\x56\xad\xb0\x01\xa6\xca\xbc\xff\x12\x87\xce\x3f\xe7\x46\x7c\x80\x58\xd3\xdb\xff\x2f\x7b\x6f\x1e\x6d\xcb\x79\xd5\x07\x7e\xdf\x57\x73\xd5\x39\x75\x86\x7b\xcf\x9d\xdf\xa4\x37\xe9\x49\x7a\x7a\x9a\xe5\x11\x2c\x0f\x09\xc6\xd8\xc4\xe0\xe0\xf6\xd0\x09\x0d\xa4\xa1\x01\x93\x26\xe9\x5e\x1d\xd2\xfd\x07\x59\xdd\x7f\x24\x21\xe9\x84\x10\x08\xd0\x2c\x58\xac\x80\x6d\x02\xb6\xf0\xd0\x06\x9b\x18\xdb\xb2\x2c\xc9\x96\x35\x5a\x4f\x7a\xf3\x70\xe7\x7b\xe6\xb1\xe6\xaa\xaf\xf7\xae\xe9\xd4\xb9\x7a\x18\x3b\xd0\x2b\x31\xbe\x25\x9d\x77\xa7\x73\xea\xd4\xa9\xfa\x6a\xef\xdf\xde\xfb\xb7\x7f\x9b\x8c\x9a\x22\xfb\xdd\xdf\x91\xd9\xf6\x0e\x7f\xf1\xd1\xc7\x7f\xf9\x6f\xef\xc7\x55\xcc\xa2\xe4\x47\x17\x7f\x82\x90\x1f\x78\x8e\xd4\xd6\x0f\xf1\x79\x62\x91\x41\x69\x97\x3f\x76\xe3\xcb\x74\x24\x46\xf4\xde\x7b\xbf\x0f\xc2\xc1\x79\xca\x27\x23\x3a\x06\x54\x39\x18\x97\x09\x1b\x47\x54\x11\x54\xaa\xc0\xbd\xd9\x9f\x48\x38\xc8\x10\x00\xad\x40\x65\x09\xe7\x18\x06\x14\x95\xaf\x21\x82\x07\x30\x80\xf7\x5b\x18\xcb\x80\xe1\x08\x58\x51\x8a\xdb\xe8\x51\x73\x3a\x55\xd2\xe5\xb1\xb6\x2e\xac\xb4\x94\x77\x1e\xc5\xf7\x30\x0a\x31\x23\xb8\x04\x2b\x9d\xc0\xca\x58\x7a\x37\xfe\xb8\x14\x93\x8a\x71\x36\x06\xa5\x87\xe0\xef\x83\x6e\x4f\x00\x23\x6c\x08\x2e\xbc\x3d\x93\x97\x63\x9d\x4b\xb8\x5e\xb5\xaa\xff\xc5\xfb\xef\xd1\x9b\x82\x18\xc6\xe3\x30\x18\x35\x07\x8e\x5d\xde\xbc\x74\xcd\x11\x87\xa3\x21\xff\xc2\xe3\x1f\xf9\x95\x37\x85\xff\xdd\xcf\x2c\x03\x52\xdf\xc4\x69\x87\xd6\xe0\xe9\xb9\xe3\xae\x67\xe8\xe9\x65\xc4\xcc\x79\xaa\xeb\x95\x09\x1c\x66\x6a\xbe\x29\x99\x9f\x66\xbd\xbc\x69\xf9\x0a\x15\x42\x68\xcd\x24\xde\x99\xe3\xb5\x0e\x07\x2b\x72\x21\xf0\x58\x7f\xe0\x88\xed\xc1\xc6\x37\x9e\x7b\xe2\xc4\x1b\xea\x8b\x12\xbb\xf3\xbe\x16\xfd\xd8\x6f\x49\x5f\x3a\x73\x87\xff\x4b\xf5\x9a\xec\x66\xbd\x7c\x9c\xe4\x95\xa6\x4c\xbd\x3b\x1d\xe2\x91\x55\xa6\x8a\x03\x26\x78\xce\x62\xcc\x5e\x93\x92\xf6\x63\x20\xe7\x73\x4f\x72\x26\xfd\xea\xc6\x66\xb7\x6e\xbb\x37\xf6\xfc\xcb\x6b\x9f\x5a\x9b\x5f\x78\xe7\xc2\x7c\x9b\xbc\xf1\x6d\x15\x72\xf5\x02\x23\x83\x7e\xd0\x3b\x74\x68\xf0\xd4\x5c\x3d\x70\x16\x1b\xdc\x2a\x1b\x70\xef\x50\xdf\xa4\x99\x56\xee\x54\x27\x97\x16\x47\x13\xa7\xf4\x03\x96\xc2\x6c\x36\x33\x74\x9e\xf0\x82\x6c\x1b\xcd\x02\x7a\x96\xe7\x34\x78\x12\xdc\x58\x61\xa0\x0e\x3d\xcb\x18\x0e\xed\xb2\x33\x09\x34\xbc\x41\x01\xec\xba\xba\x2b\x79\xba\x26\xf9\x86\xd6\x90\x35\x55\xd4\x3f\xf8\x43\xef\x78\xe6\x4f\xbf\xf4\xd8\xd9\x9b\x1b\x3b\xf3\x83\x49\x3f\xf6\x8a\x08\xc2\xc0\x91\xc5\x37\x33\x82\xce\x30\x9e\x34\x96\x95\xfc\x28\xb9\xef\xdc\xed\xeb\xf7\xde\x79\x66\x7d\x79\x71\x1e\x9b\x42\x45\xdf\x1b\x98\xaf\x9c\xbf\x5c\xef\x34\x7b\x2b\x12\x86\xea\x7c\xaa\xf6\x60\x3b\x7b\x4b\xe5\xd2\xf2\xe0\xad\x6f\xbc\x77\xbb\xd9\xda\x3a\xb4\xdb\xec\x54\x5e\xba\xf2\x2c\xf2\x30\x88\x8c\x3c\x8c\x44\x77\x39\x2e\xbb\xa3\x43\xc5\xf7\x4a\x93\x82\x10\xf0\x6a\xfe\xc3\xf7\xdd\x7d\xf5\xa1\x73\xf7\x5c\x89\xa3\x57\xd7\x9e\xbf\x72\xf5\xfc\xdc\xf2\xf2\xe2\x60\x65\x6d\xd9\xf9\xfb\xef\xf9\xc1\xe7\x9f\x7d\xe9\xa5\xde\xd3\xcf\xbf\x78\xbc\x3f\x18\xe9\xf8\x9c\x3b\x4e\x1d\xdf\x39\xbc\xb6\xd6\xbe\xe7\x8e\x3b\xd2\xe6\xc4\xb0\xe6\xb8\xe3\x46\x44\x02\xe1\xfc\x95\x67\xc8\xd9\x53\x0f\x90\xc3\xc7\x2a\xbe\x22\x87\x55\xdb\x1a\x2e\x8a\x62\x24\x89\x92\x10\x2e\x2d\x1b\x81\xaa\x84\xd5\xe1\xb0\xb5\x1a\xf2\x80\x9d\xbf\xfa\x0c\xb9\x1b\x9f\xab\x57\x55\x05\x7e\xdf\x58\x8c\x4c\x00\xbe\xaa\x22\x47\x86\x6d\x05\x95\x41\xd7\xab\x8b\xa2\x5f\x09\xc3\x40\x43\x41\x3d\x55\x63\x82\xaa\x39\x8a\x40\xac\x32\xac\x39\xf6\xbd\x6f\x78\xdd\x2b\x8f\x3f\xf9\xd4\x9d\xdf\xb8\xfa\x5c\xda\x88\x27\x26\x42\xfe\x38\xf2\x16\xb3\xb4\xf0\xbb\xb3\x77\xdd\x79\xfd\xa1\xfb\x1f\xb8\x54\xad\x54\xc0\x3e\x79\xea\x8d\x6b\x1b\x95\x8b\xe7\x2f\x9f\x16\x84\x28\xa6\x6f\x2d\x2c\x1b\x23\x59\xf2\x85\x9d\xbd\xf5\x65\xcc\x8e\xef\x76\x36\x20\x50\x28\x7b\xb7\x9d\x58\x7d\x51\x92\x7c\x72\xf9\xc2\xd5\x6a\xbb\xb9\xdb\x60\x34\x88\x63\xda\xda\x9c\xde\x03\xfc\xc1\x5b\xad\x9d\x6a\x10\xfa\x7c\xb7\xbb\x4d\x70\x40\xc5\x89\xa3\xb7\x83\x23\x0d\x5d\x51\x26\x13\x41\x72\xc7\x33\x25\xe7\xbc\x04\x4d\xf3\x16\xa3\x30\x1d\x0b\x3b\x55\xe9\x4b\x6e\x3f\x00\x8f\x10\xd0\xdb\x72\x73\xab\x0d\x40\xad\x17\x0d\xfb\x88\x73\x7c\xb4\x05\xa8\x4f\x08\xd8\x3e\xe8\x7b\xf8\x70\xfd\x89\xe7\xa1\x9a\xf9\x90\x7c\xe9\xeb\x9f\x8f\x87\x5f\xd0\x98\x42\x10\xc6\x03\x41\xa2\x42\xc1\xbb\xd1\x58\x6c\x1f\x3f\x76\xf2\xda\x91\xc3\xb7\x6d\xad\xac\x1c\x6e\x65\x96\xd3\x76\x7d\xab\x0f\x76\xe7\x95\x17\x2f\x1e\x9b\x0c\x26\x8b\x81\x1f\xa2\x97\x74\x55\xbd\xb4\xed\x38\x91\x75\xed\xda\x8d\xaa\xeb\xbb\xd1\xc6\xee\x0d\x52\x29\xd5\x88\x5e\xa9\xec\x78\x6e\x68\xed\xec\x76\xa3\x6e\x6b\x58\x01\x10\xa9\x87\x60\xb7\x25\x59\x9a\x18\xb5\x72\x73\xd0\x1f\xaa\x1b\x9b\xd7\x97\x15\x49\xe5\x1b\x3b\x37\xc8\xa9\x93\x77\x5f\x65\xa2\xda\xde\xd9\x6a\x9a\x3b\x9b\xcd\x95\x38\xc1\xc7\xc0\xa2\x78\x3e\xbd\x74\xe9\x9a\x79\xe6\xdc\x99\xdd\xbf\xf5\xb6\xf7\xfc\xf9\xca\xca\xb1\xf5\xe7\x9f\x7f\xf2\xde\x4e\x67\xaf\x81\xc7\xb5\xbc\x72\x78\x73\x6d\xed\xd8\xe6\x1b\x5e\xf7\xb6\x67\xf1\x50\x5b\xad\x96\xd9\x6b\x37\x57\xef\x3a\x74\x36\x1e\xa0\x21\x29\x6a\x4b\x2e\x95\xf7\x9a\xdb\xad\xea\xa0\x3f\xa8\x2d\xaf\x1e\xda\x40\x2a\xc9\x5e\x6b\xa7\x81\xc3\x30\x36\x77\x6f\x62\x00\x44\x96\x4f\x9c\xb8\x02\xc6\x80\xdf\xbc\xb6\xb1\x0c\xe0\x18\xad\x76\x68\x56\xab\x2d\xcc\x27\x6e\x6e\xaf\xcf\xe1\x3a\xd9\x6a\xae\xc7\x01\x5a\x79\x6e\xae\x85\xd7\xa5\xdf\x1f\x49\x93\x91\x3b\xef\x79\xa1\x09\xb7\xa5\x28\x49\xb2\x5d\x5b\xae\xf7\xc6\xd6\x58\xdd\xda\x5e\x5f\x53\x24\x85\x6c\xec\xdd\x20\xb7\x9f\xba\xfb\xaa\xa2\x19\xc3\xbd\xdd\xa6\xd9\xdc\x6d\x1d\x8a\xd5\x09\xb3\x29\x56\xbd\x5e\x0d\xcd\xc5\xeb\x1f\x7e\xf3\x73\xf0\x9a\x43\xed\xf6\x5e\xe3\xb9\x0b\xcf\x10\xe4\xe1\x4b\xa2\x10\x53\x3d\xa6\xf7\x63\x94\xac\xd7\xfc\x7e\x34\xdc\xfb\xce\x3d\xf4\xdc\x6b\x1f\x7e\xf3\xb3\x31\x8e\x62\x42\xb8\x78\x6c\xf9\x82\x10\x4b\x53\xcc\x92\x18\xd2\xc6\xc7\x19\x46\xee\xb4\x91\x2d\xa3\x1d\xd0\x5c\x05\x32\x13\x71\x9f\x51\xfa\xa6\x05\x99\xf6\x54\xc6\x21\x1d\x8b\xc2\x73\x6b\xb8\x4f\x74\x3c\x5d\xda\x34\x53\xc6\xe5\xa9\x00\x7c\x4e\x0d\xe0\xd3\x12\x7f\xda\x75\xc6\xf3\x3c\x27\x2d\x4e\xe3\x9c\x55\x93\x98\x55\xa5\xe6\x99\xda\x41\x32\xb3\x3b\xf4\xc9\x78\x3c\x11\xc6\xc3\x89\xd8\xba\xd6\x5a\x1d\xb7\xad\x33\x54\x89\xae\x86\xe3\xb0\xa1\xd6\xe5\x97\x82\x31\x37\x98\xe1\xef\x74\xad\x4e\x50\xdd\xae\xbf\xc5\x7c\xc7\x9b\x7e\x9c\xd8\xbe\xeb\xb4\xda\x37\x20\xf8\x14\x6a\x1f\x78\xcb\x5b\xaf\x7f\xf8\xcf\x6e\x1c\xbe\x7b\xf5\x57\xa6\xd9\x96\xe9\x78\xd2\xbc\x53\x6e\xb6\x91\x8e\x4f\xb1\x30\x27\x39\xda\xcd\xa8\xc3\x7c\x0a\x81\x13\x1d\x35\x9e\x53\x6e\x66\x06\x12\xc1\xdf\xac\x9e\x2b\x4d\xfa\xc1\x29\xb7\x54\x5a\x86\xe8\x93\xb2\x9d\x36\x20\xd7\x0a\x89\xe6\x6a\x84\xc2\xfd\x40\x27\x63\x4a\x47\x16\x21\xcd\x1e\xf1\x21\xb2\x27\xa6\x4e\xe8\x6a\xcd\x2c\x2b\xc3\xd7\xb8\xe7\xd9\xed\x37\xbe\xbc\xf9\xcc\xea\xf1\xc6\x93\xf5\x3b\x6b\xeb\x8a\x21\x87\x47\x4e\xf9\x93\x5a\x55\x7a\x6c\xef\xd3\x64\x4b\xfb\x7d\xf7\xd8\xf0\x7e\xfd\x58\xef\x98\x57\xb3\xaa\x9e\xe2\x54\x25\xe6\x00\x16\x15\xc0\xe6\xc2\x9a\x8b\x93\x5a\x2c\x4c\x06\x5e\x85\x18\x5a\x23\x3c\x81\x75\x68\x78\x52\xec\x0b\xba\x60\x8d\x47\x8b\x21\x19\x2f\xb2\xfa\xe2\x25\xa1\x62\xb6\xbc\xdb\xae\x3f\xd9\xb9\xae\x96\x84\xab\x8d\x93\xb5\x9e\xb9\xa2\x05\xb2\xca\x62\xa0\xb0\x72\x4f\xc3\x5b\xb9\xb7\xd1\x29\xd0\x26\x63\xcb\x35\x81\x00\x56\x75\xc0\xd7\x68\x46\xea\x50\x79\x1e\x57\xe0\x7f\xf0\x71\x78\x65\xb5\x8a\x4d\x7a\x0e\x8f\xa2\xbd\xed\x17\xc6\x42\xe7\x86\x6b\x42\x6c\x5b\xf7\x49\xa8\x7a\x0a\xa0\x3c\x19\xce\x9e\x13\xcd\xb5\xae\x86\x52\x7f\x57\x1e\xea\x87\xa9\xbb\x74\x3b\x0b\x33\x51\x36\x3c\xf6\x58\xed\x38\x0b\x95\x52\x6e\xce\x03\xef\x94\xf9\xf6\xcb\x81\xb3\xfe\x14\x09\xb4\x1d\x26\x76\x57\x25\x3a\x69\x44\xac\xd3\x18\x32\x31\x14\x62\x21\xa6\x00\xa5\x95\x84\x30\xae\x1c\xfc\x55\x9a\xd6\x84\x74\x4e\xc5\xfc\x5b\x1f\x7e\xd7\xfb\x2a\xda\xc2\xfb\x24\x5f\x3a\x76\xcf\xdb\xef\x8e\xde\x7d\x66\x25\xfa\xf5\x5f\xf8\x13\xfa\xaf\xfe\xf9\xba\xf0\xfe\x0f\x48\xfc\xf8\xdd\x7e\xa8\x2f\x72\xf6\xc8\x7b\x44\xf2\xc6\x37\xcb\xd1\x8d\xab\x8e\xb8\xb7\xb5\x21\x8d\x47\x11\xc5\x46\x72\x59\x26\xa4\x74\x1b\xe3\x0b\xab\x22\x39\x7a\x5c\xe7\x62\x9d\x27\xf4\x5e\x97\xd2\xcb\xcf\xc8\xec\x63\x9f\x96\xe8\x70\x18\x3c\x79\xb3\xfd\xe4\x5b\x7f\xec\x91\x7f\x00\x20\xfa\x98\x60\x45\x43\xc0\xa5\x0e\x35\xe5\x12\xfd\xec\xde\x57\x48\xbf\xda\xa5\x87\xe6\x5d\xaa\x55\x9b\x31\xa5\xc0\x13\xab\xf4\x75\x6b\xef\xa6\x82\xa8\xd0\x08\x2e\x30\x17\x20\xa4\xa2\x3a\x45\xbe\x02\x20\x5b\x1c\x15\x48\x71\x30\x45\x88\x13\xda\x82\xf4\x26\x40\x11\xd4\x58\xba\x2b\x44\xa8\x0a\xfb\x60\x04\x49\x07\x2c\xd1\xf1\xa0\xd8\xe1\xcb\x84\xb8\x1c\x03\x8b\x05\xc7\xc9\x44\x49\x15\x26\x3e\x5c\x96\xf2\x04\xa2\xb8\x44\xc9\x58\x56\x88\x40\x82\x5e\xac\x9c\x9b\xca\x84\x65\x3a\xaf\x49\x34\x1b\x85\x21\x1b\x84\x4e\x39\x60\x43\x8d\xc8\x41\xb8\x7d\xe3\xc6\xcd\x6e\x77\xef\x8b\x25\x59\x6f\x35\x0e\x1d\xbd\xb6\xed\xea\x2a\xf1\x92\xb1\x6c\xdc\x24\xf4\xc4\xb9\x33\x43\x4f\x7c\x79\xef\xfa\xf5\x1b\xca\x68\x38\x94\xbf\xf4\xf5\xcf\xfc\xca\xf7\xd0\x77\xfc\x54\xa3\x3b\x31\x48\xaf\xfb\x99\xed\xe5\x3b\x64\xea\xe2\x88\xba\xf4\xbd\xe8\x54\xe1\x3b\xb5\x45\xb4\x20\x4a\x93\x5a\xab\x6c\x00\x74\x06\x4c\x01\x90\x1b\x9c\x55\xd6\xda\x4e\x65\xf4\xca\xc8\xe6\x3b\xc6\x95\xdd\xf6\x33\x96\x5d\x9a\x88\xa2\x36\x7c\xfa\x4b\x73\xc1\xd2\x99\xf9\x3f\x1b\x4b\x65\x79\x34\x8a\xc5\xb2\x8b\xea\x36\x2c\x85\xce\x74\x0a\x3c\xa3\x7c\x58\x4d\x0a\x68\xa7\x03\x1d\x72\xf0\xcb\x0b\x96\x35\x1e\x2d\x23\x88\xe6\xbc\x26\x9b\xdb\xea\xa0\xdd\xa9\x5d\xdc\xe9\xee\xbd\x78\x63\xf7\xf7\x4e\xaf\x1e\xba\xa7\xd5\xf6\xee\x5a\x5e\x1e\x92\x47\xde\x56\x5b\x7d\xec\x73\xf7\xbc\xdd\x58\x30\x3e\xe3\x41\xa4\xd2\x0d\x0b\x32\xa7\x53\xfd\xf4\x02\x80\xcd\x13\x17\xb9\x7e\xee\xd4\x1a\x4f\xb5\x89\x13\x60\x9b\x8e\x06\x29\x10\x31\xa3\xd4\xfc\x83\x03\xa5\xc3\xf1\x58\xdb\xe9\x74\xeb\xbb\x5b\x41\x63\x32\xf2\x4d\x3c\x6f\xb2\x0a\x80\x41\xa1\x8e\xaa\x32\x47\x52\x87\xfe\xc2\xfc\xb2\xa0\x9b\x6b\xfe\x0f\xbd\xf3\xfd\xcf\xee\x34\x77\x2b\x1b\x9b\xeb\xf5\x4b\x57\x2f\x2f\x36\x5b\xcd\x0a\x09\xa6\x12\x29\xd5\x4a\xd5\x3e\x7b\xc7\x5d\x1b\x18\x38\x3d\x78\xef\xfd\xd7\x33\x9f\xe4\xe1\x5d\x2e\x78\xe3\x66\x77\x0c\xc1\xa9\x08\x16\x4c\x83\x48\xc6\xa3\x45\xc0\xbb\xd3\x1c\xd7\xae\x5c\xed\x37\x0e\x1f\x5d\xee\xff\xbd\xf7\x7e\xf0\xab\xcf\xbd\xf4\xe2\x9a\xe3\x78\xd2\x97\x9f\x7a\xf2\x94\x13\x05\xaf\x4a\xb9\x3f\x74\xff\xfd\xd7\x14\x59\x09\x16\x1b\x8b\x83\xa3\x87\x0e\x75\xf0\xef\x01\xe7\x52\x73\xb7\x53\x7e\xf9\xfc\xe5\x25\xcc\x9c\x76\x7b\x1b\xd5\xe1\x88\x77\x4f\x9c\x3a\xda\x3f\x77\xe7\xfd\x5b\xf8\xd8\x2f\x22\x17\xc2\x6b\x00\x80\xcb\x73\x0b\x75\xc7\xac\x54\x9d\x00\x9c\xb7\xed\xb9\x44\xd6\xc8\x86\x66\x18\x93\x6e\x6f\x50\x1a\x8e\xac\x2a\xa6\x90\x45\x49\x0c\x6c\x0f\x2c\x2c\x15\xa4\xa3\x87\x8f\xf6\x9e\x79\xe1\x45\x0a\x20\x82\x44\xcc\xdb\x51\x54\xc5\x93\x64\xb4\xf3\x94\x01\x56\xd3\x5c\x0f\x5c\x97\xc7\x4b\x81\x4f\x0c\x00\xb0\x32\x72\x79\x61\x1f\x58\xc4\x91\xfd\x80\x1b\x5b\x5b\x5b\xee\xb1\xdb\x8e\x05\xaf\x7b\xe0\xe1\x6b\x4b\x0b\x4b\xc3\x0b\x57\x2e\xad\xbc\x74\xfe\xe5\x23\x38\xad\x0a\xb7\xb3\x77\xdd\x75\xa3\x56\xa9\x58\x0f\xdf\xff\xf0\xe5\x24\x49\x8f\x99\x6d\x2f\xbc\x79\x7d\xab\x72\xf5\xf2\xcd\x43\xe0\x6f\x84\x64\x2c\x29\x0b\xbb\x9d\x51\xb9\xd2\xa8\x5a\xab\x2b\x87\x9a\xad\x56\xbb\x8a\x80\xea\xd4\x9d\xb7\x7f\x15\xc0\x8c\xdd\xef\x0f\xe5\x9b\xd7\x77\x01\x08\x72\x39\xc4\xaa\xb7\x40\xfd\x41\x6f\xac\x2c\xac\x2d\x92\x13\xb7\xdd\xbe\x79\xf9\xca\x95\x43\x38\xaa\x79\x60\xf7\xc7\xf0\xbb\xa7\xc3\x80\x52\x49\x83\xcb\xe4\x08\x74\x26\xb3\x96\x89\xd7\xcf\x80\x0f\x12\x15\xfa\xbf\xb3\x49\x2b\x58\x2a\x67\xd6\xc4\x63\xe3\xa1\xa5\xd9\x13\xc7\x04\x80\xab\xc1\x39\x10\x10\x1b\x0b\x84\x86\xdd\x5e\x17\x3c\xca\xf1\xf0\xde\x73\x0f\x5c\x18\x8c\xfa\xe5\x57\x5e\x7e\xe9\x34\xd2\x7e\xe0\xdc\xe6\x57\xe6\x9e\x7b\x1e\xf8\x86\xaa\xaa\x8e\xa6\xea\xde\xbd\xf7\x3c\x74\x31\x1f\xb2\x98\xe4\x9e\x28\x93\xd9\x50\x36\xe5\x9d\xdd\xad\x3d\x65\x6b\x6b\xe7\x44\xe0\x07\xd5\x08\x55\xcb\xe3\x20\x5d\x08\x00\x88\x45\x0c\xfc\xe5\xdc\xdc\x82\x5d\x2a\x57\x46\xae\x6d\x99\x23\x67\xd8\xae\x2d\x2d\x5e\x02\x07\x2a\xf5\xba\xbd\x32\x38\xca\x39\x38\x68\x1d\x6e\x22\x41\x14\x45\x8f\x0a\x82\x84\x9d\x7b\x8a\xa2\xfb\x61\xe8\xcb\x43\x77\x3c\x04\xdb\xf5\x75\x30\x82\xe2\xee\xf6\xde\x52\xdc\x18\x99\xf8\x2d\x35\x8a\xc2\xca\xce\xd6\x96\xe1\x79\x6e\xed\xcc\xb9\x3b\xd6\xef\x3a\xfb\xe0\x8d\xb3\xf0\x28\x16\x81\xd2\x06\xbe\x78\x3e\xe5\x73\xcf\x7f\xe5\x81\xe3\x6b\xa7\xe3\x04\x42\x00\x17\xc3\x5c\x58\x78\x05\xc5\xc9\x3b\xad\xf6\x1c\xaa\xfc\x8c\x27\x63\x04\xb3\xc2\xbd\xe7\x5e\x7f\xa1\xd3\x6e\x2e\x74\x9b\x3b\xab\x5c\x12\xae\x1a\x95\x6a\xa7\xd7\xe9\x1b\x9d\x4e\x6f\x0d\xad\x8e\x20\x0a\x7e\x80\x5c\x07\x88\x8e\x6a\xf5\x85\xb1\x51\xae\x0c\x5d\x6b\x62\x0e\x9d\x61\xab\xbe\xbc\x7c\x01\xcc\x39\x6b\x36\x3b\x55\x00\xe4\x73\x70\xce\x55\x84\x9b\x48\x8b\xe0\xe9\x6c\x7b\x49\xd6\x5c\x08\x72\x94\x31\x7c\xb6\xe5\xc3\xc7\x9e\x42\x5b\x05\x9f\xad\x9e\xd6\xdb\xa7\x63\x5b\xbb\xdd\xc5\xeb\x57\xd7\x97\x8f\x9e\x3c\xba\xfb\xa3\x1f\xfc\xd0\x1f\x7e\xed\x99\x2f\xdf\xe1\x7a\x8e\xf6\xd5\xaf\x7e\xe9\xe1\xd0\x7b\x75\x3a\xe9\x1c\x00\x5c\x4d\xd5\xdc\xa5\x85\xb5\xd6\xc9\xe3\x67\x36\xd2\x94\x60\x4c\x63\x98\x3b\xb2\x74\x51\xad\x94\x26\x41\xe6\x33\x78\x31\xd1\xca\x8b\x67\x8b\xe7\xa9\x85\x7d\x63\x6e\x69\xc1\xc2\x66\x35\xfc\xbc\x2f\x8c\x4e\xc7\xbd\x17\x9b\xc4\x48\x4e\x28\xa0\x33\x72\x66\xf9\x94\xb7\x34\x93\x3c\xa3\xaa\x4e\xa6\x84\xd8\x19\x71\xb0\x1c\x39\x4e\x33\xaa\xbc\x20\xa0\x4b\xa6\x2a\x0a\x59\x95\xad\x30\x06\x2e\x39\x12\xcf\x03\x9b\xd4\x1e\xc0\x35\x6f\x49\x43\x6b\x30\xb2\x7d\xeb\x82\x30\x50\xde\xa4\x2c\xcd\x1f\x8f\x2a\xf5\xe5\xd2\xfd\x6b\x67\xba\x4f\x3f\xff\x42\xeb\x85\x0b\xff\xf1\xf0\x9b\xdf\xf2\xde\xfe\xc5\xeb\x97\xf7\xce\xbf\x72\xd1\xf6\x47\xad\x8a\x5e\x1e\xf5\xef\x7d\xe0\x4e\x95\x29\x87\x1c\x3b\x9c\x11\x5d\xa2\xb3\xf3\xc7\x72\xd1\xdb\x4c\xd4\x98\x4f\x67\xd0\xe7\x4d\x6b\x53\x81\x63\x9e\x0b\xf0\x62\xa0\x9d\x29\xa1\xe5\x67\x23\xcc\x79\x0e\x34\x70\x01\x71\xfa\xa1\xec\x2c\xd4\xd9\xe8\xc8\x1a\xd2\x3a\xb8\x72\x7d\x8f\x0a\x9a\xce\x25\x2c\xf4\x95\x34\x88\x4c\x35\x1a\x9a\x65\x4e\x1c\x9b\xb3\x89\xcd\xe8\xc8\x06\x04\x57\x61\xc2\x29\xa1\x6e\x6d\xb7\xdf\xb0\x7e\x6d\x78\x62\x7d\x6b\xf7\xb9\xea\x62\xe9\xc9\xa3\xf7\x1c\x6d\x2b\x06\xf5\x0e\xbf\xf7\xec\x2b\x87\x08\x79\x79\xf7\xf3\x3b\x4b\x93\x2b\xe1\xd2\xc8\x0b\x56\xbb\xa6\xbb\x6a\x99\xb6\x19\x56\x24\xc9\xab\x08\x62\xa0\x44\x34\x30\xc0\xe0\x00\x22\x10\x02\xa4\x6a\xc6\x32\xa5\xd8\x18\xcb\x19\x04\xd8\x2a\xaa\x24\xc8\x84\x5b\x35\x4e\xc6\x0d\x30\x0f\x93\xa8\x2e\x8d\xa3\x32\xed\x85\xa5\x9d\x6f\xf4\xae\xef\xde\x9c\xb4\xe7\x17\xe5\x49\xed\x70\xc9\xdf\xc7\x3d\xcf\xea\x01\x38\x48\x94\x78\xba\xcf\xb3\xb6\xbc\x04\xec\x46\x79\xf3\x21\x29\x26\xc9\xc1\xa5\xd5\x8e\x28\x61\xfd\x88\xd2\x9b\x74\x82\xfe\xb8\xeb\x31\x0b\xc0\x94\x37\x09\x21\xbc\x43\x94\xc6\xa9\x0b\xdf\x88\xae\x40\xac\x11\x4f\xca\xaa\x51\x42\x8c\xc1\x0a\x0f\x2d\x44\x53\x69\xb4\x42\x6a\x6b\x94\xef\x5c\x26\xde\xe2\x45\x1a\x56\x37\x98\x68\x57\x02\xd2\x9e\x1f\x33\x7d\x08\x38\x3a\x90\x10\xcd\x4d\xc7\xab\x16\xbd\xd8\x2f\xfe\x9f\x09\x53\xe0\xc3\xbf\xf6\xe8\x5f\x06\x76\xb1\x53\x02\xdb\x83\x97\xde\xff\xd6\x9f\xfa\x8f\xa5\xba\x7c\x6e\xc5\xa4\xa4\xd9\x09\x78\xa8\x96\xc9\xbb\x7e\xe6\x6d\xfc\xc2\x13\xaf\xb0\xc7\x3e\xf2\x5c\x9f\xd7\x54\xe9\x81\x7b\xa8\xf1\xc6\x07\x23\xbe\x74\x04\xbc\xbc\x81\x9a\x0c\x29\x91\x3e\x98\x56\xb8\x49\x96\x8c\xc2\xdf\x8d\x28\xd9\x5e\x17\xd8\x57\x9e\x94\xe8\xb3\x2f\x41\x34\x12\x78\xbf\x22\x1c\x22\xbf\x78\xe2\xf4\xed\x48\xef\x67\x54\x14\x89\x24\x09\x31\x80\xe4\x00\x3e\x02\x3d\xa4\x22\x93\x89\xc0\x25\x8a\xa7\x0c\x89\x68\x2c\x1e\xf1\xc0\xe2\x49\xbe\x84\x45\x31\x90\xc3\x88\x87\x21\x6f\x89\x21\xdb\x20\x8a\xb1\x91\x40\xd3\x71\x65\xc9\x52\x8d\xb3\x8d\xf8\x6a\xb4\x73\x05\x60\x96\x76\x95\xa4\xf3\xf0\xa2\x84\x16\x90\x4f\xee\x8a\x23\xbb\x28\x57\x4a\x8c\xb9\xb2\xd9\x9a\xc8\x26\xa3\xc5\x6e\x2e\x4a\x31\x5f\x6a\x63\x58\x92\xdd\x7c\xf9\xf9\x67\xe6\x2e\x5f\x78\x69\x15\x2b\x10\xa7\x2b\xc7\xff\xa1\x7a\xb2\xf1\x8f\x96\x0f\x1f\xb1\x34\x4d\x8f\x68\x3e\xae\x77\x1a\x73\x0f\x7a\x5d\xe5\xca\x85\xf3\xf3\x37\xae\x5e\x5a\xf5\x3d\x4f\x3e\x7c\xf8\x78\x7f\x51\x9c\x7f\xd7\x91\xd7\xde\xf5\x6b\x92\xaa\xda\x39\x70\x2c\x4c\x66\x4b\x86\xeb\xa6\x18\x3c\x01\x4c\x34\x4f\x6a\x26\x92\x2b\x09\xc5\x8b\xe4\x13\x50\x30\xa5\x24\x34\x77\xb6\xf5\xd6\xce\x56\xd9\xb1\x2d\x45\x92\x60\xa1\x36\x16\xac\xc5\x95\xd5\xb1\xa2\x68\x51\x22\xeb\xc2\x73\x20\x99\x03\xfa\x0c\xf8\xa7\xf6\x35\xf9\x39\xf9\x1d\x4d\x3f\x73\x51\x4e\x32\x39\xe7\x99\x78\x4e\x3a\x43\x0e\x41\x6f\x10\x30\x6b\x3c\x91\x3b\x9d\xb6\xde\xdc\xdd\x35\xbb\x9d\xae\x69\x4d\x26\x1a\x38\xaf\xf0\xdc\xca\xa1\xfb\xe6\x0c\xf7\x54\xb5\x1a\xf9\x7b\xd1\x9d\x1f\x5d\x3e\x39\x77\x29\x49\x7c\x14\x92\x07\x71\x98\x91\xb6\x0c\xf1\xa9\xfc\x29\x29\x18\xf5\x22\x0f\x8e\xf2\x5b\x89\xe4\xee\x2f\xd9\x21\x0d\x21\x64\xdd\x66\xcf\xd8\xbc\xb6\xdb\xd8\xbd\xb9\xb7\x32\x1c\x8c\xeb\x41\x10\x4a\x02\x0e\xe9\x03\xc7\x2a\x4a\x82\x0f\x0e\x1a\x27\x5d\x44\x2b\xab\x2b\x93\x5a\xbd\xe6\x9b\xa6\xe1\xbf\x9a\x53\x7c\x0b\x12\x48\x32\xf7\xdb\x93\x35\xda\x2f\xd5\xa4\x8e\x63\x7b\xd2\xde\x46\xa7\xb6\x7e\x75\x7b\xad\xd5\xec\x2f\x5b\x13\xd7\xe4\x21\x97\xa6\x32\x42\x71\x49\x21\x3a\x73\xe7\xc9\x8d\x13\xa7\x8f\x76\x0a\xa5\xc1\x57\x4d\x94\x9c\xfd\x07\xb5\x66\x03\xd6\x6a\xb6\x8d\x8b\x2f\x5f\x5b\x1d\x0e\x46\xa5\xa4\xa1\x8a\xfa\x99\x03\xd4\x74\xcd\xb9\xed\xf8\xa1\xe6\xfc\x42\x7d\x52\x2e\x1b\x31\xaa\xda\xdd\x6d\x95\xb7\xb7\x9a\x26\xac\x07\xda\x58\xa8\x37\x4f\x9c\xba\xcd\x21\xaf\x12\xa1\xa3\xe4\xb9\xaf\xbf\xb4\xb2\xb1\xbe\xb3\x8a\x0a\x7f\x5a\x49\x19\x2c\x2d\xd5\xb7\xce\xdc\x79\x87\x1d\xdf\x58\xfb\x36\xc3\x24\x3b\xa5\x0a\x6d\xc3\x39\x64\xad\xbd\x61\x69\xe3\x7a\x6b\x69\xf3\x66\xfb\xc8\x70\x60\x35\x7c\x2f\xd4\xf0\xf3\x89\x02\xf3\x65\x55\xb2\x44\x59\x70\x2a\xa6\x69\x9f\x3a\x73\xaa\x6f\x94\x34\xff\x55\xc2\xa2\x85\xb3\xcb\x44\x6a\x79\x91\x6b\xdf\xbc\xba\x61\xee\x6c\xb4\x0f\x0f\xfb\x93\xf9\x00\xf6\x17\x47\xeb\x92\xe0\xae\xae\x2d\xef\x9e\x7b\xe0\xae\xdd\xe2\x90\x3b\x5c\x88\x7e\x10\x44\x2f\x3e\xf7\x8d\xf9\xf6\x4e\x77\xc9\x73\xfd\x12\x26\x8c\xf1\x7d\xe7\xe6\x6b\xbb\x0f\xbc\xe6\xfe\x5d\x9a\x75\xde\x4c\x57\x0d\x67\xa2\x60\x55\x56\x8d\x4b\xb3\xab\x26\xe6\x4c\x46\xd3\x3e\xfa\x4c\x37\x95\xf2\x69\x07\x38\x89\xb2\x92\xa8\xef\xf9\xac\xb9\xdd\xae\x6c\x5c\xd9\x5a\xda\x5b\xdf\xbd\x6d\xd4\x9f\x2c\x85\x7e\x60\xc4\xf7\x0e\xec\x07\xd6\x96\x73\xf7\x7d\x67\x5f\x59\x39\x0c\xd1\x1e\x2d\x30\x82\x28\x2d\xc8\x45\x91\xa8\xd8\xb1\x36\x1c\x0c\x65\xd7\x71\xa3\x50\xe0\xbd\xda\x52\x75\x7b\x6e\x79\x6e\x64\x5b\xae\xb4\x7e\x71\x63\x71\xfb\xca\xd6\xc9\x7e\xa7\x7f\xd4\xb5\xbc\x1a\x8f\xb8\x28\x29\x52\xbf\x54\x35\xb7\xee\x7b\xf0\xde\x4d\x45\x53\xd9\x4c\x4e\x0e\x27\xa6\x42\x14\xf4\xfc\xd7\x5e\x38\xe6\x8c\x26\x2b\x10\x1c\xe8\x70\x2b\xc3\x3a\x55\x3b\xf7\x3d\xfc\xe0\xa5\x4a\xcd\xf4\x73\x06\x64\xfa\xf6\xdd\x4e\x4f\x7e\xe6\x89\xa7\xcf\x06\xbe\x5f\x21\x71\x63\x72\x6c\x82\xa2\x0c\xba\x09\x92\xe4\x1f\x3e\x76\xe8\xe6\xdc\xc2\x7c\x6f\x7e\xb1\x11\x37\x6d\x36\xb7\x9b\x35\x4d\x34\xc2\xf2\x62\x69\x78\xe1\xe5\x67\x0f\x3f\xff\xf4\x97\x1e\xb9\xfb\xe4\xfd\xf1\xb2\x51\x0d\xa3\x7d\xec\xec\xbd\x9f\x44\x7b\xf1\xc5\xcf\x7c\xfe\x35\x01\x18\x88\x52\xb5\x7a\xe3\xbe\x87\xee\xdb\x56\x54\x49\xa4\xd9\xa8\x98\x34\x8a\x7d\xe9\xf9\x97\x56\xd7\xaf\x5c\xbf\x1d\x83\x26\x49\x96\xfb\x46\xd5\x5c\xbf\xff\xa1\x07\x36\x54\x4d\x16\x8a\x90\x2c\x9e\x3c\x37\x1c\xf2\x17\xbe\xf6\xdc\x71\x7b\x64\xad\x86\x61\x60\x80\x07\x80\xcf\xa6\xb4\xef\x7b\xcd\x83\x2f\x57\xeb\x15\x7f\x9f\x16\x2d\xd8\xe0\xa1\xf8\xf5\x27\xbe\x76\xd6\x77\xdc\x46\x18\x01\x64\xc8\x8b\x47\xb1\x63\x09\x8e\x9f\x3e\x71\xfe\xe4\x9d\xa7\x37\x29\xa3\xb3\xac\x03\xc2\x5f\x45\xf2\xca\x30\x02\x96\x12\x01\xe8\xf6\xcb\x0b\xb5\x9b\xfa\x7c\x75\xf0\xaa\x6c\x28\xa3\x05\x89\x00\x32\x9d\xd7\x57\x34\x7a\xd3\x39\xc2\xb3\x32\x03\x3c\x6d\x98\x24\xd3\x99\xba\xa9\xe4\x55\x51\x3b\x92\x17\xbf\xe1\x19\x2b\x8c\x16\x81\x4c\x9e\xc1\xcd\x47\xbf\xe5\x72\xe2\xb3\x53\x2d\x72\xec\x3b\x2b\x18\x41\xf8\x4c\xdf\x5e\x9a\x18\x2d\x8c\x9a\x4c\xd2\x0d\x85\x33\x83\xd5\x97\xd6\xde\x9e\x7c\xe5\xe2\x25\x73\x67\x73\xa3\x56\x97\xe6\xfe\xde\xda\x1b\x1e\x79\x4b\xef\xd2\xb5\xab\x8d\x07\xef\x5c\x55\x8e\x2f\xea\x83\x97\xb6\xc2\xce\xd3\x2f\xb7\xd5\xdb\x8e\x56\xda\x7f\xfe\x27\xbf\xab\xbf\xf7\x7d\x3f\x49\x6f\x6e\x59\xb4\x5c\x91\xc8\x68\xb2\x7b\xd4\x69\xfe\xc2\x89\x47\x4e\x7c\x23\x3b\x0e\x5a\x60\x3e\xef\x1b\x6c\xc9\xa7\x42\x0d\xbc\x20\xe3\xce\xf9\xcc\x94\x3b\x5e\x98\xe9\xcc\x73\xe1\x34\x5e\x00\xcc\xf9\x75\xc7\xa9\x84\x37\x1e\xbb\x76\x47\x93\xaa\x6f\xef\xde\x75\x7b\xdd\xad\x9b\x8c\x63\x94\xd8\x19\x32\xc1\xf7\x05\xb5\xd3\x45\x0e\x25\x61\x7a\x89\x0a\x86\x9c\xd0\x0e\x65\x88\x6d\x65\xec\x94\x66\x3c\xc4\xbe\xfa\x76\x97\x8b\xbb\xed\x09\xdb\x5a\x3f\x6f\x10\xfb\xf1\xa3\x67\x8f\x5d\xd1\x17\x0c\x37\x53\x9a\xc8\x4e\xe6\xf5\xf3\xad\xf2\x68\x7b\xdc\x40\x51\x04\x30\xe4\x35\x1a\x09\x9a\x53\xe2\x92\xad\x78\x65\x17\xc3\x4d\x89\xaa\x82\x8b\xa1\x2a\x71\x22\x15\x67\xde\x43\x54\xea\xf0\x48\xb4\x28\x20\x72\xe2\x48\x1e\x19\x01\x84\x1a\xc9\x1e\xed\xc9\x22\xed\x49\x8a\xd0\xaf\x1d\xd3\x27\xe5\xd5\xc4\xd6\xf2\xcc\x61\xa7\xd3\x38\xf8\xec\xd2\x98\x19\x15\x39\x9d\x12\x12\xe5\x93\x3b\x92\xc6\x49\x3e\x33\xea\x24\x0f\x36\xf2\xd2\x54\xda\x59\x19\x15\x67\x5f\x47\x85\x09\x24\xc9\xcc\x84\xcc\xb1\x3f\xff\x39\x40\xee\x10\x39\x40\xe8\x4d\x04\x1b\x3b\x5d\x22\x16\x28\x84\x4a\x48\x02\x01\x40\x88\xcd\xd4\x3e\x0d\x20\x82\xf6\xc9\x87\x7e\xfd\x27\xbe\xb5\x0c\xef\xcf\xfe\x1f\x3f\x06\x30\x5a\x27\x7f\xf8\x07\x8f\xca\x43\xaf\xb7\xe0\x87\xee\xb1\x77\x7f\xcf\x07\xfe\xb5\x5e\xd5\xce\x3d\x7c\x3c\x24\x15\x38\x1f\xe1\x6d\x2a\x79\xea\xc5\x31\xf9\xbd\x5f\xfc\x18\x93\x4b\xc4\x7a\xfc\xc6\x27\x7f\x51\xbc\xc2\x34\xda\xfd\xe1\x1f\x3b\x7f\x41\x3c\x79\xfa\x84\x20\x1c\x59\x8b\xc8\xa1\x15\x4e\x00\xa8\xe0\x34\x22\x2c\x73\x11\x4c\x3b\xfb\x01\x65\xdd\x3e\x21\x1b\x9b\x8c\xac\xdf\x14\xc8\x95\xab\x12\xb1\xdc\xc9\xd7\xa3\x52\xe7\x17\xcb\x87\x8f\xbe\xb8\xb4\xb4\xa6\x40\xa4\xab\x61\xae\x94\x45\x2e\x38\x87\x18\x94\xc6\x88\x95\xd8\xe0\xa5\x01\x29\x07\x14\xe3\xf4\xac\x82\xed\xd3\xf4\xac\xa4\xf3\x7c\xf9\xb4\x68\xc3\x52\xa1\xa4\xb4\x9e\x8f\xaf\x89\xdb\x35\x92\x92\x04\x23\xbc\x10\xe2\xf2\x14\xd4\x91\xac\x78\x93\xd4\x27\x23\x14\xe3\xc9\xd0\xee\x94\xeb\x9e\x5c\x06\x46\x52\x0c\x1d\x47\x7c\x2c\xb6\x1c\x8c\x16\x35\xaf\x93\x38\x39\xdd\x81\xae\xa9\x72\xa3\xb1\xe8\x19\x46\xc9\x2f\xc9\xb5\xdf\x34\x1c\xe5\x38\x19\xdb\xdb\x01\x8f\xec\xf8\x60\xa7\x7a\x80\xf1\xd8\xde\x92\xa2\xd2\x13\xc7\x4e\x38\x8a\x24\x74\x26\xe3\x89\xda\x58\x5c\x1c\xaf\xac\x1e\xfa\x4d\xca\x03\x16\xd8\xe3\x52\xb6\x1e\xf3\x22\x56\xf6\xa0\x94\xcc\xfc\x9c\x74\x26\x24\xe4\xd6\x42\x11\xac\xd8\xd3\x5f\x2f\x9b\xcc\x90\x65\x37\x0c\x23\x4f\x40\xca\x87\x22\x73\x91\x73\x3d\x74\x2c\x32\xa5\x00\x24\x94\x84\x70\xff\x48\x5e\x9e\xb1\x16\x53\xd9\xc3\x42\x36\x77\x4a\x8c\x25\x39\x68\x2e\x8c\xfd\xcd\x33\xe0\x8a\xac\xd3\xc5\xc6\x4a\x58\x36\xcc\x71\xad\xd6\x8d\x5a\xcd\x66\x30\x1c\x0c\x8c\xcb\xfd\xde\x33\x23\x6d\xe9\xcf\x1b\x6d\xfe\x0e\x12\xac\xbf\x6b\x54\x53\x7f\x4b\x31\x64\x6b\x2a\xca\xce\x73\xa4\x3f\x4d\xb0\x15\x52\xb9\xb3\xe8\x16\x29\x23\xa9\x03\xe0\x33\x33\x7e\xa7\xcf\x9b\x36\x38\x80\x09\xe2\x9a\x14\x44\xba\x12\x05\x92\x18\x45\x8c\x84\xc8\xc5\x92\x43\x1e\xa9\xd4\x8b\x9d\x0f\xac\xeb\xb8\x43\x82\x5f\xec\xf5\x1a\xf8\x4a\xb3\x52\x76\x16\x17\xe6\x87\xf5\xf9\xda\x64\x6e\xbe\x6a\x15\xdf\xdb\xb6\x1d\xc1\x75\x1c\xf0\xca\xd4\xd6\x4a\xc2\xb0\x52\x57\xfb\x8a\x2a\x02\x70\x86\x7d\x43\xf4\xab\x6b\xdc\xd3\x74\xd1\x56\x64\xc1\xf5\x1d\x12\xc2\xba\x10\x78\x26\xa3\x99\x8e\xd1\xbb\xf8\xf2\xa5\x43\x9b\x37\x37\xe6\x6a\x75\x73\x72\xe8\xe8\x4a\xaf\xb1\x38\x37\x79\xd5\xac\x62\x54\xbc\xb0\x2c\x1a\x85\x48\xc5\x74\xf8\xf6\x56\xab\xd2\x6e\x0e\xab\x9e\xe3\x21\x5b\x27\xc2\x0c\x23\xf6\x9c\x01\xb6\x80\x70\x9b\x82\x1f\xb7\xd9\xf5\x2b\x97\x1b\x57\x2e\xf3\xa5\xc0\x0f\x15\xec\xca\xc7\x24\xa1\x28\x52\xb7\x54\x52\xdb\x94\x4c\xbc\x28\xea\xf4\x34\xa5\xa2\x03\x76\x8e\x81\xa4\xe3\x5a\xfc\xc6\xd5\x8d\xda\xde\xce\xf6\x3c\x66\xf6\x05\x81\x45\xaa\xcc\x60\x6d\x13\x87\xb1\x6e\x47\x96\xab\x66\xe0\x53\xcc\x28\x72\x49\xa6\x96\xaa\xf1\x41\xb9\xca\x71\xaa\x55\x5c\x5f\x31\x74\xc2\x0d\x83\xf9\x9a\x26\x78\x8e\x45\x51\xa7\x51\x41\x2a\x16\xdc\x6f\x92\xeb\x86\x25\xb8\xef\x75\x7b\x6c\x93\xbd\x9d\xe6\x2a\x7c\xc6\xfe\xd1\x63\xab\xed\x85\xc5\xf9\x49\x76\x26\x1c\xdb\x46\xd9\xd5\x89\x59\x53\x7a\xb2\x46\xac\xdd\xed\x41\x25\xf2\xc6\x1a\x0f\x6c\x85\x70\x5f\x02\xdc\x88\x99\x4c\x5f\xd3\x05\x9b\xf3\xb1\xdb\xef\x6d\x06\x73\xf3\x0d\x38\x99\x82\x9c\x9c\xad\xd0\xdb\xda\xdd\x94\x9c\xc9\x10\x80\xa6\x2f\x63\x0d\x48\x80\xb3\x22\x8b\x2c\x80\x97\x85\x83\xe1\x96\xbd\xb0\xb0\xc4\xe0\xf6\x8f\x39\x95\x82\x48\x03\x51\x61\x93\xca\x92\xb8\x09\xf8\x4f\xe0\xfb\x0a\xb6\x51\x7e\x3b\x24\xee\x30\xca\xb3\xbe\x85\xfe\xc7\xb8\xf1\x05\xa9\x0e\xbe\xc0\x43\x4f\xe3\x91\x6f\x44\x61\xa4\xc1\xd1\xc8\xf8\x16\x29\xd1\x87\x82\xbb\xd2\x5e\x78\xe6\x85\x73\xbb\xdb\xbb\x4d\x00\x8a\xad\xc6\xd2\xfc\x78\x2a\x62\x95\xbc\x55\xa7\xd9\x31\xba\xad\xae\x4a\x63\x55\xa6\xc0\x17\x15\x61\x58\x6d\x54\xba\xf5\xc5\x7a\xaf\x32\x5f\x81\x63\x05\x1f\xd7\xf7\xf4\xc0\xf3\xca\xbe\xef\x97\xe1\x9a\xc3\x73\x39\xce\x10\x09\x21\x08\xf0\x15\x5d\xb2\x87\xde\xa0\xb7\x58\xc1\xb9\xd5\x44\x83\xbf\x2b\x5c\x60\xb6\x6d\xd9\xfc\xf2\xc5\xcb\x8d\xc0\x03\x77\x12\x85\x72\x92\xd9\x11\x00\x14\xca\xe3\x76\xbf\x65\x1b\x35\xc3\x17\xa9\xa8\xa4\xc0\xd6\x73\x3d\x37\xdc\xdc\xdc\x54\x01\x34\x0e\xd0\xcd\x46\x41\xa8\xc1\x51\x8a\xb1\x22\x4f\xac\xc9\x47\x03\xa4\xd8\xdc\xbc\x72\xf3\x68\x6f\xaf\xdf\x68\xaf\xb7\x27\xa2\x28\x47\x47\x6e\x3f\x72\x53\xd4\x24\x6f\x6b\xfb\xe6\xfc\x73\x5f\x7f\xec\x0d\x47\x97\x6f\xa3\x8e\x67\xc1\x79\x96\xc9\xa1\xc3\x77\x3d\x85\xb7\xdf\xc5\xf3\xaf\x1c\x76\x5d\x4f\x55\x74\xb5\xa5\x94\xb4\x49\x3f\x70\x9a\x4b\x25\x53\x80\x3d\xea\xdc\xf5\x4d\x58\xdd\xd8\x7c\x56\xdf\xba\xb9\xb9\x86\x40\x1e\x56\x56\x08\x0b\xd1\x15\x55\x79\xd2\x71\xc6\xed\x95\xca\x82\x0c\x06\x5c\xe7\x61\xa8\x12\x81\x59\x96\x6d\x47\x17\x2f\x5e\x59\xf2\xbc\xc0\x44\x1a\x73\x7c\x5b\x89\x82\x2b\xa8\xca\x70\xaf\xdf\xb5\xf4\xb9\x8a\x27\x52\xa6\x62\x4f\x2a\x38\x0b\xc7\xf3\x03\xef\xe6\xd6\xb6\xc9\x24\xc9\xe6\x48\x94\x86\xf7\xe0\x05\xbb\x0a\xdf\x8b\x57\x2e\x5d\xbd\x73\x6b\x6b\xe7\xb0\x59\xad\xf4\x56\x0e\xaf\xee\x2c\xae\x2e\xf5\xa6\x3c\x82\xbc\x4f\x8c\x4c\x46\x13\x38\xfb\xac\x57\x6a\xd4\x9b\xb5\x23\x2b\xbb\x92\x2a\x87\xe9\xa4\xa3\xa2\xbd\x26\xf4\xd5\x51\x6c\x0e\x43\x69\xe6\xf2\x78\x56\xb0\x23\x53\x02\xdb\x74\x7c\xdf\xb4\x5d\x22\x16\x26\x4a\x56\x5d\xce\x5b\xc8\xd0\x0b\x9d\x81\x84\x19\x4b\xa2\x98\xb8\x25\x45\xe9\xde\x2c\xf1\x99\x6b\x14\x44\xf9\xb0\xb2\x4c\xf4\x36\x93\xa5\xcf\x66\xae\xcc\xa4\x4c\x8b\xf3\xdd\x0b\x83\xcc\x48\x61\xb2\x30\x5a\x06\xee\x84\x1e\xed\xf6\xbb\xfa\x60\x34\x2c\xe9\x72\xa9\x79\xf1\x8f\x3f\xf5\xe7\x2f\xed\xbe\xf8\xd4\x83\xed\xbf\xfd\x23\xa5\xef\xfd\x9e\xa3\xc1\x57\x5f\xee\x8c\x7e\xe8\xb5\xcb\xc6\xbf\xf8\xfc\x9f\xb9\x96\x33\xd2\x2f\x5e\xda\x0e\xbd\xa0\x2b\x5e\x7e\xe5\xa9\xb5\xd3\x0b\x8f\x1e\x7a\xd3\xf1\x2d\x2f\x9a\x4a\x7d\xf1\x19\x85\x36\x3e\xa3\xd8\x46\xa7\xd2\x67\xd3\x8e\xbf\x5c\xd9\x89\xbc\x7a\x06\x78\x71\x8e\x68\x72\x89\xa3\x2c\xec\x8a\x6f\x6f\x41\x20\xf3\xf7\xae\x5c\xb4\x9f\xde\xa9\xb3\xa7\x5f\x78\xad\x5b\xaf\xd6\x26\xc7\xd6\xb8\x6f\xe8\xdc\x57\x15\x1e\xa8\x32\x09\x75\x8d\x08\x83\x31\x11\xdc\x80\x0a\x13\x07\x82\x41\x87\x88\xbe\x4f\x04\x45\x26\x82\x2a\x71\x5e\x82\xe5\xb7\xb2\xa8\xf2\x89\x7d\xce\xda\xda\x5e\xd8\xf9\xe2\xc6\x17\xcb\xf7\x2c\xbe\x50\x3b\x5e\x1e\x40\x60\x9f\x0f\xd4\x38\x72\xd7\xdc\xd0\x3d\x5a\x19\xf9\x6e\xc8\xdc\x91\x27\x46\xfd\x88\xf9\x70\xcf\xd9\x8e\xad\xb9\x70\x43\x8f\xb7\x89\x21\x77\x99\xa4\xd5\xa8\x0d\x8e\x40\x16\x6d\x26\x26\x69\x38\xee\x46\x32\x9d\xb0\x39\x36\x51\x34\xd1\xc3\x9e\x7d\x49\xa2\x91\x56\x11\x43\xad\x2e\x85\x9c\xa7\x0d\xdf\x69\x46\x9b\x14\x48\xcb\x34\xe6\x0a\x4f\x57\x47\x14\x71\x32\x7b\x8d\x39\x4f\xb2\xb4\xa9\x06\x72\x76\x01\xa2\xb8\xf6\x9d\xfa\x5e\x9e\xc7\x08\x8c\x4c\x75\x2d\x92\xca\x7b\x72\x7a\x93\x62\x4b\xc2\x05\x67\xe9\x90\x59\x1c\x22\xf6\xba\x77\xc7\x35\x77\xf2\xb5\x8f\x89\x80\xdc\xe3\x72\x18\xf8\x4d\xe4\x02\x22\x16\x83\x57\x0a\xa8\x7b\x2b\xa6\x7a\x5c\xdf\x22\xa5\xe1\xdf\xff\x5f\xbf\xcd\x8f\x9f\x3e\x29\xf5\xfd\xce\x5c\x18\xf8\xb7\xbd\xfd\x4d\xef\xfb\x67\xe5\x72\xfd\x81\x87\x8f\x07\x44\x87\x7b\x74\xe0\x88\x64\x65\x4d\xa3\x67\xef\x90\xc9\xee\x97\x47\xe4\xfa\xc6\x85\xf7\xfb\x01\xb8\x9f\x20\x98\xff\xdc\x85\xdf\xfe\xa5\x23\xbd\x13\x47\xfb\x5b\x77\xbf\xfe\x79\xad\x7a\xca\xac\xc9\x28\x48\x4d\x54\x95\xc7\x54\xc6\x20\x00\x54\x0e\xe8\x7c\x34\x64\x64\x38\x70\xd7\x23\xda\x7f\xc6\x0b\xdb\x1f\x8d\xa4\xe0\xd9\xe3\xf5\x93\x56\x59\x94\x42\xbb\xd5\x8c\xab\xc9\x51\x8c\x00\xd3\x62\x60\xac\x19\x25\x70\x24\xc5\x45\x09\x75\x84\x1b\x6a\x89\xb8\xd4\x21\x2e\x77\xa9\x08\x76\x39\x96\x25\x63\x59\x8a\x94\xe6\x53\x78\x05\x96\x76\x45\xe3\xc9\x63\x2c\x85\xa7\x94\x66\x75\x77\x96\x62\xb1\x9c\x67\x9a\x14\xc1\x39\x63\x94\x4e\xcb\x94\x79\xdb\x68\x6e\x67\xf2\x51\x2b\xb9\xc4\x26\xcf\xd0\x16\x4d\x0c\xd2\xf4\xb6\xa2\xe9\x53\x54\x41\x76\x4b\xaa\x6e\x45\x41\xc0\x1c\xd5\x5e\xb7\x37\x86\xff\x4e\xb5\x86\xff\x86\x31\xe1\x7f\xd0\x4c\xfd\x5f\x18\x73\xe5\x76\xca\xc3\xe5\x59\xd2\x56\x91\x64\x7f\x6d\xf9\x50\xcf\x83\x08\x51\x96\x65\x94\x34\x88\xc2\x84\x33\x4e\xa6\x51\x7c\x41\x61\x7c\xdf\x04\xd3\x2c\xbc\xa5\x05\x0b\xcc\xf7\x7b\xeb\xe4\x5b\x1c\x55\x11\x49\xc9\x09\xa3\x60\xe0\x29\xf2\xf0\x32\x89\x25\x7a\x8b\x5c\x65\x81\xf3\x35\x3d\x18\x4a\x67\x92\x2a\x94\xce\x16\x31\x09\xa7\x85\x3f\x64\xd6\x32\x33\x8e\x42\xa4\x68\x8a\xd7\x58\x2c\x07\xba\x31\x67\xf7\xba\x9d\x49\xbf\xdf\xd3\x1d\xf8\xb8\xe1\xea\xa1\x8f\x9a\x66\xc5\x8f\x44\x16\xda\x2e\x9d\x0e\x86\xa4\x45\xcf\xc0\x67\x00\x2b\x9d\x2a\xa3\x4e\x73\x71\x94\xec\x03\xc5\x84\xd0\x82\x82\xf9\x34\x25\x82\xf7\x2e\xea\xa4\x0a\x9e\x64\x44\x63\xad\x1a\x74\x2d\x17\x60\x11\xb7\xab\x9e\x87\x0d\x46\x28\xa9\x05\x80\x34\xc2\xc9\x69\xb9\x6e\x38\x6f\x35\xc7\x72\xbb\x35\x31\x28\xdb\x88\x00\x24\x79\x92\x2c\xb9\xaa\xa2\x4e\xf4\x92\x36\x2a\x55\x4b\xc3\x6a\xdd\x1c\xd6\xca\x95\x91\x5c\xd6\xdd\x00\x30\x09\x52\x6d\x11\x32\xfb\x81\xef\x87\xe0\x64\x05\x35\x1c\x09\x4a\x30\x60\x32\x05\x88\xed\x22\x20\xc2\x81\x15\xe2\x74\x46\x12\x67\x80\x86\x4b\xbd\xbe\x6b\x5c\xbf\xde\x9e\xc3\xcc\x2f\xca\x58\x01\x92\xf5\x24\x45\x74\x74\x4d\x19\x55\xea\xe5\x5e\x63\xa1\xd2\x31\x6b\xfa\x44\x10\x24\xa6\x01\x14\xd4\x5d\x1c\xd1\x33\x09\xa8\xeb\x6b\x70\xec\x68\x03\xb8\x24\x09\x81\x24\x31\x47\x51\x65\x1b\x33\x72\x9e\xeb\xab\x93\x89\x63\x62\x23\x4f\x1c\xc0\x09\xa2\x23\x2a\xba\x25\x6a\xe5\x09\x60\x9c\x81\x56\x13\x77\xb0\x34\xb6\xb7\x3b\x30\xd7\xaf\x37\x57\x76\x76\x06\x5a\x00\xa7\x80\x63\xb7\x00\x15\x5c\x26\x28\x36\x15\xf4\x49\xc8\xa5\xb1\x56\x12\xf7\x04\x91\x45\xbc\x90\xa0\xb2\xd2\xd8\x09\x0d\x25\x60\x5b\x47\x94\xfd\xb1\xa2\xbb\x3d\x79\x12\xc9\x60\x43\x28\x80\x6d\x0d\xd5\x1a\xc0\xa6\x89\xe9\xf9\x0c\xf1\xb3\xed\xed\xf5\xf5\x6e\x6f\xbc\xa0\x69\xd7\xc7\xa5\xb2\x3e\xa8\xcc\x19\xdd\xfa\x5c\x79\x58\x33\xcb\x63\x38\x2e\xcf\xb6\x43\x66\x01\x9e\x70\x1c\x3c\x8f\x80\x51\x03\x34\xcb\x38\xbe\x59\xb0\xe1\x9e\xe9\x95\xcc\x52\x5b\x54\xc4\x3d\xd9\x20\x23\x0d\x8c\xbc\xef\x07\xc2\xde\x76\xbf\x32\x1a\x4c\xd6\x02\x1f\xae\x31\xb6\xd4\x46\x38\x75\x91\x61\x1e\xc4\x16\x45\x69\x0c\x3b\x18\x33\x35\xe8\x98\x95\x92\x83\xec\xa7\x6c\xf1\x04\x71\xb9\x9a\x4e\x79\x93\xc5\xac\x33\x9f\x32\xca\xa7\x00\xa1\xd0\xca\x9d\x85\x65\x58\x01\x49\xe8\x36\xf0\x9e\xc8\x8b\x42\x91\x28\xce\xd3\x91\xe1\x48\xa4\xc3\x16\x7b\x61\x77\x6b\x67\x79\x6f\x7b\x6f\x11\xec\x1f\x32\xb2\x42\x08\x44\x3d\x26\x81\x93\x02\xf7\x05\x01\xa9\xa5\x19\xca\x44\x37\x8d\xd1\x7c\xa5\x36\x2e\x55\xca\x63\xc3\x34\x6c\xdd\xd4\x50\x01\x49\xe4\x28\x25\x16\x04\xd8\x10\xa8\xc2\x4e\x71\x44\xa7\x90\x80\x57\xe6\x2b\x8a\xe4\x95\xca\x9a\x53\xaa\x68\x91\xb9\xa2\x6f\xa9\x65\xcd\xc3\xc6\xdb\xee\x5e\xcf\xd8\x69\x76\x17\x01\x88\x97\xe2\xd7\x20\x65\x1a\xae\x81\xac\x89\x36\x3c\x77\x58\xae\x1b\x63\xb5\xa1\xee\x9a\xf5\x8a\x8d\x54\x11\xd7\xf1\x04\xbf\xd9\x29\xd5\x96\xaa\x1e\x18\x67\x61\x0c\xc1\x93\xe7\xba\x26\x06\x4d\x71\xa0\x0f\xe7\xd3\x2c\x55\xad\x93\x77\x9c\xda\xae\xcc\x9b\x93\xfd\x11\xe5\xa5\x0b\xcf\x1d\x7b\xea\xf1\xcf\x7e\x0f\x8e\x1b\x46\x65\x10\x6c\x54\x3a\x76\xea\xd8\x73\xba\x59\xe9\xb6\xf6\x3a\xe6\xb5\x8b\xd7\x4e\x08\xa2\x38\x11\x15\x65\xac\x99\xe5\x81\x5a\xad\x38\xca\xe2\xdc\x00\xee\xa9\xb0\xb9\xbe\x53\xd9\x5a\xdf\x58\x83\x80\xa8\x8a\x54\x07\xe4\xb2\x33\x41\xf4\x25\x55\x71\x34\xb3\x34\x51\xab\x65\x4f\x39\xbc\xb0\x6d\x54\x4c\x17\xab\x83\xdd\xed\xbd\x52\xeb\xa5\x9d\x95\x10\xc0\x72\x0c\xee\xd1\xbf\x08\xcc\x13\x65\x19\xf6\x5d\xea\x6a\x55\x73\x20\x2e\xd4\x76\xaa\x4b\x73\x13\x41\x92\x22\xcf\x72\x84\xbd\x1b\x9b\x26\xfc\x7e\x55\x1d\x8d\xbb\x10\x04\xaa\xbe\xeb\x12\xd8\x57\x4c\xbf\x49\xe9\x46\x18\xc4\xcb\x93\xf1\x64\xce\x9a\x58\xb5\xdd\x9d\xbd\x23\xf1\xbc\x21\xc6\xb0\xf2\xe3\x8a\x92\x34\x96\x35\xb5\x67\xd4\xca\x7b\x73\xcb\x4b\x5b\x8b\xab\x87\x9a\xfa\x52\x63\x2c\xc8\x12\xcb\x6b\x5d\xc5\x4a\x41\x36\x25\xe1\xd6\xa2\xe6\x9c\x4f\xed\x19\x2f\xb6\x04\xe7\xf8\x93\x66\x09\xb2\x99\x61\xba\x39\xab\x81\x17\xeb\xd4\x51\xde\xb6\x56\xc8\x74\x16\xf3\xb1\xd3\x1a\x35\xcd\x06\x10\xcf\x64\x67\xf7\xd5\x5a\x52\x30\x53\xac\xc1\xd0\x9c\x50\x91\xeb\xf2\xd2\xe9\xd8\xc1\x69\xd6\xaf\x48\xfb\x75\xad\x11\xb5\xc7\x43\x51\xe2\x4c\xd1\x8f\x9f\xbe\x9d\x9d\x3e\x7d\xcf\x6b\x9f\x3c\x7c\x8a\xdd\x7b\x6e\xcd\xfb\xec\xe3\x8f\xf7\xad\xab\x7f\x5a\xfb\x63\xf7\xfb\x36\x85\xcb\x9f\x6a\x55\x3a\x93\xe0\xf2\xe3\xff\x74\x6e\xb9\xbe\x77\xe4\x35\x27\x7a\x95\x52\x95\x45\x9e\x97\xd0\x4e\x69\x51\xb7\x97\x17\xee\xd1\x59\xb9\x61\xbe\xbf\x18\x97\x65\x74\xd3\xf1\x9d\x79\x82\x72\xda\x1f\x38\x3d\x67\x33\x1d\xda\xc9\x67\x56\x4a\xb2\xdf\x38\x55\xff\xba\x78\xa9\xd9\xb3\x36\xb7\x1f\x16\x27\xf6\x6d\x93\xb5\x05\x25\x6e\x04\xae\x54\x08\xb7\x27\x24\x50\x75\x12\x41\x60\x87\x3f\x53\x58\xf3\x60\xc0\xc1\x82\x46\x44\x08\x7c\x38\x2b\x22\xd8\x72\xc0\x2a\x27\x8e\x12\x45\x91\x97\xc9\xb5\x8d\xef\xb7\x2f\xf5\xe6\x7b\xad\xd1\x73\x0b\xa7\xaa\x9b\x46\x5d\xf1\xd2\x04\x1b\x17\x15\x0a\x0f\x21\xd0\x4c\x35\x20\xab\x99\x53\xd7\x87\xd3\x96\xba\x69\xc4\x42\x0b\x52\x73\xa1\x13\x52\x64\x80\xee\x4b\xd7\x72\x08\x8e\xf3\xf3\x95\x26\xa8\x72\xfd\x36\x3e\x13\x05\x24\xc9\xf9\x74\x11\x4d\xf1\x00\x4f\x59\x5b\x34\xcd\x46\xd3\xb8\x71\x31\x2d\x94\xa5\x6b\x86\x66\x35\xf4\x04\xc8\xc6\x28\x8f\x25\x3a\x9f\x2c\x56\x56\x4a\x49\xe2\x2c\x49\x1e\x66\x42\x37\xd3\x0a\x02\x3e\xc1\x2f\xc0\x16\xfa\xea\xa2\x1f\xf9\xf6\x38\xbc\xc2\xd5\x8b\x97\x51\xc4\xe1\xc8\xf7\xbf\xee\x87\x7e\xbe\x6e\x34\xbe\xf7\xa1\x53\x21\x29\xab\xe0\x2e\x3d\x91\xe8\x15\x03\x53\x34\xa4\x3f\x08\x89\x20\x0b\x57\x2f\xed\x7c\xe3\xb3\x81\x1f\x94\x83\x20\xa8\x83\xcf\xa8\x5f\x5a\x7f\x79\xfd\xe2\xfa\xf9\x67\xb0\x3d\x7e\x71\x7e\x65\x7e\xa1\xba\xba\xa4\xc9\xa5\x8a\x20\x4a\xe8\xb8\x2d\x87\x4f\x76\x47\xed\xee\xcb\x1b\xdd\xf5\x6b\xb2\xa4\x76\x4d\xdd\x1c\xdf\xb3\x7c\xda\xf3\xf7\x6c\xb2\xdb\x67\x44\xf1\x20\xd2\x01\xeb\x1b\x48\x01\x52\x14\xe2\xce\x3b\x1e\x77\x8a\x29\x44\x47\x11\x12\x00\xbd\x82\xac\xd1\x2f\x5c\xfd\x38\x79\xcd\xe4\x01\x7a\xba\x7e\x9a\xdc\x3c\x79\x93\x5a\xdc\x25\xc6\xa0\x42\x1d\x58\x0f\x91\x12\xc4\x94\x87\xb8\x61\x4c\x54\xd3\xa6\xa4\x28\xe6\x33\x73\xec\x6c\x14\x21\xd6\xd0\xc1\xe9\x84\x42\x1c\x1a\x50\xe4\xeb\x82\x3f\x10\x50\x46\x4c\xc4\x66\xca\x88\x61\x12\x0c\x2c\x22\x85\x3b\x0f\x40\x4e\x82\x92\x59\x0c\x40\x15\x9c\x68\x45\x91\x03\x29\x49\xb0\x7b\x01\xc3\x2e\x31\xce\xcf\x42\xb8\x11\x8b\x23\x0a\x98\x8e\x16\xe2\xc2\x7f\x32\xe2\x37\xa6\x58\xe0\x5c\x59\x95\xfa\x4e\x50\xde\xda\x59\xaf\x5b\xd6\x04\x33\xb4\xff\xf8\xc1\xf9\xb7\xfd\xbe\xe8\x3b\x38\x9d\xe7\x77\xbc\xcd\xce\x0f\x1a\x8b\xd5\x2d\x1a\xe7\xa2\x33\x1a\x16\x8f\xf9\xc9\x9a\xa4\xc6\x38\xd6\xf5\x10\x92\x27\x6a\x0c\x3c\xcf\xde\xf2\x0c\xba\x53\x3e\x4d\x45\x4f\x1b\xb8\x28\x2d\x14\xbf\x08\xcd\xf8\x0c\x9c\x67\x39\xa5\x5c\x3b\x34\x8e\xb3\xd2\xfe\x85\x0c\x37\xd3\x1c\x7d\x27\x43\xc3\x68\x9e\xc1\xa6\xb4\x08\x68\x69\x9a\x4f\x4d\x38\xcc\x59\xe8\x9b\xc5\x08\x34\xb7\x7f\x53\xb4\x90\xdc\x94\xb4\xf8\xfa\xf8\x26\x01\xa4\x54\x96\x75\xaa\x18\x15\xd1\xa8\x0c\x64\xcc\x48\x32\xd9\x08\x22\xaa\xfa\xa8\xf7\x91\xd3\x16\xf0\x28\xc2\xfd\xf3\xde\x38\xdd\x57\x75\x9f\x19\x9a\x99\x1e\x57\xf1\x35\x05\x45\xf1\x3c\x17\x9d\x17\xbe\x90\xc1\xc0\x65\x32\x54\x4d\x3e\xd6\x1d\xa9\x1f\x91\x61\x8d\xd8\xb6\xe9\xbb\xbe\x1e\xfa\x01\x44\x20\xc8\x9a\xe2\x8c\x4f\x4b\x8e\x3e\xd2\x1d\x50\x83\x14\xc0\xd6\x44\xd5\xb5\xb1\x5e\x36\xfa\x7a\xb9\x34\x34\x6b\xd5\x91\x5e\x29\x5b\xac\x64\xb8\x9e\x28\x86\x3e\xbe\x2c\x48\x8e\x05\xb5\x70\x7d\x51\x56\x98\xc6\x07\x92\xc1\x47\xa2\xa7\x34\x84\xc8\xaa\x11\xdf\xd7\xc2\x20\x48\x33\x6a\x3c\x6b\xcf\x8e\xe2\x0e\x4b\x11\x1c\x2b\x65\xbe\x24\x21\x30\x95\x2d\x55\x53\x86\x46\xb5\xd4\x07\x27\xdd\x97\xcd\xea\x08\x22\x4d\x08\x0d\x22\xaa\x54\x4c\x43\xf7\xf4\x5a\xc0\x87\x75\x6a\x39\x65\x11\xf7\x87\x80\x17\x00\xb2\xaa\xa9\x23\x1d\x80\x13\x66\x57\x27\x63\xcb\xf4\x82\xd1\x42\x18\x79\x55\x74\xe8\xa2\x2c\x0d\x45\xb5\xbc\x2d\xa8\xd5\x8d\x48\xaa\x74\x7c\x5a\x02\x53\x09\xab\x5c\x08\xc7\x5c\x1c\xc3\xe2\xb7\x65\x41\xe2\x00\xc6\x22\x49\x52\xe5\xa1\xa4\x95\xb6\x24\xcd\x5c\x67\x6a\xa5\xcd\x45\xc3\x09\x18\x4d\xa7\x13\x15\xda\xc5\xf3\x41\xf7\x60\x73\x95\x72\x57\xd3\x5d\x00\xa1\x7c\xe0\x7b\x0c\x80\x96\x67\x72\x1c\x0d\x13\xc5\x6a\x05\x11\x6a\xab\xc2\xb9\xb4\xe1\x38\x27\x00\xca\x07\x46\x49\x1b\x94\x4c\xa3\x67\x18\xa5\x91\x22\x63\xe0\x08\x60\x77\x02\x67\xc9\x0a\xe5\x58\xe1\x0a\xf5\x60\xa2\x18\xa3\xc5\x1a\x65\x02\x93\xfa\x82\xa8\x6d\x0b\xa2\xb1\xc9\x88\xda\x71\x6d\x66\x87\x7e\x14\x79\x10\x36\x59\x13\x32\xf1\x5d\x46\xa3\x10\x65\x34\x44\x94\x85\x50\x18\x82\x76\x26\xb5\x61\xb1\x6d\x44\x91\xb0\x11\x78\x42\xdf\xb6\xb9\x9f\xdc\x15\x69\x28\x9a\x91\xc6\xe3\x8c\x54\x46\x9c\xa5\x84\xb2\x42\xfc\x94\x63\x61\x3a\x25\x1d\xe5\xa2\xbc\x31\xfd\x86\x49\x92\x1c\x62\xb7\xb5\xa6\x2a\x0a\xac\x25\x7c\x72\x19\xc0\x8a\x98\xde\x93\x3c\x01\xb9\xf0\xf9\x71\x4a\xa5\x88\xc0\x4c\xf4\x60\x3d\xd9\x92\x2e\x4f\x74\x43\xb5\xf5\x92\x6e\xa9\x86\xea\x94\x4c\xcd\x32\xca\x86\x23\xab\x4a\x80\x59\x43\x0c\x32\x50\x3b\x91\x07\x11\x03\x7b\x16\xc8\xa2\xe0\x02\xfe\x1d\xcb\xb2\xa4\xc3\xdb\x07\x08\x96\xf5\xb2\xd2\x2d\xd5\xf4\xa1\xaa\xcb\x9e\x28\x61\x31\x3b\x8c\x35\xfb\x70\xe2\x12\xd8\x34\xae\xc8\xa2\xeb\xa8\x82\x85\x6d\xb7\x48\xaf\x00\x20\xdd\xae\x35\xca\x9d\xf9\xe5\xf2\xa8\x52\x93\x42\x55\x4b\x66\xb8\x49\xb2\x10\x49\xa2\x09\x01\x42\xd8\x52\x75\xc1\xeb\x37\xe5\x89\x35\x9c\x54\x7d\xcf\x57\xb1\xb2\x29\x89\x72\x74\xd7\xdd\x67\x07\xb2\x21\xa1\x2c\x06\x52\xb4\xea\xa3\x6e\x77\xc5\x01\x7b\x77\xe5\xea\xcb\x4b\xdb\x9b\x37\x96\xb1\x09\x02\x95\x4b\xca\x7a\x85\xdc\x75\xcf\xc3\xcf\xae\x1d\x3f\xf9\x12\x2e\x96\x9b\xd7\xae\x55\x21\xf8\xed\x02\x20\x1d\xea\x66\xa9\x59\xaa\x57\x7a\x08\xe8\xe1\xf3\x05\xd8\x00\x8a\xa2\xd9\x4c\x94\x1c\x41\x91\x47\xb8\x4e\x51\x0f\x47\x90\x45\x4b\xd1\xf5\xa6\x66\x9a\x1d\xb9\x54\x9e\x08\x10\x4d\xc5\x54\x6e\x1c\x13\xce\xc4\x00\x3e\x5c\xc0\x64\xc9\x86\xd7\x8c\xe3\x72\x97\x24\xda\x5a\xc9\x68\x96\x17\xe6\x9b\xe6\xea\xe2\xc0\x68\xcc\xd9\x82\x01\x8e\x41\x14\xe0\xde\x90\x82\x8a\xbf\x64\xb9\xae\xd7\x81\xa8\x54\x61\xb2\x1c\xd8\xc3\xf1\x24\xf4\x7d\x03\x40\xb3\x8a\x6b\x34\xe3\xd8\xa3\x99\x4f\xaf\x97\x07\xbe\xc5\x05\xc0\x0c\x6b\x56\x1e\x2b\x86\xde\x2f\xd5\xab\x6d\xb3\x51\xeb\xcc\x1d\x59\xe9\xd5\x96\x1a\x96\x52\x36\xe0\x9a\x32\xbe\xaf\xbc\x4e\x0a\x33\x18\x8a\x33\x29\xb2\x5c\x1a\x49\x75\xbf\xa6\x03\x28\x72\x8c\x3a\xed\x9a\xca\xc8\xa8\x69\x29\x79\x56\x09\x78\x3a\xa1\x77\xaa\x41\x90\x7a\x90\xac\x06\x91\x4d\x30\xa6\xd9\xf7\x69\x1a\x8e\xa5\x0e\x25\xcd\x1d\xf1\x9c\x3b\x96\xcf\x2f\xcb\x2c\x7f\x21\x8b\x92\xf1\x3b\xe9\x14\xf1\xd2\x22\xfa\x9c\x99\x22\x97\x02\x31\xf0\xab\xe3\x71\x9f\xd9\xd6\x58\x76\x2c\x5b\x65\x96\x57\x22\xbb\x7b\x7d\x38\xb7\xbb\xc1\xe3\x5f\xf8\x58\x97\xee\x3d\x55\x5e\x2d\x8f\x84\x72\xf7\xeb\xc6\x6a\xfd\xf6\xa3\x42\xe3\x84\x1e\x18\xc7\x25\x56\x5b\xeb\xec\xa8\xb4\x2d\x00\x60\x7c\xfa\xda\xe5\xc3\x67\xcc\xdf\x28\x2f\x94\x47\xb3\x83\x38\x0a\x9c\xaf\x02\x1f\x83\x4e\x73\x33\xb9\xe0\x70\x5a\xae\xcc\xe9\xa8\x74\xca\x85\xcb\xe8\xca\xd1\x2c\x37\x2d\xe2\x45\x39\xa2\xf2\xa2\x34\x54\x2a\x0b\x2f\xb4\x2e\xf5\x76\x58\x67\x72\x86\x6c\xec\x9e\x9e\xac\xce\xaf\x50\x7b\x62\x70\x49\x80\xf0\xd1\x8e\xbb\x57\x00\xd9\x63\x06\x85\x47\xb2\x14\x8b\x05\x05\x46\x29\x02\x20\x10\x41\xa4\xc4\xdd\xb5\x3a\xd1\x18\xce\xae\x64\xa5\xf0\xe2\xb5\x37\xb1\x9d\xd1\x92\xef\x06\xff\x79\xf9\xb4\x79\x45\x2d\x93\xb8\x63\x35\x96\xa1\xce\xb8\x2d\x19\xbd\xa2\xd8\x71\x57\xd0\x65\xa3\xd9\xac\x91\x34\xd0\x08\x6d\x32\x13\xa0\x14\x92\xd7\x79\x49\x56\x88\xbb\x82\xb3\xeb\x8f\xae\x3f\x49\xf9\xa2\xad\x13\x58\x4a\x35\xa0\x3c\x6d\x11\xa2\x79\xb5\x35\x86\x22\x8c\xe6\x94\xf2\x69\x5b\x43\x8c\x2e\x50\x38\x27\x76\x99\xd9\x88\x3d\x5a\x58\xae\x51\xa6\xb3\x86\xe9\x68\x80\x80\x9f\xf9\xbc\xc5\x4d\x6c\x0b\xb1\x31\xbb\x0c\xfb\x94\x44\xd4\x19\xc8\x6b\xc8\xf4\xd5\x29\x3e\x42\x67\x13\xbc\xdf\x14\xf0\x22\xe7\x09\xc1\xee\xd1\xb7\xbe\xf6\x9d\x3f\x3d\x57\x3f\xfc\x83\xf7\x9f\x08\x49\xdd\x08\xc9\xd8\x15\x88\x66\xea\xa4\x62\x32\xb2\xbe\xed\x91\x17\x2f\xfb\x44\x61\xe4\x37\x7f\xe0\x81\xf7\x39\xbf\xf5\xc9\x5f\x76\xd3\xf1\xc3\x28\x5b\x86\x25\x4f\x15\x13\x9a\x3b\xad\x2d\x09\x1e\x19\x00\xf1\xd3\xa9\x6d\x76\xfa\xd5\x71\x3c\xcb\x1f\x4e\xba\x7c\x13\xa7\xd4\xbe\xf8\x97\x77\xcf\xfd\xcc\x7b\xfe\xe7\xf8\x12\xa9\x8a\x4e\x3e\xfe\xc4\xef\x93\x87\xdb\xa7\xc8\x43\xc7\xce\x92\xcd\x43\x97\x88\xc3\x3b\x64\x75\xa7\x42\x7a\xb5\x09\xb1\x34\x8b\x04\x62\x18\x9f\xe9\x90\x55\xe3\xb9\x6f\x94\x83\xbd\x0b\x50\x26\x57\x23\x61\xcd\xa7\x3f\xf0\x47\x0f\x91\x0b\xc7\xce\xd3\x2b\x27\x2f\x90\xc5\xee\x6d\x64\x50\xa9\x93\x2e\xf3\xa8\xbc\x33\x00\x24\xe0\x51\x43\xf5\xa9\x06\x47\x3e\x40\x1e\xba\xae\x12\x49\x13\xa9\x01\x57\xf5\xc5\x9b\x2f\x92\xfa\x52\x8d\xde\x76\xec\x24\xed\x74\x5d\xda\x99\xf4\x88\x61\x80\xcd\xb0\xb1\x6b\xcd\xa0\x92\xac\x90\xa1\x37\xa0\x01\x80\x5f\x94\x3c\xd3\xa8\x88\x58\x9a\x44\x48\x3d\x43\x91\x51\xcb\xe9\xee\x6e\x6d\xfa\xed\xce\x9e\x59\x2f\xd5\x8e\xb3\x23\x4b\xc3\xd2\x23\x0f\x9a\xd6\xef\x7c\x8c\xc8\xa6\xf6\x89\xce\xd5\xdd\x37\x95\xd7\x6a\x57\x93\xc2\x25\xaa\xfb\xd3\x58\xcf\x37\x13\xca\x8e\x73\xd0\x69\xf8\x13\x27\x92\x53\xc7\xca\x12\xe2\x57\x0a\x84\x59\x9c\xcd\xc6\x2c\x75\x94\x01\xcd\x98\xef\xcc\xb2\x86\xad\xe4\x55\x49\x98\x15\x0b\x4b\xd0\x54\x1a\x3f\x5e\xcf\x34\x4f\x6f\xe7\xad\xbf\x29\xcd\x8b\xf2\xa8\x30\x55\x2a\x23\x7e\xa5\x01\x7c\xac\x54\x91\x05\x88\xb8\x3f\x96\x27\x5d\xa7\x72\x68\x29\x0b\x81\xe7\x14\xbc\x88\x66\x9f\x95\x4e\x5b\x23\x58\x32\xef\x9c\xd1\x8a\x59\xa3\xa9\x40\x38\x0d\x02\x8f\x14\xd3\x6b\x59\x5e\xb5\xc0\xda\x9d\xfe\x2d\xc1\x26\x6c\x3a\x4c\x27\xcd\x29\xa7\x45\x80\x9c\x9f\x36\xa5\x81\xa4\x5f\x8b\x12\x6e\xa8\xb7\x2c\x11\x0d\xb3\x7c\x22\x20\x5b\x55\xf5\xf4\x41\x09\x75\xdc\x4a\x60\x90\x0d\xd7\xf1\xf4\xc0\x87\x08\x2d\xc2\xf2\x2d\x56\xcb\x19\x66\xe1\x7c\x70\x76\xae\xac\x28\x8e\x6a\xe8\x96\x5e\x32\x2c\xdd\x34\x2c\xcd\xd0\x5c\x55\x37\x42\x88\xfb\xb0\x5c\x2a\x26\x6d\x72\xd1\x34\xa5\x0c\x6b\x44\x2e\xa9\xb4\x42\xe7\x22\x06\x4e\x5c\x33\xfb\x7c\x32\x18\x39\x8e\x6d\xeb\x1e\xbc\x4f\x14\x05\x02\x3c\x5d\x48\x4a\x3f\xe8\x5c\x85\x50\x92\x24\x57\x92\x25\x04\x3b\x36\x38\xfa\x18\x04\xc1\xfb\xd9\x6a\x49\xf3\x24\x4d\xc3\xba\x50\x4c\xd0\xd4\x6a\x1a\xa1\x72\xd9\x52\x2b\x13\xee\xd8\xd6\x04\x00\x74\xdc\x28\x24\x2b\xb2\xa7\x68\xaa\xa3\xc0\xd7\x28\x04\x5c\xd5\xeb\xe3\x10\x0e\x51\x1a\xdb\x3e\x26\x3c\x01\x50\x8d\xcb\x73\xd5\xb1\x5e\x9b\x8f\x88\x6a\x2a\x0e\x2c\xe2\x78\x6e\xb8\xce\x65\xa3\x1e\x04\x15\x97\x0e\x44\x65\x82\x8e\x4a\x50\x75\x75\x52\x9b\x37\x27\xc6\xdc\x1c\x11\x0d\x53\x0b\x00\xa5\x66\x72\x17\x84\x15\x13\x59\x89\x77\x16\xe1\x34\x98\x38\x54\x4c\x06\xd0\x5d\xd6\x7a\x7a\x67\xc4\x27\x23\xcb\x82\x73\xaa\x41\x50\x83\x82\x0c\x11\x00\x2a\x17\x40\x3c\x66\x32\xc7\x7a\x49\x9b\x94\x4d\x7d\x62\x98\xba\xad\x2a\x12\x18\x7b\x41\x86\xf5\x2d\xc5\x2b\x5a\x14\x85\x6a\x00\x88\x2b\xa8\x38\x4c\x20\x7d\xdb\x92\x63\xa1\x60\x4d\x57\x86\xb5\x46\xa5\xdf\x58\xaa\xfa\x95\xaa\x0e\xb1\xa9\xa0\xc3\x2d\x88\x1d\xa9\xac\x52\xd5\x04\xd7\x35\xbd\x88\x87\x83\xc9\xc8\xa6\xc8\xcd\x06\x60\xe8\x02\xa8\xea\xcd\x2d\x54\x2c\xb3\xa6\x43\x40\x4b\x55\xf8\x70\x0a\x27\xf9\x10\xf1\x99\x7c\x16\xb9\x85\x00\xdf\x6c\x21\x3a\xe7\xcd\x90\x14\x14\xa7\xfe\x07\x95\x63\x22\xbf\x6a\xaa\x43\x7f\xce\xd8\x83\x3b\xd9\x77\x6c\xb1\x1c\xc5\x03\x1e\x10\xe7\xb3\x98\x6a\x22\x62\x20\x03\xd7\x58\x86\xc0\x44\xd1\x64\x78\x28\x36\x80\x54\x47\xd5\x15\x4f\xd7\x35\x17\x7e\xe7\xca\x9a\x04\xcf\xc3\x75\x87\x5d\x29\x60\x56\xbd\x14\x61\x70\x94\x5a\x0c\x88\xae\x4b\x83\x72\x45\xdf\x01\x4b\x08\x31\x7a\x00\xf1\xba\xe4\x94\xab\xa5\xae\x59\xd1\x7a\x9a\xc2\x26\xdc\x73\x42\x54\xa2\xc0\xf5\xcb\x42\x3f\xd4\x14\xc9\x2a\x99\x4a\x97\x47\x1a\xf1\x5d\x51\x4d\x9e\x5f\xee\xd6\xe7\xcb\x9d\x92\x21\x38\x22\xf1\x23\x12\x72\x64\xa5\x50\x01\x9b\x61\xa4\x88\xcc\x37\x34\x47\x55\x6a\xbc\x6c\x8a\xfe\x64\xa0\x0f\x5c\xdb\x55\x03\x3f\x14\x17\x2a\x4b\x9a\x56\x22\xd1\xb5\xeb\xe7\x57\x3f\xf7\x99\x4f\xbe\x79\x69\x7e\x99\x18\xaa\x41\xf6\xba\xbb\x04\x9b\x19\xfd\x78\x88\x09\x2c\x53\x89\x93\xb3\xf7\x3f\xf0\xd5\xe3\xa7\x6f\xbf\x88\xcd\x1d\x5b\xbb\x3b\x0e\xc4\xbb\xad\x9a\x58\x1e\x2a\xb0\xae\xcc\x86\xd9\x5e\x58\x2d\x0d\x6a\x55\xea\x2b\x8a\x8b\xe6\x02\xde\x8b\xfa\xb5\x86\x3e\xf2\xad\xf2\xae\x84\xb9\x6c\x2f\x50\x01\xf8\xda\x46\xbd\xd2\xae\x2f\x56\xfa\x66\x55\x71\x05\x0a\x27\xc3\x0b\x69\xac\x71\x2b\x86\x61\xa9\xa4\x4e\x46\x66\xa9\xc5\xc3\x08\xb3\x59\x3a\x06\x89\xba\x59\x6e\x57\xe6\xe7\x5a\x7a\xa9\x34\x06\xff\x1e\x81\x4b\xc2\xae\x86\x64\xb8\x98\xa8\xf8\xe5\xfa\x7c\x3f\xf4\x78\x24\xc8\xda\x58\xd1\x7a\x5d\x67\x62\x95\x7d\x17\x2b\x2f\x1c\x13\x38\x09\xe0\x65\x28\x80\xcf\x02\x78\x7f\x0b\xf6\x69\xcb\x9a\x3a\x56\x4a\xc6\x18\xf6\x3d\x36\xe6\x6a\x23\x73\xae\x62\x69\x95\x8a\x07\x97\xd6\x77\xc7\x3e\x29\x34\x73\x91\x99\x61\x0f\x49\x52\x94\x93\x7d\xe3\x73\xa7\x61\x38\x2f\xfc\x9d\x67\x6e\x3f\x05\xa0\x69\xe2\x35\xe9\x9e\xe7\x29\xcb\x39\x5f\xad\x8c\x4e\x2b\xf2\x69\x67\x1c\xcd\x5b\xda\x92\xec\x6c\x8e\xf1\xd2\x3c\x46\x21\x31\x9c\xa5\x22\x78\x36\xce\x97\xce\x50\xc0\x72\x9d\x86\xc4\xf8\x33\x32\x93\x45\xce\xab\x71\xfb\xe9\x05\x3c\x22\x85\xec\x6b\xdc\x6b\xc0\x89\xef\x21\xdf\xca\x0b\x49\xd0\xdb\xbc\xf2\xc4\xaf\xaa\x7b\x4a\xaf\xb2\x50\x69\xd2\x3a\xe3\x73\xbd\xf9\x87\x84\xa0\xf6\x50\xa0\x1d\x7d\xc0\x78\xc3\x82\xd6\x58\x9d\xaf\x75\xab\x0d\x52\xab\xc0\x67\x56\x09\xe9\x5c\x1f\x11\xfa\xa9\x67\x99\x7a\xcd\x13\xc3\xca\xc4\xcb\x35\x7d\xa7\x63\x34\xf6\xa5\x2b\x93\x1e\x40\x3e\xe5\x6d\x14\x85\xdd\x8a\x14\x87\xd4\x5d\xa5\x1d\xa1\x53\x4a\x73\x7a\xe1\x62\x8d\xe1\xbc\x72\x81\x0a\xc7\x10\x0d\x91\xe5\xe3\xe2\x86\xb7\x40\x76\xda\x57\x06\xcf\xfb\x97\xbb\x47\x87\x84\x2f\xd5\x16\x97\x4e\x4c\x8c\x8a\x46\x35\x6d\xd9\xd3\x04\x19\x4c\x2a\x83\x70\x3b\x0a\x30\x5f\xd6\xea\x70\x29\x0a\x69\xa4\x28\x91\xbe\xd7\xe2\x02\x76\xfb\xa3\x60\x37\xc0\x3d\xc0\x9a\x8d\xa8\x6f\x1f\x6b\xbd\x42\xc6\x95\xc5\xa8\x55\x99\xe3\xb6\x04\x16\x83\x65\xfc\x11\x96\x1f\x67\x76\x7d\x53\xad\x26\xa4\x08\x70\x3e\x1d\xfc\xc8\x79\xd6\xf2\x94\x69\x8e\xf0\xfc\x77\x6c\x1a\xad\xa4\xec\x2c\x96\x20\x8b\x7c\xcc\x73\x71\x80\x7a\x94\xf1\xab\x68\xdc\x1f\x87\xa3\x0f\xe2\x4a\x7a\x18\x65\x36\x11\xdc\x62\x18\x92\xc8\x4f\xc2\x06\x2c\x65\xe1\xd8\x8a\x28\xe0\xf1\x88\xef\x90\xe4\x2d\x3f\xf8\x1c\x82\x66\x08\x93\x94\xb8\xab\xf6\xe7\x45\xbe\x25\x76\x08\x5d\x56\x49\xce\x8e\x2f\x96\x66\xb3\x9b\x22\xba\x55\x5f\xc7\xb7\x06\x78\x11\xec\xe2\xcc\xd0\x23\x8f\xdc\xff\x7d\x3f\xba\x58\x3f\xf1\xc1\x73\xc7\x42\xb2\x5c\x0b\xc9\xc8\xa2\x44\x2d\xeb\xa4\x6a\x8a\xa4\xdd\xf5\xc9\x13\x2f\x78\x28\x46\xff\xdb\x02\x13\xfe\x25\xbe\xd5\x7f\xff\x8e\x9f\xc3\xc3\xf1\x0c\x59\xf6\x7e\xfd\xd1\x7f\x35\x4a\x85\x02\x85\x6c\x4c\xec\x54\xa7\x8e\x84\x1f\x7c\xf7\xcf\x86\xbf\xf7\xe8\xbf\xff\x2b\x0d\x2b\xc0\x13\x8f\x3a\xa7\xb8\x7b\x4f\xf6\x53\xcc\xc3\x62\xd9\x6b\x1e\x13\x3e\x58\x32\x8d\x31\xd3\xbf\x9a\x6a\x00\x26\x77\x32\xac\x46\x88\xbb\x89\xb2\x84\xcb\xd2\x21\x0c\x29\xe1\x41\x3c\x12\x8e\xf0\x31\x1c\xaa\x02\x8e\x02\x8c\x1e\xee\x23\xf0\x04\x00\xcf\xa8\x5d\xc3\x01\xd8\xea\xe4\x3f\x7c\xf8\x9f\x93\x1f\xf9\xb1\xbf\x45\x7e\xe2\x3d\xef\x27\x1f\xf9\xc8\x2e\x79\xe2\xb9\x4f\x90\xbb\x4f\x74\x88\xb4\x25\x10\x66\x1f\x21\x95\xe3\x6b\xe4\xec\xeb\x8f\xd0\xd1\xc5\x0e\xdd\x7d\xb1\x49\x5d\x35\x22\x63\xec\x1e\x86\xf0\x44\x53\x00\x67\x78\x91\xd0\xda\xdb\x56\x27\xf6\xd8\x9f\xf4\x87\x23\x49\xd1\x8c\x78\x11\xfd\xfd\x1f\x26\xce\x6f\xff\x21\xd1\x17\xca\x5f\xec\x5f\xdc\x7a\xbd\x39\xa7\x9c\x47\xbf\x82\xdd\x8c\x31\x75\x87\x82\x07\x4c\x2a\x50\xf1\xbc\xa6\x78\x05\x0b\x09\x34\x45\x7b\x15\x62\x9f\x98\x98\x2e\x71\x9e\xf2\x99\xe3\x04\x13\x3c\x47\x20\x99\x91\xcd\xb4\xca\xd2\x9c\x2d\x4b\xce\x52\x96\x85\x4a\xda\xd3\x92\x8c\x6f\x94\xd7\x5f\x0b\x04\x84\x99\x6a\x01\x2d\x16\x44\x62\x20\x49\x79\x96\xc8\xa5\xd9\x0a\xe5\x19\x16\xe0\x51\x2a\x9c\x06\x41\xad\x17\xc5\x9a\xd3\xb2\x2a\x01\x72\x0b\x53\xf2\xb2\x90\x24\xb6\xd3\xa2\x48\x8c\xc2\x59\x1c\x0b\xc6\x40\x3c\xf9\x5b\x5e\x07\x9c\x66\x8d\x0b\xbf\xe3\xa9\xec\xf0\xb4\x4f\x23\x81\x5a\x59\x31\x45\xc8\x64\xdb\x68\x2a\xd6\x4d\xd3\x56\x13\x36\x2d\xb8\x24\x8e\x82\x15\xc4\x2d\x13\x6e\x37\x0a\x0d\x19\x9a\x8a\x5d\x30\x12\x60\x56\x55\x55\x64\xd5\x73\xd1\xb1\x07\x22\x66\x7b\x52\x09\x8c\x88\x89\x62\x20\x49\x32\x00\x4e\xc5\x53\x54\xc5\x01\x87\xed\xc1\x93\x7d\xb8\x57\x42\x2c\xb7\xf9\xbe\xcf\xbf\xc9\xba\xc6\x11\xf7\x4c\x53\x64\x91\x56\xcb\x0a\x04\x4c\xba\x66\xcb\x8a\xe7\x7a\x32\x82\xc0\x42\x46\x09\x4b\xe1\x08\x78\x31\x29\x8c\xc0\x07\xde\x4b\xf5\x00\xf8\xe2\x23\xc0\xf7\xe2\x7e\x08\xb6\x25\xe4\x89\x50\x0d\x45\x4e\x36\x86\x40\x02\x00\x71\x01\x27\x7c\xe1\x12\x02\x9c\x18\x82\x83\x06\x70\x25\x86\xdc\xf3\x44\x49\xe5\xaa\x5a\x62\x86\x20\xd8\xc8\xc3\xa4\xf0\x11\x01\x70\x19\x96\x1f\x68\xe3\xe1\x80\xfa\x38\xf9\x15\xcf\x0f\x00\x21\x00\xbe\xa5\xa6\xa8\x45\x3b\x1a\xd1\x34\xbc\xb6\x92\x2a\xb9\x82\x5a\x1e\x7b\x81\x6e\xc3\xaa\x76\x99\x45\xa2\x69\x27\x65\x1a\xfd\xa7\xf7\x5f\x12\x93\xb1\xf8\x66\x15\xf4\x8a\x58\x22\x82\xc2\x45\x45\x57\x0c\x47\xf7\x5d\x4f\xc5\xc0\x09\xaf\x0c\x80\x79\x4f\x2b\xc9\xf0\x50\xed\x52\x59\x75\x01\x80\xfb\x8a\x2c\x44\xa8\xe8\x13\xf3\xd9\x92\xc5\x4e\xc4\x48\x64\x82\xc6\x44\xc1\x10\xfb\x7a\x55\x69\x3a\x96\x87\xa3\xf3\xb8\x66\xc8\x4e\xad\x51\x1e\x57\x6a\xba\xad\x68\x02\x66\x3f\x79\xda\x83\x41\xf5\x1a\x41\xaa\xc7\xa8\x5c\x83\x98\x75\xe8\xea\x08\xda\x01\x60\xfb\x25\x53\xb5\xaa\x35\x7d\x52\xae\x48\x8e\xa4\x84\x10\x58\x84\xa9\xea\x0e\x7f\x95\x1a\x6a\xda\xaa\x32\xf5\xd9\x33\x63\x9c\x48\x41\xf5\x9e\xcc\xea\x39\x61\x46\x80\x05\x82\xc2\xbc\xbe\xca\x68\xaf\x56\x96\x75\xcb\xa6\x5a\x7c\x5d\x12\x95\x11\x14\x0d\x08\xf1\x78\x20\x6e\x80\xcf\x2c\x7a\xc8\xf5\x56\x55\x0a\xd7\x97\x86\x8a\x0a\xd1\x09\xb3\x01\x64\xd9\x49\xda\x0d\x6f\xad\xa8\x00\x4d\x92\x4a\x21\xd1\x49\xe0\xd6\x4b\xae\xcb\xe6\x89\x35\x51\xa5\x66\x80\x75\x07\x45\xf2\x4b\x25\x66\x9b\x9a\x6d\xa9\x61\xc7\x61\x13\x31\x3f\x42\xd1\x0b\x83\xb2\xe4\xf8\x51\x9d\xb9\x86\x28\x75\x83\x00\xc2\x12\x89\x05\x7a\x89\x4e\x4c\xd5\xb3\x04\xa7\xe7\x05\xed\x61\x14\xb1\xa9\xfc\x1a\x00\x74\x1e\x04\xe0\xe4\xc6\x60\x44\x47\x4e\xc8\x2c\x3b\x64\x80\xa1\xb9\xeb\x0b\xa2\x51\x15\xc2\x71\xc4\x1e\x7f\xec\xf3\xf7\xd9\xae\x45\x6f\x6e\x5f\xcf\x5e\x93\xc4\x78\x70\x57\x9d\xbe\xfd\xf6\xab\xf7\xdf\xf3\xe0\x79\x13\x35\xa8\x27\x03\x51\x50\xbd\xab\x70\xb9\x88\xbc\x28\x0d\xc3\x80\x09\x58\x50\x33\xca\xc1\xa8\x1c\x76\x7c\xa1\x37\xa6\x7c\xc4\xe2\xa6\x35\xc5\xf1\x69\x5d\x74\x1c\xa1\xea\xb7\x26\xa2\x30\x0e\x7c\x08\x7b\x64\xc1\xd3\x4b\xa1\x65\xb2\xae\xad\xf4\x2d\x4e\xc7\x12\xae\xd8\x98\x6f\x2d\xb9\x3e\x33\x03\xcb\x8e\x0c\xaf\x39\x21\x64\x12\xc0\x1d\x29\x41\x44\xa0\xe9\xbe\x65\x46\xed\x91\xdc\xb4\x78\xd0\xbf\x21\xa1\xa8\x51\x66\xd6\x90\x7a\x23\xf8\x61\x64\x3a\x1e\xbc\x85\xe7\x4f\x94\x60\xe4\x44\x91\xe6\x0b\x34\xbe\x1f\xa3\xbc\x34\x16\x8f\xce\x8d\x24\x29\x82\x00\x34\xf4\x60\xd9\x3a\x0a\xa3\xae\x12\x84\x9e\x32\xb0\x02\x36\xd9\x85\x53\xcf\xb0\x4b\x54\xa6\xfb\x7c\x73\x9c\xb7\xc8\x33\xa7\x79\x37\xf0\x4c\xb7\x6b\x42\xb1\xcb\x34\x78\xa6\x12\x40\x39\x83\xb6\x20\x38\x99\x72\x05\xc8\x8c\xc2\x58\xba\x3c\x52\x10\x93\x02\x36\x5a\xa4\x25\x4c\x65\x0b\x72\x82\xc1\xfe\xce\xde\x59\x41\x75\x3e\x15\x2e\x9f\x71\x03\x85\xf5\x9e\x4f\x21\x9b\xb9\x71\xb2\x91\xbc\x85\xbb\x64\x9a\x62\xe4\xa4\x26\xf8\xd6\xb1\xa5\xca\xf6\xc4\x54\x24\x1c\x36\x11\xb9\x61\x85\x6d\xd2\x77\x0b\x77\xdf\xff\xce\xf0\xf5\xa7\x16\xf5\xdb\x57\xc4\x93\x75\x46\x90\x3b\x72\x1e\x5c\xbf\x3a\x0c\x89\x7f\xa3\xe5\xd9\xcf\x5c\x1c\xb8\x17\xbe\xf1\x00\x6e\x12\x91\xed\xfb\x27\x6a\x95\x8f\x89\xa7\xf8\x2e\x19\xce\x88\x70\xe6\x33\x94\x69\xde\x40\x95\x29\x51\x14\x1a\x4d\xd2\xae\xf1\x9c\x9e\x98\x77\x5c\xa7\x52\x0d\x34\xa5\x2a\xce\x8c\x4c\x26\xc5\xe9\x19\x24\xab\x9d\xe6\x59\x6d\x83\x04\x8d\x65\xbe\x7d\x07\x61\xdb\xd6\x38\xa0\x83\xcb\x37\x2b\xcd\xa1\xaa\x09\x97\xd8\x92\x47\xa5\xc6\xc0\x08\x2b\x70\x43\xd7\x14\x45\xae\x0a\x2e\xc3\x7e\x56\x8d\x22\xe3\xb7\xd3\xc3\x2a\xc4\x98\x1b\x4a\x93\x6a\x42\x5b\x52\xd4\xa6\x1a\xda\x7d\x41\xe2\x7d\xd3\x14\xdc\xa5\x63\xd8\xf6\x9f\x35\xc4\x44\x69\x4e\xbe\x70\x56\x31\x37\x95\x07\x4b\xb1\xd0\x54\xda\x74\x97\x9c\x81\x58\x5c\x22\x1d\x5f\x11\x02\x70\x8a\xc2\xbc\xd1\x20\x29\x28\x44\x28\xa5\x09\x36\x3a\x48\xa6\x0d\xe2\x9c\x12\xfc\x19\xfb\xb0\x38\x98\xc4\x00\xcd\x22\xb6\x2d\x21\x90\x0d\xe3\xca\x3b\x09\x02\xca\xe1\xbe\x4a\xb2\xb3\xb8\xe0\xc0\xd5\xa1\x30\x96\x6b\x71\xe2\xfa\x10\xc2\x28\x94\x68\xd8\x02\xe2\x45\xc4\xf3\x7c\x02\xd6\x7d\x26\xec\x9b\x18\x43\x32\xbf\xa3\x92\x2c\x33\x16\x65\x3e\xe3\x16\xab\x31\x66\x36\x4c\x87\x01\x92\xd9\x46\xf5\xbf\x9c\xd2\x80\x8e\xb4\x8c\x60\xf7\xe1\xbb\xde\xf8\x77\x57\x16\xcf\xfc\x4f\x77\x1d\x8e\xc8\xe1\x46\x10\x83\x5d\xa5\xa4\x13\xb3\x22\x92\xfe\x28\x20\x5f\x7e\xd6\x23\xb6\xed\x7e\xe2\xa3\x9f\xfb\x0f\xff\xe3\x07\xdf\xfe\xa1\x57\xed\xe8\xa7\xde\xfd\xbf\x70\xab\x0d\x8e\x74\xc1\x8a\x49\xf9\xdc\x15\xe2\x51\xbe\x51\x6a\x84\xa3\xbf\xc6\x29\x5d\x7f\xa5\x09\x5f\x62\x94\x16\x88\x59\xb1\xa0\x9e\x44\x3d\x2c\x0f\x93\x52\x1e\xc9\x34\x85\x83\x13\x72\x04\x2a\x42\x34\x1a\xc6\x9e\x53\x8c\x75\x78\x05\xa2\x6b\x65\x72\x71\xe3\x02\xf9\xbd\x4f\xff\x3c\x59\x7b\x74\x91\xff\x9b\x7f\xf9\x4b\xfc\xdd\xef\xfd\x00\xf9\xf9\xff\xf5\x51\x5a\x5f\x2d\x93\x05\x70\xb2\xde\x56\x9f\xec\xf4\x3a\xa1\xed\x38\x2e\x00\x1f\xf0\x56\xdc\xbb\xfc\xa9\x3f\x7a\xfa\xd4\x6b\xef\x7a\xcd\x60\x18\x91\xe0\xbd\x7f\x97\x44\x7f\xf0\x47\x44\x69\x54\xbf\xd2\x6b\x76\xe7\x44\x80\xdf\x52\x20\xc6\xd2\x8c\x9e\xec\x11\x6c\x61\x02\xb7\x4d\x23\x88\x7f\xf1\x3f\x49\x16\x09\x18\x79\x82\xd9\x96\xc8\x87\x33\xcb\x84\x18\x58\x88\x61\x40\x99\x04\x40\x1d\x03\x66\xac\xfe\x09\x70\x0d\x78\x18\x8f\x65\x94\x48\x42\x82\x8e\x93\x85\xf8\xd3\x74\x8e\xe5\x3e\xc9\x71\xfa\xed\x86\x21\xfb\x05\x11\x62\x3d\xd8\x94\x37\x18\xaf\x5a\x9c\xe6\x83\x13\xad\xe6\x56\x6a\x44\x6d\x50\x7a\xf3\x85\x4b\xb4\xe6\xc3\x37\x12\xc4\x01\xaa\x47\xe1\xbe\x03\x60\x26\xa2\xee\x13\xec\x4b\xc6\x70\x03\x3e\x87\x0a\xd8\x48\xa4\x71\x38\x12\x4f\xae\x63\x54\xa2\x49\x77\x20\xf6\x96\xf0\x78\x46\x50\xca\x89\x8c\x87\x7e\xf0\x58\x2e\x2e\x31\xc7\x02\xa0\xba\x38\x0c\x8c\x7f\x0e\x8a\xc0\x23\x85\xdf\xfb\xc7\xce\x7f\x53\xae\x0f\x9c\x7b\x85\xc8\xa8\xce\x42\x05\x99\x01\x14\xa0\x12\xdc\xea\x2c\x4c\x33\x3d\x48\x47\x12\x44\x11\xec\x97\x1a\xe0\x50\x07\x45\xd5\x50\xf4\x14\x59\x59\x98\x15\xc3\x42\x12\xf9\xcb\xde\x0a\x93\xe2\x32\x97\x30\x48\x01\xc4\x17\x89\x02\xd8\x05\x80\x78\x42\x08\x00\x69\xe6\x58\x04\xe4\x7a\x89\x91\x2c\x2b\x81\x2a\x6b\x01\x96\x8f\x45\x2a\x46\x2c\x40\x9a\x44\x14\xaf\x0f\x1a\x67\xfa\x13\x63\x2c\x02\x26\x97\x00\xb1\xaa\xba\x92\xc7\x22\x53\x3a\x1a\x56\x8f\x04\x16\xa2\x90\xae\x08\x30\x4b\x4e\x6c\x84\x2c\x4b\x81\xc2\x24\x5f\x00\x5b\xc5\xe3\x59\x0d\x31\x59\x90\x0a\x00\xb7\xe4\x48\x46\x75\x6b\x09\x3e\xb3\x84\xd9\x60\x29\x92\x7d\x6a\x49\x01\xe6\x09\x1d\x17\x39\x28\x42\x0e\x07\xc2\x9c\xe3\x1c\xc0\x0f\x4e\x22\xe1\x03\x17\x0b\x79\x04\xcc\x83\x55\x1e\x00\x9a\x73\x43\x29\x70\x99\x14\x00\xc4\x8e\x93\x28\x08\x88\x03\x29\x60\x81\x14\x32\x88\x2b\xbc\x3e\x83\xb5\x8e\x06\x3e\x48\x06\xf4\x26\x31\x6e\x52\x4d\x83\x8f\x19\x05\x9c\x05\x1e\x13\x3d\x5f\x13\x23\x08\x39\x30\x40\x09\x88\x10\x8c\x22\x21\x70\x07\x51\x24\xc9\xb8\xd2\x91\x6a\x9c\xf0\xc4\xa2\x00\xae\x1b\xf6\xb6\x71\x43\xd2\x55\x59\x44\x09\x3a\x51\xa2\x11\x5c\xd6\x00\x22\x5c\xdf\x1d\xc3\x53\x9c\x88\xc7\x62\x03\x34\x8a\x5f\x13\xc7\xd2\x34\xce\x58\x27\xd1\x23\x4b\x33\x6a\x2c\xad\x21\x08\x49\x08\xc9\xb2\xb5\x95\xa6\x85\xf1\xb5\xf1\xfb\x66\xd5\x03\xac\x56\x40\x34\x5b\x6b\x08\x74\x6e\x41\x17\x1d\x1b\x21\x12\xbc\x29\x00\x5e\x9a\x92\x99\x24\x00\xe7\xa2\xcc\x42\x59\x11\x22\x15\x1f\x86\x18\xc5\xeb\x4b\xc8\x22\x88\x88\x16\x98\x37\x53\xc9\x15\xca\xf3\xe0\x36\x9e\x0e\xe8\x73\xd8\xbf\xd2\x73\x2c\x11\xb3\xc7\x54\x84\xfd\xca\xba\x88\xbd\x33\x80\xf0\x51\x8d\xcb\xcf\x35\x20\xa2\x28\xa4\xa8\xb9\x3b\x99\x48\x43\xd7\x41\x7a\x08\xc6\x16\x2c\x52\x75\x78\x7f\xcd\x0f\x30\xe0\x89\x65\xa5\x53\x56\x47\x84\xe3\xf0\xec\x40\xec\xb6\x5d\xc1\x1d\x59\x32\xf7\x1d\x23\xf4\xbc\x52\xe4\x45\x6a\xe8\x04\x2a\xe1\x15\x52\x2e\x55\xed\xb9\xba\x36\xe8\xb4\xa3\x6a\x94\x96\x87\xce\xdd\x7d\xe6\x4a\xbd\x62\x8e\x5f\xff\xf0\x43\xe7\xe3\xdc\x14\x9c\x60\x88\xad\x46\x0b\xab\xde\x4d\x45\x0b\x1c\xcf\x0a\x25\x2f\x60\x16\x9a\x0f\x11\xee\x5f\x45\xf5\xe1\x7e\x1a\x62\xbf\x31\x2c\xfb\xa4\x4f\x18\xb5\x8c\xe1\x9a\x05\xae\xcd\x27\xae\x2b\xe0\x95\x22\x78\xce\xe0\x56\xf0\x34\x75\x0c\x9f\xcd\xc2\xa6\x4b\x25\xce\xaa\x27\x94\x21\x58\x67\x3c\x9c\xd8\xd1\xc4\x73\x04\x27\x04\x9b\x29\x61\xa3\xa5\x11\x05\x9a\x31\x81\x65\x6f\x33\x51\xc8\x29\x28\x3c\x2b\xcf\xa3\x3f\x00\x67\x8e\xb8\xde\xb5\x01\x13\xbb\x96\x68\xfb\x3e\x65\xbe\x1f\xb1\x62\x56\x5f\x92\x58\x24\xc8\x34\x52\x21\x92\x51\x54\x1e\x8a\xb2\x07\x4f\xf0\xe1\x7c\xc5\x7b\x94\x66\x64\x54\xf6\x25\x3a\x8b\x2c\x80\x99\xe2\x7b\x92\x04\x9d\x91\x01\x2b\x10\x12\xa6\x0c\xa1\xbc\x19\x3e\x2b\xae\x15\xc7\x2c\xe4\x7f\xcf\x9f\x5f\xd4\x19\xc8\x87\xf8\xf2\x22\x85\x22\x6f\x06\xe1\x33\xaa\x0b\x3c\x17\x4c\x9b\x96\xfd\xa7\x8c\xe1\xe9\xb1\xb3\x94\xc6\x10\x4d\xdb\xf3\x69\xa6\xd2\xce\xe9\x4c\xa9\x27\x83\xc5\xd9\xb9\x3c\x7c\x58\xf0\x16\x96\x34\xef\xa5\xf3\xbd\xca\xd6\x75\xef\xb6\xea\xda\x1b\xff\x31\xfb\xfe\xef\xbf\x2b\x58\xae\x11\x5d\x40\xf2\x51\x48\xf6\x2e\x75\xc8\x95\xce\xd0\x1e\x5f\xb8\x19\xf0\xeb\x97\x5f\xb0\xfb\x9b\x4f\xe8\xb5\xfe\x9f\xdc\xfd\x9a\x85\x9d\x23\x87\x25\x57\x96\x85\xa2\x26\x5a\x81\x78\x4a\xa7\xb2\xb1\x33\x82\x69\x99\x68\x00\xe5\xc5\x59\x6b\xd3\x98\x96\x67\x5c\x80\x54\x36\x8b\xf3\xa9\x50\x5c\x92\x21\xc6\x5f\x25\xa0\x32\x67\x08\x26\x59\xcd\xb8\x87\x2b\x8c\x41\xa0\xa6\xcb\x5c\x3b\x27\xb7\x16\x10\x77\x9e\x25\x37\x03\x2b\xa4\x7b\x3b\xbe\x34\x1c\x58\xaa\xe2\x0a\x3a\x21\x06\x77\x3a\x1e\xdc\x43\xae\x16\xea\xd4\x96\x44\x61\xa0\xd4\x82\x51\xe3\x28\xb7\x30\x21\x47\x79\x89\x84\xe0\xd0\x47\xa3\x90\x8c\x2e\x62\x50\x2c\x12\x29\x52\x48\xe4\xe3\x48\x43\x3f\xe9\x8d\x88\xc1\x2d\x1c\xbb\x4f\x62\x4d\x5b\x30\x6b\xb0\x7e\x59\x6c\x0c\x30\x0f\x8d\xb3\x2f\x90\xd6\x89\x29\x59\xcc\xc0\xfb\x21\xe3\x61\x98\x9c\x0e\xf0\x33\x31\x45\x10\x6c\x31\xf1\xe0\xf9\x9e\x18\x71\x55\x30\xc0\xb8\xaa\xc4\x73\xfd\x24\x2b\xcb\x12\x1b\x8a\xb8\x44\xf4\x13\xd9\x68\x87\xfa\xd8\x93\x01\x7e\x4b\x24\xc2\xca\x84\x9b\x5d\xc0\x2c\xc8\x5a\xc6\x3a\x3e\xe0\x13\x21\x80\x63\xd0\xb0\xd9\x04\x7c\xb0\xe3\x11\x09\x00\xb0\x02\xc7\x1e\x49\xaf\xe6\xdd\xe6\x97\x22\x1f\x67\x47\x6e\x39\x76\x90\x17\xd8\x87\x7f\xd9\x26\xde\xa2\x0b\x14\x87\x0f\x1f\xba\xfd\xb6\xbb\xde\x74\xea\xe8\x03\xff\xdb\x89\x95\x88\x1c\x5f\x0e\xc8\xd8\x46\xd5\x0c\x04\xbb\x12\x41\x6d\xbb\x2f\x7f\xdd\x25\xa3\x89\xfb\x25\x00\xbb\xef\xf9\xc0\xdb\x3f\x14\x72\x72\xb0\xcd\x66\xe8\x42\x82\xd3\x87\x5a\xcd\x0e\x71\x43\x97\x08\x06\x00\x63\xf0\x8e\x9f\xfb\xc8\x3f\xd9\x7f\xd9\x30\x0b\xde\x84\x87\xf9\xe9\x2f\xfc\xf1\xef\xfe\xd0\x3f\x62\xcc\xfc\xb9\x0f\x3d\x88\x93\x58\xc6\x67\xce\xbc\xa4\x3f\xfd\xcc\x37\x14\xb3\xb4\xe4\x0c\x27\x2f\xfb\x62\x96\xb3\x17\x63\x29\x37\xfc\xe9\x37\x1f\xfd\x77\xf1\xaf\x7e\xfa\x47\x7e\xb6\x68\x08\x0b\x72\xde\xfb\x1f\x05\x6a\xcf\xad\xd7\x4f\x21\x44\xa2\xff\x85\x9f\x9e\xde\x5a\x25\x8b\xce\xee\xdf\x77\x02\xb2\x7c\xa2\x41\x1a\xf7\xc9\xe4\x85\xaf\x7d\x95\x1c\xe9\x2f\x11\x9c\xc1\xe2\xe1\xcc\x00\x31\x24\xa2\x02\x00\x97\xc2\x0d\x16\xa1\xa3\xd3\xc9\x9f\x3c\xf6\x71\xf2\xd5\xe7\xbf\x18\x8f\x08\x8e\xf3\xb9\x02\xcd\x46\x8f\xa7\x8d\xc1\x3c\xef\x83\x23\x33\x4d\x0a\xa9\xbc\x1c\x2b\xe8\x55\x1c\x2c\xd8\xbf\x96\x8d\xd1\xa9\x77\x4e\xc2\xa7\xa4\xf9\x7b\xea\xcf\x68\x9e\x82\xe7\xc9\x04\x51\xf8\x0e\xd6\x2f\x7d\x1d\x5c\xaf\x7f\x1b\x5f\x88\x1f\x86\x6b\xf6\xb3\x4b\x10\x04\xfe\x42\x8b\x84\x77\x18\x64\xd0\xea\x90\x27\xbe\xf0\x25\x3a\x74\x8f\xd0\xc3\xe5\xb3\xa4\xd6\x79\x9e\x76\x5b\xd7\xc8\x08\x82\x8b\xd2\x5c\x95\x38\x4e\x89\x4e\xe8\x84\x30\x75\x4c\xbd\x40\xa1\xb1\x7e\x05\x07\xe4\xe1\x42\x10\xc7\x74\xd4\xdc\xa6\x01\x77\x90\x74\x8d\xe2\x66\x31\xa9\x92\x09\x21\x1d\xb0\x11\xc5\x32\x9b\x8c\x7d\x00\x08\x92\xa2\x28\x9d\x47\x98\xc8\xb8\xe0\xff\x51\x5c\x07\xc1\x30\x96\x25\xd2\x86\x68\xa9\xa9\x9b\xd4\x47\xd2\x41\x32\x3c\x99\x1c\x95\x14\x1e\x04\x96\x08\x5f\xc7\x59\xb7\x28\x6d\x66\x4d\x72\xe9\x2c\x51\xe4\x4e\xa6\x1b\xa6\xaa\xd3\x31\xf5\x28\xd9\x35\x4d\x8b\x51\xb8\xe3\xf8\xd9\x02\x81\xa0\x0d\x70\x59\x5a\x69\x61\xf1\x24\xb2\x04\x34\xd3\x8c\xa9\x9f\xf7\xcb\x66\x4a\x67\x59\x2d\x23\xae\x36\xf2\x9c\x73\x94\x96\x4a\x78\x96\xc8\x4a\xde\x2b\x7e\x9f\xac\x0a\x1b\x1f\x07\x1d\x70\xda\xcf\x93\x5b\xd9\xff\x05\x22\x32\x9d\x56\x2e\x3d\x04\xe7\x70\x3a\x26\xf9\xbb\x90\xb4\x06\x84\x25\xc8\x50\xec\xb4\x3c\x63\x67\x73\x54\x6b\x35\x47\x8d\xf1\xc8\x5d\x04\x67\x69\x86\x11\x97\x51\x5b\xd9\x73\x5a\x43\x4d\xaf\x75\xdf\xf1\xc8\xbb\x3e\xf7\x03\x8f\x4c\x0b\xec\x19\x61\xc8\x1e\x23\x6d\x20\x1a\xe9\x25\xbe\x5b\x36\xc3\x96\x33\x62\xd4\x19\xa3\x17\x94\xf3\x8a\x3d\xf8\x71\x70\x92\x14\xae\x7c\xbc\xda\x18\x9d\xca\x65\xf3\x82\xbf\x4b\x8f\x87\x12\x07\x9c\xe9\x20\x1b\xec\x45\x0a\xc3\xd7\x13\xc3\x17\xe6\x73\xc7\xe1\x09\x2e\xfc\x62\x3c\xbc\xa5\x1d\xa4\x39\xb7\xb0\x08\xce\x62\x88\x80\xfa\x2c\xb3\xfd\xbb\xfb\x84\x0e\x8b\x0d\x63\xd1\x2d\x5c\x76\xd1\x04\x67\x96\x2a\x9a\xe5\xed\x4e\xdf\x93\xce\xb2\x70\xa7\xdd\x53\x3c\x7f\x5d\x9a\xc2\x9c\xd6\x19\x8a\xbc\x08\x52\xe4\x2c\x4c\x79\xc2\x39\x1f\x62\x5a\x92\x28\x3c\x78\xce\x5c\xcd\x68\x38\x45\x46\x70\x0e\x76\xa3\x5c\xb0\x36\xcd\xc9\xe5\x72\x53\x34\xca\x14\xbd\xa6\x3d\xd2\x99\x26\x44\xd2\xba\x11\xc5\xaf\x4e\x3b\x9c\x72\xfa\x29\xe5\xb6\xe5\xb0\xe7\x5e\x6a\x95\xce\xbf\xb2\x65\xb8\x0e\x2f\x9f\x63\xbd\x96\xf0\xa5\xc7\x2e\x09\x6e\x24\x4d\xec\xe1\xa4\xd7\xed\xb5\x46\xe3\xc1\xd5\x60\x3c\xbc\xd9\xb4\x37\xbe\x52\x35\x4b\x83\xa5\xa5\xb9\x41\x63\xee\x88\x33\x69\x95\x82\xcb\x3d\x29\xca\x15\xae\x38\x9d\x06\x04\x09\x63\x98\xc7\x7c\x83\xac\x05\x2f\x55\x22\x88\xc8\xf4\x53\x73\x5e\x14\x1e\x22\xb1\x28\x7f\x98\x4c\x21\x4a\x87\xc9\xb0\x84\xca\x1a\x0a\x98\xe8\x24\x3e\x86\xed\xa8\x57\x82\xd9\x1a\x1f\x6c\x5c\xc4\x70\x9e\x76\x3c\x32\x9b\xa9\x60\x77\x14\x04\x57\xb0\x8e\x43\x83\x07\x11\x0e\x47\x00\x70\xe8\x45\x71\x77\x21\xc4\x5f\x70\x38\x92\x2b\x52\x75\x84\x0a\x0f\xa8\x23\x8b\xfc\x47\x2a\x96\x88\x8f\x3d\xd1\x9e\x43\xc4\xeb\x11\x00\x7c\x91\x38\x4a\x44\x9c\xd0\xe1\xaa\x26\x93\x7a\x6d\x9e\x48\x2f\x88\xa4\xbb\xd3\x21\xeb\xe4\x06\x91\xcd\x12\xa9\x69\x75\x58\xff\x0e\x97\x20\xb6\xc2\x24\x11\x07\xdc\xe0\xbb\x7d\x12\x02\x78\xc5\x79\x26\x44\xc7\xa0\x4f\x26\x8a\xe0\x13\x55\x08\x88\x3b\xd4\x88\xd1\xa0\x5c\x9e\x60\xab\x78\xea\x2d\x95\x84\xca\x83\x5d\xd8\x42\xe8\x13\xa1\x5c\x8d\xad\xbb\xd4\xeb\x80\x19\xf1\x49\xd5\x5f\x22\xef\xfe\xd3\xb7\x93\xb6\xd9\x25\x1f\x79\xed\xa3\x44\x5c\xaa\x90\xd2\x90\x91\x8a\xc4\x88\x25\xb8\x84\x81\x8f\x76\x6f\x91\x2a\xe3\x74\x46\x14\xee\x56\x6a\xa1\xd9\x74\x93\xac\x63\x9f\x24\xe9\xb1\x78\x4e\xf4\x6c\x86\x97\x7f\xfb\x7e\x7c\x3f\xe0\x95\x71\x18\x11\x3c\x8e\x9d\x3a\x74\xee\x47\x56\xea\x9c\x9c\x5e\x0d\xc9\xc4\x46\x3a\x9f\x46\x4c\x53\x06\xb0\x11\x91\xc7\x9f\xf3\x48\x6f\xe8\xbd\xf4\xd1\xcf\xfd\xda\xdb\xde\xff\x7d\x3f\x17\xf0\x03\xf0\xf0\x17\x82\x46\x21\x49\xc3\xc4\x16\xe1\x2f\x80\x8f\xd8\xb1\x7c\x33\xa5\x7d\xac\x7c\xfc\xc9\x8f\xff\xdb\x37\x4e\xda\x77\xac\x2c\x1f\x3d\xec\x79\xce\x7f\xda\xb5\xad\x2f\x1c\x3b\x7c\xca\x52\x2b\x25\xe2\x0c\xc6\x7f\xb3\xce\x10\xc2\x07\x58\x4f\x81\x1b\xa6\xca\x1a\x99\x80\x5b\x96\x5e\xa7\x85\x2c\xa6\x44\x7a\x83\x3d\x72\x73\xfb\xf2\x7e\x67\xf2\xff\xdb\xea\xfb\xf5\x7f\xf2\xe1\x83\x65\xfc\xd7\x1c\x07\xce\xfe\xf8\xa7\xf9\x77\x7f\x8e\xff\x7c\x23\x7d\xc0\xf6\xc0\xc3\xf7\x82\xeb\xf6\xc8\x9f\x7e\xe1\x53\x74\x83\xcc\x93\x43\xfa\x21\x7a\xd8\xec\x91\xd6\x72\x0b\xac\x5e\x97\x34\x02\x4a\x1a\x3c\xa0\x54\x84\xc8\x8f\xe1\x50\xaf\xb5\x58\xc9\x06\xe7\x7b\x63\x96\x9f\x30\x23\x6e\x88\xc0\x77\x0c\x79\x44\x59\xde\xf9\x9e\x24\x83\x23\xce\x0b\xf0\x24\x4d\x4f\xa5\x82\x28\xb4\xd0\xef\x3b\x9d\x2b\x5a\xd0\xfd\x88\x29\xda\x8c\x4c\x5c\x8b\xf6\x27\xfd\x24\x07\x84\x6b\x36\x48\x59\xdf\x35\x00\x50\xa6\x07\x20\xce\xa6\x25\xbf\x44\x4a\x61\x89\x0c\x9d\x21\x0d\x90\xec\xe9\x83\x1b\x0a\x25\xca\xcb\x84\xb8\x82\x04\x00\x92\x11\xd1\x75\x48\x28\x59\xd4\x93\xb0\xa3\x4a\xa3\x62\x9c\x68\x05\xf7\x29\xcb\x48\xd1\x40\xea\x53\xec\x1c\x05\x51\x8c\x4d\x7f\x04\x4e\x54\x08\x19\x0d\x45\x31\x46\x7a\x2c\x0c\xb0\xbc\x48\x43\x92\x00\xe4\xb8\xef\x16\xab\x28\x2c\x8c\x87\xe3\x20\xd3\x1f\x33\x2a\xc8\xa1\x13\xc2\x20\xa9\xcf\x0a\x38\x4c\x25\x4d\x03\xb2\x94\x46\x14\xe3\x0c\xa4\x18\x85\x09\xc6\xe5\x2c\x99\x9b\x18\xa5\xe9\x4d\x96\x14\x68\x13\xbe\x53\x94\x0e\xe8\x4a\x64\x80\x9c\x89\xad\x76\xbb\xc3\xc6\x68\xdc\xaf\xfa\xbe\xab\x85\x61\x54\x8d\xc7\x44\x13\x1e\x17\x92\xba\xed\x1d\xb3\xbd\xe7\x3b\x0b\x8b\x8b\xeb\x0b\x0b\x0b\xbd\x2c\xa5\x68\xdb\xb6\xe7\xbb\x41\x0b\x76\xb2\xeb\xfb\xb4\x25\x0a\x62\x4c\xf7\xcc\x66\xe3\xc4\x33\x7d\x92\x54\x19\x27\x59\x3b\x2e\xa7\x24\xca\x72\x6f\xb4\x28\xfb\x95\xf5\x5a\x09\x09\x8f\x71\xaa\x8a\x91\x35\x09\xcc\x0e\xe8\xcd\x5b\x0e\xf2\x3d\xe4\x9d\x5a\x51\x41\x67\x36\xd9\x2d\xcd\x27\x10\x24\x11\x03\x9b\x81\x7d\x7c\x56\x75\x62\xdf\x18\xdb\xbc\xb7\x96\xef\xe7\x05\xdc\x1a\xfc\xd2\x7d\x7a\x58\x94\xe7\x99\x2e\x52\xec\x46\xcf\xcb\xd4\x69\x89\x3e\x25\xc2\xd2\x6c\x02\x0f\xcd\xe8\x0b\x3c\xe3\x37\x4e\x3f\x72\xc6\x4f\x63\x59\x0b\x7e\xb6\xca\xf9\xcc\x10\x15\x3a\x2d\x1c\x70\x92\x71\xcf\xa3\xfc\x5c\x25\x83\x29\xa3\xa2\x14\x0e\x67\x11\x4d\xa9\x13\x51\xda\x8a\x46\x79\x36\xd9\x2d\x1d\xb7\x92\x9c\xbe\x28\x81\x9b\x28\x3d\x15\x21\x48\x24\x24\x6b\xb4\x88\xf9\xa0\x0e\xdc\x4f\xe7\xaf\xef\xb9\xcd\x7e\x57\x09\xc0\x51\x6c\xed\xfc\xe1\xff\x5d\x7d\xa6\xaa\xb8\x9e\x33\xb2\x5c\x7b\x20\x09\x92\x2d\x8b\xf2\x58\x10\x15\xab\x52\x5e\x74\x23\x61\xd5\x15\xfa\x47\xc3\x8d\x21\x00\xbc\x30\xd1\x1a\x15\x71\xdd\xa3\x10\x0d\xec\x1f\x1b\x31\x03\x16\x60\xbd\x3d\x06\x76\xa1\x28\x10\x35\x94\x90\x80\x4d\x7c\xb0\x23\x8e\x28\xc5\x20\x55\x81\xe5\xaf\x62\x17\x98\x22\xc0\x7d\x67\x13\x0e\x91\x50\x80\x0c\x23\x4d\x25\xaa\xe2\x11\xcf\x56\x01\xd0\x62\x25\xd7\x26\x7b\xa1\x40\x5c\x63\x44\xaa\x8a\xcf\x1b\x5d\x93\x68\xe3\x32\x71\x4b\x2e\x69\xd6\xda\x64\xc4\x2d\xb2\x72\x68\x85\xa8\x57\x01\x22\x61\x7d\xaf\x13\x90\xa1\xe7\x93\x5d\x7f\x8f\x8c\xa9\x4b\xee\xa9\xd6\x48\xa7\x6c\x92\xfa\x8e\x1f\x67\x7d\xfb\xa6\x05\xf7\x65\x48\xea\xaa\x02\xc7\x5a\x21\xfe\xba\x0b\x51\x99\x4b\x1c\xc0\x5d\x02\xdc\xc7\x01\x00\xdc\xa0\xaa\x10\xa3\x3b\x26\xa6\xed\x13\xee\xc1\x27\xb4\xfb\x24\x90\x39\x31\x8f\x10\x72\x17\x59\x4e\x93\xd3\x01\xb1\xcb\x32\xf1\x14\x9b\x4c\x44\x87\x04\x5b\x0a\xa9\x4b\x1a\x11\xea\x21\x91\x21\x10\x04\x58\x0d\x1f\x13\xae\x81\x27\x11\xdf\x90\x08\x5d\x89\x43\xb7\x82\x5f\x9e\xd5\x03\xc9\xc9\xc0\x51\x94\x46\x51\x00\x14\x83\xd8\x36\x11\x4f\x48\xaa\xcd\x33\xba\x4d\x3c\xcb\xb8\xd2\x99\xe4\x57\x31\xdf\x35\x1d\x54\x50\x50\xe7\xcf\xe2\x34\x1a\xcf\x46\x4e\xc4\x31\x28\xcf\x33\xbc\xb4\x18\x8a\x31\x5a\xd0\xe8\x9b\xb9\x6b\xfe\x62\x77\x53\xe0\x70\x93\xd3\x2b\xf7\x90\x94\xb7\x7b\x06\x7f\xfc\x3b\x6f\xfe\xf1\xff\xfd\xe1\xdb\x8d\x93\xa7\x96\x03\x32\x0a\x34\x52\xad\xab\xb1\xa6\xd9\x63\xcf\xb8\x64\x73\xcf\xdf\xec\x0d\xae\xdf\xfd\xd9\xa7\x3e\xdd\xfb\x07\x3f\xf8\xb3\xb7\x2e\xf9\x22\x73\x1c\xe5\x87\xda\x02\x11\x17\x12\x09\xd2\x57\x51\x1a\x20\x8a\xf8\x2f\xe5\xf0\x5e\xdc\x7e\xfe\x3b\xd2\xe3\xa7\xe7\xf9\x56\x81\x07\x9e\xfb\x79\xa4\xf4\xa5\x20\x18\x9d\x02\x22\x5c\xef\x5b\x01\x75\xdf\xa9\xe7\xe3\xbf\xe5\xed\x37\x7e\xe1\x23\x07\x27\xe1\x60\x3b\xd8\xbe\x85\xed\x0b\x7f\xf6\xc5\x12\x7c\x01\xb7\x4b\x1e\x84\xc7\xfd\xf0\xb8\x2d\xad\x16\xc6\xc5\x1c\x32\x1d\x47\x8f\x0d\xcd\xdb\xf0\x40\x12\xef\x25\x78\xac\xc3\xa3\x8b\x76\xee\x91\xb7\xbd\x29\x3c\x38\x93\xd3\xed\xd4\x27\xde\x17\x7f\x7d\xe4\xe5\xef\xae\xcf\xbd\xcf\x47\x62\xc0\x84\xcd\xef\x4a\xfa\x73\x36\xbe\x2a\x48\xd7\x55\x40\xf6\xb7\x91\xfe\x57\xf0\x8d\xbf\xfc\x13\xbf\x7a\x8b\xf0\x3e\x6d\x5f\x8a\x15\xa6\x18\x11\x00\xc1\xfb\x31\xe0\x1d\xff\x85\x80\x17\xe5\xa3\xe6\xf4\x0c\xf0\x5a\xaf\x06\xbc\x00\xba\x65\x00\xbc\x82\x0d\xe0\x58\x54\x88\x28\x2b\x31\x8d\xaa\xb8\x61\x95\xca\x16\x19\x00\x5e\x07\x00\x2f\x4d\x01\x2f\x1c\x49\xb9\x00\x78\x31\xe8\x80\xc0\xda\x87\x3b\x14\x85\x27\x71\x80\x83\x64\x25\xf9\xf8\x58\x23\x57\x4e\xba\xcd\x70\x50\x21\xb6\x86\xfa\xb5\x0a\x11\x20\xd0\x16\xfb\x7d\xe2\xc9\x01\x39\xd2\x3c\x49\xbe\xff\x0b\x6f\x21\x17\x96\x2e\x91\x4f\xbe\xf6\x3f\x93\x52\xad\x4a\xb4\x11\x7c\x5e\x09\x02\x15\xe6\xc7\x60\xd5\x97\x09\x29\x0f\x45\x00\xe4\x24\x29\x0f\x89\x31\xff\x88\x38\xd8\x72\x25\x50\xa2\x58\x11\x91\x1c\xc0\x81\x28\x07\x23\x8a\x39\xe0\x0d\xe1\x1c\xf8\xa2\x45\xe6\x77\xb4\x58\x40\xd1\xa5\x3e\xd9\x31\x06\x44\xae\x97\x48\x69\x90\x34\xb5\xa1\xb6\x2d\x8e\xee\x16\xe0\x98\x23\x00\xfc\xae\xc1\xe3\x7d\x49\x10\x04\x84\x0a\xcb\xa3\x5c\x4c\x9a\xfc\xf4\xff\xf3\xe3\x7f\x61\x86\x57\x48\xb3\xbc\x82\x65\xb5\xaf\x6c\x34\x8d\x93\xab\x8b\x1a\x59\x5d\xd5\x88\x6d\x47\xe4\xc9\x17\x5d\x72\x73\xcf\x19\x73\xde\x7f\x13\x82\xdd\xf8\xe0\xd8\xad\x6d\x94\x70\x60\xaf\xbe\x9d\x2d\x48\x01\xee\x24\x3d\x75\xd9\xcd\x1c\x1d\x9c\x9a\x83\xed\x60\x3b\xd8\xbe\x43\xb2\xf7\x68\xb7\xec\x14\xd4\xb6\xd3\x80\x3d\x4c\x7f\x87\xdf\x77\xe0\xb1\x07\x0f\x1c\x5b\xbd\x91\x7e\xdf\x4f\xc1\xee\x81\xad\x3b\xd8\x6e\xb5\xf9\xe9\x63\x56\x71\xf2\x60\xfb\x6f\xe3\xa6\xa7\xfb\x78\x0b\xb4\x20\xf6\x3f\xd3\x0a\x94\x3d\x7f\x7a\x25\x6f\xcd\xb9\x4d\x54\x26\x70\x66\x69\x0e\xe0\x31\xc7\x5b\xc8\xe8\xa6\x4f\xcb\xd1\x51\xc4\x0a\xfb\xfb\x26\x1a\xbc\xb7\x02\xbc\x98\x4d\x44\x4e\xa9\xfd\x67\x5f\xfd\xe4\xff\x3b\x57\xfe\xc9\xb3\x5f\xbb\x20\xad\x1d\xea\xba\xa4\xd9\x0f\x48\xab\xc9\x43\x25\xf0\x1e\xf9\xbd\xcf\x7f\xf8\x6a\xf6\x02\x35\xd0\x6f\x79\x22\x22\xf1\x60\x31\x7c\x9b\x1b\x5e\x3e\xe7\xe0\x34\x1c\x6c\x07\xdb\xc1\xf6\x1d\x1a\xb4\xa3\xef\xd8\x24\x49\xd2\x04\x41\xaf\x9a\x82\x95\x61\x0a\x6c\x5b\x29\xe8\xed\xa4\x7f\xc7\xd2\x5f\x70\x00\x76\x6f\xbd\xfd\x86\xfe\x93\xf1\xd7\x47\xc8\x6f\x1c\x9c\x8c\x03\xa0\xfb\x5d\xb1\x25\xbc\x5d\x4e\x0a\x14\x9c\x18\xf0\x92\x02\xa5\xa1\x20\xf7\x4f\xbe\xdd\x9e\xfa\xfd\xb0\x14\x23\x71\xd4\xcf\x2d\x23\xd5\xe1\x0f\xbf\xf0\x5b\xff\xec\x2d\x0f\xbd\xe3\xfb\x76\xf6\x16\xef\x90\x84\xe8\xbc\xeb\x8e\xfe\xe9\xa3\x8f\xfd\xc1\x95\x99\x03\x94\x0e\x96\xe7\xb7\xb3\x1d\x50\x0f\x0e\xb6\x83\xed\x60\xfb\x1b\x0a\x78\x11\xd8\x5e\x4f\xbf\x96\x52\xff\x12\x91\x69\x86\x17\x1f\x93\x34\xb0\x8f\x4b\xd1\x00\x76\x0f\x3c\xc5\xc1\x76\xe0\x23\x0f\xb6\xbf\x72\x2c\x34\x2b\x59\x46\xa7\xf4\xf3\x6f\x02\x78\xb1\xfc\x84\x7c\x2a\xe4\x56\x8d\x82\x20\x28\x7f\xf6\x89\x4f\x60\x1b\x09\x96\x9e\x9a\xa9\xe1\x9a\xd9\xc7\xaf\x7e\xfc\x5f\x1f\x9c\xef\x83\xed\x60\x3b\xd8\x0e\xb6\xef\xee\x2d\x03\xb6\x98\xd1\xc5\x4c\x6f\xa2\x7a\x38\xe5\x5c\x66\xa5\xe9\xe8\x20\xa3\x7b\xb0\x1d\x6c\x07\xdb\x7f\x8d\xed\x56\xc4\x03\xa4\x35\xb4\xd2\x68\x5c\x26\x53\x5e\x56\x40\x0e\xf2\xb6\x07\xdb\xc1\x76\xb0\x1d\x6c\x07\xdb\xbe\x2d\xcd\xd4\x86\xe9\xc3\x3d\x38\x23\x07\xdb\x77\xd3\xf6\x0f\x7f\xeb\x67\xbe\x2b\x3f\xf7\x03\xe4\x9e\xf8\xf1\x9d\x0c\x78\x49\x6a\xb4\xc6\x07\xcb\xf8\x60\x3b\xd8\x0e\xb6\x83\xed\x60\x3b\xd8\x0e\xb6\x83\xed\x60\xfb\x4e\xdf\x72\xc0\x7b\xc0\x9b\x39\xd8\x0e\xb6\x83\xed\x60\x3b\xd8\x0e\xb6\x83\xed\x60\x3b\xd8\xfe\x26\x6e\xff\x9f\x00\x03\x00\xe4\x09\x17\xfd\x56\x11\x7d\x21\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\x7f\xa0\xf7\x3e\x88\xd2\x00\x00")) - signError20 = HexToBytes("signError20", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\xa0\x02\x5f\xfd\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x14\x00\x00\x00\x14\x08\x06\x00\x00\x00\x8d\x89\x1d\x0d\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x0b\x12\x00\x00\x0b\x12\x01\xd2\xdd\x7e\xfc\x00\x00\x02\x52\x49\x44\x41\x54\x38\x8d\xbd\x93\x4f\x48\x14\x51\x1c\xc7\x3f\x93\x85\x19\x54\x20\xbd\x64\x65\x23\xd8\x8b\xc2\xc2\x12\x42\x11\x2c\x08\x76\x33\xf7\xa2\xe1\xa5\x0e\x19\x86\x50\x1e\x3a\x15\x94\x97\x4e\x1b\x21\x42\xa7\xc0\xd2\x43\x11\x1b\x06\x75\x90\x42\xbc\xd4\xb1\x08\x2a\x10\x44\x97\x8e\xce\x21\x7c\xb9\x6e\xfe\xcd\x9d\xf7\xe6\x75\xd8\x99\x71\x66\x77\xd2\x4e\xfd\x60\x98\xe1\xbd\xef\xfb\xfc\xbe\xbf\xdf\xef\x0d\xfc\x8f\x28\x0f\x0e\x9a\x7f\xd1\xad\x77\x74\xec\xaf\x2b\xa5\xd3\x46\x2d\x2c\x98\x52\x26\xb3\xa7\xb8\x94\x4e\x9b\x9d\xe9\x69\x53\x4a\xa5\x22\x3a\xcb\xff\x30\xc6\x34\xac\xb4\xb7\xab\x63\x93\x93\xa0\x14\x46\x29\xd6\x86\x87\x11\xc5\xa2\x55\x0b\x5b\xcd\xe5\x4c\x63\x6f\x2f\x28\x05\x5a\xb3\x99\xcf\x23\x6c\xdb\x8a\x00\x7f\xa4\x52\xe6\xf8\xd8\x18\x46\xa9\xaa\x50\x29\x8c\xd6\x6c\x8c\x8e\xd2\x32\x3f\x1f\xe8\x96\xb3\x59\x73\x38\x97\x03\xc7\x89\x68\xb7\x0a\x05\x12\xb6\x6d\x05\xc2\xb5\xf1\x71\x83\xd6\x18\xc7\x09\x1c\xfa\xef\xcd\x42\x81\x64\xb1\x68\xd9\x6d\x6d\xa6\xa9\xbb\x1b\xb4\x86\x4a\x05\xd7\xd7\x38\x0e\x68\xcd\xc9\xa9\xa9\x5d\xe0\xb7\x64\xb2\xff\xd4\xc0\xc0\xab\x30\x08\xad\x31\x95\x4a\xd5\xc1\xec\x2c\x4d\x9d\x9d\x18\xad\x77\xd7\x5d\x37\x80\xfe\x5c\x5c\xbc\x7c\xc6\xb6\x5f\x46\xfa\xf3\x39\x99\xbc\xd2\xda\xd5\xf5\x22\x00\x7a\x65\x05\x49\x5c\xb7\xba\xe6\xba\xb8\xe5\x32\xce\xf2\x72\xb5\xba\xc6\xc6\x81\x73\xb6\xfd\x2c\xd2\x43\x3f\xde\x67\x32\x77\x92\xcd\xcd\x0f\xfd\xf2\x7d\x47\x95\xa5\xa5\x88\xce\x1f\xed\x4a\x22\x31\x72\x61\x6e\x2e\x5f\x37\xe5\x70\xcc\xa4\xd3\xb7\x12\x4a\x3d\x52\xa5\x52\xdd\x5e\xf8\x8e\x9c\x95\xb2\xee\x7c\x2c\x10\xe0\xa3\x10\xc6\x05\x90\x92\xb8\x0b\x69\x09\x41\x36\x06\x78\x20\x0e\xf6\x41\x08\xb3\x25\x25\xdb\x52\xb2\x0d\xfc\x8e\x79\xb6\xa5\xe4\x6b\x5f\x5f\x5d\xae\xba\x0c\x33\x42\x18\x25\x65\xac\xeb\x38\xa7\x07\x85\xe0\x62\xc8\x69\x04\xf8\x5a\x08\xa3\x43\xb0\xfd\x7e\x54\x7f\xbf\x01\xe8\xf7\x58\x01\xf0\x39\x98\xbd\x00\x47\xa0\x67\x13\xde\xfd\x6d\xdf\x02\xae\x42\xf5\x62\x4f\x08\x61\x1c\xcf\x59\x1c\xf4\x66\x28\xf1\x63\x4f\x12\xa7\x3b\x84\x37\x94\xeb\x52\x5a\x7e\xb3\x77\x6a\x9e\xb2\x10\x23\xe1\x43\xbf\x84\xb8\x1d\xa7\xdb\x01\x86\x7c\x87\x7e\xe4\x6b\x12\x5b\x30\x74\x17\x9e\xd6\x3a\x79\x00\x83\x06\x26\xc2\x6b\xf7\x6a\x7b\xe8\xc7\x7d\x0f\xda\x02\x97\x6e\xc0\x9b\x98\xca\x00\x98\x80\x1e\x1b\xde\x7a\x67\xe2\xa7\x9c\x81\x13\x40\x16\x68\xdd\x80\xef\xeb\x60\xcb\x6a\x82\xb0\xce\x08\x68\x38\x0a\xa7\xcf\xc3\xb5\x4f\xf0\xa4\x09\xbe\xcc\xc3\x2a\xc0\x1f\x58\xda\x42\xca\x5d\x05\xc2\xa8\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\xda\x9f\x52\x14\xa0\x02\x00\x00")) +// readEmbedFile: read 'embed' file system and return []byte data. +func readEmbedFile(filename string) (out []byte) { + var err error + out, err = embeddedFiles.ReadFile(filename) + if err != nil { + log.Printf("Unable to read embedded file: %s, %v\n", filename, err) } + return } diff --git a/gohFunctions.go b/gohFunctions.go old mode 100644 new mode 100755 index b143f8c..be4fbbe --- a/gohFunctions.go +++ b/gohFunctions.go @@ -1,8 +1,11 @@ // gohFunctions.go -// Source file auto-generated on Fri, 06 Sep 2019 04:25:58 using Gotk3ObjHandler v1.3.6 ©2019 H.F.M - /* + Source file auto-generated on Fri, 02 Apr 2021 13:10:55 using Gotk3 Objects Handler v1.7.5 ©2018-21 hfmrow + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2018-21 H.F.M - Search Engine v1.9 github.com/hfmrow/search-engine This program comes with absolutely no warranty. See the The MIT License (MIT) for details: https://opensource.org/licenses/mit-license.php */ @@ -17,8 +20,11 @@ import ( "io/ioutil" "log" "os" + "os/user" + "path" "path/filepath" "reflect" + "regexp" "strings" "github.com/gotk3/gotk3/gdk" @@ -29,6 +35,7 @@ import ( /*******************************************************/ /* Functions declarations, used to initialize objects */ /*****************************************************/ + // newBuilder: initialise builder with glade xml string func newBuilder(varPath interface{}) (err error) { var Gtk3Interface []byte @@ -44,162 +51,247 @@ func newBuilder(varPath interface{}) (err error) { func loadObject(name string) (newObj glib.IObject) { var err error if newObj, err = mainObjects.mainUiBuilder.GetObject(name); err != nil { - log.Panic(err) + fmt.Printf("Unable to load %s object, maybe it was deleted from the Glade file ... : %s\n%s\n", + name, err.Error(), + fmt.Sprint("An update with GOH may avoid this issue.")) + os.Exit(1) } return newObj } -// WindowDestroy: is the triggered handler when closing/destroying the gui window. -func windowDestroy() { - // Doing something before quit. - if err := mainOptions.Write(); err != nil { /* Update mainOptions with values of gtk conctrols and write to file */ - fmt.Printf("%s\n%v\n", "Writing options error.", err) - } - // Bye ... - gtk.MainQuit() -} +// Used as fake function for default callback in signals section +func blankNotify() {} /*************************************************/ /* Images functions, used to initialize objects */ -/***********************************************/ -// setImage: Set Image to GtkImage objects -func setImage(object *gtk.Image, varPath interface{}, size ...int) { - if inPixbuf, err := getPixBuff(varPath, size...); err == nil { - object.SetFromPixbuf(inPixbuf) - return - } else if len(varPath.(string)) != 0 { - fmt.Printf("SetImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } +/* You can use it to load your own embedded */ +/* images, icons ... */ +/*********************************************/ + +// TryStockIcon: Convenience function to combine a stock-icons-theme +// and an asset/filename icon to send to "GetPixBuf()" function. +func TryStockIcon(iconLookupFlag gtk.IconLookupFlags, stockName, assetName interface{}) (names []interface{}) { + names = append(names, stockName) + names = append(names, iconLookupFlag) + names = append(names, assetName) + return } -// setWinIcon: Set Icon to GtkWindow objects -func setWinIcon(object *gtk.Window, varPath interface{}, size ...int) { - if inPixbuf, err := getPixBuff(varPath, size...); err == nil { - object.SetIcon(inPixbuf) - } else if len(varPath.(string)) != 0 { - fmt.Printf("SetWinIcon: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } +// OptPict: hold options for SetPict() +type OptPict struct { + Size int + // 0 = limit height, 1 = limit width, 2 = percents, + // 3 = limit height or width depending on MaxSize value. + ResizeMethode int + // Max size accepted relative to "ResizeMethode" = 3 + MaxSize int + // SpinButton icon position + Position gtk.EntryIconPosition + // Ask for a GdkPixbufAnimation image + Animated bool + // Rotate image / icon + Rotate gdk.PixbufRotation + // Opacity [0.0 to 1.0] work with: Box, ToggleButton, ToolButton, MenuButton, Button + Opacity float64 } -// setButtonImage: Set Icon to GtkButton objects -func setButtonImage(object *gtk.Button, varPath interface{}, size ...int) { +// SetPic: Assign image to an Object depending on type, accept stock-icons-theme, +// filename or []byte. Use OptPict{} struct to set options, size can be applied +// directly as int. The options are described below: +// - Load a gif animated image and specify using animation (true), resizing not +// allowed with animations. +// SetPict(GtkImage, "linearProgressHorzBlue.gif", OptPict{Animated: true}) +// - Resize to 32 pixels height, keep porportions & assign image to GtkButton. +// SetPict(GtkButton, "stillImage.png", 32) or +// SetPict(GtkButton, "stillImage.png", OptPict{Size: 32}) +// - With default size, resizing not allowed for GtkSpinButton position at right-end. +// SetPict(GtkSpinButton, "stillImage.png", OptPict{Position: gtk.ENTRY_ICON_SECONDARY}) +// - Load a stock-icons-theme or an asset/filename icon to a GtkMenuButton where stock not available. +// SetPict(gtk.MenuButton, TryStockIcon("open-menu-symbolic", "stillImage.png"), 18) or +// SetPict(gtk.MenuButton, TryStockIcon("open-menu-symbolic", "stillImage.png"), OptPict{Size: 18}) +// - Rotate upsidedown, resize 14px: +// SetPict(gtk.MenuButton, TryStockIcon("open-menu-symbolic", "stillImage.png"), OptPict{Size: 14, Rotate: gdk.PIXBUF_ROTATE_UPSIDEDOWN}) +func SetPict(iObject, varPath interface{}, options ...interface{}) (err error) { + var inPixbuf *gdk.Pixbuf + var inPixbufAnimation *gdk.PixbufAnimation var image *gtk.Image - inPixbuf, err := getPixBuff(varPath, size...) - if err == nil { - if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { - object.SetImage(image) - object.SetAlwaysShowImage(true) - return + + var opt OptPict + + if len(options) > 0 { + switch options[0].(type) { + case int: + opt.Size = options[0].(int) + default: + opt = options[0].(OptPict) } } - if err != nil && len(varPath.(string)) != 0 { - fmt.Printf("SetButtonImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) + + // Since the default initialization value is set to 0, + // we need to change it to show a visible image ... + if opt.Opacity == 0 { + opt.Opacity = 1 } -} -// setToolButtonImage: Set Icon to GtkToolButton objects -func setToolButtonImage(object *gtk.ToolButton, varPath interface{}, size ...int) { - var image *gtk.Image - inPixbuf, err := getPixBuff(varPath, size...) - if err == nil { - if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { - object.SetIconWidget(image) - return + // Get pixbuff type (normal or animation for GtkImage) + if opt.Animated { + if inPixbufAnimation, err = GetPixBufAnimation(varPath); err == nil { + image, err = gtk.ImageNewFromAnimation(inPixbufAnimation) + } + } else { + if inPixbuf, err = GetPixBuf(varPath, opt); err == nil { + image, err = gtk.ImageNewFromPixbuf(inPixbuf) } } - if err != nil && len(varPath.(string)) != 0 { - fmt.Printf("setToolButtonImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) + + // Handling the error if there is + if err != nil { + var filename string + // Look for a stock icon or a filename or an ambedded asset + switch path := varPath.(type) { + case []interface{}: + filename = path[2].(string) + default: + filename = path.(string) + } + if _, err = os.Stat(filename); len(filename) > 0 /*os.IsNotExist(err)*/ { + err = fmt.Errorf("SetPict: [%v] %v", varPath, err) + fmt.Println(err.Error()) // double output + } + return } -} -// setToggleButtonImage: Set Icon to GtkToggleButton objects -func setToggleButtonImage(object *gtk.ToggleButton, varPath interface{}, size ...int) { - var image *gtk.Image - inPixbuf, err := getPixBuff(varPath, size...) - if err == nil { - if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { + // Objects parsing + if image != nil { + + image.SetOpacity(opt.Opacity) + + switch object := iObject.(type) { + + case *gtk.Button: // Set Image to GtkButton object.SetImage(image) object.SetAlwaysShowImage(true) - return + + case *gtk.MenuButton: // Set Image to GtkMenuButton + object.SetImage(image) + object.SetAlwaysShowImage(true) + + case *gtk.ToggleButton: // Set Image to GtkToggleButton + object.SetImage(image) + object.SetAlwaysShowImage(true) + + case *gtk.ToolButton: // Set Image to GtkToolButton + object.SetIconWidget(image) + + case *gtk.Box: // Add Image to GtkBox + object.Add(image) + + case *gtk.SpinButton: // Set Icon to GtkSpinButton, No resize, No Animate. + object.SetIconFromPixbuf(opt.Position, inPixbuf) + + case *gtk.ApplicationWindow: // Set Icon to GtkApplicationWindow, No Animate. + object.SetIcon(inPixbuf) + + case *gtk.Window: // Set Icon to GtkWindow, No Animate. + object.SetIcon(inPixbuf) + + case *gtk.Image: // Set Image to GtkImage + if opt.Animated { + object.SetFromAnimation(inPixbufAnimation) + } else { + object.SetFromPixbuf(inPixbuf) + } } + } else { + err = fmt.Errorf("Image error: %v", err) } - if err != nil && len(varPath.(string)) != 0 { - fmt.Printf("SetToggleButtonImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } + return } -// SetSpinButtonImage: Set Icon to GtkSpinButton objects. Position = "left" or "right" -func setSpinButtonImage(object *gtk.SpinButton, varPath interface{}, position ...string) { - var inPixbuf *gdk.Pixbuf - var err error - pos := gtk.ENTRY_ICON_PRIMARY - if len(position) > 0 { - if position[0] == "right" { - pos = gtk.ENTRY_ICON_SECONDARY +// GetPixBuf: Get gdk.PixBuf from stock, filename or []byte, depending +// on type. For an explanation of the options, see above, OptPict{}. +// note: If stock-icons-theme does not exist, the asset/filename icon is used. +func GetPixBuf(varPath interface{}, opt OptPict) (outPixbuf *gdk.Pixbuf, err error) { + var pixbufLoader *gdk.PixbufLoader + + // Look for a stock icon and a filename or ambedded asset + switch varPath.(type) { + case []interface{}: + var iconTheme *gtk.IconTheme + if iconTheme, err = gtk.IconThemeGetDefault(); err == nil { + stock := varPath.([]interface{})[0].(string) + iconLookupFlags := varPath.([]interface{})[1].(gtk.IconLookupFlags) + outPixbuf, err = iconTheme.LoadIcon(stock, opt.Size, iconLookupFlags) + } + if err != nil { + varPath = varPath.([]interface{})[2] + fmt.Println(err.Error() + ". try to load the secondary choice.") } } - if inPixbuf, err = getPixBuff(varPath); err == nil { - object.SetIconFromPixbuf(pos, inPixbuf) - return - } else if len(varPath.(string)) != 0 { - fmt.Printf("SetSpinButtonImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } -} -// setBoxImage: Set Image to GtkBox objects -func setBoxImage(object *gtk.Box, varPath interface{}, size ...int) { - var image *gtk.Image - inPixbuf, err := getPixBuff(varPath, size...) - if err == nil { - if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { - image.Show() - object.Add(image) - return + if outPixbuf == nil { // in this case, no stock icon was found or was not requested + switch varPath.(type) { + case string: // Its a filename + outPixbuf, err = gdk.PixbufNewFromFile(varPath.(string)) + case []uint8: // Its a binary data (embedded asset) + if pixbufLoader, err = gdk.PixbufLoaderNew(); err == nil { + outPixbuf, err = pixbufLoader.WriteAndReturnPixbuf(varPath.([]byte)) + } + } + + if err == nil && opt.Size != 0 { + newWidth, newHeight := NormalizeSize(outPixbuf.GetWidth(), outPixbuf.GetHeight(), opt) + if outPixbuf, err = outPixbuf.ScaleSimple(newWidth, newHeight, gdk.INTERP_HYPER); err == nil { + outPixbuf, err = outPixbuf.RotateSimple(opt.Rotate) + } } } - if err != nil && len(varPath.(string)) != 0 { - fmt.Printf("setBoxImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } + return } -// getPixBuff: Get gtk.Pixbuff image representation from file or []byte, depending on type -// size: resize height keeping porportions. 0 = no change -func getPixBuff(varPath interface{}, size ...int) (outPixbuf *gdk.Pixbuf, err error) { - sze := 0 - if len(size) != 0 { - sze = size[0] - } - switch reflect.TypeOf(varPath).String() { - case "string": - outPixbuf, err = gdk.PixbufNewFromFile(varPath.(string)) - case "[]uint8": - pbLoader, err := gdk.PixbufLoaderNew() - if err == nil { - outPixbuf, err = pbLoader.WriteAndReturnPixbuf(varPath.([]byte)) +// GetPixBufAnimation: Get gdk.PixBufAnimation from filename or []byte, depending on type +func GetPixBufAnimation(varPath interface{}) (outPixbufAnimation *gdk.PixbufAnimation, err error) { + var pixbufLoader *gdk.PixbufLoader + switch varPath.(type) { + case string: + outPixbufAnimation, err = gdk.PixbufAnimationNewFromFile(varPath.(string)) + case []uint8: + if pixbufLoader, err = gdk.PixbufLoaderNew(); err == nil { + outPixbufAnimation, err = pixbufLoader.WriteAndReturnPixbufAnimation(varPath.([]byte)) } } - if err == nil && sze != 0 { - newWidth, wenHeight := normalizeSize(outPixbuf.GetWidth(), outPixbuf.GetHeight(), sze, 2) - outPixbuf, err = outPixbuf.ScaleSimple(newWidth, wenHeight, gdk.INTERP_BILINEAR) - } - return outPixbuf, err + return } // NormalizeSize: compute new size with kept proportions based on defined format. -// format: 0 percent, 1 reducing width, 2 reducing height -func normalizeSize(oldWidth, oldHeight, newValue, format int) (outWidth, outHeight int) { - switch format { - case 0: // percent - outWidth = int((float64(oldWidth) * float64(newValue)) / 100) - outHeight = int((float64(oldHeight) * float64(newValue)) / 100) - case 1: // Width - outWidth = newValue - outHeight = int(float64(oldHeight) * (float64(newValue) / float64(oldWidth))) - case 2: // Height - outWidth = int(float64(oldWidth) * (float64(newValue) / float64(oldHeight))) - outHeight = newValue +// formats: 0 = limit height, 1 = limit width, 2 = percents, +// 3 = limit height or width depending on MaxSize value. +func NormalizeSize(oldWidth, oldHeight int, opt OptPict) (outWidth, outHeight int) { + switch opt.ResizeMethode { + case 0: // limit Height + outWidth = int(float64(oldWidth) * (float64(opt.Size) / float64(oldHeight))) + outHeight = opt.Size + case 1: // limit Width + outWidth = opt.Size + outHeight = int(float64(oldHeight) * (float64(opt.Size) / float64(oldWidth))) + case 2: // percent + outWidth = int((float64(oldWidth) * float64(opt.Size)) / 100) + outHeight = int((float64(oldHeight) * float64(opt.Size)) / 100) + case 3: // limit Height or Width + switch { + case oldWidth >= opt.MaxSize: + opt.Size = opt.MaxSize + opt.ResizeMethode = 1 + return NormalizeSize(oldWidth, oldHeight, opt) + case oldHeight >= opt.MaxSize: + opt.Size = opt.MaxSize + opt.ResizeMethode = 0 + return NormalizeSize(oldWidth, oldHeight, opt) + } + opt.ResizeMethode = 0 + return NormalizeSize(oldWidth, oldHeight, opt) } - return outWidth, outHeight + return } /***************************************/ @@ -209,14 +301,13 @@ func normalizeSize(oldWidth, oldHeight, newValue, format int) (outWidth, outHeig /***********************************/ // getBytesFromVarAsset: Get []byte representation from file or asset, depending on type func getBytesFromVarAsset(varPath interface{}) (outBytes []byte, err error) { - var rBytes []byte switch reflect.TypeOf(varPath).String() { case "string": - rBytes, err = ioutil.ReadFile(varPath.(string)) + return ioutil.ReadFile(varPath.(string)) case "[]uint8": - rBytes = varPath.([]byte) + return varPath.([]byte), err } - return rBytes, err + return } // HexToBytes: Convert Gzip Hex to []byte used for embedded binary in source code @@ -229,17 +320,16 @@ func HexToBytes(varPath string, gzipData []byte) (outByte []byte) { return bBuffer.Bytes() } } + } else { + fmt.Printf("An error occurred while reading: %s\n%s\n", varPath, err.Error()) } - if err != nil { - fmt.Printf("An error occurred while reading: %s\n%v\n", varPath, err.Error()) - } - return outByte + return } /*******************************/ /* Simplified files Functions */ /*****************************/ -// tempMake: Make temporary directory +// Make temporary directory func tempMake(prefix string) (dir string) { var err error if dir, err = ioutil.TempDir("", prefix+"-"); err != nil { @@ -248,24 +338,56 @@ func tempMake(prefix string) (dir string) { return dir + string(os.PathSeparator) } -// getAbsRealPath: Retrieve app current realpath and options filenme +// Retrieve current realpath and options filename. Options/Config path +// depend on devMode value, true means actual directory, false means +// $USER/.config/Creat/appName/* func getAbsRealPath() (absoluteRealPath, optFilename string) { - absoluteBaseName, err := os.Executable() + var err error + var cUser *user.User + var base, absoluteBaseName string + + var setExt = func(filename, ext string) (out string) { + return filename[:len(filename)-len(path.Ext(filename))] + ext + } + + if absoluteBaseName, err = os.Executable(); err == nil { + absoluteRealPath, base = filepath.Split(absoluteBaseName) + configPath := absoluteRealPath + baseNoExt := setExt(base, "") + if !devMode { + if cUser, err = user.Current(); err == nil { + configPath = filepath.Join(cUser.HomeDir, ".config", ToCamel(Creat), baseNoExt) + if _, err = os.Stat(configPath); os.IsNotExist(err) { + err = os.MkdirAll(configPath, 0755) + } + } + } + if err == nil { + optFilename = setExt(filepath.Join(configPath, baseNoExt), ".opt") + } + } + if err != nil { log.Fatal(err) } - base := filepath.Base(absoluteBaseName) - splited := strings.Split(base, ".") - length := len(splited) - if length == 1 { - optFilename = base - } else { - splited = splited[:length-1] - optFilename = strings.Join(splited, ".") - } - return filepath.Dir(absoluteBaseName) + string(os.PathSeparator), - filepath.Dir(absoluteBaseName) + string(os.PathSeparator) + optFilename + ".opt" + return } -// Used as fake function for signals section -func blankNotify() {} +// ToCamel: Turn string into camel case +func ToCamel(inString string, lowerAtFirst ...bool) (outString string) { + var laf bool + if len(lowerAtFirst) != 0 { + laf = lowerAtFirst[0] + } + nonAlNum := regexp.MustCompile("[[:punct:][:space:]]") + tmpString := nonAlNum.Split(inString, -1) + + for idx, word := range tmpString { + if laf && idx < 1 { + outString += strings.ToLower(word) + } else { + outString += strings.Title(word) + } + } + return outString +} diff --git a/gohImages.go b/gohImages.go index 0967419..589897f 100644 --- a/gohImages.go +++ b/gohImages.go @@ -1,43 +1,38 @@ // gohImages.go -// Source file auto-generated on Wed, 02 Oct 2019 23:28:15 using Gotk3ObjHandler v1.3.8 ©2018-19 H.F.M - /* + Source file auto-generated on Fri, 02 Apr 2021 13:10:55 using Gotk3 Objects Handler v1.7.5 ©2018-21 hfmrow + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2018-21 H.F.M - Search Engine v1.9 github.com/hfmrow/search-engine This program comes with absolutely no warranty. See the The MIT License (MIT) for details: https://opensource.org/licenses/mit-license.php */ package main -/*************************************************************/ -/* This section preserve user modifications on update. */ -/* Images declarations, used to initialize objects with it */ -/* The functions: setImage, setWinIcon and setButtonImage */ -/* accept both kind of variables: filename or []byte */ -/* content in case of using embedded binary data. The */ -/* variables names are the same. You can use function */ -/* "func assetsDeclarationsUseEmbedded(bool)" */ -/* to toggle between filenames and embedded binary. */ -/* The "set...Image/Icon" functions could receive */ -/* a display size if necessary or a pos. argument. */ -/**************************************************/ +/**********************************************************/ +/* This section preserve user modifications on update. */ +/* Images declarations, used to initialize objects with */ +/* The SetPict() func, accept both kind of variables: */ +/* filename or []byte content in case of using */ +/* embedded binary data. The variables names are the */ +/* same. "assetsDeclarationsUseEmbedded(bool)" func */ +/* could be used to toggle between filenames and */ +/* embedded binary type. See SetPict() */ +/* declaration to learn more on how to use it. */ +/************************************************/ func assignImages() { - setImage(mainObjects.ImageTop, searchEngine700x48) - setWinIcon(mainObjects.MainWindow, find48) - setButtonImage(mainObjects.SearchButton, find18) - setButtonImage(mainObjects.SearchButtonExit, cancel18x18) - setButtonImage(mainObjects.SearchButtonExport, saveAll18) - setButtonImage(mainObjects.SearchButtonNewerThan, calendar18) - setButtonImage(mainObjects.SearchButtonOlderThan, calendar18) - setButtonImage(mainObjects.SearchButtonResetComboEntry, reset18x18) - setButtonImage(mainObjects.TimeButtonOkNewer, checked18x18) - setButtonImage(mainObjects.TimeButtonOkOlder, checked18x18) - setButtonImage(mainObjects.TimeButtonResetNewer, reset18x18) - setButtonImage(mainObjects.TimeButtonResetOlder, reset18x18) - setImage(mainObjects.TimeImageTopNewer, searchEngine400x27) - setImage(mainObjects.TimeImageTopOlder, searchEngine400x27) - setWinIcon(mainObjects.TimeWindowNewer, "") - setWinIcon(mainObjects.TimeWindowOlder, "") + size := 18 + SetPict(mainObjects.ImageTop, searchEngineTop550x48) + SetPict(mainObjects.MainWindow, find48) + SetPict(mainObjects.SearchButton, searchFolder48, size) + SetPict(mainObjects.SearchButtonExit, logout48, size-2) + SetPict(mainObjects.SearchButtonExport, floppySave48, size-4) + SetPict(mainObjects.SearchButtonNewerThan, calendarPers48, size) + SetPict(mainObjects.SearchButtonOlderThan, calendarPers48, size) + SetPict(mainObjects.SearchButtonResetComboEntry, clearHist48, size-2) } /**********************************************************/ @@ -46,20 +41,20 @@ func assignImages() { /* bridge between the differents types used, string or */ /* []byte, and to simply switch from one to another. */ /*****************************************************/ -var calendar18 interface{} // assets/images/calendar-18.png -var calendar48 interface{} // assets/images/calendar-48.png -var cancel18x18 interface{} // assets/images/cancel-18x18.png -var checked18x18 interface{} // assets/images/checked-18x18.png -var copyDocument20 interface{} // assets/images/Copy-document-20.png -var find18 interface{} // assets/images/find-18.png -var find48 interface{} // assets/images/find-48.png -var folderOpen20 interface{} // assets/images/folder-open-20.png -var globalNetwork20 interface{} // assets/images/Global-Network-20.png -var mainGlade interface{} // assets/glade/main.glade -var open18 interface{} // assets/images/open-18.png -var play20 interface{} // assets/images/Play-20.png -var reset18x18 interface{} // assets/images/reset-18x18.png -var saveAll18 interface{} // assets/images/save-all-18.png -var searchEngine400x27 interface{} // assets/images/Search-Engine-400x27.png -var searchEngine700x48 interface{} // assets/images/Search-Engine-700x48.png -var signError20 interface{} // assets/images/Sign-Error-20.png +var mainGlade interface{} // assets/glade/main.glade +var calendarPers48 interface{} // assets/images/calendar-pers-48.png +var clearHist48 interface{} // assets/images/clear-hist-48.png +var copyDocument20 interface{} // assets/images/Copy-document-20.png +var crossIcon48 interface{} // assets/images/Cross-icon-48.png +var find48 interface{} // assets/images/find-48.png +var floppySave48 interface{} // assets/images/floppy-save-48.png +var folder48 interface{} // assets/images/folder-48.png +var globalNetwork20 interface{} // assets/images/Global-Network-20.png +var logout48 interface{} // assets/images/logout-48.png +var play20 interface{} // assets/images/Play-20.png +var reset48 interface{} // assets/images/reset-48.png +var searchEngineTop370x32 interface{} // assets/images/search-engine-top-370x32.png +var searchEngineTop550x48 interface{} // assets/images/search-engine-top-550x48.png +var searchFolder48 interface{} // assets/images/search-folder-48.png +var stop48 interface{} // assets/images/Stop-48.png +var tickIcon48 interface{} // assets/images/Tick-icon-48.png diff --git a/gohObjects.go b/gohObjects.go index ae1c216..300a8bd 100644 --- a/gohObjects.go +++ b/gohObjects.go @@ -1,8 +1,11 @@ // gohObjects.go -// Source file auto-generated on Wed, 02 Oct 2019 23:28:15 using Gotk3ObjHandler v1.3.8 ©2018-19 H.F.M - /* + Source file auto-generated on Fri, 02 Apr 2021 13:10:55 using Gotk3 Objects Handler v1.7.5 ©2018-21 hfmrow + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2018-21 H.F.M - Search Engine v1.9 github.com/hfmrow/search-engine This program comes with absolutely no warranty. See the The MIT License (MIT) for details: https://opensource.org/licenses/mit-license.php */ @@ -44,6 +47,7 @@ type MainControlsObj struct { SearchCheckbuttonWordOr *gtk.CheckButton SearchComboboxTextAnd *gtk.ComboBoxText SearchComboboxTextDateType *gtk.ComboBoxText + SearchComboboxTextDateZone *gtk.ComboBoxText SearchComboboxTextEntryAnd *gtk.Entry SearchComboboxTextEntryNot *gtk.Entry SearchComboboxTextEntryOr *gtk.Entry @@ -55,22 +59,6 @@ type MainControlsObj struct { SearchTreeview *gtk.TreeView SearchTreeviewSelection *gtk.TreeSelection Statusbar *gtk.Statusbar - TimeButtonOkNewer *gtk.Button - TimeButtonOkOlder *gtk.Button - TimeButtonResetNewer *gtk.Button - TimeButtonResetOlder *gtk.Button - TimeCalendarNewer *gtk.Calendar - TimeCalendarOlder *gtk.Calendar - TimeImageTopNewer *gtk.Image - TimeImageTopOlder *gtk.Image - TimeSpinbuttonHourNewer *gtk.SpinButton - TimeSpinbuttonHourOlder *gtk.SpinButton - TimeSpinbuttonMinutsNewer *gtk.SpinButton - TimeSpinbuttonMinutsOlder *gtk.SpinButton - TimeSpinbuttonSecondsNewer *gtk.SpinButton - TimeSpinbuttonSecondsOlder *gtk.SpinButton - TimeWindowNewer *gtk.Window - TimeWindowOlder *gtk.Window TopImageEventbox *gtk.EventBox } @@ -101,6 +89,7 @@ func gladeObjParser() { mainObjects.SearchCheckbuttonWordOr = loadObject("SearchCheckbuttonWordOr").(*gtk.CheckButton) mainObjects.SearchComboboxTextAnd = loadObject("SearchComboboxTextAnd").(*gtk.ComboBoxText) mainObjects.SearchComboboxTextDateType = loadObject("SearchComboboxTextDateType").(*gtk.ComboBoxText) + mainObjects.SearchComboboxTextDateZone = loadObject("SearchComboboxTextDateZone").(*gtk.ComboBoxText) mainObjects.SearchComboboxTextEntryAnd = loadObject("SearchComboboxTextEntryAnd").(*gtk.Entry) mainObjects.SearchComboboxTextEntryNot = loadObject("SearchComboboxTextEntryNot").(*gtk.Entry) mainObjects.SearchComboboxTextEntryOr = loadObject("SearchComboboxTextEntryOr").(*gtk.Entry) @@ -112,81 +101,5 @@ func gladeObjParser() { mainObjects.SearchTreeview = loadObject("SearchTreeview").(*gtk.TreeView) mainObjects.SearchTreeviewSelection = loadObject("SearchTreeviewSelection").(*gtk.TreeSelection) mainObjects.Statusbar = loadObject("Statusbar").(*gtk.Statusbar) - mainObjects.TimeButtonOkNewer = loadObject("TimeButtonOkNewer").(*gtk.Button) - mainObjects.TimeButtonOkOlder = loadObject("TimeButtonOkOlder").(*gtk.Button) - mainObjects.TimeButtonResetNewer = loadObject("TimeButtonResetNewer").(*gtk.Button) - mainObjects.TimeButtonResetOlder = loadObject("TimeButtonResetOlder").(*gtk.Button) - mainObjects.TimeCalendarNewer = loadObject("TimeCalendarNewer").(*gtk.Calendar) - mainObjects.TimeCalendarOlder = loadObject("TimeCalendarOlder").(*gtk.Calendar) - mainObjects.TimeImageTopNewer = loadObject("TimeImageTopNewer").(*gtk.Image) - mainObjects.TimeImageTopOlder = loadObject("TimeImageTopOlder").(*gtk.Image) - mainObjects.TimeSpinbuttonHourNewer = loadObject("TimeSpinbuttonHourNewer").(*gtk.SpinButton) - mainObjects.TimeSpinbuttonHourOlder = loadObject("TimeSpinbuttonHourOlder").(*gtk.SpinButton) - mainObjects.TimeSpinbuttonMinutsNewer = loadObject("TimeSpinbuttonMinutsNewer").(*gtk.SpinButton) - mainObjects.TimeSpinbuttonMinutsOlder = loadObject("TimeSpinbuttonMinutsOlder").(*gtk.SpinButton) - mainObjects.TimeSpinbuttonSecondsNewer = loadObject("TimeSpinbuttonSecondsNewer").(*gtk.SpinButton) - mainObjects.TimeSpinbuttonSecondsOlder = loadObject("TimeSpinbuttonSecondsOlder").(*gtk.SpinButton) - mainObjects.TimeWindowNewer = loadObject("TimeWindowNewer").(*gtk.Window) - mainObjects.TimeWindowOlder = loadObject("TimeWindowOlder").(*gtk.Window) mainObjects.TopImageEventbox = loadObject("TopImageEventbox").(*gtk.EventBox) - -} - - - -/*************************************/ -/* GtkObjects Widget naming. Usualy */ -/* used in css to identify objects */ -/**********************************/ -func widgetNaming() { - mainObjects.ImageTop.SetName("ImageTop") - mainObjects.MainWindow.SetName("MainWindow") - mainObjects.SearchButton.SetName("SearchButton") - mainObjects.SearchButtonExit.SetName("SearchButtonExit") - mainObjects.SearchButtonExport.SetName("SearchButtonExport") - mainObjects.SearchButtonNewerThan.SetName("SearchButtonNewerThan") - mainObjects.SearchButtonOlderThan.SetName("SearchButtonOlderThan") - mainObjects.SearchButtonResetComboEntry.SetName("SearchButtonResetComboEntry") - mainObjects.SearchCheckbuttonCaseSensitive.SetName("SearchCheckbuttonCaseSensitive") - mainObjects.SearchCheckbuttonCharClasses.SetName("SearchCheckbuttonCharClasses") - mainObjects.SearchCheckbuttonCharClassesStrictMode.SetName("SearchCheckbuttonCharClassesStrictMode") - mainObjects.SearchCheckbuttonFollowSL.SetName("SearchCheckbuttonFollowSL") - mainObjects.SearchCheckbuttonRegex.SetName("SearchCheckbuttonRegex") - mainObjects.SearchCheckbuttonSplitedAnd.SetName("SearchCheckbuttonSplitedAnd") - mainObjects.SearchCheckbuttonSplitedNot.SetName("SearchCheckbuttonSplitedNot") - mainObjects.SearchCheckbuttonSplitedOr.SetName("SearchCheckbuttonSplitedOr") - mainObjects.SearchCheckbuttonWildCard.SetName("SearchCheckbuttonWildCard") - mainObjects.SearchCheckbuttonWordAnd.SetName("SearchCheckbuttonWordAnd") - mainObjects.SearchCheckbuttonWordNot.SetName("SearchCheckbuttonWordNot") - mainObjects.SearchCheckbuttonWordOr.SetName("SearchCheckbuttonWordOr") - mainObjects.SearchComboboxTextAnd.SetName("SearchComboboxTextAnd") - mainObjects.SearchComboboxTextDateType.SetName("SearchComboboxTextDateType") - mainObjects.SearchComboboxTextEntryAnd.SetName("SearchComboboxTextEntryAnd") - mainObjects.SearchComboboxTextEntryNot.SetName("SearchComboboxTextEntryNot") - mainObjects.SearchComboboxTextEntryOr.SetName("SearchComboboxTextEntryOr") - mainObjects.SearchComboboxTextNot.SetName("SearchComboboxTextNot") - mainObjects.SearchComboboxTextOr.SetName("SearchComboboxTextOr") - mainObjects.SearchComboboxTextType.SetName("SearchComboboxTextType") - mainObjects.SearchFilechooserbutton.SetName("SearchFilechooserbutton") - mainObjects.SearchSpinbuttonDepth.SetName("SearchSpinbuttonDepth") - mainObjects.SearchTreeview.SetName("SearchTreeview") - mainObjects.Statusbar.SetName("Statusbar") - mainObjects.TimeButtonOkNewer.SetName("TimeButtonOkNewer") - mainObjects.TimeButtonOkOlder.SetName("TimeButtonOkOlder") - mainObjects.TimeButtonResetNewer.SetName("TimeButtonResetNewer") - mainObjects.TimeButtonResetOlder.SetName("TimeButtonResetOlder") - mainObjects.TimeCalendarNewer.SetName("TimeCalendarNewer") - mainObjects.TimeCalendarOlder.SetName("TimeCalendarOlder") - mainObjects.TimeImageTopNewer.SetName("TimeImageTopNewer") - mainObjects.TimeImageTopOlder.SetName("TimeImageTopOlder") - mainObjects.TimeSpinbuttonHourNewer.SetName("TimeSpinbuttonHourNewer") - mainObjects.TimeSpinbuttonHourOlder.SetName("TimeSpinbuttonHourOlder") - mainObjects.TimeSpinbuttonMinutsNewer.SetName("TimeSpinbuttonMinutsNewer") - mainObjects.TimeSpinbuttonMinutsOlder.SetName("TimeSpinbuttonMinutsOlder") - mainObjects.TimeSpinbuttonSecondsNewer.SetName("TimeSpinbuttonSecondsNewer") - mainObjects.TimeSpinbuttonSecondsOlder.SetName("TimeSpinbuttonSecondsOlder") - mainObjects.TimeWindowNewer.SetName("TimeWindowNewer") - mainObjects.TimeWindowOlder.SetName("TimeWindowOlder") - mainObjects.TopImageEventbox.SetName("TopImageEventbox") - } diff --git a/gohOptions.go b/gohOptions.go index 0822c60..8664189 100644 --- a/gohOptions.go +++ b/gohOptions.go @@ -1,8 +1,11 @@ // gohOptions.go -// Source file auto-generated on Wed, 02 Oct 2019 17:33:10 using Gotk3ObjHandler v1.3.8 ©2018-19 H.F.M - /* + Source file auto-generated on Fri, 02 Apr 2021 13:10:55 using Gotk3 Objects Handler v1.7.5 ©2018-21 hfmrow + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2018-21 H.F.M - Search Engine v1.9 github.com/hfmrow/search-engine This program comes with absolutely no warranty. See the The MIT License (MIT) for details: https://opensource.org/licenses/mit-license.php */ @@ -13,60 +16,82 @@ import ( "bytes" "encoding/json" "errors" + "fmt" "io/ioutil" + "os" + glfsff "github.com/hfmrow/genLib/files/findFiles" gltsbh "github.com/hfmrow/genLib/tools/bench" gltses "github.com/hfmrow/genLib/tools/errors" gidg "github.com/hfmrow/gtk3Import/dialog" - gidgat "github.com/hfmrow/gtk3Import/dialog/about" + gidgcr "github.com/hfmrow/gtk3Import/dialog/chooser" gimc "github.com/hfmrow/gtk3Import/misc" gitw "github.com/hfmrow/gtk3Import/treeview" - // gidgcr "github.com/hfmrow/gtk3Import/dialog/chooser" ) // App infos -var Name = "SearchEngine" -var Vers = "v1.8.5" +var Name = "Search Engine" +var Vers = "v1.9" var Descr = "This program is designed to search files over directory,\nsubdirectory, and retrieving information based on\ndate, type, patterns contained in name." var Creat = "H.F.M" -var YearCreat = "2018-19" +var YearCreat = "2018-21" var LicenseShort = "This program comes with absolutely no warranty.\nSee the The MIT License (MIT) for details:\nhttps://opensource.org/licenses/mit-license.php" var LicenseAbrv = "License (MIT)" -var Repository = "github.com/hfmrow/searchEngine" +var Repository = "github.com/hfmrow/search-engine" // Vars declarations -var absoluteRealPath, optFilename = getAbsRealPath() -var mainOptions *MainOpt -var devMode bool -var tempDir string -var doTempDir bool -var namingWidget bool - -var errNoSelection = errors.New("There is no selection currently.") -var tvs *gitw.TreeViewStructure -var columnsNames = [][]string{{"Name", "text"}, {"Size", "text"}, {"Type", "text"}, {"Time", "text"}, {"Path", "text"}} -var timer = gltsbh.BenchNew(false) -var statusbar = gimc.StatusBar{} -var clipboard = gimc.Clipboard{} -var titlebar *gimc.TitleBar -var maintitle string -var filesScanned int - -// Functions mapping -var Check = gltses.Check -var DialogMessage = gidg.DialogMessage - -// var FileChooser = gidgcr.FileChooser - -// To store original label content for newer than and older than buttons. -var origLabelNT, origLabelOT string - -type searchTimeCal struct { - y, m, d uint - H, M, S float64 - Ready bool -} +var ( + maintitle, + tempDir, + absoluteRealPath, + optFilename string + + mainOptions *MainOpt + devMode bool + + doTempDir bool + errNoSelection = errors.New("There is no selection currently.") + + columnsNames = [][]string{ + {"Name", "text"}, + {"Size", "text"}, + {"Type", "text"}, + {"Time", "text"}, + {"Path", "text"}, + {"sizeSort", "int64"}, // This one will be invisible (int64) + {"dateSort", "int64"}} // This one will be invisible (int64) + + columnsMap = map[string]int{ + `name`: 0, + `size`: 1, + `type`: 2, + `time`: 3, + `path`: 4, + `sizeSort`: 5, + `dateSort`: 6, + } + + filesScanned int + + // Functions mapping + timer = gltsbh.BenchNew(false) + statusbar = gimc.StatusBar{} + clipboard = gimc.Clipboard{} + titlebar *gimc.TitleBar + tvs *gitw.TreeViewStructure + Check = gltses.Check + DialogMessage = gidg.DialogMessage + storeFoundFiles []glfsff.StoreFiles + + // Popup + popupMenu *gimc.PopupMenuIconStruct + PopupMenuIconStructNew = gimc.PopupMenuIconStructNew + + // To store original label content for newer than and older than buttons. + origLabelNT, + origLabelOT string +) type searchList struct { And []string @@ -76,7 +101,7 @@ type searchList struct { type MainOpt struct { /* Public, will be saved and restored */ - AboutOptions *gidgat.AboutInfos + About *gidg.AboutInfos MainWinWidth, MainWinHeight int LanguageFilename string LastDirectory string @@ -88,6 +113,7 @@ type MainOpt struct { FollowSymlinks bool FileType int DateType int + DateZone int Depth int WordAnd bool WordOr bool @@ -100,23 +126,26 @@ type MainOpt struct { AppLauncher string WebSearchEngine string FileExplorer string + OptionsPath string /* Private, will NOT be saved */ - searchNewerThan searchTimeCal - searchOlderThan searchTimeCal - foundFilesList []string + calendar *gidgcr.Calendar + calDataNewerThan *gidgcr.CalendarData + calDataOlderThan *gidgcr.CalendarData + displayFilesList [][]string } // Main options initialisation func (opt *MainOpt) Init() { - opt.AboutOptions = new(gidgat.AboutInfos) + opt.About = new(gidg.AboutInfos) opt.LanguageFilename = "assets/lang/eng.lang" opt.WebSearchEngine = `https://www.google.com/search?q=` opt.FileExplorer = "thunar" opt.AppLauncher = "xdg-open" + opt.Depth = -1 opt.MainWinWidth = 800 opt.MainWinHeight = 600 @@ -143,6 +172,7 @@ func (opt *MainOpt) UpdateObjects() { mainObjects.SearchComboboxTextType.SetActive(opt.FileType) mainObjects.SearchComboboxTextDateType.SetActive(opt.DateType) + mainObjects.SearchComboboxTextDateZone.SetActive(opt.DateZone) mainObjects.SearchCheckbuttonFollowSL.SetActive(opt.FollowSymlinks) } @@ -169,6 +199,7 @@ func (opt *MainOpt) UpdateOptions() { opt.FileType = mainObjects.SearchComboboxTextType.GetActive() opt.DateType = mainObjects.SearchComboboxTextDateType.GetActive() + opt.DateZone = mainObjects.SearchComboboxTextDateZone.GetActive() opt.FollowSymlinks = mainObjects.SearchCheckbuttonFollowSL.GetActive() } @@ -176,20 +207,25 @@ func (opt *MainOpt) UpdateOptions() { // Read Options from file func (opt *MainOpt) Read() (err error) { var textFileBytes []byte + opt.Init() if textFileBytes, err = ioutil.ReadFile(optFilename); err == nil { err = json.Unmarshal(textFileBytes, &opt) } - return err + if err != nil { + fmt.Printf("Error while reading options file: %s\n", err.Error()) + } + return } // Write Options to file func (opt *MainOpt) Write() (err error) { - var out bytes.Buffer var jsonData []byte + var out bytes.Buffer opt.UpdateOptions() + opt.About.DlgBoxStruct = nil // remove dialog object before saving if jsonData, err = json.Marshal(&opt); err == nil { if err = json.Indent(&out, jsonData, "", "\t"); err == nil { - err = ioutil.WriteFile(optFilename, out.Bytes(), 0644) + err = ioutil.WriteFile(optFilename, out.Bytes(), os.ModePerm) } } return err diff --git a/gohSignals.go b/gohSignals.go index 19d844c..1795e3b 100644 --- a/gohSignals.go +++ b/gohSignals.go @@ -1,8 +1,11 @@ // gohSignals.go -// Source file auto-generated on Wed, 02 Oct 2019 23:28:15 using Gotk3ObjHandler v1.3.8 ©2018-19 H.F.M - /* + Source file auto-generated on Fri, 02 Apr 2021 13:10:55 using Gotk3 Objects Handler v1.7.5 ©2018-21 hfmrow + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2018-21 H.F.M - Search Engine v1.9 github.com/hfmrow/search-engine This program comes with absolutely no warranty. See the The MIT License (MIT) for details: https://opensource.org/licenses/mit-license.php */ @@ -21,22 +24,14 @@ func signalsPropHandler() { mainObjects.SearchButtonOlderThan.Connect("clicked", SearchButtonOlderThanClicked) mainObjects.SearchButtonResetComboEntry.Connect("clicked", SearchButtonResetComboEntryClicked) mainObjects.SearchCheckbuttonCharClasses.Connect("clicked", SearchCheckbuttonCharClassesClicked) - mainObjects.SearchCheckbuttonFollowSL.Connect("notify", blankNotify) mainObjects.SearchCheckbuttonRegex.Connect("toggled", SearchCheckbuttonRegexToggled) - mainObjects.SearchComboboxTextDateType.Connect("changed", SearchComboboxTextDateTypeChanged) + mainObjects.SearchComboboxTextDateType.Connect("changed", ComboboxTextGenericChanged) + mainObjects.SearchComboboxTextDateZone.Connect("changed", ComboboxTextGenericChanged) mainObjects.SearchComboboxTextEntryAnd.Connect("activate", SearchButtonClicked) mainObjects.SearchComboboxTextEntryNot.Connect("activate", SearchButtonClicked) mainObjects.SearchComboboxTextEntryOr.Connect("activate", SearchButtonClicked) mainObjects.SearchComboboxTextType.Connect("changed", SearchComboboxTextTypeChanged) mainObjects.SearchFilechooserbutton.Connect("file-set", SearchFilechooserbuttonFileSet) - mainObjects.SearchTreeview.Connect("button-press-event", SearchTreeviewButtonPressEvent) - mainObjects.SearchTreeviewSelection.Connect("changed", updateStatusbar) - mainObjects.TimeButtonOkNewer.Connect("clicked", TimeButtonOkNewerClicked) - mainObjects.TimeButtonOkOlder.Connect("clicked", TimeButtonOkOlderClicked) - mainObjects.TimeButtonResetNewer.Connect("clicked", TimeButtonResetNewerClicked) - mainObjects.TimeButtonResetOlder.Connect("clicked", TimeButtonResetOlderClicked) - mainObjects.TimeCalendarNewer.Connect("day-selected-double-click", TimeButtonOkNewerClicked) - mainObjects.TimeCalendarOlder.Connect("day-selected-double-click", TimeButtonOkOlderClicked) + mainObjects.SearchTreeview.Connect("button-press-event", popupMenu.CheckRMBFromTreeView) mainObjects.TopImageEventbox.Connect("button-release-event", TopImageEventboxClicked) - } diff --git a/gohStartGtk.go b/gohStartGtk.go index dbf6124..280c8a8 100644 --- a/gohStartGtk.go +++ b/gohStartGtk.go @@ -1,8 +1,11 @@ // gohStartGtk.go -// Source file auto-generated on Fri, 06 Sep 2019 04:25:58 using Gotk3ObjHandler v1.3.6 ©2019 H.F.M - /* + Source file auto-generated on Fri, 02 Apr 2021 13:10:55 using Gotk3 Objects Handler v1.7.5 ©2018-21 hfmrow + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2018-21 H.F.M - Search Engine v1.9 github.com/hfmrow/search-engine This program comes with absolutely no warranty. See the The MIT License (MIT) for details: https://opensource.org/licenses/mit-license.php */ @@ -16,29 +19,27 @@ import ( "github.com/gotk3/gotk3/gtk" ) -/******************************/ +/*******************************/ /* Gtk3 Window Initialisation */ -/******************************/ +/*****************************/ func mainStartGtk(winTitle string, width, height int, center bool) { mainObjects = new(MainControlsObj) gtk.Init(nil) - if newBuilder(mainGlade) == nil { - // Init tempDir and Remove it on quit if requested. + if err := newBuilder(mainGlade); err == nil { + + /* Init tempDir and plan to delete it when leaving. */ if doTempDir { tempDir = tempMake(Name) defer os.RemoveAll(tempDir) } - // Parse Gtk objects + + /* Parse Gtk objects */ gladeObjParser() - // Naming widgets as Gtk objects - if namingWidget { - widgetNaming() - } - // Objects Signals initialisations - signalsPropHandler() + /* Fill control with images */ assignImages() - // Set Window Properties + + /* Set Window Properties */ if center { mainObjects.MainWindow.SetPosition(gtk.WIN_POS_CENTER) } @@ -46,13 +47,26 @@ func mainStartGtk(winTitle string, width, height int, center bool) { mainObjects.MainWindow.SetDefaultSize(width, height) mainObjects.MainWindow.Connect("delete-event", windowDestroy) mainObjects.MainWindow.ShowAll() - // Start main application ... + + /* Start main application before signals init... */ mainApplication() - /* Update gtk conctrols with stored values into mainOptions */ - mainOptions.UpdateObjects() - // Start Gui loop + + /* Objects Signals initialisations */ + signalsPropHandler() + + /* Execute after signals initialisation */ + afterSignals() + + /* Start Gui loop */ gtk.Main() } else { - log.Fatal("Builder initialisation error.") + log.Fatal("Builder initialisation error.", err.Error()) + } +} + +// windowDestroy: on closing/destroying the gui window. +func windowDestroy() { + if onShutdown() { + gtk.MainQuit() } } diff --git a/main.go b/main.go index 637b16a..94c7dd4 100755 --- a/main.go +++ b/main.go @@ -1,8 +1,11 @@ // main.go -// Source file auto-generated on Wed, 02 Oct 2019 17:33:10 using Gotk3ObjHandler v1.3.8 ©2018-19 H.F.M - /* + Source file auto-generated on Fri, 02 Apr 2021 13:10:55 using Gotk3 Objects Handler v1.7.5 ©2018-21 hfmrow + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2018-21 H.F.M - Search Engine v1.9 github.com/hfmrow/search-engine This program comes with absolutely no warranty. See the The MIT License (MIT) for details: https://opensource.org/licenses/mit-license.php */ @@ -11,38 +14,56 @@ package main import ( "fmt" + "log" + gidgcr "github.com/hfmrow/gtk3Import/dialog/chooser" gimc "github.com/hfmrow/gtk3Import/misc" ) func main() { - var err error - /* Be or not to be ... in dev mode ... */ + /* Build options */ + // devMode: is used in some functions to control the behavior of the program + // When software is ready to be published, this flag must be set at "false" + // that means: + // - options file will be stored in $HOME/.config/[Creat]/[softwareName], + // - translate function if used, will no more auto-update "sts" map sentences, + // - all built-in assets will be used instead of the files themselves. + // Be aware to update assets via "Goh" and translations with "Got" before all. devMode = true + absoluteRealPath, optFilename = getAbsRealPath() - /* Build directory for tempDir */ - doTempDir = false + // Initialization of assets according to the chosen mode (devMode). + // you can set this flag to your liking without reference to devMode. + assetsDeclarationsUseEmbedded(!devMode) - /* Naming widgets as Gtk objects names to use in css. - Set to false if they already named in Glade.*/ - namingWidget = true + // Create temp directory .. or not + doTempDir = false - /* Set to true when you choose using embedded assets functionality */ - assetsDeclarationsUseEmbedded(!devMode) + /* Init & read options file */ + mainOptions = new(MainOpt) // Assignate options' structure. + mainOptions.Read() // Read values from options' file if exists. - /* Init Options */ - mainOptions = new(MainOpt) - mainOptions.Init() + maintitle = fmt.Sprintf("%s %s %s %s %s", + Name, + Vers, + YearCreat, + Creat, + LicenseAbrv) - /* Read Options */ - err = mainOptions.Read() - if err != nil { - fmt.Printf("%s\n%v\n", "Options file not found or error on parsing.", err) - } + /* Init gtk display */ + mainStartGtk(maintitle, + mainOptions.MainWinWidth, + mainOptions.MainWinHeight, true) +} +/*******************************************\ +/* Executed before signals initialisation. */ +/******************************************/ +func mainApplication() { /* Init AboutBox */ - mainOptions.AboutOptions.InitFillInfos( + mainOptions.About.InitFillInfos( + mainObjects.MainWindow, "About "+Name, Name, Vers, @@ -52,61 +73,77 @@ func main() { LicenseShort, Repository, Descr, - searchEngine400x27, - checked18x18) - - maintitle = fmt.Sprintf("%s %s %s %s %s", - mainOptions.AboutOptions.AppName, - mainOptions.AboutOptions.AppVers, - mainOptions.AboutOptions.YearCreat, - mainOptions.AboutOptions.AppCreats, - mainOptions.AboutOptions.LicenseAbrv) - - /* Init gtk display */ - mainStartGtk(maintitle, - mainOptions.MainWinWidth, - mainOptions.MainWinHeight, true) + "", + tickIcon48) -} - -func mainApplication() { /* Translate init */ translate = MainTranslateNew(absoluteRealPath+mainOptions.LanguageFilename, devMode) /* Get cmdline if exist */ cmdLineParser() - /* Set options */ - mainObjects.SearchCheckbuttonCharClassesStrictMode.SetVisible(false) - mainOptions.UpdateOnChanges = false - - SearchCheckbuttonRegexToggled() - - /* Update gtk controls with stored values into mainOptions */ - mainOptions.UpdateObjects() - /* Init Clipboard */ Check(clipboard.Init()) /* Init Statusbar */ - statusbar.StructureSetup(mainObjects.Statusbar, []string{"Status:", "Found:", "Selected: ", "Base directory:", "Search time:", "Display time:"}) + statusbar.Init(mainObjects.Statusbar, []string{"Status:", "Found:", "Selected: ", "Base directory:", "Search time:", "Display time:"}) /* Init titlebar */ - titlebar = gimc.TitleBarNew(mainObjects.MainWindow, maintitle) + titlebar = gimc.TitleBarStructureNew(mainObjects.MainWindow) - /* Init Objects */ + /* Init Comboboxes */ fillAllComboboxText() + + /* Init SpinButtons */ initSpinButtons() - // initComboboxes() // TODO Remove this function if all ok + + /* Init Popup menu */ + initPopup() + + /* Init Treeview */ + initTreeview() /* Storing originals labels for newer than and older than buttons */ origLabelNT, _ = mainObjects.SearchButtonNewerThan.GetLabel() origLabelOT, _ = mainObjects.SearchButtonOlderThan.GetLabel() - /* Init some disp */ - initTreeview() /* Init Treeview */ - mainObjects.popUpMenu = initPopup(mainObjects.SearchTreeview, tvs.ListStore) /* Init Popup menu */ + /* Init calendar window */ + mainOptions.calendar = gidgcr.CalendarNew(mainObjects.MainWindow, nil, "title", calendarPers48, []string{"Reset", "Ok"}, reset48, tickIcon48) + mainOptions.calendar.DisplayTime = true + mainOptions.calendar.ButtonsSize = 18 + mainOptions.calendar.ButtonOkPosition = 1 + initCalData() +} - /* Init display */ +/******************************************\ +/* Executed after signals initialisation. */ +/*****************************************/ +func afterSignals() { + /* Set options */ + mainOptions.UpdateObjects() + mainObjects.SearchCheckbuttonCharClassesStrictMode.SetVisible(false) + mainOptions.UpdateOnChanges = false + SearchCheckbuttonRegexToggled() SearchCheckbuttonCharClassesClicked() + if mainObjects.SearchCheckbuttonRegex.GetActive() { + mainObjects.SearchCheckbuttonWildCard.SetSensitive(false) + } +} + +/*************************************\ +/* Executed just before closing all. */ +/************************************/ +func onShutdown() bool { + var err error + // Update mainOptions with GtkObjects and save it + if err = mainOptions.Write(); err == nil { + // What you want to execute before closing the app. + // Return: + // true for exit applicaton + // false does not exit application + } + if err != nil { + log.Fatalf("Unexpected error on exit: %s", err.Error()) + } + return true } diff --git a/miscFunc.go b/miscFunc.go index 87dca79..6c600a2 100644 --- a/miscFunc.go +++ b/miscFunc.go @@ -21,12 +21,21 @@ import ( // initTreeview func initTreeview() { var err error - /* Initialiste liststore Columns */ + /* Init liststore Columns */ if tvs, err = gitw.TreeViewStructureNew(mainObjects.SearchTreeview, true, false); err == nil { - for _, col := range columnsNames { - tvs.AddColumn(col[0], col[1], true, true, true, true, true, true) + tvs.AddColumns(columnsNames, true, true, true, true, true, true) + + tvs.SelectionChangedFunc = updateStatusbar + + if err = tvs.StoreSetup(new(gtk.ListStore)); err == nil { + + // Assign sorted column (col 1 will be sorted using values of col 5) + tvs.Columns[columnsMap["size"]].Column.SetSortColumnID(columnsMap["sizeSort"]) + tvs.Columns[columnsMap["time"]].Column.SetSortColumnID(columnsMap["dateSort"]) + + // Callback function for selection "changed" signal. + tvs.SelectionChangedFunc = updateStatusbar } - err = tvs.StoreSetup(new(gtk.ListStore)) } if err != nil { Check(err) @@ -38,10 +47,10 @@ func updateStatusbar() { statusbar.Set(fmt.Sprintf("%d files scanned", filesScanned), 0) statusbar.Set(fmt.Sprintf("%d", tvs.CountRows()), 1) statusbar.Set(fmt.Sprintf("%d", tvs.Selection.CountSelectedRows()), 2) - // statusbar.Set(glsg.TruncatePath(mainOptions.LastDirectory, 3), 3) - if len(timer.Results) > 1 { - statusbar.Set(fmt.Sprintf("%dm %ds %dms", timer.NumTime[0].Min, timer.NumTime[0].Sec, timer.NumTime[0].Ms), 4) - statusbar.Set(fmt.Sprintf("%dm %ds %dms", timer.NumTime[1].Min, timer.NumTime[1].Sec, timer.NumTime[1].Ms), 5) + + if len(timer.Lapses) > 1 { + statusbar.Set(fmt.Sprintf("%dm %ds %dms", timer.Lapses[0].Min, timer.Lapses[0].Sec, timer.Lapses[0].Ms), 4) + statusbar.Set(fmt.Sprintf("%dm %ds %dms", timer.Lapses[1].Min, timer.Lapses[1].Sec, timer.Lapses[1].Ms), 5) } titlebar.Update([]string{glsg.TruncatePath(mainOptions.LastDirectory, 3)}) } @@ -60,12 +69,12 @@ func cmdLineParser() { } name := filepath.Base(os.Args[0]) fmt.Printf("%s %s %s %s\n%s\n%s\n\nUsage: %s \"PathToScan\"\n", - mainOptions.AboutOptions.AppName, - mainOptions.AboutOptions.AppVers, - mainOptions.AboutOptions.YearCreat, - mainOptions.AboutOptions.AppCreats, - mainOptions.AboutOptions.LicenseShort, - mainOptions.AboutOptions.Description, + mainOptions.About.AppName, + mainOptions.About.AppVers, + mainOptions.About.YearCreat, + mainOptions.About.AppCreats, + mainOptions.About.LicenseShort, + mainOptions.About.Description, name) } @@ -83,24 +92,6 @@ func initSpinButtons() { var ad *gtk.Adjustment if ad, err = gtk.AdjustmentNew(-1, -1, 100, 1, 0, 0); err == nil { mainObjects.SearchSpinbuttonDepth.Configure(ad, 1, 0) - if ad, err = gtk.AdjustmentNew(0, 0, 23, 1, 0, 0); err == nil { - mainObjects.TimeSpinbuttonHourNewer.Configure(ad, 1, 0) - if ad, err = gtk.AdjustmentNew(0, 0, 59, 1, 0, 0); err == nil { - mainObjects.TimeSpinbuttonHourOlder.Configure(ad, 1, 0) - if ad, err = gtk.AdjustmentNew(0, 0, 59, 1, 0, 0); err == nil { - mainObjects.TimeSpinbuttonMinutsNewer.Configure(ad, 1, 0) - if ad, err = gtk.AdjustmentNew(0, 0, 23, 1, 0, 0); err == nil { - mainObjects.TimeSpinbuttonMinutsOlder.Configure(ad, 1, 0) - if ad, err = gtk.AdjustmentNew(0, 0, 59, 1, 0, 0); err == nil { - mainObjects.TimeSpinbuttonSecondsNewer.Configure(ad, 1, 0) - if ad, err = gtk.AdjustmentNew(0, 0, 59, 1, 0, 0); err == nil { - mainObjects.TimeSpinbuttonSecondsOlder.Configure(ad, 1, 0) - } - } - } - } - } - } } if err != nil { Check(err) diff --git a/objectHandler.go b/objectHandler.go index baf0439..6606f92 100755 --- a/objectHandler.go +++ b/objectHandler.go @@ -9,12 +9,13 @@ package main import ( "errors" "fmt" - "strings" + "io/ioutil" + "log" + "os" + "time" - "github.com/gotk3/gotk3/gdk" "github.com/gotk3/gotk3/gtk" - glfs "github.com/hfmrow/genLib/files" glsg "github.com/hfmrow/genLib/strings" gidgcr "github.com/hfmrow/gtk3Import/dialog/chooser" ) @@ -26,26 +27,7 @@ func SearchFilechooserbuttonFileSet() { // Let's go search func SearchButtonClicked() { - if err := fillListstore(); err != nil { - DialogMessage(mainObjects.MainWindow, "error", "Error occured during search", "\n\n"+err.Error(), "", "Ok") - } -} - -// SearchTreeviewButtonPressEvent -func SearchTreeviewButtonPressEvent(tw *gtk.TreeView, event *gdk.Event) bool { - eventButton := gdk.EventButtonNewFromEvent(event) - selection, err := tw.GetSelection() - Check(err) // Is there anything out there ? - if selection.CountSelectedRows() > 0 && err == nil { - if eventButton.Button() == 3 { - mainObjects.popUpMenu.PopupAtPointer(event) - - // return true to stop propagate event, so nothing get selected on RMB click - return true - } - } - // return false to propagate event - return false + fillListstore() } // Save results as text file @@ -53,41 +35,111 @@ func SearchButtonExportClicked() { var err error var ok bool var filename string + var tmpFilesList string - if len(mainOptions.foundFilesList) != 0 { + if len(storeFoundFiles) != 0 { filename, ok, err = gidgcr.FileChooser(mainObjects.MainWindow, "save", "", "") if ok { - err = glfs.WriteFile(filename, - []byte(strings.Join(mainOptions.foundFilesList, glsg.GetOsLineEnd()))) + for _, file := range storeFoundFiles { + tmpFilesList += file.FilePath + glsg.GetOsLineEnd() + } + err = ioutil.WriteFile(filename, []byte(tmpFilesList), os.ModePerm) } else { if len(filename) != 0 && ok { err = errors.New("Error writing file ...") } } } else { - err = errors.New("Nothing to save ...") + err = errors.New("There is nothing to export ...") } if err != nil { DialogMessage(mainObjects.MainWindow, "info", "Attention !!!", "\nYou got a problem:\n\n"+err.Error(), "", "Ok") } } +// TODO find a way to make it working ... +func timeControl(older, newer time.Time) (out bool) { + // var mess = DialogMessage(mainObjects.MainWindow, "error", "Error date selection", "\n\nDate time selection will never retrieve any file.", "", "Ok") + // var blankTime time.Time + // if newer != blankTime || older != blankTime { + // switch { + // case newer.After(older): + // mess() + // return false + // case time.Now().After(older): + // return true + // case newer.After(time.Now()): + // mess() + // return false + // } + // } else { + // return true + // } + // mess() + return true +} + +// initCalData: Init calendar +func initCalData() { + mainOptions.calDataNewerThan = gidgcr.CalendarDataNew() + mainOptions.calDataNewerThan.Init() // Set values to nul. is needed for files search + + mainOptions.calDataOlderThan = gidgcr.CalendarDataNew() + mainOptions.calDataOlderThan.Init() // Set values to nul. is needed for files search +} + // Handle SearchButtonNewerThanClicked func SearchButtonNewerThanClicked() { - displayTimeWin(mainObjects.TimeWindowNewer, "Choose date time for newer than files") - setCal(mainObjects.TimeCalendarNewer, &mainOptions.searchNewerThan, - mainObjects.TimeSpinbuttonHourNewer, - mainObjects.TimeSpinbuttonMinutsNewer, - mainObjects.TimeSpinbuttonSecondsNewer) + + if mainOptions.calDataNewerThan.ToTime() == mainOptions.calDataNewerThan.BlankTime { + mainOptions.calDataNewerThan.Init(time.Now()) + } + mainOptions.calendar.TitleWindow = "Choose newer than date time" + mainOptions.calendar.Result = mainOptions.calDataNewerThan + ok, err := mainOptions.calendar.Run() + if err != nil { + log.Fatalf("SearchButtonNewerThanClicked: %s\n", err.Error()) + } + if ok && timeControl(mainOptions.calDataOlderThan.ToTime(), mainOptions.calDataNewerThan.ToTime()) { + mainOptions.calDataNewerThan = mainOptions.calendar.Result + setCalendarbuttonLabel(mainObjects.SearchButtonNewerThan, mainOptions.calDataNewerThan) + } else { + mainOptions.calDataNewerThan.Init() + mainObjects.SearchButtonNewerThan.SetLabel(origLabelNT) + } + fmt.Println(mainOptions.calDataNewerThan.ToLayout()) +} + +// setCalendarbuttonLabel: fill label of desined button with content of CalendarData struct +func setCalendarbuttonLabel(button *gtk.Button, calData *gidgcr.CalendarData) { + button.SetLabel(fmt.Sprintf("%4d-%02d-%02d %02d:%02d:%02d", + calData.Year, + calData.Month, + calData.Day, + calData.Hour, + calData.Min, + calData.Sec)) } // Handle SearchButtonOlderThanClicked func SearchButtonOlderThanClicked() { - displayTimeWin(mainObjects.TimeWindowOlder, "Choose date time for older than files") - setCal(mainObjects.TimeCalendarOlder, &mainOptions.searchOlderThan, - mainObjects.TimeSpinbuttonHourOlder, - mainObjects.TimeSpinbuttonMinutsOlder, - mainObjects.TimeSpinbuttonSecondsOlder) + + if mainOptions.calDataOlderThan.ToTime() == mainOptions.calDataOlderThan.BlankTime { + mainOptions.calDataOlderThan.Init(time.Now()) + } + mainOptions.calendar.TitleWindow = "Choose older than date time" + mainOptions.calendar.Result = mainOptions.calDataOlderThan + ok, err := mainOptions.calendar.Run() + if err != nil { + log.Fatalf("SearchButtonOlderThanClicked: %s\n", err.Error()) + } + if ok && timeControl(mainOptions.calDataOlderThan.ToTime(), mainOptions.calDataNewerThan.ToTime()) { + setCalendarbuttonLabel(mainObjects.SearchButtonOlderThan, mainOptions.calDataOlderThan) + } else { + mainOptions.calDataOlderThan.Init() + mainObjects.SearchButtonOlderThan.SetLabel(origLabelOT) + } + fmt.Println(mainOptions.calDataOlderThan.ToLayout()) } //Switch visibility when Regex behind used @@ -125,14 +177,23 @@ func SearchButtonResetComboEntryClicked() { func SearchComboboxTextTypeChanged() { if mainOptions.UpdateOnChanges { - if err := fillListstore(); err != nil { - DialogMessage(mainObjects.MainWindow, "error", "Error occured during search", "\n\n"+err.Error(), "", "Ok") - } + fillListstore() } } -func SearchComboboxTextDateTypeChanged() { - if mainOptions.UpdateOnChanges { - doDisplay() +func ComboboxTextGenericChanged() { + doDisplay() +} + +// genericHideWindow: Signal handler delete_event (hidding window) +func genericHideWindow(w *gtk.Window) bool { + if w.GetVisible() { + w.Hide() } + return true +} + +// TopImageEventboxClicked: display Aboutbox +func TopImageEventboxClicked() { + mainOptions.About.Show() } diff --git a/popup.go b/popup.go index 95a5ac2..37c6e9e 100755 --- a/popup.go +++ b/popup.go @@ -7,81 +7,73 @@ package main import ( + "fmt" "os" "path/filepath" "strings" + "time" "github.com/gotk3/gotk3/glib" "github.com/gotk3/gotk3/gtk" + "gopkg.in/djherbis/times.v1" glfs "github.com/hfmrow/genLib/files" + glsg "github.com/hfmrow/genLib/strings" glts "github.com/hfmrow/genLib/tools" ) -// initPopup: The popup for TreeView control ... -func initPopup(tw *gtk.TreeView, ls *gtk.ListStore) *gtk.Menu { - var MenuItemNewWithImage = func(label string, icon interface{}) (menuItem *gtk.MenuItem, err error) { - box, err := gtk.BoxNew(gtk.ORIENTATION_HORIZONTAL, 1) - if err == nil { - image, err := gtk.ImageNew() - if err == nil { - setImage(image, icon, 14) - label, err := gtk.LabelNewWithMnemonic(label) - if err == nil { - menuItem, err = gtk.MenuItemNew() - if err == nil { - label.SetHAlign(gtk.ALIGN_START) - box.Add(image) - box.PackEnd(label, true, true, 8) - menuItem.Container.Add(box) - menuItem.ShowAll() - } +// initPopup: The popup for the TreeView. +func initPopup() *gtk.Menu { + popupMenu = PopupMenuIconStructNew() + + popupMenu.AddItem("_Launch/Open", launchFile, popupMenu.OPT_ICON|popupMenu.OPT_NORMAL, play20) + popupMenu.AddItem("_Web browser", openInBrowser, popupMenu.OPT_ICON|popupMenu.OPT_NORMAL, globalNetwork20) + popupMenu.AddItem("Open _directory", openDir, popupMenu.OPT_ICON|popupMenu.OPT_NORMAL, folder48) + popupMenu.AddItem("_Copy to clipboard", toClipboard, popupMenu.OPT_ICON|popupMenu.OPT_NORMAL, copyDocument20) + popupMenu.AddItem("", nil, popupMenu.OPT_SEPARATOR) + popupMenu.AddItem("Time to _Newer than", func() { toCalendar(false) }, popupMenu.OPT_ICON|popupMenu.OPT_NORMAL, calendarPers48) + popupMenu.AddItem("Time to _Older than", func() { toCalendar(true) }, popupMenu.OPT_ICON|popupMenu.OPT_NORMAL, calendarPers48) + popupMenu.AddItem("", nil, popupMenu.OPT_SEPARATOR) + popupMenu.AddItem("_Delete", deleteEntry, popupMenu.OPT_ICON|popupMenu.OPT_NORMAL, stop48) + return popupMenu.MenuBuild() +} + +// toCalendar: default, set to newer than otherwise, set to older than +func toCalendar(toOlder bool) { + var err error + var selected [][]string + if selected, err = tvs.GetSelectedRows(); err == nil { + for _, entry := range storeFoundFiles { + if entry.FilePath == filepath.Join(selected[0][4], selected[0][0]) { + var timeInfo time.Time + infos := times.Get(entry.FileInfo) + switch mainObjects.SearchComboboxTextDateType.GetActive() { + case 0, 2: + timeInfo = infos.AccessTime() + case 1, 3: + timeInfo = infos.ModTime() } - } - } - return menuItem, err - } - /* Make menu */ - menu, err := gtk.MenuNew() - Check(err) - var menuItem, menuItem1, menuItem2, menuItem3, menuItem4 *gtk.MenuItem - var separatorMenuItem *gtk.SeparatorMenuItem - if menuItem, err = MenuItemNewWithImage("_Launch/Open", play20); err == nil { - if menuItem1, err = MenuItemNewWithImage("_Web browser", globalNetwork20); err == nil { - if menuItem2, err = MenuItemNewWithImage("_Open directory", folderOpen20); err == nil { - if menuItem3, err = MenuItemNewWithImage("_Copy path", copyDocument20); err == nil { - if separatorMenuItem, err = gtk.SeparatorMenuItemNew(); err == nil { - menuItem4, err = MenuItemNewWithImage("_Delete", signError20) - } + if mainObjects.SearchComboboxTextDateZone.GetActive() == 0 { + timeInfo = timeInfo.UTC() + } + if !toOlder { + mainOptions.calDataNewerThan.FromTime(timeInfo) + setCalendarbuttonLabel(mainObjects.SearchButtonNewerThan, mainOptions.calDataNewerThan) + } else { + mainOptions.calDataOlderThan.FromTime(timeInfo) + setCalendarbuttonLabel(mainObjects.SearchButtonOlderThan, mainOptions.calDataOlderThan) } } } } - Check(err) - - menuItem.Connect("activate", func() { launchFile() }) - menuItem1.Connect("activate", func() { go openInBrowser() }) - menuItem2.Connect("activate", func() { openDir() }) - menuItem3.Connect("activate", func() { toClipboard() }) - menuItem4.Connect("activate", func() { deleteEntry() }) - /* Add options items to menu */ - menu.Append(menuItem) - menu.Append(menuItem1) - menu.Append(menuItem2) - menu.Append(menuItem3) - menu.Append(separatorMenuItem) - menu.Append(menuItem4) - /* Show menu */ - menu.ShowAll() - return menu } -// Copy path to clipboard +// toClipboard: Copy path(s) to clipboard func toClipboard() { var err error var selected [][]string var tmpFileNames string - if selected, err = getSelectedAsString(); err == nil { + if selected, err = tvs.GetSelectedRows(); err == nil { for _, row := range selected { tmpFileNames += filepath.Join(row[4], row[0]) + "\n" } @@ -90,89 +82,112 @@ func toClipboard() { "You got a problem with some selected row(s)\n\n"+err.Error()+"\n", "", "Ok") } - - clipboard.SetText(tmpFileNames) + clipboard.SetText(strings.Trim(tmpFileNames, glsg.GetTextEOL([]byte(tmpFileNames)))) clipboard.Store() } -// getSelectedAsString: Retrieve values of ll selected rows -func getSelectedAsString() (outSlice [][]string, err error) { - var iters []*gtk.TreeIter - if iters, err = tvs.GetSelectedIters(); err == nil { - outSlice, err = tvs.GetSelectedRows(iters...) - } - if len(outSlice) == 0 { - return outSlice, errNoSelection - } - return -} - -// Open in browser +// openInBrowser: func openInBrowser() { - var err error - var result []byte - var selected [][]string - if selected, err = getSelectedAsString(); err == nil { - _, _ = glib.IdleAdd(func() { // idle run to permit gtk3 working right during goroutine - result, err = glts.ExecCommand(mainOptions.AppLauncher, - mainOptions.WebSearchEngine+glfs.BaseNoExt(filepath.Base(selected[0][0]))) - if err != nil && err != errNoSelection { // don't warn on "unselected row" case. - DialogMessage(mainObjects.MainWindow, "info", "Information !", - "You got a problem with:\n"+filepath.Join(selected[0][4], selected[0][0])+ - "\n\n"+err.Error()+"\n\nTerminal output:\n"+string(result), "", "Ok") - } - }) - } + + var ( + selected [][]string + err error + filename string + ) + + if selected, err = tvs.GetSelectedRows(); err == nil { + filename = mainOptions.WebSearchEngine + glfs.BaseNoExt(filepath.Base(selected[0][0])) + open(filename) + } /* else { + + }*/ + + // var err error + // var result []byte + // var selected [][]string + // if selected, err = tvs.GetSelectedRows(); err == nil { + // // Using Goroutine to freeing current thread and make it independent. + // go glib.IdleAdd(func() { // IdleAdd run to permit gtk3 working right during goroutine + // openresult, err = glts.ExecCommand(mainOptions.AppLauncher, + // mainOptions.WebSearchEngine+glfs.BaseNoExt(filepath.Base(selected[0][0]))) + // }) + // } } -// Run filename +// launchFile: func launchFile() { - var selected [][]string - var err error - var filename string - if selected, err = getSelectedAsString(); err == nil { - glib.IdleAdd(func() { // idle run to permit gtk3 working right during goroutine - filename = filepath.Join(selected[0][4], selected[0][0]) - go glts.ExecCommand(mainOptions.AppLauncher, filename) - }) - } + + var ( + selected [][]string + err error + filename string + ) + + if selected, err = tvs.GetSelectedRows(); err == nil { + filename = filepath.Join(selected[0][4], selected[0][0]) + open(filename) + } /* else { + + }*/ } -// Open directory filename +// openDir: func openDir() { - var selected [][]string - var err error - var filename string - if selected, err = getSelectedAsString(); err == nil { - glib.IdleAdd(func() { // idle run to permit gtk3 working right during goroutine - filename = filepath.Join(selected[0][4], selected[0][0]) - go glts.ExecCommand(mainOptions.AppLauncher, filepath.Dir(filename)) - }) + + var ( + selected [][]string + err error + filename string + ) + + if selected, err = tvs.GetSelectedRows(); err == nil { + filename = filepath.Join(selected[0][4], selected[0][0]) + open(filepath.Dir(filename)) + } /* else { + + }*/ +} + +// open: show file or dir depending on "path". +func open(path string) { + + var goFunc = func() { + if outTerm, err := glts.ExecCommand([]string{mainOptions.AppLauncher, path}); err != nil { + + // Error is handled by "xdg-open" command + + fmt.Println(err, outTerm) + } } + // IdleAdd to permit gtk3 working right during goroutine + glib.IdleAdd(func() { + // Using goroutine to permit the usage of another + // thread and freeing the current one. + go goFunc() + }) } -// deleteEntry +// deleteEntry: func deleteEntry() { var err error - var selected [][]string var tmpFileNames string var iters []*gtk.TreeIter - if iters, err = tvs.GetSelectedIters(); err == nil { - if selected, err = tvs.GetSelectedRows(iters...); err == nil { - for _, row := range selected { - tmpFileNames += filepath.Join(row[4], row[0]) + "\n" - } - if DialogMessage(mainObjects.MainWindow, "info", "Information !", - "\nAre you sure, you want to delete file(s):\n\n"+strings.Trim(tmpFileNames, "\n"), - "", sts["yes"], sts["no"]) == 0 { - - for idx, row := range selected { - if err = os.Remove(filepath.Join(row[4], row[0])); err == nil { - err = tvs.RemoveSelectedRows(iters[idx]) - } - if err != nil { - break - } + // Iters needed to be able to remove selected rows + if iters = tvs.GetSelectedIters(); len(iters) > 0 { + for _, iter := range iters { + tmpFileNames += tvs.GetColValue(iter, 0).(string) + "\n" // Get filename + } + if DialogMessage(mainObjects.MainWindow, "info", "Information !", + fmt.Sprintf("\nAre you sure, want you to delete %d file(s):\n\n", len(iters))+strings.Trim(tmpFileNames, "\n"), + "", sts["yes"], sts["no"]) == 0 { + + for _, iter := range iters { + if err = os.RemoveAll( + // Get Full path + filepath.Join(tvs.GetColValue(iter, 4).(string), + tvs.GetColValue(iter, 0).(string))); err == nil || os.IsNotExist(err) { + // do it one by one in case of error, process will be stopped. + tvs.RemoveSelectedRows(iter) } } } diff --git a/SearchEngine.proj b/search-engine.proj similarity index 56% rename from SearchEngine.proj rename to search-engine.proj index 8f26361..b31f969 100644 --- a/SearchEngine.proj +++ b/search-engine.proj @@ -1,22 +1,35 @@ { - "GOHVersion": "v1.3.8", - "AppName": "SearchEngine", + "FileSign": [ + "Gotk3 Objects Handler", + "v1.6.8", + "©2018-20", + "H.F.M", + "github.com/hfmrow/gotk3-obj-handler", + "License (MIT Restricted)" + ], + "AppName": "Search Engine", "AppCreator": "H.F.M", - "AppVers": "v1.8.5", + "AppVers": "v1.9", + "AppDescr": "", "License": "", "LicenseShort": "", "LicenseAbr": "MIT", - "YearCreate": "2018-19", + "YearCreate": "2018-21", + "Repository": "github.com/hfmrow/search-engine", "ManualAdd": "/*MANUAL*/", "DefaultSignal": "notify", "PackageName": "main", "MainWindowName": "MainWindow", + "GtkApplicationName": "app", + "GtkApplicationId": "id.application.name", "ObjStructName": "mainObjects", "OptStructName": "mainOptions", "Gotk3Path": "github.com/gotk3/gotk3", - "GladeXmlFile": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/glade/main.glade", + "GtkSourcePath": "\"github.com/hfmrow/gotk3_gtksource/source\"", + "GladeXmlFile": "", "GladeXmlFileRel": "assets/glade/main.glade", - "GladeXmlFileCheckSum": "cb367bd0f943a2946eb76f34712a208f", + "GladeXmlFileCheckSum": "042d43f717cbc3189659a4e8a55bf07a", + "DefaultProjExt": "*.proj", "BackupExt": [ "*.go", "*.lang", @@ -28,19 +41,17 @@ "FirstCharLower": true, "ScanSubDir": true, "BinData": true, - "Directory": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images", - "ExtInName": [ - "" - ], + "Directory": "assets/images", + "ExtInName": null, "ScanExt": [ - ".png" + "*.png" ] }, "OutFiles": { "Custom": "gohCustom.go", "License": "LICENSE", - "OutProjectFilename": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/SearchEngine.proj", - "OutProjectPath": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/", + "OutProjectFilename": "search-engine.proj", + "OutProjectPath": "github.com/hfmrow/search-engine", "Main": "main.go", "Signals": "gohSignals.go", "StartGtk": "gohStartGtk.go", @@ -53,7 +64,6 @@ }, "MainGladeVarNameMinimal": "mainGlade", "FlagsBuild": { - "BuildAll": false, "SortObjNames": true, "SkipEmptyName": true, "SkipLowercaseNames": true, @@ -61,11 +71,19 @@ "CleanCode": false, "AutoSwitchToEmbedded": false, "MinimalBuild": false, + "ApplicationBuild": false, "CheckIsGotk3ObjAvailable": true, "WarnMissingFuncDecl": true, - "WarnMissingObjDecl": false, + "WarnMissingObjDecl": true, + "AddLicToMainFile": true, + "NamingCSS": false, + "NamingCSSLowerCase": false, + "NamingCSSForce": false, + "NamingCSSClear": false, "ChooseGotk3Dir": false, - "Assets": false, + "GtkSourceUsed": false, + "UseGolangEmbed": true, + "AssetsManualSelection": true, "Main": false, "Objects": false, "Options": false, @@ -75,13 +93,14 @@ "Images": false, "License": false }, - "ObjectsCount": 50, + "ObjectsCount": 35, "ObjectsAdded": 0, "ObjectsRemoved": 0, "ActualObjects": [ { "ObjectType": "GtkImage", "ObjectName": "ImageTop", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -93,6 +112,7 @@ { "ObjectType": "GtkWindow", "ObjectName": "MainWindow", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -104,6 +124,7 @@ { "ObjectType": "GtkButton", "ObjectName": "SearchButton", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -115,6 +136,7 @@ { "ObjectType": "GtkButton", "ObjectName": "SearchButtonExit", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -126,6 +148,7 @@ { "ObjectType": "GtkButton", "ObjectName": "SearchButtonExport", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -137,6 +160,7 @@ { "ObjectType": "GtkButton", "ObjectName": "SearchButtonNewerThan", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -148,6 +172,7 @@ { "ObjectType": "GtkButton", "ObjectName": "SearchButtonOlderThan", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -159,6 +184,7 @@ { "ObjectType": "GtkButton", "ObjectName": "SearchButtonResetComboEntry", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -170,6 +196,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonCaseSensitive", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -181,6 +208,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonCharClasses", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -192,6 +220,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonCharClassesStrictMode", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -203,6 +232,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonFollowSL", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -214,6 +244,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonRegex", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -225,6 +256,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonSplitedAnd", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -236,6 +268,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonSplitedNot", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -247,6 +280,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonSplitedOr", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -258,6 +292,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonWildCard", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -269,6 +304,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonWordAnd", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -280,6 +316,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonWordNot", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -291,6 +328,7 @@ { "ObjectType": "GtkCheckButton", "ObjectName": "SearchCheckbuttonWordOr", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -302,6 +340,7 @@ { "ObjectType": "GtkComboBoxText", "ObjectName": "SearchComboboxTextAnd", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -313,6 +352,19 @@ { "ObjectType": "GtkComboBoxText", "ObjectName": "SearchComboboxTextDateType", + "LibPrefix": "gtk", + "Suffix": "", + "Prefix": "", + "Value": "", + "Commented": "", + "ManualyAdded": false, + "Unkowen": false, + "NewObject": false + }, + { + "ObjectType": "GtkComboBoxText", + "ObjectName": "SearchComboboxTextDateZone", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -324,6 +376,7 @@ { "ObjectType": "GtkEntry", "ObjectName": "SearchComboboxTextEntryAnd", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -335,6 +388,7 @@ { "ObjectType": "GtkEntry", "ObjectName": "SearchComboboxTextEntryNot", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -346,6 +400,7 @@ { "ObjectType": "GtkEntry", "ObjectName": "SearchComboboxTextEntryOr", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -357,6 +412,7 @@ { "ObjectType": "GtkComboBoxText", "ObjectName": "SearchComboboxTextNot", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -368,6 +424,7 @@ { "ObjectType": "GtkComboBoxText", "ObjectName": "SearchComboboxTextOr", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -379,6 +436,7 @@ { "ObjectType": "GtkComboBoxText", "ObjectName": "SearchComboboxTextType", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -390,6 +448,7 @@ { "ObjectType": "GtkFileChooserButton", "ObjectName": "SearchFilechooserbutton", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -401,6 +460,7 @@ { "ObjectType": "GtkSpinButton", "ObjectName": "SearchSpinbuttonDepth", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -412,6 +472,7 @@ { "ObjectType": "GtkTreeView", "ObjectName": "SearchTreeview", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -423,6 +484,7 @@ { "ObjectType": "GtkTreeSelection", "ObjectName": "SearchTreeviewSelection", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -434,182 +496,7 @@ { "ObjectType": "GtkStatusbar", "ObjectName": "Statusbar", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkButton", - "ObjectName": "TimeButtonOkNewer", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkButton", - "ObjectName": "TimeButtonOkOlder", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkButton", - "ObjectName": "TimeButtonResetNewer", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkButton", - "ObjectName": "TimeButtonResetOlder", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkCalendar", - "ObjectName": "TimeCalendarNewer", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkCalendar", - "ObjectName": "TimeCalendarOlder", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkImage", - "ObjectName": "TimeImageTopNewer", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkImage", - "ObjectName": "TimeImageTopOlder", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkSpinButton", - "ObjectName": "TimeSpinbuttonHourNewer", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkSpinButton", - "ObjectName": "TimeSpinbuttonHourOlder", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkSpinButton", - "ObjectName": "TimeSpinbuttonMinutsNewer", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkSpinButton", - "ObjectName": "TimeSpinbuttonMinutsOlder", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkSpinButton", - "ObjectName": "TimeSpinbuttonSecondsNewer", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkSpinButton", - "ObjectName": "TimeSpinbuttonSecondsOlder", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkWindow", - "ObjectName": "TimeWindowNewer", - "Suffix": "", - "Prefix": "", - "Value": "", - "Commented": "", - "ManualyAdded": false, - "Unkowen": false, - "NewObject": false - }, - { - "ObjectType": "GtkWindow", - "ObjectName": "TimeWindowOlder", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -621,6 +508,7 @@ { "ObjectType": "GtkEventBox", "ObjectName": "TopImageEventbox", + "LibPrefix": "gtk", "Suffix": "", "Prefix": "", "Value": "", @@ -635,157 +523,157 @@ "VarFilesRemoved": 0, "VarFilesList": [ { - "VarName": "calendar18", - "FilenameRel": "assets/images/calendar-18.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/calendar-18.png", - "LineNb": -1, - "Suffix": "", - "Prefix": "", - "MainGladeVarNameMinimal": "" - }, - { - "VarName": "calendar48", - "FilenameRel": "assets/images/calendar-48.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/calendar-48.png", - "LineNb": -1, + "RelRoot": "assets/glade", + "VarName": "mainGlade", + "FilenameRel": "assets/glade/main.glade", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "cancel18x18", - "FilenameRel": "assets/images/cancel-18x18.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/cancel-18x18.png", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "calendarPers48", + "FilenameRel": "assets/images/calendar-pers-48.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "checked18x18", - "FilenameRel": "assets/images/checked-18x18.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/checked-18x18.png", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "clearHist48", + "FilenameRel": "assets/images/clear-hist-48.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { + "RelRoot": "assets/images", "VarName": "copyDocument20", "FilenameRel": "assets/images/Copy-document-20.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/Copy-document-20.png", - "LineNb": -1, "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "find18", - "FilenameRel": "assets/images/find-18.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/find-18.png", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "crossIcon48", + "FilenameRel": "assets/images/Cross-icon-48.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { + "RelRoot": "assets/images", "VarName": "find48", "FilenameRel": "assets/images/find-48.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/find-48.png", - "LineNb": -1, "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "folderOpen20", - "FilenameRel": "assets/images/folder-open-20.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/folder-open-20.png", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "floppySave48", + "FilenameRel": "assets/images/floppy-save-48.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "globalNetwork20", - "FilenameRel": "assets/images/Global-Network-20.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/Global-Network-20.png", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "folder48", + "FilenameRel": "assets/images/folder-48.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "mainGlade", - "FilenameRel": "assets/glade/main.glade", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/glade/main.glade", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "globalNetwork20", + "FilenameRel": "assets/images/Global-Network-20.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "open18", - "FilenameRel": "assets/images/open-18.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/open-18.png", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "logout48", + "FilenameRel": "assets/images/logout-48.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { + "RelRoot": "assets/images", "VarName": "play20", "FilenameRel": "assets/images/Play-20.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/Play-20.png", - "LineNb": -1, "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 + }, + { + "RelRoot": "assets/images", + "VarName": "reset48", + "FilenameRel": "assets/images/reset-48.png", + "Suffix": "", + "Prefix": "", + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "reset18x18", - "FilenameRel": "assets/images/reset-18x18.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/reset-18x18.png", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "searchEngineTop370x32", + "FilenameRel": "assets/images/search-engine-top-370x32.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "saveAll18", - "FilenameRel": "assets/images/save-all-18.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/save-all-18.png", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "searchEngineTop550x48", + "FilenameRel": "assets/images/search-engine-top-550x48.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "searchEngine400x27", - "FilenameRel": "assets/images/Search-Engine-400x27.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/Search-Engine-400x27.png", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "searchFolder48", + "FilenameRel": "assets/images/search-folder-48.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "searchEngine700x48", - "FilenameRel": "assets/images/Search-Engine-700x48.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/Search-Engine-700x48.png", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "stop48", + "FilenameRel": "assets/images/Stop-48.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 }, { - "VarName": "signError20", - "FilenameRel": "assets/images/Sign-Error-20.png", - "FilenameAbs": "/media/syndicate/storage/Documents/dev/go/src/github.com/hfmrow/searchEngine/assets/images/Sign-Error-20.png", - "LineNb": -1, + "RelRoot": "assets/images", + "VarName": "tickIcon48", + "FilenameRel": "assets/images/Tick-icon-48.png", "Suffix": "", "Prefix": "", - "MainGladeVarNameMinimal": "" + "MainGladeVarNameMinimal": "", + "LineNb": -1 } ] } \ No newline at end of file diff --git a/searchFunc.go b/searchFunc.go index 8cd3c63..89900d8 100644 --- a/searchFunc.go +++ b/searchFunc.go @@ -14,16 +14,16 @@ import ( "github.com/dustin/go-humanize" "github.com/gotk3/gotk3/gtk" + "gopkg.in/djherbis/times.v1" glfsff "github.com/hfmrow/genLib/files/findFiles" glss "github.com/hfmrow/genLib/slices" gltsbh "github.com/hfmrow/genLib/tools/bench" - - "gopkg.in/djherbis/times.v1" ) -/* Scan files and display it */ -func fillListstore() (err error) { +// fillListstore: Scan files and display it +func fillListstore() { + var err error var fileInfo os.FileInfo find := glfsff.SearchNew() timer = gltsbh.BenchNew(false) @@ -37,9 +37,10 @@ func fillListstore() (err error) { if fileInfo.IsDir() && find.Ready { timer.Lapse("Searching") - if mainOptions.foundFilesList, err = find.FindDepth(mainOptions.LastDirectory, - mainOptions.Depth, false, mainObjects.SearchCheckbuttonFollowSL.GetActive()); err != nil { - return err + if storeFoundFiles, err = find.FindDepth(mainOptions.LastDirectory, + mainOptions.Depth, true, mainObjects.SearchCheckbuttonFollowSL.GetActive()); err != nil { + DialogMessage(mainObjects.MainWindow, "error", "Error occured during search", "\n\n"+err.Error(), "", sts["ok"]) + return } timer.Lapse("Display") /* Show results */ @@ -53,15 +54,17 @@ func fillListstore() (err error) { } } } - return err + if err != nil { + DialogMessage(mainObjects.MainWindow, "error", "Error occured during search", "\n\n"+err.Error(), "", "Ok") + } } -// Get text from gtk.comboBoxTextEntry object +// getEntryText: func getEntryText(cbxEntry *gtk.ComboBoxText) string { return cbxEntry.GetActiveText() } -/* Fill / Clean comboBoxText */ +// fillComboboxText: Fill / Clean comboBoxText func fillComboboxText(cbxt *gtk.ComboBoxText, text string, removAll ...bool) { if len(removAll) == 0 { cbxt.PrependText(text) @@ -70,7 +73,7 @@ func fillComboboxText(cbxt *gtk.ComboBoxText, text string, removAll ...bool) { } } -/* Fill All comboBoxText */ +// fillAllComboboxText: func fillAllComboboxText(removAll ...bool) { if len(removAll) != 0 { fillComboboxText(mainObjects.SearchComboboxTextAnd, "", removAll[0]) @@ -96,7 +99,7 @@ func fillAllComboboxText(removAll ...bool) { } } -/* Build words to fit search structure */ +// makeWords: Build words to fit search structure func makeWords(find *glfsff.Search, line string, wWord, op string) { words := strings.Split(line, " ") for _, word := range words { @@ -104,71 +107,80 @@ func makeWords(find *glfsff.Search, line string, wWord, op string) { } } -/* search job */ +// doDisplay: display found files func doDisplay() { - var err error - var dispTime, extDir string - var stats os.FileInfo - var mTime, aTime time.Time - // var isText bool + + var ( + dispTime, + extDir string + timeUnix int64 + mTime, + aTime time.Time + ) tvs.StoreDetach() + defer tvs.StoreAttach() tvs.ListStore.Clear() /* Store and display found files */ - if len(mainOptions.foundFilesList) != 0 { - for _, file := range mainOptions.foundFilesList { + if len(storeFoundFiles) != 0 { + for _, file := range storeFoundFiles { extDir = "" - if stats, err = os.Lstat(file); err == nil && !os.IsNotExist(err) { - switch { - case stats.IsDir(): - extDir = "Dir" - case stats.Mode()&os.ModeSymlink != 0: - extDir = "Link" - default: - // if isText, _, err = g.IsTextFileSimple(file, -1, 0.6, 97); err == nil && isText { - // extDir = filepath.Ext(file) + "/txt" - // } else { - if ext := filepath.Ext(file); len(ext) > 1 { - extDir = ext[1:] - } - // } + switch { + case file.FileInfo.IsDir(): + extDir = "Dir" + case file.FileInfo.Mode()&os.ModeSymlink != 0: + extDir = "Link" + default: + if ext := filepath.Ext(file.FileInfo.Name()); len(ext) > 1 { + extDir = ext[1:] } - - mTime = times.Get(stats).ModTime() - aTime = times.Get(stats).AccessTime() - switch mainObjects.SearchComboboxTextDateType.GetActive() { - case 0: - dispTime = aTime.String()[:16] - case 1: - dispTime = mTime.String()[:16] - case 2: - dispTime = humanize.Time(aTime) - case 3: - dispTime = humanize.Time(mTime) - } - tvs.AddRow(nil, tvs.ColValuesStringSliceToIfaceSlice( - filepath.Base(file), - humanize.Bytes(uint64(stats.Size())), - // fmt.Sprintf("%d", stats.Size()), - extDir, - dispTime, - filepath.Dir(file))) } + if mainObjects.SearchComboboxTextDateZone.GetActive() == 0 { + mTime = times.Get(file.FileInfo).ModTime().UTC() + aTime = times.Get(file.FileInfo).AccessTime().UTC() + } else { + mTime = times.Get(file.FileInfo).ModTime().Local() + aTime = times.Get(file.FileInfo).AccessTime().Local() + } + switch mainObjects.SearchComboboxTextDateType.GetActive() { + case 0: + dispTime = aTime.String()[:16] + timeUnix = aTime.Unix() + case 1: + dispTime = mTime.String()[:16] + timeUnix = mTime.Unix() + case 2: + dispTime = humanize.Time(aTime) + timeUnix = aTime.Unix() + case 3: + dispTime = humanize.Time(mTime) + timeUnix = mTime.Unix() + } + tvs.AddRow(nil, + file.FileInfo.Name(), + humanize.Bytes(uint64(file.FileInfo.Size())), + extDir, + dispTime, + filepath.Dir(file.FilePath), + file.FileInfo.Size(), // invisible + timeUnix) // invisible } } - tvs.StoreAttach() - } -/* Get entry from controls */ +// computeEntry: Get entry from controls func computeEntry(find *glfsff.Search) bool { - var wWordAnd, wWordOr, wWordNot, entryAnd, entryOr, entryNot string + var ( + wWordAnd, + wWordOr, + wWordNot string - entryAnd = getEntryText(mainObjects.SearchComboboxTextAnd) - entryOr = getEntryText(mainObjects.SearchComboboxTextOr) - entryNot = getEntryText(mainObjects.SearchComboboxTextNot) + entryAnd = getEntryText(mainObjects.SearchComboboxTextAnd) + entryOr = getEntryText(mainObjects.SearchComboboxTextOr) + entryNot = getEntryText(mainObjects.SearchComboboxTextNot) + ) /* Check if there is some entry */ if len(entryAnd+entryOr+entryNot) == 0 { @@ -222,7 +234,7 @@ func computeEntry(find *glfsff.Search) bool { return true } -/* Get datas from controls */ +// computeOptions: Get options from controls func computeOptions(find *glfsff.Search) { mainOptions.LastDirectory = mainObjects.SearchFilechooserbutton.GetFilename() @@ -249,24 +261,12 @@ func computeOptions(find *glfsff.Search) { find.POSIXcharClass = mainObjects.SearchCheckbuttonCharClasses.GetActive() find.POSIXstrictMode = mainObjects.SearchCheckbuttonCharClassesStrictMode.GetActive() - if mainOptions.searchNewerThan.Ready { - find.SearchTime.SetNewerThan(mainOptions.searchNewerThan.Ready, - int(mainOptions.searchNewerThan.d), - int(mainOptions.searchNewerThan.m), - int(mainOptions.searchNewerThan.y), - int(mainOptions.searchNewerThan.H), - int(mainOptions.searchNewerThan.M), - int(mainOptions.searchNewerThan.S)) - } - - if mainOptions.searchOlderThan.Ready { - find.SearchTime.SetOlderThan(mainOptions.searchOlderThan.Ready, - int(mainOptions.searchOlderThan.d), - int(mainOptions.searchOlderThan.m), - int(mainOptions.searchOlderThan.y), - int(mainOptions.searchOlderThan.H), - int(mainOptions.searchOlderThan.M), - int(mainOptions.searchOlderThan.S)) + // send date/time to search options corresponding to current choosen zone. + if mainObjects.SearchComboboxTextDateZone.GetActive() == 1 { + find.SearchTime.SetNewerThan(mainOptions.calDataNewerThan.ToTimeAsUTC()) + find.SearchTime.SetOlderThan(mainOptions.calDataOlderThan.ToTimeAsUTC()) + } else { + find.SearchTime.SetNewerThan(mainOptions.calDataNewerThan.ToTime()) + find.SearchTime.SetOlderThan(mainOptions.calDataOlderThan.ToTime()) } - } diff --git a/timeWindow.go b/timeWindow.go deleted file mode 100755 index fb7fb9e..0000000 --- a/timeWindow.go +++ /dev/null @@ -1,143 +0,0 @@ -// timeWindow.go - -/* - ©2019 H.F.M. MIT license -*/ - -package main - -import ( - "strings" - "time" - - "github.com/gotk3/gotk3/gtk" -) - -/************************/ -/* Handling TIME window */ -/************************/ -// TimeButtonOkNewerClicked -func TimeButtonOkNewerClicked() { - getCal(mainObjects.TimeCalendarNewer, &mainOptions.searchNewerThan, - mainObjects.TimeSpinbuttonHourNewer, - mainObjects.TimeSpinbuttonMinutsNewer, - mainObjects.TimeSpinbuttonSecondsNewer) - mainOptions.searchNewerThan.Ready = true - genericHideWindow(mainObjects.TimeWindowNewer) - /* Display dateTime */ - dateTime := strings.Split(time.Date(int(mainOptions.searchNewerThan.y), - time.Month(mainOptions.searchNewerThan.m), - int(mainOptions.searchNewerThan.d), - int(mainOptions.searchNewerThan.H), - int(mainOptions.searchNewerThan.M), - int(mainOptions.searchNewerThan.S), - 0, time.Local).String(), " ")[:2] - // markupLabel(mainObjects.SearchLabelNewerThan, " "+strings.Join(dateTime, " ")+" ") - // origLabelNT, _ = mainObjects.SearchButtonNewerThan.GetLabel() - mainObjects.SearchButtonNewerThan.SetLabel(" " + strings.Join(dateTime, " ") + " ") -} - -// TimeButtonOkOlderClicked -func TimeButtonOkOlderClicked() { - getCal(mainObjects.TimeCalendarOlder, &mainOptions.searchOlderThan, - mainObjects.TimeSpinbuttonHourOlder, - mainObjects.TimeSpinbuttonMinutsOlder, - mainObjects.TimeSpinbuttonSecondsOlder) - mainOptions.searchOlderThan.Ready = true - genericHideWindow(mainObjects.TimeWindowOlder) - /* Display dateTime */ - dateTime := strings.Split(time.Date(int(mainOptions.searchOlderThan.y), - time.Month(mainOptions.searchOlderThan.m), - int(mainOptions.searchOlderThan.d), - int(mainOptions.searchOlderThan.H), - int(mainOptions.searchOlderThan.M), - int(mainOptions.searchOlderThan.S), - 0, time.Local).String(), " ")[:2] - // markupLabel(mainObjects.SearchLabelOlderThan, " "+strings.Join(dateTime, " ")+" ") - // origLabelOT, _ = mainObjects.SearchButtonOlderThan.GetLabel() - mainObjects.SearchButtonOlderThan.SetLabel(" " + strings.Join(dateTime, " ") + " ") - -} - -// TimeButtonResetNewerClicked -func TimeButtonResetNewerClicked() { - mainOptions.searchNewerThan.Ready = false - mainObjects.SearchButtonNewerThan.SetLabel(origLabelNT) - genericHideWindow(mainObjects.TimeWindowNewer) -} - -// TimeButtonResetOlderClicked -func TimeButtonResetOlderClicked() { - mainOptions.searchOlderThan.Ready = false - mainObjects.SearchButtonOlderThan.SetLabel(origLabelOT) - genericHideWindow(mainObjects.TimeWindowOlder) -} - -// Get datetime values -func getCal(cal *gtk.Calendar, sdt *searchTimeCal, spinH, spinM, spinS *gtk.SpinButton) { - sdt.y, sdt.m, sdt.d = cal.GetDate() - sdt.H = spinH.GetValue() - sdt.M = spinM.GetValue() - sdt.S = spinS.GetValue() - sdt.m++ -} - -// Set datetime values -func setCal(cal *gtk.Calendar, sdt *searchTimeCal, spinH, spinM, spinS *gtk.SpinButton) { - var err error - - /* Set datetime default values */ - Now := time.Now() - y := uint(Now.Year()) - m := uint(Now.Month()) - d := uint(Now.Day()) - H := float64(Now.Hour()) - M := float64(Now.Minute()) - S := float64(Now.Second()) - /* Set values from last selection if exist */ - if sdt.Ready { - y = sdt.y - m = sdt.m - d = sdt.d - H = sdt.H - M = sdt.M - S = sdt.S - } - /* Set control values */ - if err = cal.SetProperty("day", d); err == nil { - if err = cal.SetProperty("month", m-1); err == nil { - if err = cal.SetProperty("year", y); err == nil { - spinH.SetValue(H) - spinM.SetValue(M) - spinS.SetValue(S) - } - } - } - if err != nil { - DialogMessage(mainObjects.MainWindow, "error", "Error occured during calendar setup", "\n\n"+err.Error(), "", "Ok") - } -} - -// Display Calendar window -func displayTimeWin(window *gtk.Window, title string) { - window.SetTitle(title) - window.SetSkipTaskbarHint(true) - window.SetKeepAbove(true) - window.SetSizeRequest(400, 10) - window.SetResizable(false) - window.SetModal(true) - window.Connect("delete_event", genericHideWindow) - window.ShowAll() -} - -// Signal handler delete_event (hidding window) -func genericHideWindow(w *gtk.Window) bool { - if w.GetVisible() { - w.Hide() - } - return true -} - -func TopImageEventboxClicked() { - mainOptions.AboutOptions.Show() /* Init Aboutbox */ -} diff --git a/translate.go b/translate.go index db17945..71df1d6 100644 --- a/translate.go +++ b/translate.go @@ -1,6 +1,6 @@ // translate.go -// File generated on Thu, 03 Oct 2019 01:29:58 using Gotk3ObjectsTranslate v1.3 2019 H.F.M +// File generated on Thu, 03 Dec 2020 02:45:20 using Gotk3 Objects Translate v1.5 2019-20 H.F.M /* * This program comes with absolutely no warranty. @@ -15,7 +15,6 @@ import ( "encoding/json" "fmt" "io/ioutil" - "os" "strings" "github.com/gotk3/gotk3/gtk" @@ -44,6 +43,7 @@ func (trans *MainTranslate) initGtkObjectsText() { trans.setTextToGtkObjects(&mainObjects.SearchCheckbuttonWordOr.Widget, "SearchCheckbuttonWordOr") trans.setTextToGtkObjects(&mainObjects.SearchComboboxTextAnd.Widget, "SearchComboboxTextAnd") trans.setTextToGtkObjects(&mainObjects.SearchComboboxTextDateType.Widget, "SearchComboboxTextDateType") + trans.setTextToGtkObjects(&mainObjects.SearchComboboxTextDateZone.Widget, "SearchComboboxTextDateZone") trans.setTextToGtkObjects(&mainObjects.SearchComboboxTextEntryAnd.Widget, "SearchComboboxTextEntryAnd") trans.setTextToGtkObjects(&mainObjects.SearchComboboxTextEntryNot.Widget, "SearchComboboxTextEntryNot") trans.setTextToGtkObjects(&mainObjects.SearchComboboxTextEntryOr.Widget, "SearchComboboxTextEntryOr") @@ -53,18 +53,7 @@ func (trans *MainTranslate) initGtkObjectsText() { trans.setTextToGtkObjects(&mainObjects.SearchFilechooserbutton.Widget, "SearchFilechooserbutton") trans.setTextToGtkObjects(&mainObjects.SearchSpinbuttonDepth.Widget, "SearchSpinbuttonDepth") trans.setTextToGtkObjects(&mainObjects.SearchTreeview.Widget, "SearchTreeview") - trans.setTextToGtkObjects(&mainObjects.TimeButtonOkNewer.Widget, "TimeButtonOkNewer") - trans.setTextToGtkObjects(&mainObjects.TimeButtonOkOlder.Widget, "TimeButtonOkOlder") - trans.setTextToGtkObjects(&mainObjects.TimeButtonResetNewer.Widget, "TimeButtonResetNewer") - trans.setTextToGtkObjects(&mainObjects.TimeButtonResetOlder.Widget, "TimeButtonResetOlder") - trans.setTextToGtkObjects(&mainObjects.TimeImageTopNewer.Widget, "TimeImageTopNewer") - trans.setTextToGtkObjects(&mainObjects.TimeImageTopOlder.Widget, "TimeImageTopOlder") - trans.setTextToGtkObjects(&mainObjects.TimeSpinbuttonHourNewer.Widget, "TimeSpinbuttonHourNewer") - trans.setTextToGtkObjects(&mainObjects.TimeSpinbuttonHourOlder.Widget, "TimeSpinbuttonHourOlder") - trans.setTextToGtkObjects(&mainObjects.TimeSpinbuttonMinutsNewer.Widget, "TimeSpinbuttonMinutsNewer") - trans.setTextToGtkObjects(&mainObjects.TimeSpinbuttonMinutsOlder.Widget, "TimeSpinbuttonMinutsOlder") - trans.setTextToGtkObjects(&mainObjects.TimeSpinbuttonSecondsNewer.Widget, "TimeSpinbuttonSecondsNewer") - trans.setTextToGtkObjects(&mainObjects.TimeSpinbuttonSecondsOlder.Widget, "TimeSpinbuttonSecondsOlder") + trans.setTextToGtkObjects(&mainObjects.Statusbar.Widget, "Statusbar") } // Translations structure declaration. To be used in main application. var translate = new(MainTranslate) @@ -75,6 +64,7 @@ var translate = new(MainTranslate) // when "devMode" is set at true. var sts = map[string]string{ `no`: `No`, + `ok`: `Ok`, `yes`: `Yes`, } @@ -95,9 +85,9 @@ type MainTranslate struct { // MainTranslateNew: Initialise new translation structure and assign language file content to GtkObjects. // devModeActive, indicate that the new sentences must be added to previous language file. func MainTranslateNew(filename string, devModeActive ...bool) (mt *MainTranslate) { + var err error mt = new(MainTranslate) - if _, err := os.Stat(filename); err == nil { - mt.read(filename) + if err = mt.read(filename); err == nil { mt.initGtkObjectsText() if len(devModeActive) != 0 { if devModeActive[0] { @@ -109,9 +99,9 @@ func MainTranslateNew(filename string, devModeActive ...bool) (mt *MainTranslate } } } else { - fmt.Printf("%s\n%s\n", "Error loading language file !\nNot an error when is just creating from glade Xml or GOH project file.", err.Error()) + fmt.Printf("%s\n%s\n", "Error loading language file !\nNot an error when you just creating from glade Xml or GOH project file.", err.Error()) } - return mt + return } // readFile: language file. @@ -122,7 +112,7 @@ func (trans *MainTranslate) read(filename string) (err error) { trans.objectsLoaded = true } } - return err + return } // Write json datas to file @@ -134,64 +124,74 @@ func (trans *MainTranslate) write(filename string) (err error) { err = ioutil.WriteFile(filename, out.Bytes(), 0644) } } - return err + return } type parsingFlags struct { - SkipLowerCase bool - SkipEmptyLabel bool - SkipEmptyName bool - DoBackup bool + SkipLowerCase, + SkipEmptyLabel, + SkipEmptyName, + DoBackup bool } type progInfo struct { - Name string - Version string - Creat string - MainObjStructName string - GladeXmlFilename string - TranslateFilename string + Name, + Version, + Creat, + MainObjStructName, + GladeXmlFilename, + TranslateFilename, + ProjectRootDir, + GohProjFile string } type language struct { - LangNameLong string - LangNameShrt string - Author string - Date string - Updated string + LangNameLong, + LangNameShrt, + Author, + Date, + Updated string Contributors []string } type object struct { - Class string - Id string - Label string - LabelMarkup bool - LabelWrap bool - Tooltip string + Class, + Id, + Label, + Tooltip, + Text, + Uri, + Comment string + LabelMarkup, + LabelWrap, TooltipMarkup bool - Text string - Uri string - Comment string - Idx int + Idx int } // Define available property within objects type propObject struct { - Class string - Label bool - LabelMarkup bool - LabelWrap bool - Tooltip bool - TooltipMarkup bool - Text bool - Uri bool + Class string + Label, + LabelMarkup, + LabelWrap, + Tooltip, + TooltipMarkup, + Text, + Uri bool } // Property that exists for Gtk3 Object ... (Used for Class capability) var propPerObjects = []propObject{ {Class: "GtkButton", Label: true, Tooltip: true, TooltipMarkup: true}, - {Class: "GtkToolButton", Label: true, Tooltip: true, TooltipMarkup: true}, + {Class: "GtkMenuButton", Label: true, Tooltip: true, TooltipMarkup: true}, + + // {Class: "GtkToolButton", Label: true, Tooltip: true, TooltipMarkup: true}, // Deprecated since 3.10 + // {Class: "GtkImageMenuItem", Label: true, Tooltip: true, TooltipMarkup: true}, // Deprecated since 3.10 + + {Class: "GtkMenuItem", Label: true, Tooltip: true, TooltipMarkup: true}, + {Class: "GtkCheckMenuItem", Label: true, Tooltip: true, TooltipMarkup: true}, + {Class: "GtkRadioMenuItem", Label: true, Tooltip: true, TooltipMarkup: true}, + {Class: "GtkToggleButton", Label: true, Tooltip: true, TooltipMarkup: true}, {Class: "GtkLabel", Label: true, LabelMarkup: true, Tooltip: true, TooltipMarkup: true, LabelWrap: true}, {Class: "GtkSpinButton", Tooltip: true, TooltipMarkup: true}, @@ -208,6 +208,9 @@ var propPerObjects = []propObject{ {Class: "GtkTreeView", Tooltip: true, TooltipMarkup: true}, {Class: "GtkFileChooserButton", Tooltip: true, TooltipMarkup: true}, {Class: "GtkTextView", Tooltip: true, TooltipMarkup: true}, + {Class: "GtkSourceView", Tooltip: true, TooltipMarkup: true}, + {Class: "GtkStatusbar", Tooltip: true, TooltipMarkup: true}, + {Class: "GtkScrolledWindow", Tooltip: true, TooltipMarkup: true}, } // setTextToGtkObjects: read translations from structure and set them to object. @@ -239,8 +242,10 @@ func (trans *MainTranslate) setTextToGtkObjects(obj *gtk.Widget, objectId string if props.Uri { obj.SetProperty("uri", currObject.Uri) } + break } } + break } } } diff --git a/vendor/github.com/dustin/go-humanize/bigbytes_test.go b/vendor/github.com/dustin/go-humanize/bigbytes_test.go new file mode 100644 index 0000000..236ad08 --- /dev/null +++ b/vendor/github.com/dustin/go-humanize/bigbytes_test.go @@ -0,0 +1,220 @@ +package humanize + +import ( + "math/big" + "testing" +) + +func TestBigByteParsing(t *testing.T) { + tests := []struct { + in string + exp uint64 + }{ + {"42", 42}, + {"42MB", 42000000}, + {"42MiB", 44040192}, + {"42mb", 42000000}, + {"42mib", 44040192}, + {"42MIB", 44040192}, + {"42 MB", 42000000}, + {"42 MiB", 44040192}, + {"42 mb", 42000000}, + {"42 mib", 44040192}, + {"42 MIB", 44040192}, + {"42.5MB", 42500000}, + {"42.5MiB", 44564480}, + {"42.5 MB", 42500000}, + {"42.5 MiB", 44564480}, + // No need to say B + {"42M", 42000000}, + {"42Mi", 44040192}, + {"42m", 42000000}, + {"42mi", 44040192}, + {"42MI", 44040192}, + {"42 M", 42000000}, + {"42 Mi", 44040192}, + {"42 m", 42000000}, + {"42 mi", 44040192}, + {"42 MI", 44040192}, + {"42.5M", 42500000}, + {"42.5Mi", 44564480}, + {"42.5 M", 42500000}, + {"42.5 Mi", 44564480}, + {"1,005.03 MB", 1005030000}, + // Large testing, breaks when too much larger than + // this. + {"12.5 EB", uint64(12.5 * float64(EByte))}, + {"12.5 E", uint64(12.5 * float64(EByte))}, + {"12.5 EiB", uint64(12.5 * float64(EiByte))}, + } + + for _, p := range tests { + got, err := ParseBigBytes(p.in) + if err != nil { + t.Errorf("Couldn't parse %v: %v", p.in, err) + } else { + if got.Uint64() != p.exp { + t.Errorf("Expected %v for %v, got %v", + p.exp, p.in, got) + } + } + } +} + +func TestBigByteErrors(t *testing.T) { + got, err := ParseBigBytes("84 JB") + if err == nil { + t.Errorf("Expected error, got %v", got) + } + got, err = ParseBigBytes("") + if err == nil { + t.Errorf("Expected error parsing nothing") + } +} + +func bbyte(in uint64) string { + return BigBytes((&big.Int{}).SetUint64(in)) +} + +func bibyte(in uint64) string { + return BigIBytes((&big.Int{}).SetUint64(in)) +} + +func TestBigBytes(t *testing.T) { + testList{ + {"bytes(0)", bbyte(0), "0 B"}, + {"bytes(1)", bbyte(1), "1 B"}, + {"bytes(803)", bbyte(803), "803 B"}, + {"bytes(999)", bbyte(999), "999 B"}, + + {"bytes(1024)", bbyte(1024), "1.0 kB"}, + {"bytes(1MB - 1)", bbyte(MByte - Byte), "1000 kB"}, + + {"bytes(1MB)", bbyte(1024 * 1024), "1.0 MB"}, + {"bytes(1GB - 1K)", bbyte(GByte - KByte), "1000 MB"}, + + {"bytes(1GB)", bbyte(GByte), "1.0 GB"}, + {"bytes(1TB - 1M)", bbyte(TByte - MByte), "1000 GB"}, + + {"bytes(1TB)", bbyte(TByte), "1.0 TB"}, + {"bytes(1PB - 1T)", bbyte(PByte - TByte), "999 TB"}, + + {"bytes(1PB)", bbyte(PByte), "1.0 PB"}, + {"bytes(1PB - 1T)", bbyte(EByte - PByte), "999 PB"}, + + {"bytes(1EB)", bbyte(EByte), "1.0 EB"}, + // Overflows. + // {"bytes(1EB - 1P)", Bytes((KByte*EByte)-PByte), "1023EB"}, + + {"bytes(0)", bibyte(0), "0 B"}, + {"bytes(1)", bibyte(1), "1 B"}, + {"bytes(803)", bibyte(803), "803 B"}, + {"bytes(1023)", bibyte(1023), "1023 B"}, + + {"bytes(1024)", bibyte(1024), "1.0 KiB"}, + {"bytes(1MB - 1)", bibyte(MiByte - IByte), "1024 KiB"}, + + {"bytes(1MB)", bibyte(1024 * 1024), "1.0 MiB"}, + {"bytes(1GB - 1K)", bibyte(GiByte - KiByte), "1024 MiB"}, + + {"bytes(1GB)", bibyte(GiByte), "1.0 GiB"}, + {"bytes(1TB - 1M)", bibyte(TiByte - MiByte), "1024 GiB"}, + + {"bytes(1TB)", bibyte(TiByte), "1.0 TiB"}, + {"bytes(1PB - 1T)", bibyte(PiByte - TiByte), "1023 TiB"}, + + {"bytes(1PB)", bibyte(PiByte), "1.0 PiB"}, + {"bytes(1PB - 1T)", bibyte(EiByte - PiByte), "1023 PiB"}, + + {"bytes(1EiB)", bibyte(EiByte), "1.0 EiB"}, + // Overflows. + // {"bytes(1EB - 1P)", bibyte((KIByte*EIByte)-PiByte), "1023EB"}, + + {"bytes(5.5GiB)", bibyte(5.5 * GiByte), "5.5 GiB"}, + + {"bytes(5.5GB)", bbyte(5.5 * GByte), "5.5 GB"}, + }.validate(t) +} + +func TestVeryBigBytes(t *testing.T) { + b, _ := (&big.Int{}).SetString("15347691069326346944512", 10) + s := BigBytes(b) + if s != "15 ZB" { + t.Errorf("Expected 15 ZB, got %v", s) + } + s = BigIBytes(b) + if s != "13 ZiB" { + t.Errorf("Expected 13 ZiB, got %v", s) + } + + b, _ = (&big.Int{}).SetString("15716035654990179271180288", 10) + s = BigBytes(b) + if s != "16 YB" { + t.Errorf("Expected 16 YB, got %v", s) + } + s = BigIBytes(b) + if s != "13 YiB" { + t.Errorf("Expected 13 YiB, got %v", s) + } +} + +func TestVeryVeryBigBytes(t *testing.T) { + b, _ := (&big.Int{}).SetString("16093220510709943573688614912", 10) + s := BigBytes(b) + if s != "16093 YB" { + t.Errorf("Expected 16093 YB, got %v", s) + } + s = BigIBytes(b) + if s != "13312 YiB" { + t.Errorf("Expected 13312 YiB, got %v", s) + } +} + +func TestParseVeryBig(t *testing.T) { + tests := []struct { + in string + out string + }{ + {"16 ZB", "16000000000000000000000"}, + {"16 ZiB", "18889465931478580854784"}, + {"16.5 ZB", "16500000000000000000000"}, + {"16.5 ZiB", "19479761741837286506496"}, + {"16 Z", "16000000000000000000000"}, + {"16 Zi", "18889465931478580854784"}, + {"16.5 Z", "16500000000000000000000"}, + {"16.5 Zi", "19479761741837286506496"}, + + {"16 YB", "16000000000000000000000000"}, + {"16 YiB", "19342813113834066795298816"}, + {"16.5 YB", "16500000000000000000000000"}, + {"16.5 YiB", "19947276023641381382651904"}, + {"16 Y", "16000000000000000000000000"}, + {"16 Yi", "19342813113834066795298816"}, + {"16.5 Y", "16500000000000000000000000"}, + {"16.5 Yi", "19947276023641381382651904"}, + } + + for _, test := range tests { + x, err := ParseBigBytes(test.in) + if err != nil { + t.Errorf("Error parsing %q: %v", test.in, err) + continue + } + + if x.String() != test.out { + t.Errorf("Expected %q for %q, got %v", test.out, test.in, x) + } + } +} + +func BenchmarkParseBigBytes(b *testing.B) { + for i := 0; i < b.N; i++ { + ParseBigBytes("16.5 Z") + } +} + +func BenchmarkBigBytes(b *testing.B) { + for i := 0; i < b.N; i++ { + bibyte(16.5 * GByte) + } +} diff --git a/vendor/github.com/dustin/go-humanize/bytes_test.go b/vendor/github.com/dustin/go-humanize/bytes_test.go new file mode 100644 index 0000000..0bb811c --- /dev/null +++ b/vendor/github.com/dustin/go-humanize/bytes_test.go @@ -0,0 +1,146 @@ +package humanize + +import ( + "testing" +) + +func TestByteParsing(t *testing.T) { + tests := []struct { + in string + exp uint64 + }{ + {"42", 42}, + {"42MB", 42000000}, + {"42MiB", 44040192}, + {"42mb", 42000000}, + {"42mib", 44040192}, + {"42MIB", 44040192}, + {"42 MB", 42000000}, + {"42 MiB", 44040192}, + {"42 mb", 42000000}, + {"42 mib", 44040192}, + {"42 MIB", 44040192}, + {"42.5MB", 42500000}, + {"42.5MiB", 44564480}, + {"42.5 MB", 42500000}, + {"42.5 MiB", 44564480}, + // No need to say B + {"42M", 42000000}, + {"42Mi", 44040192}, + {"42m", 42000000}, + {"42mi", 44040192}, + {"42MI", 44040192}, + {"42 M", 42000000}, + {"42 Mi", 44040192}, + {"42 m", 42000000}, + {"42 mi", 44040192}, + {"42 MI", 44040192}, + {"42.5M", 42500000}, + {"42.5Mi", 44564480}, + {"42.5 M", 42500000}, + {"42.5 Mi", 44564480}, + // Bug #42 + {"1,005.03 MB", 1005030000}, + // Large testing, breaks when too much larger than + // this. + {"12.5 EB", uint64(12.5 * float64(EByte))}, + {"12.5 E", uint64(12.5 * float64(EByte))}, + {"12.5 EiB", uint64(12.5 * float64(EiByte))}, + } + + for _, p := range tests { + got, err := ParseBytes(p.in) + if err != nil { + t.Errorf("Couldn't parse %v: %v", p.in, err) + } + if got != p.exp { + t.Errorf("Expected %v for %v, got %v", + p.exp, p.in, got) + } + } +} + +func TestByteErrors(t *testing.T) { + got, err := ParseBytes("84 JB") + if err == nil { + t.Errorf("Expected error, got %v", got) + } + got, err = ParseBytes("") + if err == nil { + t.Errorf("Expected error parsing nothing") + } + got, err = ParseBytes("16 EiB") + if err == nil { + t.Errorf("Expected error, got %v", got) + } +} + +func TestBytes(t *testing.T) { + testList{ + {"bytes(0)", Bytes(0), "0 B"}, + {"bytes(1)", Bytes(1), "1 B"}, + {"bytes(803)", Bytes(803), "803 B"}, + {"bytes(999)", Bytes(999), "999 B"}, + + {"bytes(1024)", Bytes(1024), "1.0 kB"}, + {"bytes(9999)", Bytes(9999), "10 kB"}, + {"bytes(1MB - 1)", Bytes(MByte - Byte), "1000 kB"}, + + {"bytes(1MB)", Bytes(1024 * 1024), "1.0 MB"}, + {"bytes(1GB - 1K)", Bytes(GByte - KByte), "1000 MB"}, + + {"bytes(1GB)", Bytes(GByte), "1.0 GB"}, + {"bytes(1TB - 1M)", Bytes(TByte - MByte), "1000 GB"}, + {"bytes(10MB)", Bytes(9999 * 1000), "10 MB"}, + + {"bytes(1TB)", Bytes(TByte), "1.0 TB"}, + {"bytes(1PB - 1T)", Bytes(PByte - TByte), "999 TB"}, + + {"bytes(1PB)", Bytes(PByte), "1.0 PB"}, + {"bytes(1PB - 1T)", Bytes(EByte - PByte), "999 PB"}, + + {"bytes(1EB)", Bytes(EByte), "1.0 EB"}, + // Overflows. + // {"bytes(1EB - 1P)", Bytes((KByte*EByte)-PByte), "1023EB"}, + + {"bytes(0)", IBytes(0), "0 B"}, + {"bytes(1)", IBytes(1), "1 B"}, + {"bytes(803)", IBytes(803), "803 B"}, + {"bytes(1023)", IBytes(1023), "1023 B"}, + + {"bytes(1024)", IBytes(1024), "1.0 KiB"}, + {"bytes(1MB - 1)", IBytes(MiByte - IByte), "1024 KiB"}, + + {"bytes(1MB)", IBytes(1024 * 1024), "1.0 MiB"}, + {"bytes(1GB - 1K)", IBytes(GiByte - KiByte), "1024 MiB"}, + + {"bytes(1GB)", IBytes(GiByte), "1.0 GiB"}, + {"bytes(1TB - 1M)", IBytes(TiByte - MiByte), "1024 GiB"}, + + {"bytes(1TB)", IBytes(TiByte), "1.0 TiB"}, + {"bytes(1PB - 1T)", IBytes(PiByte - TiByte), "1023 TiB"}, + + {"bytes(1PB)", IBytes(PiByte), "1.0 PiB"}, + {"bytes(1PB - 1T)", IBytes(EiByte - PiByte), "1023 PiB"}, + + {"bytes(1EiB)", IBytes(EiByte), "1.0 EiB"}, + // Overflows. + // {"bytes(1EB - 1P)", IBytes((KIByte*EIByte)-PiByte), "1023EB"}, + + {"bytes(5.5GiB)", IBytes(5.5 * GiByte), "5.5 GiB"}, + + {"bytes(5.5GB)", Bytes(5.5 * GByte), "5.5 GB"}, + }.validate(t) +} + +func BenchmarkParseBytes(b *testing.B) { + for i := 0; i < b.N; i++ { + ParseBytes("16.5 GB") + } +} + +func BenchmarkBytes(b *testing.B) { + for i := 0; i < b.N; i++ { + Bytes(16.5 * GByte) + } +} diff --git a/vendor/github.com/dustin/go-humanize/comma_test.go b/vendor/github.com/dustin/go-humanize/comma_test.go new file mode 100644 index 0000000..c37a518 --- /dev/null +++ b/vendor/github.com/dustin/go-humanize/comma_test.go @@ -0,0 +1,145 @@ +package humanize + +import ( + "math" + "math/big" + "testing" +) + +func TestCommas(t *testing.T) { + testList{ + {"0", Comma(0), "0"}, + {"10", Comma(10), "10"}, + {"100", Comma(100), "100"}, + {"1,000", Comma(1000), "1,000"}, + {"10,000", Comma(10000), "10,000"}, + {"100,000", Comma(100000), "100,000"}, + {"10,000,000", Comma(10000000), "10,000,000"}, + {"10,100,000", Comma(10100000), "10,100,000"}, + {"10,010,000", Comma(10010000), "10,010,000"}, + {"10,001,000", Comma(10001000), "10,001,000"}, + {"123,456,789", Comma(123456789), "123,456,789"}, + {"maxint", Comma(9.223372e+18), "9,223,372,000,000,000,000"}, + {"math.maxint", Comma(math.MaxInt64), "9,223,372,036,854,775,807"}, + {"math.minint", Comma(math.MinInt64), "-9,223,372,036,854,775,808"}, + {"minint", Comma(-9.223372e+18), "-9,223,372,000,000,000,000"}, + {"-123,456,789", Comma(-123456789), "-123,456,789"}, + {"-10,100,000", Comma(-10100000), "-10,100,000"}, + {"-10,010,000", Comma(-10010000), "-10,010,000"}, + {"-10,001,000", Comma(-10001000), "-10,001,000"}, + {"-10,000,000", Comma(-10000000), "-10,000,000"}, + {"-100,000", Comma(-100000), "-100,000"}, + {"-10,000", Comma(-10000), "-10,000"}, + {"-1,000", Comma(-1000), "-1,000"}, + {"-100", Comma(-100), "-100"}, + {"-10", Comma(-10), "-10"}, + }.validate(t) +} + +func TestCommafWithDigits(t *testing.T) { + testList{ + {"1.23, 0", CommafWithDigits(1.23, 0), "1"}, + {"1.23, 1", CommafWithDigits(1.23, 1), "1.2"}, + {"1.23, 2", CommafWithDigits(1.23, 2), "1.23"}, + {"1.23, 3", CommafWithDigits(1.23, 3), "1.23"}, + }.validate(t) +} + +func TestCommafs(t *testing.T) { + testList{ + {"0", Commaf(0), "0"}, + {"10.11", Commaf(10.11), "10.11"}, + {"100", Commaf(100), "100"}, + {"1,000", Commaf(1000), "1,000"}, + {"10,000", Commaf(10000), "10,000"}, + {"100,000", Commaf(100000), "100,000"}, + {"834,142.32", Commaf(834142.32), "834,142.32"}, + {"10,000,000", Commaf(10000000), "10,000,000"}, + {"10,100,000", Commaf(10100000), "10,100,000"}, + {"10,010,000", Commaf(10010000), "10,010,000"}, + {"10,001,000", Commaf(10001000), "10,001,000"}, + {"123,456,789", Commaf(123456789), "123,456,789"}, + {"maxf64", Commaf(math.MaxFloat64), "179,769,313,486,231,570,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000"}, + {"minf64", Commaf(math.SmallestNonzeroFloat64), "0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000005"}, + {"-123,456,789", Commaf(-123456789), "-123,456,789"}, + {"-10,100,000", Commaf(-10100000), "-10,100,000"}, + {"-10,010,000", Commaf(-10010000), "-10,010,000"}, + {"-10,001,000", Commaf(-10001000), "-10,001,000"}, + {"-10,000,000", Commaf(-10000000), "-10,000,000"}, + {"-100,000", Commaf(-100000), "-100,000"}, + {"-10,000", Commaf(-10000), "-10,000"}, + {"-1,000", Commaf(-1000), "-1,000"}, + {"-100.11", Commaf(-100.11), "-100.11"}, + {"-10", Commaf(-10), "-10"}, + }.validate(t) +} + +func BenchmarkCommas(b *testing.B) { + for i := 0; i < b.N; i++ { + Comma(1234567890) + } +} + +func BenchmarkCommaf(b *testing.B) { + for i := 0; i < b.N; i++ { + Commaf(1234567890.83584) + } +} + +func BenchmarkBigCommas(b *testing.B) { + for i := 0; i < b.N; i++ { + BigComma(big.NewInt(1234567890)) + } +} + +func bigComma(i int64) string { + return BigComma(big.NewInt(i)) +} + +func TestBigCommas(t *testing.T) { + testList{ + {"0", bigComma(0), "0"}, + {"10", bigComma(10), "10"}, + {"100", bigComma(100), "100"}, + {"1,000", bigComma(1000), "1,000"}, + {"10,000", bigComma(10000), "10,000"}, + {"100,000", bigComma(100000), "100,000"}, + {"10,000,000", bigComma(10000000), "10,000,000"}, + {"10,100,000", bigComma(10100000), "10,100,000"}, + {"10,010,000", bigComma(10010000), "10,010,000"}, + {"10,001,000", bigComma(10001000), "10,001,000"}, + {"123,456,789", bigComma(123456789), "123,456,789"}, + {"maxint", bigComma(9.223372e+18), "9,223,372,000,000,000,000"}, + {"minint", bigComma(-9.223372e+18), "-9,223,372,000,000,000,000"}, + {"-123,456,789", bigComma(-123456789), "-123,456,789"}, + {"-10,100,000", bigComma(-10100000), "-10,100,000"}, + {"-10,010,000", bigComma(-10010000), "-10,010,000"}, + {"-10,001,000", bigComma(-10001000), "-10,001,000"}, + {"-10,000,000", bigComma(-10000000), "-10,000,000"}, + {"-100,000", bigComma(-100000), "-100,000"}, + {"-10,000", bigComma(-10000), "-10,000"}, + {"-1,000", bigComma(-1000), "-1,000"}, + {"-100", bigComma(-100), "-100"}, + {"-10", bigComma(-10), "-10"}, + }.validate(t) +} + +func TestVeryBigCommas(t *testing.T) { + tests := []struct{ in, exp string }{ + { + "84889279597249724975972597249849757294578485", + "84,889,279,597,249,724,975,972,597,249,849,757,294,578,485", + }, + { + "-84889279597249724975972597249849757294578485", + "-84,889,279,597,249,724,975,972,597,249,849,757,294,578,485", + }, + } + for _, test := range tests { + n, _ := (&big.Int{}).SetString(test.in, 10) + got := BigComma(n) + if test.exp != got { + t.Errorf("Expected %q, got %q", test.exp, got) + } + } +} diff --git a/vendor/github.com/dustin/go-humanize/commaf_test.go b/vendor/github.com/dustin/go-humanize/commaf_test.go new file mode 100644 index 0000000..21f7f9e --- /dev/null +++ b/vendor/github.com/dustin/go-humanize/commaf_test.go @@ -0,0 +1,44 @@ +// +build go1.6 + +package humanize + +import ( + "math" + "math/big" + "testing" +) + +func BenchmarkBigCommaf(b *testing.B) { + for i := 0; i < b.N; i++ { + Commaf(1234567890.83584) + } +} + +func TestBigCommafs(t *testing.T) { + testList{ + {"0", BigCommaf(big.NewFloat(0)), "0"}, + {"10.11", BigCommaf(big.NewFloat(10.11)), "10.11"}, + {"100", BigCommaf(big.NewFloat(100)), "100"}, + {"1,000", BigCommaf(big.NewFloat(1000)), "1,000"}, + {"10,000", BigCommaf(big.NewFloat(10000)), "10,000"}, + {"100,000", BigCommaf(big.NewFloat(100000)), "100,000"}, + {"834,142.32", BigCommaf(big.NewFloat(834142.32)), "834,142.32"}, + {"10,000,000", BigCommaf(big.NewFloat(10000000)), "10,000,000"}, + {"10,100,000", BigCommaf(big.NewFloat(10100000)), "10,100,000"}, + {"10,010,000", BigCommaf(big.NewFloat(10010000)), "10,010,000"}, + {"10,001,000", BigCommaf(big.NewFloat(10001000)), "10,001,000"}, + {"123,456,789", BigCommaf(big.NewFloat(123456789)), "123,456,789"}, + {"maxf64", BigCommaf(big.NewFloat(math.MaxFloat64)), "179,769,313,486,231,570,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000"}, + {"minf64", BigCommaf(big.NewFloat(math.SmallestNonzeroFloat64)), "0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000004940656458412465"}, + {"-123,456,789", BigCommaf(big.NewFloat(-123456789)), "-123,456,789"}, + {"-10,100,000", BigCommaf(big.NewFloat(-10100000)), "-10,100,000"}, + {"-10,010,000", BigCommaf(big.NewFloat(-10010000)), "-10,010,000"}, + {"-10,001,000", BigCommaf(big.NewFloat(-10001000)), "-10,001,000"}, + {"-10,000,000", BigCommaf(big.NewFloat(-10000000)), "-10,000,000"}, + {"-100,000", BigCommaf(big.NewFloat(-100000)), "-100,000"}, + {"-10,000", BigCommaf(big.NewFloat(-10000)), "-10,000"}, + {"-1,000", BigCommaf(big.NewFloat(-1000)), "-1,000"}, + {"-100.11", BigCommaf(big.NewFloat(-100.11)), "-100.11"}, + {"-10", BigCommaf(big.NewFloat(-10)), "-10"}, + }.validate(t) +} diff --git a/vendor/github.com/dustin/go-humanize/common_test.go b/vendor/github.com/dustin/go-humanize/common_test.go new file mode 100644 index 0000000..fc7db15 --- /dev/null +++ b/vendor/github.com/dustin/go-humanize/common_test.go @@ -0,0 +1,18 @@ +package humanize + +import ( + "testing" +) + +type testList []struct { + name, got, exp string +} + +func (tl testList) validate(t *testing.T) { + for _, test := range tl { + if test.got != test.exp { + t.Errorf("On %v, expected '%v', but got '%v'", + test.name, test.exp, test.got) + } + } +} diff --git a/vendor/github.com/dustin/go-humanize/ftoa_test.go b/vendor/github.com/dustin/go-humanize/ftoa_test.go new file mode 100644 index 0000000..45ef9c5 --- /dev/null +++ b/vendor/github.com/dustin/go-humanize/ftoa_test.go @@ -0,0 +1,123 @@ +package humanize + +import ( + "fmt" + "math/rand" + "reflect" + "regexp" + "strconv" + "strings" + "testing" + "testing/quick" +) + +func TestFtoa(t *testing.T) { + testList{ + {"200", Ftoa(200), "200"}, + {"2", Ftoa(2), "2"}, + {"2.2", Ftoa(2.2), "2.2"}, + {"2.02", Ftoa(2.02), "2.02"}, + {"200.02", Ftoa(200.02), "200.02"}, + }.validate(t) +} + +func TestFtoaWithDigits(t *testing.T) { + testList{ + {"1.23, 0", FtoaWithDigits(1.23, 0), "1"}, + {"1.23, 1", FtoaWithDigits(1.23, 1), "1.2"}, + {"1.23, 2", FtoaWithDigits(1.23, 2), "1.23"}, + {"1.23, 3", FtoaWithDigits(1.23, 3), "1.23"}, + }.validate(t) +} + +func TestStripTrailingDigits(t *testing.T) { + err := quick.Check(func(s string, digits int) bool { + stripped := stripTrailingDigits(s, digits) + + // A stripped string will always be a prefix of its original string + if !strings.HasPrefix(s, stripped) { + return false + } + + if strings.ContainsRune(s, '.') { + // If there is a dot, the part on the left of the dot will never change + a := strings.Split(s, ".") + b := strings.Split(stripped, ".") + if a[0] != b[0] { + return false + } + } else { + // If there's no dot in the input, the output will always be the same as the input. + if stripped != s { + return false + } + } + + return true + }, &quick.Config{ + MaxCount: 10000, + Values: func(v []reflect.Value, r *rand.Rand) { + rdigs := func(n int) string { + digs := []rune{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9'} + var rv []rune + for i := 0; i < n; i++ { + rv = append(rv, digs[r.Intn(len(digs))]) + } + return string(rv) + } + + ls := r.Intn(20) + rs := r.Intn(20) + jc := "." + if rs == 0 { + jc = "" + } + s := rdigs(ls) + jc + rdigs(rs) + digits := r.Intn(len(s) + 1) + + v[0] = reflect.ValueOf(s) + v[1] = reflect.ValueOf(digits) + }, + }) + + if err != nil { + t.Error(err) + } +} + +func BenchmarkFtoaRegexTrailing(b *testing.B) { + trailingZerosRegex := regexp.MustCompile(`\.?0+$`) + + b.ResetTimer() + for i := 0; i < b.N; i++ { + trailingZerosRegex.ReplaceAllString("2.00000", "") + trailingZerosRegex.ReplaceAllString("2.0000", "") + trailingZerosRegex.ReplaceAllString("2.000", "") + trailingZerosRegex.ReplaceAllString("2.00", "") + trailingZerosRegex.ReplaceAllString("2.0", "") + trailingZerosRegex.ReplaceAllString("2", "") + } +} + +func BenchmarkFtoaFunc(b *testing.B) { + for i := 0; i < b.N; i++ { + stripTrailingZeros("2.00000") + stripTrailingZeros("2.0000") + stripTrailingZeros("2.000") + stripTrailingZeros("2.00") + stripTrailingZeros("2.0") + stripTrailingZeros("2") + } +} + +func BenchmarkFmtF(b *testing.B) { + for i := 0; i < b.N; i++ { + _ = fmt.Sprintf("%f", 2.03584) + } +} + +func BenchmarkStrconvF(b *testing.B) { + for i := 0; i < b.N; i++ { + strconv.FormatFloat(2.03584, 'f', 6, 64) + } +} diff --git a/vendor/github.com/dustin/go-humanize/number_test.go b/vendor/github.com/dustin/go-humanize/number_test.go new file mode 100644 index 0000000..516f337 --- /dev/null +++ b/vendor/github.com/dustin/go-humanize/number_test.go @@ -0,0 +1,79 @@ +package humanize + +import ( + "math" + "testing" +) + +type TestStruct struct { + name string + format string + num float64 + formatted string +} + +func TestFormatFloat(t *testing.T) { + tests := []TestStruct{ + {"default", "", 12345.6789, "12,345.68"}, + {"#", "#", 12345.6789, "12345.678900000"}, + {"#.", "#.", 12345.6789, "12346"}, + {"#,#", "#,#", 12345.6789, "12345,7"}, + {"#,##", "#,##", 12345.6789, "12345,68"}, + {"#,###", "#,###", 12345.6789, "12345,679"}, + {"#,###.", "#,###.", 12345.6789, "12,346"}, + {"#,###.##", "#,###.##", 12345.6789, "12,345.68"}, + {"#,###.###", "#,###.###", 12345.6789, "12,345.679"}, + {"#,###.####", "#,###.####", 12345.6789, "12,345.6789"}, + {"#.###,######", "#.###,######", 12345.6789, "12.345,678900"}, + {"bug46", "#,###.##", 52746220055.92342, "52,746,220,055.92"}, + {"#\u202f###,##", "#\u202f###,##", 12345.6789, "12 345,68"}, + + // special cases + {"NaN", "#", math.NaN(), "NaN"}, + {"+Inf", "#", math.Inf(1), "Infinity"}, + {"-Inf", "#", math.Inf(-1), "-Infinity"}, + {"signStr <= -0.000000001", "", -0.000000002, "-0.00"}, + {"signStr = 0", "", 0, "0.00"}, + {"Format directive must start with +", "+000", 12345.6789, "+12345.678900000"}, + } + + for _, test := range tests { + got := FormatFloat(test.format, test.num) + if got != test.formatted { + t.Errorf("On %v (%v, %v), got %v, wanted %v", + test.name, test.format, test.num, got, test.formatted) + } + } + // Test a single integer + got := FormatInteger("#", 12345) + if got != "12345.000000000" { + t.Errorf("On %v (%v, %v), got %v, wanted %v", + "integerTest", "#", 12345, got, "12345.000000000") + } + // Test the things that could panic + panictests := []TestStruct{ + {"RenderFloat(): invalid positive sign directive", "-", 12345.6789, "12,345.68"}, + {"RenderFloat(): thousands separator directive must be followed by 3 digit-specifiers", "0.01", 12345.6789, "12,345.68"}, + } + for _, test := range panictests { + didPanic := false + var message interface{} + func() { + + defer func() { + if message = recover(); message != nil { + didPanic = true + } + }() + + // call the target function + _ = FormatFloat(test.format, test.num) + + }() + if didPanic != true { + t.Errorf("On %v, should have panic and did not.", + test.name) + } + } + +} diff --git a/vendor/github.com/dustin/go-humanize/ordinals_test.go b/vendor/github.com/dustin/go-humanize/ordinals_test.go new file mode 100644 index 0000000..51d85ee --- /dev/null +++ b/vendor/github.com/dustin/go-humanize/ordinals_test.go @@ -0,0 +1,22 @@ +package humanize + +import ( + "testing" +) + +func TestOrdinals(t *testing.T) { + testList{ + {"0", Ordinal(0), "0th"}, + {"1", Ordinal(1), "1st"}, + {"2", Ordinal(2), "2nd"}, + {"3", Ordinal(3), "3rd"}, + {"4", Ordinal(4), "4th"}, + {"10", Ordinal(10), "10th"}, + {"11", Ordinal(11), "11th"}, + {"12", Ordinal(12), "12th"}, + {"13", Ordinal(13), "13th"}, + {"101", Ordinal(101), "101st"}, + {"102", Ordinal(102), "102nd"}, + {"103", Ordinal(103), "103rd"}, + }.validate(t) +} diff --git a/vendor/github.com/dustin/go-humanize/si_test.go b/vendor/github.com/dustin/go-humanize/si_test.go new file mode 100644 index 0000000..e15fc69 --- /dev/null +++ b/vendor/github.com/dustin/go-humanize/si_test.go @@ -0,0 +1,124 @@ +package humanize + +import ( + "math" + "testing" +) + +func TestSI(t *testing.T) { + tests := []struct { + name string + num float64 + formatted string + }{ + {"e-24", 1e-24, "1 yF"}, + {"e-21", 1e-21, "1 zF"}, + {"e-18", 1e-18, "1 aF"}, + {"e-15", 1e-15, "1 fF"}, + {"e-12", 1e-12, "1 pF"}, + {"e-12", 2.2345e-12, "2.2345 pF"}, + {"e-12", 2.23e-12, "2.23 pF"}, + {"e-11", 2.23e-11, "22.3 pF"}, + {"e-10", 2.2e-10, "220 pF"}, + {"e-9", 2.2e-9, "2.2 nF"}, + {"e-8", 2.2e-8, "22 nF"}, + {"e-7", 2.2e-7, "220 nF"}, + {"e-6", 2.2e-6, "2.2 µF"}, + {"e-6", 1e-6, "1 µF"}, + {"e-5", 2.2e-5, "22 µF"}, + {"e-4", 2.2e-4, "220 µF"}, + {"e-3", 2.2e-3, "2.2 mF"}, + {"e-2", 2.2e-2, "22 mF"}, + {"e-1", 2.2e-1, "220 mF"}, + {"e+0", 2.2e-0, "2.2 F"}, + {"e+0", 2.2, "2.2 F"}, + {"e+1", 2.2e+1, "22 F"}, + {"0", 0, "0 F"}, + {"e+1", 22, "22 F"}, + {"e+2", 2.2e+2, "220 F"}, + {"e+2", 220, "220 F"}, + {"e+3", 2.2e+3, "2.2 kF"}, + {"e+3", 2200, "2.2 kF"}, + {"e+4", 2.2e+4, "22 kF"}, + {"e+4", 22000, "22 kF"}, + {"e+5", 2.2e+5, "220 kF"}, + {"e+6", 2.2e+6, "2.2 MF"}, + {"e+6", 1e+6, "1 MF"}, + {"e+7", 2.2e+7, "22 MF"}, + {"e+8", 2.2e+8, "220 MF"}, + {"e+9", 2.2e+9, "2.2 GF"}, + {"e+10", 2.2e+10, "22 GF"}, + {"e+11", 2.2e+11, "220 GF"}, + {"e+12", 2.2e+12, "2.2 TF"}, + {"e+15", 2.2e+15, "2.2 PF"}, + {"e+18", 2.2e+18, "2.2 EF"}, + {"e+21", 2.2e+21, "2.2 ZF"}, + {"e+24", 2.2e+24, "2.2 YF"}, + + // special case + {"1F", 1000 * 1000, "1 MF"}, + {"1F", 1e6, "1 MF"}, + + // negative number + {"-100 F", -100, "-100 F"}, + } + + for _, test := range tests { + got := SI(test.num, "F") + if got != test.formatted { + t.Errorf("On %v (%v), got %v, wanted %v", + test.name, test.num, got, test.formatted) + } + + gotf, gotu, err := ParseSI(test.formatted) + if err != nil { + t.Errorf("Error parsing %v (%v): %v", test.name, test.formatted, err) + continue + } + + if math.Abs(1-(gotf/test.num)) > 0.01 { + t.Errorf("On %v (%v), got %v, wanted %v (±%v)", + test.name, test.formatted, gotf, test.num, + math.Abs(1-(gotf/test.num))) + } + if gotu != "F" { + t.Errorf("On %v (%v), expected unit F, got %v", + test.name, test.formatted, gotu) + } + } + + // Parse error + gotf, gotu, err := ParseSI("x1.21JW") // 1.21 jigga whats + if err == nil { + t.Errorf("Expected error on x1.21JW, got %v %v", gotf, gotu) + } +} + +func TestSIWithDigits(t *testing.T) { + tests := []struct { + name string + num float64 + digits int + formatted string + }{ + {"e-12", 2.234e-12, 0, "2 pF"}, + {"e-12", 2.234e-12, 1, "2.2 pF"}, + {"e-12", 2.234e-12, 2, "2.23 pF"}, + {"e-12", 2.234e-12, 3, "2.234 pF"}, + {"e-12", 2.234e-12, 4, "2.234 pF"}, + } + + for _, test := range tests { + got := SIWithDigits(test.num, test.digits, "F") + if got != test.formatted { + t.Errorf("On %v (%v), got %v, wanted %v", + test.name, test.num, got, test.formatted) + } + } +} + +func BenchmarkParseSI(b *testing.B) { + for i := 0; i < b.N; i++ { + ParseSI("2.2346ZB") + } +} diff --git a/vendor/github.com/dustin/go-humanize/times_test.go b/vendor/github.com/dustin/go-humanize/times_test.go new file mode 100644 index 0000000..b1ab8bf --- /dev/null +++ b/vendor/github.com/dustin/go-humanize/times_test.go @@ -0,0 +1,124 @@ +package humanize + +import ( + "math" + "testing" + "time" +) + +func TestPast(t *testing.T) { + now := time.Now() + testList{ + {"now", Time(now), "now"}, + {"1 second ago", Time(now.Add(-1 * time.Second)), "1 second ago"}, + {"12 seconds ago", Time(now.Add(-12 * time.Second)), "12 seconds ago"}, + {"30 seconds ago", Time(now.Add(-30 * time.Second)), "30 seconds ago"}, + {"45 seconds ago", Time(now.Add(-45 * time.Second)), "45 seconds ago"}, + {"1 minute ago", Time(now.Add(-63 * time.Second)), "1 minute ago"}, + {"15 minutes ago", Time(now.Add(-15 * time.Minute)), "15 minutes ago"}, + {"1 hour ago", Time(now.Add(-63 * time.Minute)), "1 hour ago"}, + {"2 hours ago", Time(now.Add(-2 * time.Hour)), "2 hours ago"}, + {"21 hours ago", Time(now.Add(-21 * time.Hour)), "21 hours ago"}, + {"1 day ago", Time(now.Add(-26 * time.Hour)), "1 day ago"}, + {"2 days ago", Time(now.Add(-49 * time.Hour)), "2 days ago"}, + {"3 days ago", Time(now.Add(-3 * Day)), "3 days ago"}, + {"1 week ago (1)", Time(now.Add(-7 * Day)), "1 week ago"}, + {"1 week ago (2)", Time(now.Add(-12 * Day)), "1 week ago"}, + {"2 weeks ago", Time(now.Add(-15 * Day)), "2 weeks ago"}, + {"1 month ago", Time(now.Add(-39 * Day)), "1 month ago"}, + {"3 months ago", Time(now.Add(-99 * Day)), "3 months ago"}, + {"1 year ago (1)", Time(now.Add(-365 * Day)), "1 year ago"}, + {"1 year ago (1)", Time(now.Add(-400 * Day)), "1 year ago"}, + {"2 years ago (1)", Time(now.Add(-548 * Day)), "2 years ago"}, + {"2 years ago (2)", Time(now.Add(-725 * Day)), "2 years ago"}, + {"2 years ago (3)", Time(now.Add(-800 * Day)), "2 years ago"}, + {"3 years ago", Time(now.Add(-3 * Year)), "3 years ago"}, + {"long ago", Time(now.Add(-LongTime)), "a long while ago"}, + }.validate(t) +} + +func TestReltimeOffbyone(t *testing.T) { + testList{ + {"1w-1", RelTime(time.Unix(0, 0), time.Unix(7*24*60*60, -1), "ago", ""), "6 days ago"}, + {"1w±0", RelTime(time.Unix(0, 0), time.Unix(7*24*60*60, 0), "ago", ""), "1 week ago"}, + {"1w+1", RelTime(time.Unix(0, 0), time.Unix(7*24*60*60, 1), "ago", ""), "1 week ago"}, + {"2w-1", RelTime(time.Unix(0, 0), time.Unix(14*24*60*60, -1), "ago", ""), "1 week ago"}, + {"2w±0", RelTime(time.Unix(0, 0), time.Unix(14*24*60*60, 0), "ago", ""), "2 weeks ago"}, + {"2w+1", RelTime(time.Unix(0, 0), time.Unix(14*24*60*60, 1), "ago", ""), "2 weeks ago"}, + }.validate(t) +} + +func TestFuture(t *testing.T) { + // Add a little time so that these things properly line up in + // the future. + now := time.Now().Add(time.Millisecond * 250) + testList{ + {"now", Time(now), "now"}, + {"1 second from now", Time(now.Add(+1 * time.Second)), "1 second from now"}, + {"12 seconds from now", Time(now.Add(+12 * time.Second)), "12 seconds from now"}, + {"30 seconds from now", Time(now.Add(+30 * time.Second)), "30 seconds from now"}, + {"45 seconds from now", Time(now.Add(+45 * time.Second)), "45 seconds from now"}, + {"15 minutes from now", Time(now.Add(+15 * time.Minute)), "15 minutes from now"}, + {"2 hours from now", Time(now.Add(+2 * time.Hour)), "2 hours from now"}, + {"21 hours from now", Time(now.Add(+21 * time.Hour)), "21 hours from now"}, + {"1 day from now", Time(now.Add(+26 * time.Hour)), "1 day from now"}, + {"2 days from now", Time(now.Add(+49 * time.Hour)), "2 days from now"}, + {"3 days from now", Time(now.Add(+3 * Day)), "3 days from now"}, + {"1 week from now (1)", Time(now.Add(+7 * Day)), "1 week from now"}, + {"1 week from now (2)", Time(now.Add(+12 * Day)), "1 week from now"}, + {"2 weeks from now", Time(now.Add(+15 * Day)), "2 weeks from now"}, + {"1 month from now", Time(now.Add(+30 * Day)), "1 month from now"}, + {"1 year from now", Time(now.Add(+365 * Day)), "1 year from now"}, + {"2 years from now", Time(now.Add(+2 * Year)), "2 years from now"}, + {"a while from now", Time(now.Add(+LongTime)), "a long while from now"}, + }.validate(t) +} + +func TestRange(t *testing.T) { + start := time.Time{} + end := time.Unix(math.MaxInt64, math.MaxInt64) + x := RelTime(start, end, "ago", "from now") + if x != "a long while from now" { + t.Errorf("Expected a long while from now, got %q", x) + } +} + +func TestCustomRelTime(t *testing.T) { + now := time.Now().Add(time.Millisecond * 250) + magnitudes := []RelTimeMagnitude{ + {time.Second, "now", time.Second}, + {2 * time.Second, "1 second %s", 1}, + {time.Minute, "%d seconds %s", time.Second}, + {Day - time.Second, "%d minutes %s", time.Minute}, + {Day, "%d hours %s", time.Hour}, + {2 * Day, "1 day %s", 1}, + {Week, "%d days %s", Day}, + {2 * Week, "1 week %s", 1}, + {6 * Month, "%d weeks %s", Week}, + {Year, "%d months %s", Month}, + } + customRelTime := func(then time.Time) string { + return CustomRelTime(then, time.Now(), "ago", "from now", magnitudes) + } + testList{ + {"now", customRelTime(now), "now"}, + {"1 second from now", customRelTime(now.Add(+1 * time.Second)), "1 second from now"}, + {"12 seconds from now", customRelTime(now.Add(+12 * time.Second)), "12 seconds from now"}, + {"30 seconds from now", customRelTime(now.Add(+30 * time.Second)), "30 seconds from now"}, + {"45 seconds from now", customRelTime(now.Add(+45 * time.Second)), "45 seconds from now"}, + {"15 minutes from now", customRelTime(now.Add(+15 * time.Minute)), "15 minutes from now"}, + {"2 hours from now", customRelTime(now.Add(+2 * time.Hour)), "120 minutes from now"}, + {"21 hours from now", customRelTime(now.Add(+21 * time.Hour)), "1260 minutes from now"}, + {"1 day from now", customRelTime(now.Add(+26 * time.Hour)), "1 day from now"}, + {"2 days from now", customRelTime(now.Add(+49 * time.Hour)), "2 days from now"}, + {"3 days from now", customRelTime(now.Add(+3 * Day)), "3 days from now"}, + {"1 week from now (1)", customRelTime(now.Add(+7 * Day)), "1 week from now"}, + {"1 week from now (2)", customRelTime(now.Add(+12 * Day)), "1 week from now"}, + {"2 weeks from now", customRelTime(now.Add(+15 * Day)), "2 weeks from now"}, + {"1 month from now", customRelTime(now.Add(+30 * Day)), "4 weeks from now"}, + {"6 months from now", customRelTime(now.Add(+6*Month - time.Second)), "25 weeks from now"}, + {"1 year from now", customRelTime(now.Add(+365 * Day)), "12 months from now"}, + {"2 years from now", customRelTime(now.Add(+2 * Year)), "24 months from now"}, + {"a while from now", customRelTime(now.Add(+LongTime)), "444 months from now"}, + }.validate(t) +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/antialias.go b/vendor/github.com/gotk3/gotk3/cairo/antialias.go new file mode 100644 index 0000000..9e41879 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/antialias.go @@ -0,0 +1,27 @@ +package cairo + +// #include +// #include +// #include +import "C" +import ( + "unsafe" +) + +// Antialias is a representation of Cairo's cairo_antialias_t. +type Antialias int + +const ( + ANTIALIAS_DEFAULT Antialias = C.CAIRO_ANTIALIAS_DEFAULT + ANTIALIAS_NONE Antialias = C.CAIRO_ANTIALIAS_NONE + ANTIALIAS_GRAY Antialias = C.CAIRO_ANTIALIAS_GRAY + ANTIALIAS_SUBPIXEL Antialias = C.CAIRO_ANTIALIAS_SUBPIXEL + ANTIALIAS_FAST Antialias = C.CAIRO_ANTIALIAS_FAST // (since 1.12) + ANTIALIAS_GOOD Antialias = C.CAIRO_ANTIALIAS_GOOD // (since 1.12) + ANTIALIAS_BEST Antialias = C.CAIRO_ANTIALIAS_BEST // (since 1.12) +) + +func marshalAntialias(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Antialias(c), nil +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/cairo.go b/vendor/github.com/gotk3/gotk3/cairo/cairo.go new file mode 100644 index 0000000..ba014bd --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/cairo.go @@ -0,0 +1,65 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// Package cairo implements Go bindings for Cairo. Supports version 1.10 and +// later. +package cairo + +// #cgo pkg-config: cairo cairo-gobject gobject-2.0 +// #include +// #include +// #include +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.cairo_gobject_antialias_get_type()), marshalAntialias}, + {glib.Type(C.cairo_gobject_content_get_type()), marshalContent}, + {glib.Type(C.cairo_gobject_fill_rule_get_type()), marshalFillRule}, + {glib.Type(C.cairo_gobject_line_cap_get_type()), marshalLineCap}, + {glib.Type(C.cairo_gobject_line_join_get_type()), marshalLineJoin}, + {glib.Type(C.cairo_gobject_operator_get_type()), marshalOperator}, + {glib.Type(C.cairo_gobject_status_get_type()), marshalStatus}, + {glib.Type(C.cairo_gobject_surface_type_get_type()), marshalSurfaceType}, + + // Boxed + {glib.Type(C.cairo_gobject_context_get_type()), marshalContext}, + {glib.Type(C.cairo_gobject_surface_get_type()), marshalSurface}, + } + glib.RegisterGValueMarshalers(tm) +} + +// Constants + +// Content is a representation of Cairo's cairo_content_t. +type Content int + +const ( + CONTENT_COLOR Content = C.CAIRO_CONTENT_COLOR + CONTENT_ALPHA Content = C.CAIRO_CONTENT_ALPHA + CONTENT_COLOR_ALPHA Content = C.CAIRO_CONTENT_COLOR_ALPHA +) + +func marshalContent(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Content(c), nil +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/canvas.go b/vendor/github.com/gotk3/gotk3/cairo/canvas.go new file mode 100644 index 0000000..2887c65 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/canvas.go @@ -0,0 +1,423 @@ +package cairo + +// #include +// #include +// #include +import "C" + +import ( + "reflect" + "runtime" + "unsafe" +) + +// Context is a representation of Cairo's cairo_t. +type Context struct { + context *C.cairo_t +} + +// native returns a pointer to the underlying cairo_t. +func (v *Context) native() *C.cairo_t { + if v == nil { + return nil + } + return v.context +} + +func (v *Context) GetCContext() *C.cairo_t { + return v.native() +} + +// Native returns a pointer to the underlying cairo_t. +func (v *Context) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalContext(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + context := (*C.cairo_t)(unsafe.Pointer(c)) + return wrapContext(context), nil +} + +func wrapContext(context *C.cairo_t) *Context { + return &Context{context} +} + +func WrapContext(p uintptr) *Context { + context := (*C.cairo_t)(unsafe.Pointer(p)) + return wrapContext(context) +} + +// Closes the context. The context must not be used afterwards. +func (v *Context) Close() { + v.destroy() +} + +// Create is a wrapper around cairo_create(). +func Create(target *Surface) *Context { + c := C.cairo_create(target.native()) + ctx := wrapContext(c) + runtime.SetFinalizer(ctx, (*Context).destroy) + return ctx +} + +// reference is a wrapper around cairo_reference(). +func (v *Context) reference() { + v.context = C.cairo_reference(v.native()) +} + +// destroy is a wrapper around cairo_destroy(). +func (v *Context) destroy() { + if v.context != nil { + C.cairo_destroy(v.native()) + v.context = nil + } +} + +// Status is a wrapper around cairo_status(). +func (v *Context) Status() Status { + c := C.cairo_status(v.native()) + return Status(c) +} + +// Save is a wrapper around cairo_save(). +func (v *Context) Save() { + C.cairo_save(v.native()) +} + +// Restore is a wrapper around cairo_restore(). +func (v *Context) Restore() { + C.cairo_restore(v.native()) +} + +// GetTarget is a wrapper around cairo_get_target(). +func (v *Context) GetTarget() *Surface { + c := C.cairo_get_target(v.native()) + s := wrapSurface(c) + s.reference() + runtime.SetFinalizer(s, (*Surface).destroy) + return s +} + +// PushGroup is a wrapper around cairo_push_group(). +func (v *Context) PushGroup() { + C.cairo_push_group(v.native()) +} + +// PushGroupWithContent is a wrapper around cairo_push_group_with_content(). +func (v *Context) PushGroupWithContent(content Content) { + C.cairo_push_group_with_content(v.native(), C.cairo_content_t(content)) +} + +// TODO(jrick) PopGroup (depends on Pattern) +// cairo_pop_group + +// PopGroupToSource is a wrapper around cairo_pop_group_to_source(). +func (v *Context) PopGroupToSource() { + C.cairo_pop_group_to_source(v.native()) +} + +// GetGroupTarget is a wrapper around cairo_get_group_target(). +func (v *Context) GetGroupTarget() *Surface { + c := C.cairo_get_group_target(v.native()) + s := wrapSurface(c) + s.reference() + runtime.SetFinalizer(s, (*Surface).destroy) + return s +} + +// SetSource is a wrapper around cairo_set_source(). +func (v *Context) SetSource(p *Pattern) { + C.cairo_set_source(v.native(), p.native()) +} + +// SetSourceRGB is a wrapper around cairo_set_source_rgb(). +func (v *Context) SetSourceRGB(red, green, blue float64) { + C.cairo_set_source_rgb(v.native(), C.double(red), C.double(green), + C.double(blue)) +} + +// SetSourceRGBA is a wrapper around cairo_set_source_rgba(). +func (v *Context) SetSourceRGBA(red, green, blue, alpha float64) { + C.cairo_set_source_rgba(v.native(), C.double(red), C.double(green), + C.double(blue), C.double(alpha)) +} + +// TODO(jrick) SetSource (depends on Pattern) +// cairo_set_source + +// SetSourceSurface is a wrapper around cairo_set_source_surface(). +func (v *Context) SetSourceSurface(surface *Surface, x, y float64) { + C.cairo_set_source_surface(v.native(), surface.native(), C.double(x), + C.double(y)) +} + +// TODO(jrick) GetSource (depends on Pattern) +// cairo_get_source + +// SetAntialias is a wrapper around cairo_set_antialias(). +func (v *Context) SetAntialias(antialias Antialias) { + C.cairo_set_antialias(v.native(), C.cairo_antialias_t(antialias)) +} + +// GetAntialias is a wrapper around cairo_get_antialias(). +func (v *Context) GetAntialias() Antialias { + c := C.cairo_get_antialias(v.native()) + return Antialias(c) +} + +// SetDash is a wrapper around cairo_set_dash(). +func (v *Context) SetDash(dashes []float64, offset float64) { + header := (*reflect.SliceHeader)(unsafe.Pointer(&dashes)) + cdashes := (*C.double)(unsafe.Pointer(header.Data)) + C.cairo_set_dash(v.native(), cdashes, C.int(header.Len), + C.double(offset)) +} + +// GetDashCount is a wrapper around cairo_get_dash_count(). +func (v *Context) GetDashCount() int { + c := C.cairo_get_dash_count(v.native()) + return int(c) +} + +// GetDash is a wrapper around cairo_get_dash(). +func (v *Context) GetDash() (dashes []float64, offset float64) { + dashCount := v.GetDashCount() + cdashes := (*C.double)(C.calloc(8, C.size_t(dashCount))) + var coffset C.double + C.cairo_get_dash(v.native(), cdashes, &coffset) + header := (*reflect.SliceHeader)((unsafe.Pointer(&dashes))) + header.Data = uintptr(unsafe.Pointer(cdashes)) + header.Len = dashCount + header.Cap = dashCount + return dashes, float64(coffset) +} + +// SetFillRule is a wrapper around cairo_set_fill_rule(). +func (v *Context) SetFillRule(fillRule FillRule) { + C.cairo_set_fill_rule(v.native(), C.cairo_fill_rule_t(fillRule)) +} + +// GetFillRule is a wrapper around cairo_get_fill_rule(). +func (v *Context) GetFillRule() FillRule { + c := C.cairo_get_fill_rule(v.native()) + return FillRule(c) +} + +// SetLineCap is a wrapper around cairo_set_line_cap(). +func (v *Context) SetLineCap(lineCap LineCap) { + C.cairo_set_line_cap(v.native(), C.cairo_line_cap_t(lineCap)) +} + +// GetLineCap is a wrapper around cairo_get_line_cap(). +func (v *Context) GetLineCap() LineCap { + c := C.cairo_get_line_cap(v.native()) + return LineCap(c) +} + +// SetLineJoin is a wrapper around cairo_set_line_join(). +func (v *Context) SetLineJoin(lineJoin LineJoin) { + C.cairo_set_line_join(v.native(), C.cairo_line_join_t(lineJoin)) +} + +// GetLineJoin is a wrapper around cairo_get_line_join(). +func (v *Context) GetLineJoin() LineJoin { + c := C.cairo_get_line_join(v.native()) + return LineJoin(c) +} + +// SetLineWidth is a wrapper around cairo_set_line_width(). +func (v *Context) SetLineWidth(width float64) { + C.cairo_set_line_width(v.native(), C.double(width)) +} + +// GetLineWidth is a wrapper cairo_get_line_width(). +func (v *Context) GetLineWidth() float64 { + c := C.cairo_get_line_width(v.native()) + return float64(c) +} + +// SetMiterLimit is a wrapper around cairo_set_miter_limit(). +func (v *Context) SetMiterLimit(limit float64) { + C.cairo_set_miter_limit(v.native(), C.double(limit)) +} + +// GetMiterLimit is a wrapper around cairo_get_miter_limit(). +func (v *Context) GetMiterLimit() float64 { + c := C.cairo_get_miter_limit(v.native()) + return float64(c) +} + +// SetOperator is a wrapper around cairo_set_operator(). +func (v *Context) SetOperator(op Operator) { + C.cairo_set_operator(v.native(), C.cairo_operator_t(op)) +} + +// GetOperator is a wrapper around cairo_get_operator(). +func (v *Context) GetOperator() Operator { + c := C.cairo_get_operator(v.native()) + return Operator(c) +} + +// SetTolerance is a wrapper around cairo_set_tolerance(). +func (v *Context) SetTolerance(tolerance float64) { + C.cairo_set_tolerance(v.native(), C.double(tolerance)) +} + +// GetTolerance is a wrapper around cairo_get_tolerance(). +func (v *Context) GetTolerance() float64 { + c := C.cairo_get_tolerance(v.native()) + return float64(c) +} + +// Clip is a wrapper around cairo_clip(). +func (v *Context) Clip() { + C.cairo_clip(v.native()) +} + +// ClipPreserve is a wrapper around cairo_clip_preserve(). +func (v *Context) ClipPreserve() { + C.cairo_clip_preserve(v.native()) +} + +// ClipExtents is a wrapper around cairo_clip_extents(). +func (v *Context) ClipExtents() (x1, y1, x2, y2 float64) { + var cx1, cy1, cx2, cy2 C.double + C.cairo_clip_extents(v.native(), &cx1, &cy1, &cx2, &cy2) + return float64(cx1), float64(cy1), float64(cx2), float64(cy2) +} + +// InClip is a wrapper around cairo_in_clip(). +func (v *Context) InClip(x, y float64) bool { + c := C.cairo_in_clip(v.native(), C.double(x), C.double(y)) + return gobool(c) +} + +// ResetClip is a wrapper around cairo_reset_clip(). +func (v *Context) ResetClip() { + C.cairo_reset_clip(v.native()) +} + +// Rectangle is a wrapper around cairo_rectangle(). +func (v *Context) Rectangle(x, y, w, h float64) { + C.cairo_rectangle(v.native(), C.double(x), C.double(y), C.double(w), C.double(h)) +} + +// Arc is a wrapper around cairo_arc(). +func (v *Context) Arc(xc, yc, radius, angle1, angle2 float64) { + C.cairo_arc(v.native(), C.double(xc), C.double(yc), C.double(radius), C.double(angle1), C.double(angle2)) +} + +// ArcNegative is a wrapper around cairo_arc_negative(). +func (v *Context) ArcNegative(xc, yc, radius, angle1, angle2 float64) { + C.cairo_arc_negative(v.native(), C.double(xc), C.double(yc), C.double(radius), C.double(angle1), C.double(angle2)) +} + +// LineTo is a wrapper around cairo_line_to(). +func (v *Context) LineTo(x, y float64) { + C.cairo_line_to(v.native(), C.double(x), C.double(y)) +} + +// CurveTo is a wrapper around cairo_curve_to(). +func (v *Context) CurveTo(x1, y1, x2, y2, x3, y3 float64) { + C.cairo_curve_to(v.native(), C.double(x1), C.double(y1), C.double(x2), C.double(y2), C.double(x3), C.double(y3)) +} + +// MoveTo is a wrapper around cairo_move_to(). +func (v *Context) MoveTo(x, y float64) { + C.cairo_move_to(v.native(), C.double(x), C.double(y)) +} + +// TODO(jrick) CopyClipRectangleList (depends on RectangleList) +// cairo_copy_clip_rectangle_list + +// Fill is a wrapper around cairo_fill(). +func (v *Context) Fill() { + C.cairo_fill(v.native()) +} + +// ClosePath is a wrapper around cairo_close_path(). +func (v *Context) ClosePath() { + C.cairo_close_path(v.native()) +} + +// NewPath is a wrapper around cairo_new_path(). +func (v *Context) NewPath() { + C.cairo_new_path(v.native()) +} + +// GetCurrentPoint is a wrapper around cairo_get_current_point(). +func (v *Context) GetCurrentPoint() (x, y float64) { + C.cairo_get_current_point(v.native(), (*C.double)(&x), (*C.double)(&y)) + return +} + +// FillPreserve is a wrapper around cairo_fill_preserve(). +func (v *Context) FillPreserve() { + C.cairo_fill_preserve(v.native()) +} + +// FillExtents is a wrapper around cairo_fill_extents(). +func (v *Context) FillExtents() (x1, y1, x2, y2 float64) { + var cx1, cy1, cx2, cy2 C.double + C.cairo_fill_extents(v.native(), &cx1, &cy1, &cx2, &cy2) + return float64(cx1), float64(cy1), float64(cx2), float64(cy2) +} + +// InFill is a wrapper around cairo_in_fill(). +func (v *Context) InFill(x, y float64) bool { + c := C.cairo_in_fill(v.native(), C.double(x), C.double(y)) + return gobool(c) +} + +// TODO(jrick) Mask (depends on Pattern) +// cairo_mask_surface + +// MaskSurface is a wrapper around cairo_mask_surface(). +func (v *Context) MaskSurface(surface *Surface, surfaceX, surfaceY float64) { + C.cairo_mask_surface(v.native(), surface.native(), C.double(surfaceX), + C.double(surfaceY)) +} + +// Paint is a wrapper around cairo_paint(). +func (v *Context) Paint() { + C.cairo_paint(v.native()) +} + +// PaintWithAlpha is a wrapper around cairo_paint_with_alpha(). +func (v *Context) PaintWithAlpha(alpha float64) { + C.cairo_paint_with_alpha(v.native(), C.double(alpha)) +} + +// Stroke is a wrapper around cairo_stroke(). +func (v *Context) Stroke() { + C.cairo_stroke(v.native()) +} + +// StrokePreserve is a wrapper around cairo_stroke_preserve(). +func (v *Context) StrokePreserve() { + C.cairo_stroke_preserve(v.native()) +} + +// StrokeExtents is a wrapper around cairo_stroke_extents(). +func (v *Context) StrokeExtents() (x1, y1, x2, y2 float64) { + var cx1, cy1, cx2, cy2 C.double + C.cairo_stroke_extents(v.native(), &cx1, &cy1, &cx2, &cy2) + return float64(cx1), float64(cy1), float64(cx2), float64(cy2) +} + +// InStroke is a wrapper around cairo_in_stroke(). +func (v *Context) InStroke(x, y float64) bool { + c := C.cairo_in_stroke(v.native(), C.double(x), C.double(y)) + return gobool(c) +} + +// CopyPage is a wrapper around cairo_copy_page(). +func (v *Context) CopyPage() { + C.cairo_copy_page(v.native()) +} + +// ShowPage is a wrapper around cairo_show_page(). +func (v *Context) ShowPage() { + C.cairo_show_page(v.native()) +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/errors.go b/vendor/github.com/gotk3/gotk3/cairo/errors.go new file mode 100644 index 0000000..1e48a8a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/errors.go @@ -0,0 +1,7 @@ +package cairo + +type ErrorStatus Status + +func (e ErrorStatus) Error() string { + return StatusToString(Status(e)) +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/fillrule.go b/vendor/github.com/gotk3/gotk3/cairo/fillrule.go new file mode 100644 index 0000000..c0e3ba4 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/fillrule.go @@ -0,0 +1,22 @@ +package cairo + +// #include +// #include +// #include +import "C" +import ( + "unsafe" +) + +// FillRule is a representation of Cairo's cairo_fill_rule_t. +type FillRule int + +const ( + FILL_RULE_WINDING FillRule = C.CAIRO_FILL_RULE_WINDING + FILL_RULE_EVEN_ODD FillRule = C.CAIRO_FILL_RULE_EVEN_ODD +) + +func marshalFillRule(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return FillRule(c), nil +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/format.go b/vendor/github.com/gotk3/gotk3/cairo/format.go new file mode 100644 index 0000000..a1be678 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/format.go @@ -0,0 +1,33 @@ +package cairo + +// #include +// #include +// #include +import "C" +import ( + "unsafe" +) + +// Format is a representation of Cairo's cairo_format_t. +type Format int + +const ( + FORMAT_INVALID Format = C.CAIRO_FORMAT_INVALID + FORMAT_ARGB32 Format = C.CAIRO_FORMAT_ARGB32 + FORMAT_RGB24 Format = C.CAIRO_FORMAT_RGB24 + FORMAT_A8 Format = C.CAIRO_FORMAT_A8 + FORMAT_A1 Format = C.CAIRO_FORMAT_A1 + FORMAT_RGB16_565 Format = C.CAIRO_FORMAT_RGB16_565 + FORMAT_RGB30 Format = C.CAIRO_FORMAT_RGB30 +) + +func marshalFormat(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Format(c), nil +} + +// FormatStrideForWidth is a wrapper for cairo_format_stride_for_width(). +func FormatStrideForWidth(format Format, width int) int { + c := C.cairo_format_stride_for_width(C.cairo_format_t(format), C.int(width)) + return int(c) +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/linecap.go b/vendor/github.com/gotk3/gotk3/cairo/linecap.go new file mode 100644 index 0000000..553465a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/linecap.go @@ -0,0 +1,23 @@ +package cairo + +// #include +// #include +// #include +import "C" +import ( + "unsafe" +) + +// LineCap is a representation of Cairo's cairo_line_cap_t. +type LineCap int + +const ( + LINE_CAP_BUTT LineCap = C.CAIRO_LINE_CAP_BUTT + LINE_CAP_ROUND LineCap = C.CAIRO_LINE_CAP_ROUND + LINE_CAP_SQUARE LineCap = C.CAIRO_LINE_CAP_SQUARE +) + +func marshalLineCap(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return LineCap(c), nil +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/linejoin.go b/vendor/github.com/gotk3/gotk3/cairo/linejoin.go new file mode 100644 index 0000000..3a05920 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/linejoin.go @@ -0,0 +1,23 @@ +package cairo + +// #include +// #include +// #include +import "C" +import ( + "unsafe" +) + +// LineJoin is a representation of Cairo's cairo_line_join_t. +type LineJoin int + +const ( + LINE_JOIN_MITER LineJoin = C.CAIRO_LINE_JOIN_MITER + LINE_JOIN_ROUND LineJoin = C.CAIRO_LINE_JOIN_ROUND + LINE_JOIN_BEVEL LineJoin = C.CAIRO_LINE_JOIN_BEVEL +) + +func marshalLineJoin(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return LineJoin(c), nil +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/matrix.go b/vendor/github.com/gotk3/gotk3/cairo/matrix.go new file mode 100644 index 0000000..a934df6 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/matrix.go @@ -0,0 +1,98 @@ +package cairo + +// #include +// #include +// #include +import "C" + +import ( + "unsafe" +) + +// Matrix struct +type Matrix struct { + Xx, Yx float64 + Xy, Yy float64 + X0, Y0 float64 +} + +// NewMatrix creates a new identiy matrix +func NewMatrix(xx, yx, xy, yy, x0, y0 float64) *Matrix { + return &Matrix{ + Xx: xx, + Yx: yx, + Xy: xy, + Yy: yy, + X0: x0, + Y0: y0, + } +} + +// Native returns native c pointer to a matrix +func (m *Matrix) native() *C.cairo_matrix_t { + return (*C.cairo_matrix_t)(unsafe.Pointer(m)) +} + +// Native returns native c pointer to a matrix +func (m *Matrix) Native() uintptr { + return uintptr(unsafe.Pointer(m.native())) +} + +// InitIdentity initializes this matrix to identity matrix +func (m *Matrix) InitIdentity() { + C.cairo_matrix_init_identity(m.native()) +} + +// InitTranslate initializes a matrix with the given translation +func (m *Matrix) InitTranslate(tx, ty float64) { + C.cairo_matrix_init_translate(m.native(), C.double(tx), C.double(ty)) +} + +// InitScale initializes a matrix with the give scale +func (m *Matrix) InitScale(sx, sy float64) { + C.cairo_matrix_init_scale(m.native(), C.double(sx), C.double(sy)) +} + +// InitRotate initializes a matrix with the given rotation +func (m *Matrix) InitRotate(radians float64) { + C.cairo_matrix_init_rotate(m.native(), C.double(radians)) +} + +// Translate translates a matrix by the given amount +func (m *Matrix) Translate(tx, ty float64) { + C.cairo_matrix_translate(m.native(), C.double(tx), C.double(ty)) +} + +// Scale scales the matrix by the given amounts +func (m *Matrix) Scale(sx, sy float64) { + C.cairo_matrix_scale(m.native(), C.double(sx), C.double(sy)) +} + +// Rotate rotates the matrix by the given amount +func (m *Matrix) Rotate(radians float64) { + C.cairo_matrix_rotate(m.native(), C.double(radians)) +} + +// Invert inverts the matrix +func (m *Matrix) Invert() { + C.cairo_matrix_invert(m.native()) +} + +// Multiply multiplies the matrix by another matrix +func (m *Matrix) Multiply(a, b Matrix) { + C.cairo_matrix_multiply(m.native(), a.native(), b.native()) +} + +// TransformDistance ... +func (m *Matrix) TransformDistance(dx, dy float64) (float64, float64) { + C.cairo_matrix_transform_distance(m.native(), + (*C.double)(unsafe.Pointer(&dx)), (*C.double)(unsafe.Pointer(&dy))) + return dx, dy +} + +// TransformPoint ... +func (m *Matrix) TransformPoint(x, y float64) (float64, float64) { + C.cairo_matrix_transform_point(m.native(), + (*C.double)(unsafe.Pointer(&x)), (*C.double)(unsafe.Pointer(&y))) + return x, y +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/mimetype.go b/vendor/github.com/gotk3/gotk3/cairo/mimetype.go new file mode 100644 index 0000000..406273e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/mimetype.go @@ -0,0 +1,13 @@ +package cairo + +// MimeType is a representation of Cairo's CAIRO_MIME_TYPE_* +// preprocessor constants. +type MimeType string + +const ( + MIME_TYPE_JP2 MimeType = "image/jp2" + MIME_TYPE_JPEG MimeType = "image/jpeg" + MIME_TYPE_PNG MimeType = "image/png" + MIME_TYPE_URI MimeType = "image/x-uri" + MIME_TYPE_UNIQUE_ID MimeType = "application/x-cairo.uuid" +) diff --git a/vendor/github.com/gotk3/gotk3/cairo/operator.go b/vendor/github.com/gotk3/gotk3/cairo/operator.go new file mode 100644 index 0000000..b71cbf4 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/operator.go @@ -0,0 +1,49 @@ +package cairo + +// #include +// #include +// #include +import "C" +import ( + "unsafe" +) + +// Operator is a representation of Cairo's cairo_operator_t. +type Operator int + +const ( + OPERATOR_CLEAR Operator = C.CAIRO_OPERATOR_CLEAR + OPERATOR_SOURCE Operator = C.CAIRO_OPERATOR_SOURCE + OPERATOR_OVER Operator = C.CAIRO_OPERATOR_OVER + OPERATOR_IN Operator = C.CAIRO_OPERATOR_IN + OPERATOR_OUT Operator = C.CAIRO_OPERATOR_OUT + OPERATOR_ATOP Operator = C.CAIRO_OPERATOR_ATOP + OPERATOR_DEST Operator = C.CAIRO_OPERATOR_DEST + OPERATOR_DEST_OVER Operator = C.CAIRO_OPERATOR_DEST_OVER + OPERATOR_DEST_IN Operator = C.CAIRO_OPERATOR_DEST_IN + OPERATOR_DEST_OUT Operator = C.CAIRO_OPERATOR_DEST_OUT + OPERATOR_DEST_ATOP Operator = C.CAIRO_OPERATOR_DEST_ATOP + OPERATOR_XOR Operator = C.CAIRO_OPERATOR_XOR + OPERATOR_ADD Operator = C.CAIRO_OPERATOR_ADD + OPERATOR_SATURATE Operator = C.CAIRO_OPERATOR_SATURATE + OPERATOR_MULTIPLY Operator = C.CAIRO_OPERATOR_MULTIPLY + OPERATOR_SCREEN Operator = C.CAIRO_OPERATOR_SCREEN + OPERATOR_OVERLAY Operator = C.CAIRO_OPERATOR_OVERLAY + OPERATOR_DARKEN Operator = C.CAIRO_OPERATOR_DARKEN + OPERATOR_LIGHTEN Operator = C.CAIRO_OPERATOR_LIGHTEN + OPERATOR_COLOR_DODGE Operator = C.CAIRO_OPERATOR_COLOR_DODGE + OPERATOR_COLOR_BURN Operator = C.CAIRO_OPERATOR_COLOR_BURN + OPERATOR_HARD_LIGHT Operator = C.CAIRO_OPERATOR_HARD_LIGHT + OPERATOR_SOFT_LIGHT Operator = C.CAIRO_OPERATOR_SOFT_LIGHT + OPERATOR_DIFFERENCE Operator = C.CAIRO_OPERATOR_DIFFERENCE + OPERATOR_EXCLUSION Operator = C.CAIRO_OPERATOR_EXCLUSION + OPERATOR_HSL_HUE Operator = C.CAIRO_OPERATOR_HSL_HUE + OPERATOR_HSL_SATURATION Operator = C.CAIRO_OPERATOR_HSL_SATURATION + OPERATOR_HSL_COLOR Operator = C.CAIRO_OPERATOR_HSL_COLOR + OPERATOR_HSL_LUMINOSITY Operator = C.CAIRO_OPERATOR_HSL_LUMINOSITY +) + +func marshalOperator(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Operator(c), nil +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/pattern.go b/vendor/github.com/gotk3/gotk3/cairo/pattern.go new file mode 100644 index 0000000..229567c --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/pattern.go @@ -0,0 +1,112 @@ +package cairo + +// #include +// #include +// #include +import "C" + +import ( + "runtime" + "unsafe" +) + +//--------------------------------------------[ cairo_pattern_t == Pattern ]-- + +// Pattern is a representation of Cairo's cairo_pattern_t. +type Pattern struct { + pattern *C.cairo_pattern_t +} + +// NewPatternFromRGB is a wrapper around cairo_pattern_create_rgb(). +func NewPatternFromRGB(red, green, blue float64) (*Pattern, error) { + c := C.cairo_pattern_create_rgb(C.double(red), C.double(green), C.double(blue)) + return newPatternFromNative(c) +} + +// NewPatternFromRGBA is a wrapper around cairo_pattern_create_rgba(). +func NewPatternFromRGBA(red, green, blue, alpha float64) (*Pattern, error) { + c := C.cairo_pattern_create_rgba(C.double(red), C.double(green), C.double(blue), C.double(alpha)) + return newPatternFromNative(c) +} + +// NewPatternForSurface is a wrapper around cairo_pattern_create_for_surface(). +func NewPatternForSurface(s *Surface) (*Pattern, error) { + c := C.cairo_pattern_create_for_surface(s.native()) + return newPatternFromNative(c) +} + +// NewPatternLinear is a wrapper around cairo_pattern_create_linear(). +func NewPatternLinear(x0, y0, x1, y1 float64) (*Pattern, error) { + c := C.cairo_pattern_create_linear(C.double(x0), C.double(y0), C.double(x1), C.double(y1)) + return newPatternFromNative(c) +} + +// NewPatternRadial is a wrapper around cairo_pattern_create_radial(). +func NewPatternRadial(x0, y0, r0, x1, y1, r1 float64) (*Pattern, error) { + c := C.cairo_pattern_create_radial(C.double(x0), C.double(y0), C.double(r0), + C.double(x1), C.double(y1), C.double(r1)) + return newPatternFromNative(c) +} + +func newPatternFromNative(patternNative *C.cairo_pattern_t) (*Pattern, error) { + ptr := wrapPattern(patternNative) + e := ptr.Status().ToError() + if e != nil { + return nil, e + } + runtime.SetFinalizer(ptr, (*Pattern).destroy) + return ptr, nil +} + +// native returns a pointer to the underlying cairo_pattern_t. +func (v *Pattern) native() *C.cairo_pattern_t { + if v == nil { + return nil + } + return v.pattern +} + +// Native returns a pointer to the underlying cairo_pattern_t. +func (v *Pattern) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalPattern(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + pattern := (*C.cairo_pattern_t)(unsafe.Pointer(c)) + return wrapPattern(pattern), nil +} + +func wrapPattern(pattern *C.cairo_pattern_t) *Pattern { + return &Pattern{pattern} +} + +// reference is a wrapper around cairo_pattern_reference(). +func (v *Pattern) reference() { + v.pattern = C.cairo_pattern_reference(v.native()) +} + +// destroy is a wrapper around cairo_pattern_destroy(). +func (v *Pattern) destroy() { + C.cairo_pattern_destroy(v.native()) +} + +// Status is a wrapper around cairo_pattern_status(). +func (v *Pattern) Status() Status { + c := C.cairo_pattern_status(v.native()) + return Status(c) +} + +// AddColorStopRGB is a wrapper around cairo_pattern_add_color_stop_rgb(). +func (v *Pattern) AddColorStopRGB(offset, red, green, blue float64) error { + C.cairo_pattern_add_color_stop_rgb(v.native(), C.double(offset), + C.double(red), C.double(green), C.double(blue)) + return v.Status().ToError() +} + +// AddColorStopRGBA is a wrapper around cairo_pattern_add_color_stop_rgba(). +func (v *Pattern) AddColorStopRGBA(offset, red, green, blue, alpha float64) error { + C.cairo_pattern_add_color_stop_rgba(v.native(), C.double(offset), + C.double(red), C.double(green), C.double(blue), C.double(alpha)) + return v.Status().ToError() +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/region.go b/vendor/github.com/gotk3/gotk3/cairo/region.go new file mode 100644 index 0000000..d3e36d0 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/region.go @@ -0,0 +1,381 @@ +// region.go + +package cairo + +// #include +// #include +import "C" + +import ( + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.cairo_gobject_region_overlap_get_type()), marshalRegionOverlap}, + + // Boxed + {glib.Type(C.cairo_gobject_region_get_type()), marshalRegion}, + } + glib.RegisterGValueMarshalers(tm) +} + +// RegionOverlap is a representation of Cairo's cairo_region_overlap_t. +type RegionOverlap int + +const ( + REGION_OVERLAP_IN RegionOverlap = C.CAIRO_REGION_OVERLAP_IN + REGION_OVERLAP_OUT RegionOverlap = C.CAIRO_REGION_OVERLAP_OUT + REGION_OVERLAP_PART RegionOverlap = C.CAIRO_REGION_OVERLAP_PART +) + +func marshalRegionOverlap(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return RegionOverlap(c), nil +} + +/* + * Rectangle + */ + +// Rectangle is a representation of Cairo's cairo_rectangle_int_t. +type Rectangle struct { + X, Y int + Width, Height int +} + +// commodity function to ceate Rectangle cairo object. +func RectangleNew(x, y, width, height int) *Rectangle { + r := new(Rectangle) + r.X = x + r.Y = y + r.Width = width + r.Height = height + return r +} + +func (v *Rectangle) native() *C.cairo_rectangle_int_t { + r := new(C.cairo_rectangle_int_t) + r.x = C.int(v.X) + r.y = C.int(v.Y) + r.width = C.int(v.Width) + r.height = C.int(v.Height) + return r +} + +func toRectangle(cr *C.cairo_rectangle_int_t) *Rectangle { + return &Rectangle{ + X: int(cr.x), Y: int(cr.y), + Width: int(cr.width), Height: int(cr.height)} +} + +/* + * Region + */ + +// Region is a representation of Cairo's cairo_region_t. +type Region struct { + region *C.cairo_region_t +} + +// native returns a pointer to the underlying cairo_region_t. +func (v *Region) native() *C.cairo_region_t { + if v == nil { + return nil + } + return v.region +} + +// Native returns a pointer to the underlying cairo_region_t. +func (v *Region) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalRegion(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + region := (*C.cairo_region_t)(unsafe.Pointer(c)) + return wrapRegion(region), nil +} + +func wrapRegion(region *C.cairo_region_t) *Region { + return &Region{region} +} + +// newRegionFromNative that handle finalizer. +func newRegionFromNative(regionNative *C.cairo_region_t) (*Region, error) { + ptr := wrapRegion(regionNative) + e := ptr.Status().ToError() + if e != nil { + return nil, e + } + runtime.SetFinalizer(ptr, (*Region).destroy) + return ptr, nil +} + +// RegionCreate is a wrapper around cairo_region_create(). +func RegionCreate() (*Region, error) { + + return newRegionFromNative(C.cairo_region_create()) +} + +// CreateRectangle is a wrapper around cairo_region_create_rectangle(). +func (v *Region) CreateRectangle(rectangle *Rectangle) (*Region, error) { + + return newRegionFromNative(C.cairo_region_create_rectangle( + rectangle.native())) +} + +// CreateRectangles is a wrapper around cairo_region_create_rectangles(). +func (v *Region) CreateRectangles(rectangles ...*Rectangle) (*Region, error) { + + length := len(rectangles) + + cRectangles := make([]C.cairo_rectangle_int_t, length) + + for i := 0; i < length; i++ { + cRectangles[i] = *rectangles[i].native() + } + + pRect := &cRectangles[0] + + return newRegionFromNative( + C.cairo_region_create_rectangles( + pRect, + C.int(length))) +} + +// Copy is a wrapper around cairo_region_copy(). +func (v *Region) Copy() (*Region, error) { + + return newRegionFromNative(C.cairo_region_copy(v.native())) +} + +// reference is a wrapper around cairo_region_reference(). +func (v *Region) reference() { + v.region = C.cairo_region_reference(v.native()) +} + +// destroy is a wrapper around cairo_region_destroy(). +func (v *Region) destroy() { + C.cairo_region_destroy(v.native()) +} + +// Status is a wrapper around cairo_region_status(). +func (v *Region) Status() Status { + c := C.cairo_region_status(v.native()) + return Status(c) +} + +// GetExtents is a wrapper around cairo_region_get_extents(). +func (v *Region) GetExtents(extents *Rectangle) { + + C.cairo_region_get_extents(v.native(), extents.native()) +} + +// NumRectangles is a wrapper around cairo_region_num_rectangles(). +func (v *Region) NumRectangles() int { + + return int(C.cairo_region_num_rectangles(v.native())) +} + +// GetRectangle is a wrapper around cairo_region_get_rectangle(). +func (v *Region) GetRectangle(nth int) *Rectangle { + + cr := new(C.cairo_rectangle_int_t) + C.cairo_region_get_rectangle(v.native(), C.int(nth), cr) + + return toRectangle(cr) +} + +// IsEmpty is a wrapper around cairo_region_is_empty(). +func (v *Region) IsEmpty() bool { + + return gobool(C.cairo_region_is_empty(v.native())) +} + +// ContainsPoint is a wrapper around cairo_region_contains_point(). +func (v *Region) ContainsPoint(x, y int) bool { + + return gobool(C.cairo_region_contains_point( + v.native(), C.int(x), C.int(y))) +} + +// ContainsRectangle is a wrapper around cairo_region_contains_rectangle(). +func (v *Region) ContainsRectangle(rectangle *Rectangle) RegionOverlap { + + return RegionOverlap( + C.cairo_region_contains_rectangle( + v.native(), rectangle.native())) +} + +// Equal is a wrapper around cairo_region_equal(). +func (v *Region) Equal(region *Region) bool { + + return gobool(C.cairo_region_equal(v.native(), region.native())) +} + +// Translate is a wrapper around cairo_region_translate(). +func (v *Region) Translate(dx, dy int) { + + C.cairo_region_translate(v.native(), C.int(dx), C.int(dy)) +} + +// Intersect is a wrapper around cairo_region_intersect(). +// Note: contrary to the original statement, the source +// 'Region' remains preserved. +func (v *Region) Intersect(other *Region) (*Region, error) { + + dst, err := v.Copy() + if err != nil { + return nil, err + } + err = Status( + C.cairo_region_intersect( + dst.native(), + other.native())).ToError() + if err != nil { + return nil, err + } + + return dst, nil +} + +// IntersectRectangle is a wrapper around cairo_region_intersect_rectangle(). +// Note: contrary to the original statement, the source 'Region' remains preserved. +func (v *Region) IntersectRectangle(rectangle *Rectangle) (*Region, error) { + + dst, err := v.Copy() + if err != nil { + return nil, err + } + err = Status( + C.cairo_region_intersect_rectangle( + dst.native(), + rectangle.native())).ToError() + if err != nil { + return nil, err + } + + return dst, nil +} + +// Substract is a wrapper around cairo_region_subtract(). +// Note: contrary to the original statement, the source +// 'Region' remains preserved. +func (v *Region) Substract(other *Region) (*Region, error) { + + dst, err := v.Copy() + if err != nil { + return nil, err + } + err = Status( + C.cairo_region_subtract( + dst.native(), + other.native())).ToError() + if err != nil { + return nil, err + } + + return dst, nil +} + +// SubstractRectangle is a wrapper around cairo_region_subtract_rectangle(). +// Note: contrary to the original statement, the source 'Region' remains preserved. +func (v *Region) SubstractRectangle(rectangle *Rectangle) (*Region, error) { + + dst, err := v.Copy() + if err != nil { + return nil, err + } + err = Status( + C.cairo_region_subtract_rectangle( + dst.native(), + rectangle.native())).ToError() + if err != nil { + return nil, err + } + + return dst, nil +} + +// Union is a wrapper around cairo_region_union(). +// Note: contrary to the original statement, the source +// 'Region' remains preserved. +func (v *Region) Union(other *Region) (*Region, error) { + + dst, err := v.Copy() + if err != nil { + return nil, err + } + err = Status( + C.cairo_region_union( + dst.native(), + other.native())).ToError() + if err != nil { + return nil, err + } + + return dst, nil +} + +// UnionRectangle is a wrapper around cairo_region_union_rectangle(). +// Note: contrary to the original statement, the source 'Region' remains preserved. +func (v *Region) UnionRectangle(rectangle *Rectangle) (*Region, error) { + + dst, err := v.Copy() + if err != nil { + return nil, err + } + err = Status( + C.cairo_region_union_rectangle( + dst.native(), + rectangle.native())).ToError() + if err != nil { + return nil, err + } + + return dst, nil +} + +// Xor is a wrapper around cairo_region_xor(). +// Note: contrary to the original statement, the source +// 'Region' remains preserved. +func (v *Region) Xor(other *Region) (*Region, error) { + + dst, err := v.Copy() + if err != nil { + return nil, err + } + err = Status( + C.cairo_region_xor( + dst.native(), + other.native())).ToError() + if err != nil { + return nil, err + } + + return dst, nil +} + +// XorRectangle is a wrapper around cairo_region_xor_rectangle(). +// Note: contrary to the original statement, the source 'Region' remains preserved. +func (v *Region) XorRectangle(rectangle *Rectangle) (*Region, error) { + + dst, err := v.Copy() + if err != nil { + return nil, err + } + err = Status( + C.cairo_region_xor_rectangle( + dst.native(), + rectangle.native())).ToError() + if err != nil { + return nil, err + } + + return dst, nil +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/status.go b/vendor/github.com/gotk3/gotk3/cairo/status.go new file mode 100644 index 0000000..64b00c3 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/status.go @@ -0,0 +1,124 @@ +package cairo + +// #include +// #include +// #include +import "C" +import ( + "errors" + "strings" + "unsafe" +) + +// Status is a representation of Cairo's cairo_status_t. +type Status int + +const ( + STATUS_SUCCESS Status = C.CAIRO_STATUS_SUCCESS + STATUS_NO_MEMORY Status = C.CAIRO_STATUS_NO_MEMORY + STATUS_INVALID_RESTORE Status = C.CAIRO_STATUS_INVALID_RESTORE + STATUS_INVALID_POP_GROUP Status = C.CAIRO_STATUS_INVALID_POP_GROUP + STATUS_NO_CURRENT_POINT Status = C.CAIRO_STATUS_NO_CURRENT_POINT + STATUS_INVALID_MATRIX Status = C.CAIRO_STATUS_INVALID_MATRIX + STATUS_INVALID_STATUS Status = C.CAIRO_STATUS_INVALID_STATUS + STATUS_NULL_POINTER Status = C.CAIRO_STATUS_NULL_POINTER + STATUS_INVALID_STRING Status = C.CAIRO_STATUS_INVALID_STRING + STATUS_INVALID_PATH_DATA Status = C.CAIRO_STATUS_INVALID_PATH_DATA + STATUS_READ_ERROR Status = C.CAIRO_STATUS_READ_ERROR + STATUS_WRITE_ERROR Status = C.CAIRO_STATUS_WRITE_ERROR + STATUS_SURFACE_FINISHED Status = C.CAIRO_STATUS_SURFACE_FINISHED + STATUS_SURFACE_TYPE_MISMATCH Status = C.CAIRO_STATUS_SURFACE_TYPE_MISMATCH + STATUS_PATTERN_TYPE_MISMATCH Status = C.CAIRO_STATUS_PATTERN_TYPE_MISMATCH + STATUS_INVALID_CONTENT Status = C.CAIRO_STATUS_INVALID_CONTENT + STATUS_INVALID_FORMAT Status = C.CAIRO_STATUS_INVALID_FORMAT + STATUS_INVALID_VISUAL Status = C.CAIRO_STATUS_INVALID_VISUAL + STATUS_FILE_NOT_FOUND Status = C.CAIRO_STATUS_FILE_NOT_FOUND + STATUS_INVALID_DASH Status = C.CAIRO_STATUS_INVALID_DASH + STATUS_INVALID_DSC_COMMENT Status = C.CAIRO_STATUS_INVALID_DSC_COMMENT + STATUS_INVALID_INDEX Status = C.CAIRO_STATUS_INVALID_INDEX + STATUS_CLIP_NOT_REPRESENTABLE Status = C.CAIRO_STATUS_CLIP_NOT_REPRESENTABLE + STATUS_TEMP_FILE_ERROR Status = C.CAIRO_STATUS_TEMP_FILE_ERROR + STATUS_INVALID_STRIDE Status = C.CAIRO_STATUS_INVALID_STRIDE + STATUS_FONT_TYPE_MISMATCH Status = C.CAIRO_STATUS_FONT_TYPE_MISMATCH + STATUS_USER_FONT_IMMUTABLE Status = C.CAIRO_STATUS_USER_FONT_IMMUTABLE + STATUS_USER_FONT_ERROR Status = C.CAIRO_STATUS_USER_FONT_ERROR + STATUS_NEGATIVE_COUNT Status = C.CAIRO_STATUS_NEGATIVE_COUNT + STATUS_INVALID_CLUSTERS Status = C.CAIRO_STATUS_INVALID_CLUSTERS + STATUS_INVALID_SLANT Status = C.CAIRO_STATUS_INVALID_SLANT + STATUS_INVALID_WEIGHT Status = C.CAIRO_STATUS_INVALID_WEIGHT + STATUS_INVALID_SIZE Status = C.CAIRO_STATUS_INVALID_SIZE + STATUS_USER_FONT_NOT_IMPLEMENTED Status = C.CAIRO_STATUS_USER_FONT_NOT_IMPLEMENTED + STATUS_DEVICE_TYPE_MISMATCH Status = C.CAIRO_STATUS_DEVICE_TYPE_MISMATCH + STATUS_DEVICE_ERROR Status = C.CAIRO_STATUS_DEVICE_ERROR + // STATUS_INVALID_MESH_CONSTRUCTION Status = C.CAIRO_STATUS_INVALID_MESH_CONSTRUCTION (since 1.12) + // STATUS_DEVICE_FINISHED Status = C.CAIRO_STATUS_DEVICE_FINISHED (since 1.12) +) + +var key_Status = map[Status]string{ + + STATUS_SUCCESS: "CAIRO_STATUS_SUCCESS", + STATUS_NO_MEMORY: "CAIRO_STATUS_NO_MEMORY", + STATUS_INVALID_RESTORE: "CAIRO_STATUS_INVALID_RESTORE", + STATUS_INVALID_POP_GROUP: "CAIRO_STATUS_INVALID_POP_GROUP", + STATUS_NO_CURRENT_POINT: "CAIRO_STATUS_NO_CURRENT_POINT", + STATUS_INVALID_MATRIX: "CAIRO_STATUS_INVALID_MATRIX", + STATUS_INVALID_STATUS: "CAIRO_STATUS_INVALID_STATUS", + STATUS_NULL_POINTER: "CAIRO_STATUS_NULL_POINTER", + STATUS_INVALID_STRING: "CAIRO_STATUS_INVALID_STRING", + STATUS_INVALID_PATH_DATA: "CAIRO_STATUS_INVALID_PATH_DATA", + STATUS_READ_ERROR: "CAIRO_STATUS_READ_ERROR", + STATUS_WRITE_ERROR: "CAIRO_STATUS_WRITE_ERROR", + STATUS_SURFACE_FINISHED: "CAIRO_STATUS_SURFACE_FINISHED", + STATUS_SURFACE_TYPE_MISMATCH: "CAIRO_STATUS_SURFACE_TYPE_MISMATCH", + STATUS_PATTERN_TYPE_MISMATCH: "CAIRO_STATUS_PATTERN_TYPE_MISMATCH", + STATUS_INVALID_CONTENT: "CAIRO_STATUS_INVALID_CONTENT", + STATUS_INVALID_FORMAT: "CAIRO_STATUS_INVALID_FORMAT", + STATUS_INVALID_VISUAL: "CAIRO_STATUS_INVALID_VISUAL", + STATUS_FILE_NOT_FOUND: "CAIRO_STATUS_FILE_NOT_FOUND", + STATUS_INVALID_DASH: "CAIRO_STATUS_INVALID_DASH", + STATUS_INVALID_DSC_COMMENT: "CAIRO_STATUS_INVALID_DSC_COMMENT", + STATUS_INVALID_INDEX: "CAIRO_STATUS_INVALID_INDEX", + STATUS_CLIP_NOT_REPRESENTABLE: "CAIRO_STATUS_CLIP_NOT_REPRESENTABLE", + STATUS_TEMP_FILE_ERROR: "CAIRO_STATUS_TEMP_FILE_ERROR", + STATUS_INVALID_STRIDE: "CAIRO_STATUS_INVALID_STRIDE", + STATUS_FONT_TYPE_MISMATCH: "CAIRO_STATUS_FONT_TYPE_MISMATCH", + STATUS_USER_FONT_IMMUTABLE: "CAIRO_STATUS_USER_FONT_IMMUTABLE", + STATUS_USER_FONT_ERROR: "CAIRO_STATUS_USER_FONT_ERROR", + STATUS_NEGATIVE_COUNT: "CAIRO_STATUS_NEGATIVE_COUNT", + STATUS_INVALID_CLUSTERS: "CAIRO_STATUS_INVALID_CLUSTERS", + STATUS_INVALID_SLANT: "CAIRO_STATUS_INVALID_SLANT", + STATUS_INVALID_WEIGHT: "CAIRO_STATUS_INVALID_WEIGHT", + STATUS_INVALID_SIZE: "CAIRO_STATUS_INVALID_SIZE", + STATUS_USER_FONT_NOT_IMPLEMENTED: "CAIRO_STATUS_USER_FONT_NOT_IMPLEMENTED", + STATUS_DEVICE_TYPE_MISMATCH: "CAIRO_STATUS_DEVICE_TYPE_MISMATCH", + STATUS_DEVICE_ERROR: "CAIRO_STATUS_DEVICE_ERROR", +} + +func StatusToString(status Status) string { + s, ok := key_Status[status] + if !ok { + s = "CAIRO_STATUS_UNDEFINED" + } + return s +} + +func marshalStatus(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Status(c), nil +} + +// String returns a readable status messsage usable in texts. +func (s Status) String() string { + str := StatusToString(s) + str = strings.Replace(str, "CAIRO_STATUS_", "", 1) + str = strings.Replace(str, "_", " ", 0) + return strings.ToLower(str) +} + +// ToError returns the error for the status. Returns nil if success. +func (s Status) ToError() error { + if s == STATUS_SUCCESS { + return nil + } + return errors.New(s.String()) +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/surface.go b/vendor/github.com/gotk3/gotk3/cairo/surface.go new file mode 100644 index 0000000..6137529 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/surface.go @@ -0,0 +1,300 @@ +package cairo + +// #include +// #include +// #include +// #include +import "C" + +import ( + "runtime" + "unsafe" +) + +/* + * cairo_surface_t + */ + +// Surface is a representation of Cairo's cairo_surface_t. +type Surface struct { + surface *C.cairo_surface_t +} + +func NewSurfaceFromPNG(fileName string) (*Surface, error) { + + cstr := C.CString(fileName) + defer C.free(unsafe.Pointer(cstr)) + + surfaceNative := C.cairo_image_surface_create_from_png(cstr) + + status := Status(C.cairo_surface_status(surfaceNative)) + if status != STATUS_SUCCESS { + return nil, ErrorStatus(status) + } + + return &Surface{surfaceNative}, nil +} + +// CreateImageSurfaceForData is a wrapper around cairo_image_surface_create_for_data(). +func CreateImageSurfaceForData(data []byte, format Format, width, height, stride int) (*Surface, error) { + surfaceNative := C.cairo_image_surface_create_for_data((*C.uchar)(unsafe.Pointer(&data[0])), + C.cairo_format_t(format), C.int(width), C.int(height), C.int(stride)) + + status := Status(C.cairo_surface_status(surfaceNative)) + if status != STATUS_SUCCESS { + return nil, ErrorStatus(status) + } + + s := wrapSurface(surfaceNative) + + runtime.SetFinalizer(s, (*Surface).destroy) + + return s, nil +} + +// CreateImageSurface is a wrapper around cairo_image_surface_create(). +func CreateImageSurface(format Format, width, height int) *Surface { + c := C.cairo_image_surface_create(C.cairo_format_t(format), + C.int(width), C.int(height)) + s := wrapSurface(c) + runtime.SetFinalizer(s, (*Surface).destroy) + return s +} + +/// Create a new PDF surface. +func CreatePDFSurface(fileName string, width float64, height float64) (*Surface, error) { + cstr := C.CString(fileName) + defer C.free(unsafe.Pointer(cstr)) + + surfaceNative := C.cairo_pdf_surface_create(cstr, C.double(width), C.double(height)) + + status := Status(C.cairo_surface_status(surfaceNative)) + if status != STATUS_SUCCESS { + return nil, ErrorStatus(status) + } + + s := wrapSurface(surfaceNative) + + runtime.SetFinalizer(s, (*Surface).destroy) + + return s, nil +} + +// native returns a pointer to the underlying cairo_surface_t. +func (v *Surface) native() *C.cairo_surface_t { + if v == nil { + return nil + } + return v.surface +} + +// Native returns a pointer to the underlying cairo_surface_t. +func (v *Surface) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *Surface) GetCSurface() *C.cairo_surface_t { + return v.native() +} + +func marshalSurface(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + return WrapSurface(uintptr(c)), nil +} + +func wrapSurface(surface *C.cairo_surface_t) *Surface { + return &Surface{surface} +} + +// NewSurface creates a gotk3 cairo Surface from a pointer to a +// C cairo_surface_t. This is primarily designed for use with other +// gotk3 packages and should be avoided by applications. +func NewSurface(s uintptr, needsRef bool) *Surface { + surface := WrapSurface(s) + if needsRef { + surface.reference() + } + runtime.SetFinalizer(surface, (*Surface).destroy) + return surface +} + +func WrapSurface(s uintptr) *Surface { + ptr := (*C.cairo_surface_t)(unsafe.Pointer(s)) + return wrapSurface(ptr) +} + +// Closes the surface. The surface must not be used afterwards. +func (v *Surface) Close() { + v.destroy() +} + +// CreateSimilar is a wrapper around cairo_surface_create_similar(). +func (v *Surface) CreateSimilar(content Content, width, height int) *Surface { + c := C.cairo_surface_create_similar(v.native(), + C.cairo_content_t(content), C.int(width), C.int(height)) + s := wrapSurface(c) + runtime.SetFinalizer(s, (*Surface).destroy) + return s +} + +// TODO cairo_surface_create_similar_image (since 1.12) + +// CreateForRectangle is a wrapper around cairo_surface_create_for_rectangle(). +func (v *Surface) CreateForRectangle(x, y, width, height float64) *Surface { + c := C.cairo_surface_create_for_rectangle(v.native(), C.double(x), + C.double(y), C.double(width), C.double(height)) + s := wrapSurface(c) + runtime.SetFinalizer(s, (*Surface).destroy) + return s +} + +// reference is a wrapper around cairo_surface_reference(). +func (v *Surface) reference() { + v.surface = C.cairo_surface_reference(v.native()) +} + +// destroy is a wrapper around cairo_surface_destroy(). +func (v *Surface) destroy() { + if v.surface != nil { + C.cairo_surface_destroy(v.native()) + v.surface = nil + } +} + +// Status is a wrapper around cairo_surface_status(). +func (v *Surface) Status() Status { + c := C.cairo_surface_status(v.native()) + return Status(c) +} + +// Flush is a wrapper around cairo_surface_flush(). +func (v *Surface) Flush() { + C.cairo_surface_flush(v.native()) +} + +// TODO(jrick) GetDevice (requires Device bindings) +// cairo_surface_get_device + +// TODO(jrick) GetFontOptions (require FontOptions bindings) +// cairo_surface_get_font_options + +// TODO(jrick) GetContent (requires Content bindings) +// cairo_surface_get_content + +// MarkDirty is a wrapper around cairo_surface_mark_dirty(). +func (v *Surface) MarkDirty() { + C.cairo_surface_mark_dirty(v.native()) +} + +// MarkDirtyRectangle is a wrapper around cairo_surface_mark_dirty_rectangle(). +func (v *Surface) MarkDirtyRectangle(x, y, width, height int) { + C.cairo_surface_mark_dirty_rectangle(v.native(), C.int(x), C.int(y), + C.int(width), C.int(height)) +} + +// SetDeviceOffset is a wrapper around cairo_surface_set_device_offset(). +func (v *Surface) SetDeviceOffset(x, y float64) { + C.cairo_surface_set_device_offset(v.native(), C.double(x), C.double(y)) +} + +// GetDeviceOffset is a wrapper around cairo_surface_get_device_offset(). +func (v *Surface) GetDeviceOffset() (x, y float64) { + var xOffset, yOffset C.double + C.cairo_surface_get_device_offset(v.native(), &xOffset, &yOffset) + return float64(xOffset), float64(yOffset) +} + +// SetFallbackResolution is a wrapper around +// cairo_surface_set_fallback_resolution(). +func (v *Surface) SetFallbackResolution(xPPI, yPPI float64) { + C.cairo_surface_set_fallback_resolution(v.native(), C.double(xPPI), + C.double(yPPI)) +} + +// GetFallbackResolution is a wrapper around cairo_surface_get_fallback_resolution(). +func (v *Surface) GetFallbackResolution() (xPPI, yPPI float64) { + var x, y C.double + C.cairo_surface_get_fallback_resolution(v.native(), &x, &y) + return float64(x), float64(y) +} + +// GetType is a wrapper around cairo_surface_get_type(). +func (v *Surface) GetType() SurfaceType { + c := C.cairo_surface_get_type(v.native()) + return SurfaceType(c) +} + +// TODO(jrick) SetUserData (depends on UserDataKey and DestroyFunc) +// cairo_surface_set_user_data + +// TODO(jrick) GetUserData (depends on UserDataKey) +// cairo_surface_get_user_data + +// CopyPage is a wrapper around cairo_surface_copy_page(). +func (v *Surface) CopyPage() { + C.cairo_surface_copy_page(v.native()) +} + +// ShowPage is a wrapper around cairo_surface_show_page(). +func (v *Surface) ShowPage() { + C.cairo_surface_show_page(v.native()) +} + +// HasShowTextGlyphs is a wrapper around cairo_surface_has_show_text_glyphs(). +func (v *Surface) HasShowTextGlyphs() bool { + c := C.cairo_surface_has_show_text_glyphs(v.native()) + return gobool(c) +} + +// TODO(jrick) SetMimeData (depends on DestroyFunc) +// cairo_surface_set_mime_data + +// GetMimeData is a wrapper around cairo_surface_get_mime_data(). The +// returned mimetype data is returned as a Go byte slice. +func (v *Surface) GetMimeData(mimeType MimeType) []byte { + cstr := C.CString(string(mimeType)) + defer C.free(unsafe.Pointer(cstr)) + var data *C.uchar + var length C.ulong + C.cairo_surface_get_mime_data(v.native(), cstr, &data, &length) + return C.GoBytes(unsafe.Pointer(data), C.int(length)) +} + +// WriteToPNG is a wrapper around cairo_surface_write_png(). It writes the Cairo +// surface to the given file in PNG format. +func (v *Surface) WriteToPNG(fileName string) error { + cstr := C.CString(fileName) + defer C.free(unsafe.Pointer(cstr)) + + status := Status(C.cairo_surface_write_to_png(v.surface, cstr)) + + if status != STATUS_SUCCESS { + return ErrorStatus(status) + } + + return nil +} + +// TODO(jrick) SupportsMimeType (since 1.12) +// cairo_surface_supports_mime_type + +// TODO(jrick) MapToImage (since 1.12) +// cairo_surface_map_to_image + +// TODO(jrick) UnmapImage (since 1.12) +// cairo_surface_unmap_image + +// GetHeight is a wrapper around cairo_image_surface_get_height(). +func (v *Surface) GetHeight() int { + return int(C.cairo_image_surface_get_height(v.surface)) +} + +// GetWidth is a wrapper around cairo_image_surface_get_width(). +func (v *Surface) GetWidth() int { + return int(C.cairo_image_surface_get_width(v.surface)) +} + +// GetData is a wrapper around cairo_image_surface_get_data(). +func (v *Surface) GetData() unsafe.Pointer { + return unsafe.Pointer(C.cairo_image_surface_get_data(v.surface)) +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/surfacetype.go b/vendor/github.com/gotk3/gotk3/cairo/surfacetype.go new file mode 100644 index 0000000..a1421eb --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/surfacetype.go @@ -0,0 +1,45 @@ +package cairo + +// #include +// #include +// #include +import "C" +import ( + "unsafe" +) + +// SurfaceType is a representation of Cairo's cairo_surface_type_t. +type SurfaceType int + +const ( + SURFACE_TYPE_IMAGE SurfaceType = C.CAIRO_SURFACE_TYPE_IMAGE + SURFACE_TYPE_PDF SurfaceType = C.CAIRO_SURFACE_TYPE_PDF + SURFACE_TYPE_PS SurfaceType = C.CAIRO_SURFACE_TYPE_PS + SURFACE_TYPE_XLIB SurfaceType = C.CAIRO_SURFACE_TYPE_XLIB + SURFACE_TYPE_XCB SurfaceType = C.CAIRO_SURFACE_TYPE_XCB + SURFACE_TYPE_GLITZ SurfaceType = C.CAIRO_SURFACE_TYPE_GLITZ + SURFACE_TYPE_QUARTZ SurfaceType = C.CAIRO_SURFACE_TYPE_QUARTZ + SURFACE_TYPE_WIN32 SurfaceType = C.CAIRO_SURFACE_TYPE_WIN32 + SURFACE_TYPE_BEOS SurfaceType = C.CAIRO_SURFACE_TYPE_BEOS + SURFACE_TYPE_DIRECTFB SurfaceType = C.CAIRO_SURFACE_TYPE_DIRECTFB + SURFACE_TYPE_SVG SurfaceType = C.CAIRO_SURFACE_TYPE_SVG + SURFACE_TYPE_OS2 SurfaceType = C.CAIRO_SURFACE_TYPE_OS2 + SURFACE_TYPE_WIN32_PRINTING SurfaceType = C.CAIRO_SURFACE_TYPE_WIN32_PRINTING + SURFACE_TYPE_QUARTZ_IMAGE SurfaceType = C.CAIRO_SURFACE_TYPE_QUARTZ_IMAGE + SURFACE_TYPE_SCRIPT SurfaceType = C.CAIRO_SURFACE_TYPE_SCRIPT + SURFACE_TYPE_QT SurfaceType = C.CAIRO_SURFACE_TYPE_QT + SURFACE_TYPE_RECORDING SurfaceType = C.CAIRO_SURFACE_TYPE_RECORDING + SURFACE_TYPE_VG SurfaceType = C.CAIRO_SURFACE_TYPE_VG + SURFACE_TYPE_GL SurfaceType = C.CAIRO_SURFACE_TYPE_GL + SURFACE_TYPE_DRM SurfaceType = C.CAIRO_SURFACE_TYPE_DRM + SURFACE_TYPE_TEE SurfaceType = C.CAIRO_SURFACE_TYPE_TEE + SURFACE_TYPE_XML SurfaceType = C.CAIRO_SURFACE_TYPE_XML + SURFACE_TYPE_SKIA SurfaceType = C.CAIRO_SURFACE_TYPE_SKIA + SURFACE_TYPE_SUBSURFACE SurfaceType = C.CAIRO_SURFACE_TYPE_SUBSURFACE + // SURFACE_TYPE_COGL SurfaceType = C.CAIRO_SURFACE_TYPE_COGL (since 1.12) +) + +func marshalSurfaceType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return SurfaceType(c), nil +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/text.go b/vendor/github.com/gotk3/gotk3/cairo/text.go new file mode 100644 index 0000000..ab0e201 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/text.go @@ -0,0 +1,125 @@ +package cairo + +// #include +// #include +// #include +import "C" + +import ( + "unsafe" +) + +// FontSlant is a representation of Cairo's cairo_font_slant_t +type FontSlant int + +const ( + FONT_SLANT_NORMAL FontSlant = C.CAIRO_FONT_SLANT_NORMAL + FONT_SLANT_ITALIC FontSlant = C.CAIRO_FONT_SLANT_ITALIC + FONT_SLANT_OBLIQUE FontSlant = C.CAIRO_FONT_SLANT_OBLIQUE +) + +// FontWeight is a representation of Cairo's cairo_font_weight_t +type FontWeight int + +const ( + FONT_WEIGHT_NORMAL FontWeight = C.CAIRO_FONT_WEIGHT_NORMAL + FONT_WEIGHT_BOLD FontWeight = C.CAIRO_FONT_WEIGHT_BOLD +) + +func (v *Context) SelectFontFace(family string, slant FontSlant, weight FontWeight) { + cstr := C.CString(family) + defer C.free(unsafe.Pointer(cstr)) + C.cairo_select_font_face(v.native(), (*C.char)(cstr), C.cairo_font_slant_t(slant), C.cairo_font_weight_t(weight)) +} + +func (v *Context) SetFontSize(size float64) { + C.cairo_set_font_size(v.native(), C.double(size)) +} + +// TODO: cairo_set_font_matrix + +// TODO: cairo_get_font_matrix + +// TODO: cairo_set_font_options + +// TODO: cairo_get_font_options + +// TODO: cairo_set_font_face + +// TODO: cairo_get_font_face + +// TODO: cairo_set_scaled_font + +// TODO: cairo_get_scaled_font + +func (v *Context) ShowText(utf8 string) { + cstr := C.CString(utf8) + defer C.free(unsafe.Pointer(cstr)) + C.cairo_show_text(v.native(), (*C.char)(cstr)) +} + +// TODO: cairo_show_glyphs + +// TODO: cairo_show_text_glyphs + +type FontExtents struct { + Ascent float64 + Descent float64 + Height float64 + MaxXAdvance float64 + MaxYAdvance float64 +} + +func (v *Context) FontExtents() FontExtents { + var extents C.cairo_font_extents_t + C.cairo_font_extents(v.native(), &extents) + return FontExtents{ + Ascent: float64(extents.ascent), + Descent: float64(extents.descent), + Height: float64(extents.height), + MaxXAdvance: float64(extents.max_x_advance), + MaxYAdvance: float64(extents.max_y_advance), + } +} + +type TextExtents struct { + XBearing float64 + YBearing float64 + Width float64 + Height float64 + XAdvance float64 + YAdvance float64 +} + +func (v *Context) TextExtents(utf8 string) TextExtents { + cstr := C.CString(utf8) + defer C.free(unsafe.Pointer(cstr)) + var extents C.cairo_text_extents_t + C.cairo_text_extents(v.native(), (*C.char)(cstr), &extents) + return TextExtents{ + XBearing: float64(extents.x_bearing), + YBearing: float64(extents.y_bearing), + Width: float64(extents.width), + Height: float64(extents.height), + XAdvance: float64(extents.x_advance), + YAdvance: float64(extents.y_advance), + } +} + +// TODO: cairo_glyph_extents + +// TODO: cairo_toy_font_face_create + +// TODO: cairo_toy_font_face_get_family + +// TODO: cairo_toy_font_face_get_slant + +// TODO: cairo_toy_font_face_get_weight + +// TODO: cairo_glyph_allocate + +// TODO: cairo_glyph_free + +// TODO: cairo_text_cluster_allocate + +// TODO: cairo_text_cluster_free diff --git a/vendor/github.com/gotk3/gotk3/cairo/translations.go b/vendor/github.com/gotk3/gotk3/cairo/translations.go new file mode 100644 index 0000000..bfe5ad8 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/translations.go @@ -0,0 +1,78 @@ +package cairo + +// #include +// #include +// #include +import "C" + +// Translate is a wrapper around cairo_translate. +func (v *Context) Translate(tx, ty float64) { + C.cairo_translate(v.native(), C.double(tx), C.double(ty)) +} + +// Scale is a wrapper around cairo_scale. +func (v *Context) Scale(sx, sy float64) { + C.cairo_scale(v.native(), C.double(sx), C.double(sy)) +} + +// Rotate is a wrapper around cairo_rotate. +func (v *Context) Rotate(angle float64) { + C.cairo_rotate(v.native(), C.double(angle)) +} + +// Transform is a wrapper around cairo_transform. +func (v *Context) Transform(matrix *Matrix) { + C.cairo_transform(v.native(), matrix.native()) +} + +// SetMatrix is a wrapper around cairo_set_matrix. +func (v *Context) SetMatrix(matrix *Matrix) { + C.cairo_set_matrix(v.native(), matrix.native()) +} + +// GetMatrix is a wrapper around cairo_get_matrix. +func (v *Context) GetMatrix() *Matrix { + var matrix C.cairo_matrix_t + C.cairo_get_matrix(v.native(), &matrix) + return &Matrix{ + Xx: float64(matrix.xx), + Yx: float64(matrix.yx), + Xy: float64(matrix.xy), + Yy: float64(matrix.yy), + X0: float64(matrix.x0), + Y0: float64(matrix.y0), + } +} + +// IdentityMatrix is a wrapper around cairo_identity_matrix(). +// +// Resets the current transformation matrix (CTM) by setting it equal to the +// identity matrix. That is, the user-space and device-space axes will be +// aligned and one user-space unit will transform to one device-space unit. +func (v *Context) IdentityMatrix() { + C.cairo_identity_matrix(v.native()) +} + +// UserToDevice is a wrapper around cairo_user_to_device. +func (v *Context) UserToDevice(x, y float64) (float64, float64) { + C.cairo_user_to_device(v.native(), (*C.double)(&x), (*C.double)(&y)) + return x, y +} + +// UserToDeviceDistance is a wrapper around cairo_user_to_device_distance. +func (v *Context) UserToDeviceDistance(dx, dy float64) (float64, float64) { + C.cairo_user_to_device_distance(v.native(), (*C.double)(&dx), (*C.double)(&dy)) + return dx, dy +} + +// DeviceToUser is a wrapper around cairo_device_to_user. +func (v *Context) DeviceToUser(x, y float64) (float64, float64) { + C.cairo_device_to_user(v.native(), (*C.double)(&x), (*C.double)(&y)) + return x, y +} + +// DeviceToUserDistance is a wrapper around cairo_device_to_user_distance. +func (v *Context) DeviceToUserDistance(x, y float64) (float64, float64) { + C.cairo_device_to_user_distance(v.native(), (*C.double)(&x), (*C.double)(&y)) + return x, y +} diff --git a/vendor/github.com/gotk3/gotk3/cairo/util.go b/vendor/github.com/gotk3/gotk3/cairo/util.go new file mode 100644 index 0000000..39adda7 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/cairo/util.go @@ -0,0 +1,20 @@ +package cairo + +// #include +// #include +// #include +import "C" + +func cairobool(b bool) C.cairo_bool_t { + if b { + return C.cairo_bool_t(1) + } + return C.cairo_bool_t(0) +} + +func gobool(b C.cairo_bool_t) bool { + if b != 0 { + return true + } + return false +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk.go b/vendor/github.com/gotk3/gotk3/gdk/gdk.go new file mode 100644 index 0000000..e9382ae --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk.go @@ -0,0 +1,2464 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// Go bindings for GDK 3. Supports version 3.6 and later. +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +import "C" +import ( + "errors" + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/cairo" + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.gdk_drag_action_get_type()), marshalDragAction}, + {glib.Type(C.gdk_colorspace_get_type()), marshalColorspace}, + {glib.Type(C.gdk_event_type_get_type()), marshalEventType}, + {glib.Type(C.gdk_interp_type_get_type()), marshalInterpType}, + {glib.Type(C.gdk_modifier_type_get_type()), marshalModifierType}, + {glib.Type(C.gdk_event_mask_get_type()), marshalEventMask}, + {glib.Type(C.gdk_gravity_get_type()), marshalGravity}, + {glib.Type(C.gdk_visual_type_get_type()), marshalVisualType}, + + // Objects/Interfaces + {glib.Type(C.gdk_device_get_type()), marshalDevice}, + {glib.Type(C.gdk_display_manager_get_type()), marshalDisplayManager}, + {glib.Type(C.gdk_cursor_get_type()), marshalCursor}, + {glib.Type(C.gdk_device_manager_get_type()), marshalDeviceManager}, + {glib.Type(C.gdk_display_get_type()), marshalDisplay}, + {glib.Type(C.gdk_drag_context_get_type()), marshalDragContext}, + {glib.Type(C.gdk_rgba_get_type()), marshalRGBA}, + {glib.Type(C.gdk_screen_get_type()), marshalScreen}, + {glib.Type(C.gdk_visual_get_type()), marshalVisual}, + {glib.Type(C.gdk_window_get_type()), marshalWindow}, + + // Boxed + {glib.Type(C.gdk_event_get_type()), marshalEvent}, + } + glib.RegisterGValueMarshalers(tm) +} + +/* + * Type conversions + */ + +func gbool(b bool) C.gboolean { + if b { + return C.gboolean(1) + } + return C.gboolean(0) +} +func gobool(b C.gboolean) bool { + if b != 0 { + return true + } + return false +} + +/* + * Unexported vars + */ + +var nilPtrErr = errors.New("cgo returned unexpected nil pointer") + +/* + * Constants + */ + +// VisualType is a representation of GDK's GdkVisualType. +type VisualType int + +const ( + VISUAL_STATIC_GRAY VisualType = C.GDK_VISUAL_STATIC_GRAY + VISUAL_GRAYSCALE VisualType = C.GDK_VISUAL_GRAYSCALE + VISUAL_STATIC_COLOR VisualType = C.GDK_VISUAL_STATIC_COLOR + ISUAL_PSEUDO_COLOR VisualType = C.GDK_VISUAL_PSEUDO_COLOR + VISUAL_TRUE_COLOR VisualType = C.GDK_VISUAL_TRUE_COLOR + VISUAL_DIRECT_COLOR VisualType = C.GDK_VISUAL_DIRECT_COLOR +) + +func marshalVisualType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return VisualType(c), nil +} + +// DragAction is a representation of GDK's GdkDragAction. +type DragAction int + +const ( + ACTION_DEFAULT DragAction = C.GDK_ACTION_DEFAULT + ACTION_COPY DragAction = C.GDK_ACTION_COPY + ACTION_MOVE DragAction = C.GDK_ACTION_MOVE + ACTION_LINK DragAction = C.GDK_ACTION_LINK + ACTION_PRIVATE DragAction = C.GDK_ACTION_PRIVATE + ACTION_ASK DragAction = C.GDK_ACTION_ASK +) + +func marshalDragAction(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return DragAction(c), nil +} + +// Colorspace is a representation of GDK's GdkColorspace. +type Colorspace int + +const ( + COLORSPACE_RGB Colorspace = C.GDK_COLORSPACE_RGB +) + +func marshalColorspace(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Colorspace(c), nil +} + +// InterpType is a representation of GDK's GdkInterpType. +type InterpType int + +const ( + INTERP_NEAREST InterpType = C.GDK_INTERP_NEAREST + INTERP_TILES InterpType = C.GDK_INTERP_TILES + INTERP_BILINEAR InterpType = C.GDK_INTERP_BILINEAR + INTERP_HYPER InterpType = C.GDK_INTERP_HYPER +) + +func marshalInterpType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return InterpType(c), nil +} + +// ModifierType is a representation of GDK's GdkModifierType. +type ModifierType uint + +const ( + SHIFT_MASK ModifierType = C.GDK_SHIFT_MASK + LOCK_MASK = C.GDK_LOCK_MASK + CONTROL_MASK = C.GDK_CONTROL_MASK + MOD1_MASK = C.GDK_MOD1_MASK + MOD2_MASK = C.GDK_MOD2_MASK + MOD3_MASK = C.GDK_MOD3_MASK + MOD4_MASK = C.GDK_MOD4_MASK + MOD5_MASK = C.GDK_MOD5_MASK + BUTTON1_MASK = C.GDK_BUTTON1_MASK + BUTTON2_MASK = C.GDK_BUTTON2_MASK + BUTTON3_MASK = C.GDK_BUTTON3_MASK + BUTTON4_MASK = C.GDK_BUTTON4_MASK + BUTTON5_MASK = C.GDK_BUTTON5_MASK + SUPER_MASK = C.GDK_SUPER_MASK + HYPER_MASK = C.GDK_HYPER_MASK + META_MASK = C.GDK_META_MASK + RELEASE_MASK = C.GDK_RELEASE_MASK + MODIFIER_MASK = C.GDK_MODIFIER_MASK +) + +func marshalModifierType(p uintptr) (interface{}, error) { + c := C.g_value_get_flags((*C.GValue)(unsafe.Pointer(p))) + return ModifierType(c), nil +} + +// Selections +const ( + SELECTION_PRIMARY Atom = 1 + SELECTION_SECONDARY Atom = 2 + SELECTION_CLIPBOARD Atom = 69 + TARGET_BITMAP Atom = 5 + TARGET_COLORMAP Atom = 7 + TARGET_DRAWABLE Atom = 17 + TARGET_PIXMAP Atom = 20 + TARGET_STRING Atom = 31 + SELECTION_TYPE_ATOM Atom = 4 + SELECTION_TYPE_BITMAP Atom = 5 + SELECTION_TYPE_COLORMAP Atom = 7 + SELECTION_TYPE_DRAWABLE Atom = 17 + SELECTION_TYPE_INTEGER Atom = 19 + SELECTION_TYPE_PIXMAP Atom = 20 + SELECTION_TYPE_WINDOW Atom = 33 + SELECTION_TYPE_STRING Atom = 31 +) + +// added by terrak +// EventMask is a representation of GDK's GdkEventMask. +type EventMask int + +const ( + EXPOSURE_MASK EventMask = C.GDK_EXPOSURE_MASK + POINTER_MOTION_MASK EventMask = C.GDK_POINTER_MOTION_MASK + POINTER_MOTION_HINT_MASK EventMask = C.GDK_POINTER_MOTION_HINT_MASK + BUTTON_MOTION_MASK EventMask = C.GDK_BUTTON_MOTION_MASK + BUTTON1_MOTION_MASK EventMask = C.GDK_BUTTON1_MOTION_MASK + BUTTON2_MOTION_MASK EventMask = C.GDK_BUTTON2_MOTION_MASK + BUTTON3_MOTION_MASK EventMask = C.GDK_BUTTON3_MOTION_MASK + BUTTON_PRESS_MASK EventMask = C.GDK_BUTTON_PRESS_MASK + BUTTON_RELEASE_MASK EventMask = C.GDK_BUTTON_RELEASE_MASK + KEY_PRESS_MASK EventMask = C.GDK_KEY_PRESS_MASK + KEY_RELEASE_MASK EventMask = C.GDK_KEY_RELEASE_MASK + ENTER_NOTIFY_MASK EventMask = C.GDK_ENTER_NOTIFY_MASK + LEAVE_NOTIFY_MASK EventMask = C.GDK_LEAVE_NOTIFY_MASK + FOCUS_CHANGE_MASK EventMask = C.GDK_FOCUS_CHANGE_MASK + STRUCTURE_MASK EventMask = C.GDK_STRUCTURE_MASK + PROPERTY_CHANGE_MASK EventMask = C.GDK_PROPERTY_CHANGE_MASK + VISIBILITY_NOTIFY_MASK EventMask = C.GDK_VISIBILITY_NOTIFY_MASK + PROXIMITY_IN_MASK EventMask = C.GDK_PROXIMITY_IN_MASK + PROXIMITY_OUT_MASK EventMask = C.GDK_PROXIMITY_OUT_MASK + SUBSTRUCTURE_MASK EventMask = C.GDK_SUBSTRUCTURE_MASK + SCROLL_MASK EventMask = C.GDK_SCROLL_MASK + TOUCH_MASK EventMask = C.GDK_TOUCH_MASK + SMOOTH_SCROLL_MASK EventMask = C.GDK_SMOOTH_SCROLL_MASK + ALL_EVENTS_MASK EventMask = C.GDK_ALL_EVENTS_MASK +) + +func marshalEventMask(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return EventMask(c), nil +} + +// added by lazyshot +// ScrollDirection is a representation of GDK's GdkScrollDirection +type ScrollDirection int + +const ( + SCROLL_UP ScrollDirection = C.GDK_SCROLL_UP + SCROLL_DOWN ScrollDirection = C.GDK_SCROLL_DOWN + SCROLL_LEFT ScrollDirection = C.GDK_SCROLL_LEFT + SCROLL_RIGHT ScrollDirection = C.GDK_SCROLL_RIGHT + SCROLL_SMOOTH ScrollDirection = C.GDK_SCROLL_SMOOTH +) + +// WindowEdge is a representation of GDK's GdkWindowEdge +type WindowEdge int + +const ( + WINDOW_EDGE_NORTH_WEST WindowEdge = C.GDK_WINDOW_EDGE_NORTH_WEST + WINDOW_EDGE_NORTH WindowEdge = C.GDK_WINDOW_EDGE_NORTH + WINDOW_EDGE_NORTH_EAST WindowEdge = C.GDK_WINDOW_EDGE_NORTH_EAST + WINDOW_EDGE_WEST WindowEdge = C.GDK_WINDOW_EDGE_WEST + WINDOW_EDGE_EAST WindowEdge = C.GDK_WINDOW_EDGE_EAST + WINDOW_EDGE_SOUTH_WEST WindowEdge = C.GDK_WINDOW_EDGE_SOUTH_WEST + WINDOW_EDGE_SOUTH WindowEdge = C.GDK_WINDOW_EDGE_SOUTH + WINDOW_EDGE_SOUTH_EAST WindowEdge = C.GDK_WINDOW_EDGE_SOUTH_EAST +) + +// WindowState is a representation of GDK's GdkWindowState +type WindowState int + +const ( + WINDOW_STATE_WITHDRAWN WindowState = C.GDK_WINDOW_STATE_WITHDRAWN + WINDOW_STATE_ICONIFIED WindowState = C.GDK_WINDOW_STATE_ICONIFIED + WINDOW_STATE_MAXIMIZED WindowState = C.GDK_WINDOW_STATE_MAXIMIZED + WINDOW_STATE_STICKY WindowState = C.GDK_WINDOW_STATE_STICKY + WINDOW_STATE_FULLSCREEN WindowState = C.GDK_WINDOW_STATE_FULLSCREEN + WINDOW_STATE_ABOVE WindowState = C.GDK_WINDOW_STATE_ABOVE + WINDOW_STATE_BELOW WindowState = C.GDK_WINDOW_STATE_BELOW + WINDOW_STATE_FOCUSED WindowState = C.GDK_WINDOW_STATE_FOCUSED + WINDOW_STATE_TILED WindowState = C.GDK_WINDOW_STATE_TILED +) + +// WindowTypeHint is a representation of GDK's GdkWindowTypeHint +type WindowTypeHint int + +const ( + WINDOW_TYPE_HINT_NORMAL WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_NORMAL + WINDOW_TYPE_HINT_DIALOG WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_DIALOG + WINDOW_TYPE_HINT_MENU WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_MENU + WINDOW_TYPE_HINT_TOOLBAR WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_TOOLBAR + WINDOW_TYPE_HINT_SPLASHSCREEN WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_SPLASHSCREEN + WINDOW_TYPE_HINT_UTILITY WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_UTILITY + WINDOW_TYPE_HINT_DOCK WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_DOCK + WINDOW_TYPE_HINT_DESKTOP WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_DESKTOP + WINDOW_TYPE_HINT_DROPDOWN_MENU WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_DROPDOWN_MENU + WINDOW_TYPE_HINT_POPUP_MENU WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_POPUP_MENU + WINDOW_TYPE_HINT_TOOLTIP WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_TOOLTIP + WINDOW_TYPE_HINT_NOTIFICATION WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_NOTIFICATION + WINDOW_TYPE_HINT_COMBO WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_COMBO + WINDOW_TYPE_HINT_DND WindowTypeHint = C.GDK_WINDOW_TYPE_HINT_DND +) + +// WindowHints is a representation of GDK's GdkWindowHints +type WindowHints int + +const ( + HINT_POS WindowHints = C.GDK_HINT_POS + HINT_MIN_SIZE WindowHints = C.GDK_HINT_MIN_SIZE + HINT_MAX_SIZE WindowHints = C.GDK_HINT_MAX_SIZE + HINT_BASE_SIZE WindowHints = C.GDK_HINT_BASE_SIZE + HINT_ASPECT WindowHints = C.GDK_HINT_ASPECT + HINT_RESIZE_INC WindowHints = C.GDK_HINT_RESIZE_INC + HINT_WIN_GRAVITY WindowHints = C.GDK_HINT_WIN_GRAVITY + HINT_USER_POS WindowHints = C.GDK_HINT_USER_POS + HINT_USER_SIZE WindowHints = C.GDK_HINT_USER_SIZE +) + +// CURRENT_TIME is a representation of GDK_CURRENT_TIME + +const CURRENT_TIME = C.GDK_CURRENT_TIME + +// GrabStatus is a representation of GdkGrabStatus + +type GrabStatus int + +const ( + GRAB_SUCCESS GrabStatus = C.GDK_GRAB_SUCCESS + GRAB_ALREADY_GRABBED GrabStatus = C.GDK_GRAB_ALREADY_GRABBED + GRAB_INVALID_TIME GrabStatus = C.GDK_GRAB_INVALID_TIME + GRAB_NOT_VIEWABLE GrabStatus = C.GDK_GRAB_NOT_VIEWABLE + GRAB_FROZEN GrabStatus = C.GDK_GRAB_FROZEN +) + +// GrabOwnership is a representation of GdkGrabOwnership + +type GrabOwnership int + +const ( + OWNERSHIP_NONE GrabOwnership = C.GDK_OWNERSHIP_NONE + OWNERSHIP_WINDOW GrabOwnership = C.GDK_OWNERSHIP_WINDOW + OWNERSHIP_APPLICATION GrabOwnership = C.GDK_OWNERSHIP_APPLICATION +) + +// TODO: +// GdkInputSource +// GdkInputMode +// GdkAxisUse +// GdkAxisFlags +// GdkDeviceToolType + +// DeviceType is a representation of GdkDeviceType + +type DeviceType int + +const ( + DEVICE_TYPE_MASTER DeviceType = C.GDK_DEVICE_TYPE_MASTER + DEVICE_TYPE_SLAVE DeviceType = C.GDK_DEVICE_TYPE_SLAVE + DEVICE_TYPE_FLOATING DeviceType = C.GDK_DEVICE_TYPE_FLOATING +) + +// TODO: +// GdkColorspace +// GdkVisualType +// GdkTimeCoord + +// EventPropagation constants + +const ( + GDK_EVENT_PROPAGATE bool = C.GDK_EVENT_PROPAGATE != 0 + GDK_EVENT_STOP bool = C.GDK_EVENT_STOP != 0 +) + +// Button constants +type Button uint + +const ( + BUTTON_PRIMARY Button = C.GDK_BUTTON_PRIMARY + BUTTON_MIDDLE Button = C.GDK_BUTTON_MIDDLE + BUTTON_SECONDARY Button = C.GDK_BUTTON_SECONDARY +) + +// CrossingMode is a representation of GDK's GdkCrossingMode. + +type CrossingMode int + +const ( + CROSSING_NORMAL CrossingMode = C.GDK_CROSSING_NORMAL + CROSSING_GRAB CrossingMode = C.GDK_CROSSING_GRAB + CROSSING_UNGRAB CrossingMode = C.GDK_CROSSING_UNGRAB + CROSSING_GTK_GRAB CrossingMode = C.GDK_CROSSING_GTK_GRAB + CROSSING_GTK_UNGRAB CrossingMode = C.GDK_CROSSING_GTK_UNGRAB + CROSSING_STATE_CHANGED CrossingMode = C.GDK_CROSSING_STATE_CHANGED + CROSSING_TOUCH_BEGIN CrossingMode = C.GDK_CROSSING_TOUCH_BEGIN + CROSSING_TOUCH_END CrossingMode = C.GDK_CROSSING_TOUCH_END + CROSSING_DEVICE_SWITCH CrossingMode = C.GDK_CROSSING_DEVICE_SWITCH +) + +// NotifyType is a representation of GDK's GdkNotifyType. + +type NotifyType int + +const ( + NOTIFY_ANCESTOR NotifyType = C.GDK_NOTIFY_ANCESTOR + NOTIFY_VIRTUAL NotifyType = C.GDK_NOTIFY_VIRTUAL + NOTIFY_INFERIOR NotifyType = C.GDK_NOTIFY_INFERIOR + NOTIFY_NONLINEAR NotifyType = C.GDK_NOTIFY_NONLINEAR + NOTIFY_NONLINEAR_VIRTUAL NotifyType = C.GDK_NOTIFY_NONLINEAR_VIRTUAL + NOTIFY_UNKNOWN NotifyType = C.GDK_NOTIFY_UNKNOWN +) + +// EventType is a representation of GDK's GdkEventType. +// Do not confuse these event types with the signals that GTK+ widgets emit +type EventType int + +func marshalEventType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return EventType(c), nil +} + +const ( + EVENT_NOTHING EventType = C.GDK_NOTHING + EVENT_DELETE EventType = C.GDK_DELETE + EVENT_DESTROY EventType = C.GDK_DESTROY + EVENT_EXPOSE EventType = C.GDK_EXPOSE + EVENT_MOTION_NOTIFY EventType = C.GDK_MOTION_NOTIFY + EVENT_BUTTON_PRESS EventType = C.GDK_BUTTON_PRESS + EVENT_2BUTTON_PRESS EventType = C.GDK_2BUTTON_PRESS + EVENT_DOUBLE_BUTTON_PRESS EventType = C.GDK_DOUBLE_BUTTON_PRESS + EVENT_3BUTTON_PRESS EventType = C.GDK_3BUTTON_PRESS + EVENT_TRIPLE_BUTTON_PRESS EventType = C.GDK_TRIPLE_BUTTON_PRESS + EVENT_BUTTON_RELEASE EventType = C.GDK_BUTTON_RELEASE + EVENT_KEY_PRESS EventType = C.GDK_KEY_PRESS + EVENT_KEY_RELEASE EventType = C.GDK_KEY_RELEASE + EVENT_ENTER_NOTIFY EventType = C.GDK_ENTER_NOTIFY + EVENT_LEAVE_NOTIFY EventType = C.GDK_LEAVE_NOTIFY + EVENT_FOCUS_CHANGE EventType = C.GDK_FOCUS_CHANGE + EVENT_CONFIGURE EventType = C.GDK_CONFIGURE + EVENT_MAP EventType = C.GDK_MAP + EVENT_UNMAP EventType = C.GDK_UNMAP + EVENT_PROPERTY_NOTIFY EventType = C.GDK_PROPERTY_NOTIFY + EVENT_SELECTION_CLEAR EventType = C.GDK_SELECTION_CLEAR + EVENT_SELECTION_REQUEST EventType = C.GDK_SELECTION_REQUEST + EVENT_SELECTION_NOTIFY EventType = C.GDK_SELECTION_NOTIFY + EVENT_PROXIMITY_IN EventType = C.GDK_PROXIMITY_IN + EVENT_PROXIMITY_OUT EventType = C.GDK_PROXIMITY_OUT + EVENT_DRAG_ENTER EventType = C.GDK_DRAG_ENTER + EVENT_DRAG_LEAVE EventType = C.GDK_DRAG_LEAVE + EVENT_DRAG_MOTION EventType = C.GDK_DRAG_MOTION + EVENT_DRAG_STATUS EventType = C.GDK_DRAG_STATUS + EVENT_DROP_START EventType = C.GDK_DROP_START + EVENT_DROP_FINISHED EventType = C.GDK_DROP_FINISHED + EVENT_CLIENT_EVENT EventType = C.GDK_CLIENT_EVENT + EVENT_VISIBILITY_NOTIFY EventType = C.GDK_VISIBILITY_NOTIFY + EVENT_SCROLL EventType = C.GDK_SCROLL + EVENT_WINDOW_STATE EventType = C.GDK_WINDOW_STATE + EVENT_SETTING EventType = C.GDK_SETTING + EVENT_OWNER_CHANGE EventType = C.GDK_OWNER_CHANGE + EVENT_GRAB_BROKEN EventType = C.GDK_GRAB_BROKEN + EVENT_DAMAGE EventType = C.GDK_DAMAGE + EVENT_TOUCH_BEGIN EventType = C.GDK_TOUCH_BEGIN + EVENT_TOUCH_UPDATE EventType = C.GDK_TOUCH_UPDATE + EVENT_TOUCH_END EventType = C.GDK_TOUCH_END + EVENT_TOUCH_CANCEL EventType = C.GDK_TOUCH_CANCEL + EVENT_LAST EventType = C.GDK_EVENT_LAST +) + +/* + * General + */ + +// TODO: +// gdk_init(). +// gdk_init_check(). +// gdk_parse_args(). +// gdk_get_display_arg_name(). +// gdk_notify_startup_complete(). +// gdk_notify_startup_complete_with_id(). +// gdk_get_program_class(). +// gdk_set_program_class(). +// gdk_get_display(). deprecated since version 3.8 +// gdk_flush(). deprecated +// gdk_screen_width(). deprecated since version 3.22 +// gdk_screen_height(). deprecated since version 3.22 +// gdk_screen_width_mm(). deprecated since version 3.22 +// gdk_screen_height_mm(). deprecated since version 3.22 +// gdk_set_double_click_time(). deprecated +// gdk_beep(). deprecated +// gdk_error_trap_push(). deprecated +// gdk_error_trap_pop(). deprecated +// gdk_error_trap_pop_ignored(). deprecated + +// SetAllowedBackends is a wrapper around gdk_set_allowed_backends +func SetAllowedBackends(backends string) { + cstr := C.CString(backends) + defer C.free(unsafe.Pointer(cstr)) + C.gdk_set_allowed_backends((*C.gchar)(cstr)) +} + +/* + * GdkAtom + */ + +// Atom is a representation of GDK's GdkAtom. +type Atom uintptr + +// native returns the underlying GdkAtom. +func (v Atom) native() C.GdkAtom { + return C.toGdkAtom(unsafe.Pointer(uintptr(v))) +} + +func (v Atom) Name() string { + c := C.gdk_atom_name(v.native()) + defer C.g_free(C.gpointer(c)) + return C.GoString((*C.char)(c)) +} + +// GdkAtomIntern is a wrapper around gdk_atom_intern +func GdkAtomIntern(atomName string, onlyIfExists bool) Atom { + cstr := C.CString(atomName) + defer C.free(unsafe.Pointer(cstr)) + c := C.gdk_atom_intern((*C.gchar)(cstr), gbool(onlyIfExists)) + return Atom(uintptr(unsafe.Pointer(c))) +} + +/* + * GdkDevice + */ + +// Device is a representation of GDK's GdkDevice. +type Device struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkDevice. +func (v *Device) native() *C.GdkDevice { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkDevice(p) +} + +// Native returns a pointer to the underlying GdkDevice. +func (v *Device) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalDevice(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Device{obj}, nil +} + +func toDevice(d *C.GdkDevice) (*Device, error) { + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(d))} + return &Device{obj}, nil +} + +func (v *Device) GetPosition(screen **Screen, x, y *int) error { + cs := (**C.GdkScreen)(unsafe.Pointer(uintptr(0))) + if screen != nil { + var cval *C.GdkScreen + cs = &cval + } + + cx := (*C.gint)(unsafe.Pointer(uintptr(0))) + if x != nil { + var cval C.gint + cx = &cval + } + + cy := (*C.gint)(unsafe.Pointer(uintptr(0))) + if y != nil { + var cval C.gint + cy = &cval + } + C.gdk_device_get_position(v.native(), cs, cx, cy) + + if cs != (**C.GdkScreen)(unsafe.Pointer(uintptr(0))) { + ms, err := toScreen(*cs) + if err != nil { + return err + } + *screen = ms + } + if cx != (*C.gint)(unsafe.Pointer(uintptr(0))) { + *x = int(*cx) + } + if cy != (*C.gint)(unsafe.Pointer(uintptr(0))) { + *y = int(*cy) + } + return nil +} + +// TODO: +// gdk_device_get_name(). +// gdk_device_get_source(). +// gdk_device_set_mode(). +// gdk_device_get_mode(). +// gdk_device_set_key(). +// gdk_device_get_key(). +// gdk_device_set_axis_use(). +// gdk_device_get_axis_use(). +// gdk_device_get_associated_device(). +// gdk_device_list_slave_devices(). +// gdk_device_get_device_type(). +// gdk_device_get_display(). +// gdk_device_get_has_cursor(). +// gdk_device_get_n_axes(). +// gdk_device_get_n_keys(). +// gdk_device_warp(). +// gdk_device_get_state(). +// gdk_device_get_window_at_position(). +// gdk_device_get_window_at_position_double(). +// gdk_device_get_history(). +// gdk_device_free_history(). +// gdk_device_get_axis(). +// gdk_device_list_axes(). +// gdk_device_get_axis_value(). + +/* + * GdkCursor + */ + +// Cursor is a representation of GdkCursor. +type Cursor struct { + *glib.Object +} + +// CursorNewFromName is a wrapper around gdk_cursor_new_from_name(). +func CursorNewFromName(display *Display, name string) (*Cursor, error) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + c := C.gdk_cursor_new_from_name(display.native(), (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + + return &Cursor{glib.Take(unsafe.Pointer(c))}, nil +} + +// native returns a pointer to the underlying GdkCursor. +func (v *Cursor) native() *C.GdkCursor { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkCursor(p) +} + +// Native returns a pointer to the underlying GdkCursor. +func (v *Cursor) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalCursor(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Cursor{obj}, nil +} + +/* + * GdkDeviceManager + */ + +// DeviceManager is a representation of GDK's GdkDeviceManager. +type DeviceManager struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkDeviceManager. +func (v *DeviceManager) native() *C.GdkDeviceManager { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkDeviceManager(p) +} + +// Native returns a pointer to the underlying GdkDeviceManager. +func (v *DeviceManager) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalDeviceManager(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &DeviceManager{obj}, nil +} + +// GetDisplay() is a wrapper around gdk_device_manager_get_display(). +func (v *DeviceManager) GetDisplay() (*Display, error) { + c := C.gdk_device_manager_get_display(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &Display{glib.Take(unsafe.Pointer(c))}, nil +} + +/* + * GdkDisplay + */ + +// Display is a representation of GDK's GdkDisplay. +type Display struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkDisplay. +func (v *Display) native() *C.GdkDisplay { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkDisplay(p) +} + +// Native returns a pointer to the underlying GdkDisplay. +func (v *Display) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalDisplay(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Display{obj}, nil +} + +func toDisplay(s *C.GdkDisplay) (*Display, error) { + if s == nil { + return nil, nilPtrErr + } + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(s))} + return &Display{obj}, nil +} + +// DisplayOpen is a wrapper around gdk_display_open(). +func DisplayOpen(displayName string) (*Display, error) { + cstr := C.CString(displayName) + defer C.free(unsafe.Pointer(cstr)) + c := C.gdk_display_open((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + + return &Display{glib.Take(unsafe.Pointer(c))}, nil +} + +// DisplayGetDefault is a wrapper around gdk_display_get_default(). +func DisplayGetDefault() (*Display, error) { + c := C.gdk_display_get_default() + if c == nil { + return nil, nilPtrErr + } + + return &Display{glib.Take(unsafe.Pointer(c))}, nil +} + +// GetName is a wrapper around gdk_display_get_name(). +func (v *Display) GetName() (string, error) { + c := C.gdk_display_get_name(v.native()) + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +// GetDefaultScreen is a wrapper around gdk_display_get_default_screen(). +func (v *Display) GetDefaultScreen() (*Screen, error) { + c := C.gdk_display_get_default_screen(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &Screen{glib.Take(unsafe.Pointer(c))}, nil +} + +// DeviceIsGrabbed is a wrapper around gdk_display_device_is_grabbed(). +func (v *Display) DeviceIsGrabbed(device *Device) bool { + c := C.gdk_display_device_is_grabbed(v.native(), device.native()) + return gobool(c) +} + +// Beep is a wrapper around gdk_display_beep(). +func (v *Display) Beep() { + C.gdk_display_beep(v.native()) +} + +// Sync is a wrapper around gdk_display_sync(). +func (v *Display) Sync() { + C.gdk_display_sync(v.native()) +} + +// Flush is a wrapper around gdk_display_flush(). +func (v *Display) Flush() { + C.gdk_display_flush(v.native()) +} + +// Close is a wrapper around gdk_display_close(). +func (v *Display) Close() { + C.gdk_display_close(v.native()) +} + +// IsClosed is a wrapper around gdk_display_is_closed(). +func (v *Display) IsClosed() bool { + c := C.gdk_display_is_closed(v.native()) + return gobool(c) +} + +// GetEvent is a wrapper around gdk_display_get_event(). +func (v *Display) GetEvent() (*Event, error) { + c := C.gdk_display_get_event(v.native()) + if c == nil { + return nil, nilPtrErr + } + + //The finalizer is not on the glib.Object but on the event. + e := &Event{c} + runtime.SetFinalizer(e, (*Event).free) + return e, nil +} + +// PeekEvent is a wrapper around gdk_display_peek_event(). +func (v *Display) PeekEvent() (*Event, error) { + c := C.gdk_display_peek_event(v.native()) + if c == nil { + return nil, nilPtrErr + } + + //The finalizer is not on the glib.Object but on the event. + e := &Event{c} + runtime.SetFinalizer(e, (*Event).free) + return e, nil +} + +// PutEvent is a wrapper around gdk_display_put_event(). +func (v *Display) PutEvent(event *Event) { + C.gdk_display_put_event(v.native(), event.native()) +} + +// HasPending is a wrapper around gdk_display_has_pending(). +func (v *Display) HasPending() bool { + c := C.gdk_display_has_pending(v.native()) + return gobool(c) +} + +// SetDoubleClickTime is a wrapper around gdk_display_set_double_click_time(). +func (v *Display) SetDoubleClickTime(msec uint) { + C.gdk_display_set_double_click_time(v.native(), C.guint(msec)) +} + +// SetDoubleClickDistance is a wrapper around gdk_display_set_double_click_distance(). +func (v *Display) SetDoubleClickDistance(distance uint) { + C.gdk_display_set_double_click_distance(v.native(), C.guint(distance)) +} + +// SupportsColorCursor is a wrapper around gdk_display_supports_cursor_color(). +func (v *Display) SupportsColorCursor() bool { + c := C.gdk_display_supports_cursor_color(v.native()) + return gobool(c) +} + +// SupportsCursorAlpha is a wrapper around gdk_display_supports_cursor_alpha(). +func (v *Display) SupportsCursorAlpha() bool { + c := C.gdk_display_supports_cursor_alpha(v.native()) + return gobool(c) +} + +// GetDefaultCursorSize is a wrapper around gdk_display_get_default_cursor_size(). +func (v *Display) GetDefaultCursorSize() uint { + c := C.gdk_display_get_default_cursor_size(v.native()) + return uint(c) +} + +// GetMaximalCursorSize is a wrapper around gdk_display_get_maximal_cursor_size(). +func (v *Display) GetMaximalCursorSize() (width, height uint) { + var w, h C.guint + C.gdk_display_get_maximal_cursor_size(v.native(), &w, &h) + return uint(w), uint(h) +} + +// GetDefaultGroup is a wrapper around gdk_display_get_default_group(). +func (v *Display) GetDefaultGroup() (*Window, error) { + c := C.gdk_display_get_default_group(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &Window{glib.Take(unsafe.Pointer(c))}, nil +} + +// SupportsSelectionNotification is a wrapper around gdk_display_supports_selection_notification(). +func (v *Display) SupportsSelectionNotification() bool { + c := C.gdk_display_supports_selection_notification(v.native()) + return gobool(c) +} + +// RequestSelectionNotification is a wrapper around gdk_display_request_selection_notification(). +func (v *Display) RequestSelectionNotification(selection Atom) bool { + c := C.gdk_display_request_selection_notification(v.native(), + selection.native()) + return gobool(c) +} + +// SupportsClipboardPersistence is a wrapper around gdk_display_supports_clipboard_persistence(). +func (v *Display) SupportsClipboardPersistence() bool { + c := C.gdk_display_supports_clipboard_persistence(v.native()) + return gobool(c) +} + +// TODO: +// gdk_display_store_clipboard(). +// func (v *Display) StoreClipboard(clipboardWindow *Window, time uint32, targets ...Atom) { +// panic("Not implemented") +// } + +// SupportsShapes is a wrapper around gdk_display_supports_shapes(). +func (v *Display) SupportsShapes() bool { + c := C.gdk_display_supports_shapes(v.native()) + return gobool(c) +} + +// SupportsInputShapes is a wrapper around gdk_display_supports_input_shapes(). +func (v *Display) SupportsInputShapes() bool { + c := C.gdk_display_supports_input_shapes(v.native()) + return gobool(c) +} + +// TODO: +// gdk_display_get_app_launch_context(). +// func (v *Display) GetAppLaunchContext() { +// panic("Not implemented") +// } + +// NotifyStartupComplete is a wrapper around gdk_display_notify_startup_complete(). +func (v *Display) NotifyStartupComplete(startupID string) { + cstr := C.CString(startupID) + defer C.free(unsafe.Pointer(cstr)) + C.gdk_display_notify_startup_complete(v.native(), (*C.gchar)(cstr)) +} + +/* + * GdkDisplayManager + */ +// DisplayManager is a representation of GDK's GdkDisplayManager. +type DisplayManager struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkDisplayManager. +func (v *DisplayManager) native() *C.GdkDisplayManager { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkDisplayManager(p) +} + +// Native returns a pointer to the underlying GdkDisplayManager. +func (v *DisplayManager) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalDisplayManager(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &DisplayManager{obj}, nil +} + +func wrapDisplayManager(obj *glib.Object) *DisplayManager { + if obj == nil { + return nil + } + return &DisplayManager{obj} +} + +// DisplayManagerGet is a wrapper around gdk_display_manager_get(). +func DisplayManagerGet() (*DisplayManager, error) { + c := C.gdk_display_manager_get() + if c == nil { + return nil, nilPtrErr + } + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &DisplayManager{obj}, nil +} + +// GetDefaultDisplay is a wrapper around gdk_display_manager_get_default_display(). +func (v *DisplayManager) GetDefaultDisplay() (*Display, error) { + c := C.gdk_display_manager_get_default_display(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Display{obj}, nil +} + +// SetDefaultDisplay is a wrapper around gdk_display_manager_set_default_display(). +func (v *DisplayManager) SetDefaultDisplay(display *Display) { + C.gdk_display_manager_set_default_display(v.native(), display.native()) +} + +// ListDisplays is a wrapper around gdk_display_manager_list_displays(). +func (v *DisplayManager) ListDisplays() *[]Display { + + clist := C.gdk_display_manager_list_displays(v.native()) + if clist == nil { + return nil + } + dlist := glib.WrapSList(uintptr(unsafe.Pointer(clist))) + defer dlist.Free() + + var displays = make([]Display, 0, dlist.Length()) + for ; dlist.DataRaw() != nil; dlist = dlist.Next() { + d := (*C.GdkDisplay)(dlist.DataRaw()) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(d))} + displays = append(displays, Display{obj}) + } + return &displays +} + +// OpenDisplay is a representation of gdk_display_manager_open_display(). +func (v *DisplayManager) OpenDisplay(name string) (*Display, error) { + cstr := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr)) + + c := C.gdk_display_manager_open_display(v.native(), cstr) + if c == nil { + return nil, nilPtrErr + } + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Display{obj}, nil +} + +/* + * GdkKeymap + */ + +type Keymap struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkKeymap. +func (v *Keymap) native() *C.GdkKeymap { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkKeymap(p) +} + +// Native returns a pointer to the underlying GdkKeymap. +func (v *Keymap) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalKeymap(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Keymap{obj}, nil +} + +func wrapKeymap(obj *glib.Object) *Keymap { + return &Keymap{obj} +} + +// GetKeymap is a wrapper around gdk_keymap_get_for_display(). +func (v *Display) GetKeymap() (*Keymap, error) { + c := C.gdk_keymap_get_for_display(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Keymap{obj}, nil +} + +// TranslateKeyboardState is a wrapper around gdk_keymap_translate_keyboard_state(). +func (v *Keymap) TranslateKeyboardState(hardwareKeycode uint, state ModifierType, group int) (bool, *uint, *int, *int, *ModifierType) { + + var cKeyval C.guint + var keyval *uint + var cEffectiveGroup, cLevel C.gint + var effectiveGroup, level *int + var cConsumedModifiers C.GdkModifierType + var consumedModifiers *ModifierType + + c := C.gdk_keymap_translate_keyboard_state( + v.native(), + C.guint(hardwareKeycode), + C.GdkModifierType(state), + C.gint(group), + &cKeyval, + &cEffectiveGroup, + &cLevel, + &cConsumedModifiers, + ) + + if &cKeyval == nil { + keyval = nil + } else { + *keyval = uint(cKeyval) + } + if &cEffectiveGroup == nil { + effectiveGroup = nil + } else { + *effectiveGroup = int(cEffectiveGroup) + } + if &cLevel == nil { + level = nil + } else { + *level = int(cLevel) + } + if &cConsumedModifiers == nil { + consumedModifiers = nil + } else { + *consumedModifiers = ModifierType(cConsumedModifiers) + } + + return gobool(c), keyval, effectiveGroup, level, consumedModifiers +} + +// HaveBidiLayouts is a wrapper around gdk_keymap_have_bidi_layouts(). +func (v *Keymap) HaveBidiLayouts() bool { + return gobool(C.gdk_keymap_have_bidi_layouts(v.native())) +} + +// GetCapsLockState is a wrapper around gdk_keymap_get_caps_lock_state(). +func (v *Keymap) GetCapsLockState() bool { + return gobool(C.gdk_keymap_get_caps_lock_state(v.native())) +} + +// GetNumLockState is a wrapper around gdk_keymap_get_num_lock_state(). +func (v *Keymap) GetNumLockState() bool { + return gobool(C.gdk_keymap_get_num_lock_state(v.native())) +} + +// GetModifierState is a wrapper around gdk_keymap_get_modifier_state(). +func (v *Keymap) GetModifierState() uint { + return uint(C.gdk_keymap_get_modifier_state(v.native())) +} + +// TODO: +// gdk_keymap_get_default(). deprecated since 3.22 +// gdk_keymap_get_direction(). +// gdk_keymap_add_virtual_modifiers(). +// gdk_keymap_map_virtual_modifiers(). +// gdk_keymap_get_modifier_mask(). + +/* + * GdkKeymapKey + */ + +// TODO: +// gdk_keymap_lookup_key(). +// gdk_keymap_get_entries_for_keyval(). +// gdk_keymap_get_entries_for_keycode(). + +/* + * GDK Keyval + */ + +// TODO: +// gdk_keyval_name(). + +// KeyvalFromName() is a wrapper around gdk_keyval_from_name(). +func KeyvalFromName(keyvalName string) uint { + str := (*C.gchar)(C.CString(keyvalName)) + defer C.free(unsafe.Pointer(str)) + return uint(C.gdk_keyval_from_name(str)) +} + +// KeyvalConvertCase is a wrapper around gdk_keyval_convert_case(). +func KeyvalConvertCase(v uint) (lower, upper uint) { + var l, u C.guint + l = 0 + u = 0 + C.gdk_keyval_convert_case(C.guint(v), &l, &u) + return uint(l), uint(u) +} + +// KeyvalIsLower is a wrapper around gdk_keyval_is_lower(). +func KeyvalIsLower(v uint) bool { + return gobool(C.gdk_keyval_is_lower(C.guint(v))) +} + +// KeyvalIsUpper is a wrapper around gdk_keyval_is_upper(). +func KeyvalIsUpper(v uint) bool { + return gobool(C.gdk_keyval_is_upper(C.guint(v))) +} + +// KeyvalToLower is a wrapper around gdk_keyval_to_lower(). +func KeyvalToLower(v uint) uint { + return uint(C.gdk_keyval_to_lower(C.guint(v))) +} + +// KeyvalToUpper is a wrapper around gdk_keyval_to_upper(). +func KeyvalToUpper(v uint) uint { + return uint(C.gdk_keyval_to_upper(C.guint(v))) +} + +// KeyvalToUnicode is a wrapper around gdk_keyval_to_unicode(). +func KeyvalToUnicode(v uint) rune { + return rune(C.gdk_keyval_to_unicode(C.guint(v))) +} + +// UnicodeToKeyval is a wrapper around gdk_unicode_to_keyval(). +func UnicodeToKeyval(v rune) uint { + return uint(C.gdk_unicode_to_keyval(C.guint32(v))) +} + +/* + * GdkDragContext + */ + +// DragContext is a representation of GDK's GdkDragContext. +type DragContext struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkDragContext. +func (v *DragContext) native() *C.GdkDragContext { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkDragContext(p) +} + +// Native returns a pointer to the underlying GdkDragContext. +func (v *DragContext) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalDragContext(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &DragContext{obj}, nil +} + +func (v *DragContext) ListTargets() *glib.List { + clist := C.gdk_drag_context_list_targets(v.native()) + if clist == nil { + return nil + } + return glib.WrapList(uintptr(unsafe.Pointer(clist))) +} + +/* + * GdkEvent + */ + +// Event is a representation of GDK's GdkEvent. +type Event struct { + GdkEvent *C.GdkEvent +} + +// native returns a pointer to the underlying GdkEvent. +func (v *Event) native() *C.GdkEvent { + if v == nil { + return nil + } + return v.GdkEvent +} + +// Native returns a pointer to the underlying GdkEvent. +func (v *Event) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalEvent(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + return &Event{(*C.GdkEvent)(unsafe.Pointer(c))}, nil +} + +func (v *Event) free() { + C.gdk_event_free(v.native()) +} + +/* + * GdkEventButton + */ + +// EventButton is a representation of GDK's GdkEventButton. +type EventButton struct { + *Event +} + +func EventButtonNew() *EventButton { + ee := (*C.GdkEvent)(unsafe.Pointer(&C.GdkEventButton{})) + ev := Event{ee} + return &EventButton{&ev} +} + +// EventButtonNewFromEvent returns an EventButton from an Event. +// +// Using widget.Connect() for a key related signal such as +// "button-press-event" results in a *Event being passed as +// the callback's second argument. The argument is actually a +// *EventButton. EventButtonNewFromEvent provides a means of creating +// an EventKey from the Event. +func EventButtonNewFromEvent(event *Event) *EventButton { + ee := (*C.GdkEvent)(unsafe.Pointer(event.native())) + ev := Event{ee} + return &EventButton{&ev} +} + +// Native returns a pointer to the underlying GdkEventButton. +func (v *EventButton) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *EventButton) native() *C.GdkEventButton { + return (*C.GdkEventButton)(unsafe.Pointer(v.Event.native())) +} + +func (v *EventButton) X() float64 { + c := v.native().x + return float64(c) +} + +func (v *EventButton) Y() float64 { + c := v.native().y + return float64(c) +} + +// XRoot returns the x coordinate of the pointer relative to the root of the screen. +func (v *EventButton) XRoot() float64 { + c := v.native().x_root + return float64(c) +} + +// YRoot returns the y coordinate of the pointer relative to the root of the screen. +func (v *EventButton) YRoot() float64 { + c := v.native().y_root + return float64(c) +} + +func (v *EventButton) Button() Button { + c := v.native().button + return Button(c) +} + +func (v *EventButton) State() uint { + c := v.native().state + return uint(c) +} + +// Time returns the time of the event in milliseconds. +func (v *EventButton) Time() uint32 { + c := v.native().time + return uint32(c) +} + +func (v *EventButton) Type() EventType { + c := v.native()._type + return EventType(c) +} + +func (v *EventButton) MotionVal() (float64, float64) { + x := v.native().x + y := v.native().y + return float64(x), float64(y) +} + +func (v *EventButton) MotionValRoot() (float64, float64) { + x := v.native().x_root + y := v.native().y_root + return float64(x), float64(y) +} + +/* + * GdkEventKey + */ + +// EventKey is a representation of GDK's GdkEventKey. +type EventKey struct { + *Event +} + +func EventKeyNew() *EventKey { + ee := (*C.GdkEvent)(unsafe.Pointer(&C.GdkEventKey{})) + ev := Event{ee} + return &EventKey{&ev} +} + +// EventKeyNewFromEvent returns an EventKey from an Event. +// +// Using widget.Connect() for a key related signal such as +// "key-press-event" results in a *Event being passed as +// the callback's second argument. The argument is actually a +// *EventKey. EventKeyNewFromEvent provides a means of creating +// an EventKey from the Event. +func EventKeyNewFromEvent(event *Event) *EventKey { + ee := (*C.GdkEvent)(unsafe.Pointer(event.native())) + ev := Event{ee} + return &EventKey{&ev} +} + +// Native returns a pointer to the underlying GdkEventKey. +func (v *EventKey) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *EventKey) native() *C.GdkEventKey { + return (*C.GdkEventKey)(unsafe.Pointer(v.Event.native())) +} + +func (v *EventKey) KeyVal() uint { + c := v.native().keyval + return uint(c) +} + +func (v *EventKey) HardwareKeyCode() uint16 { + c := v.native().hardware_keycode + return uint16(c) +} + +func (v *EventKey) Type() EventType { + c := v.native()._type + return EventType(c) +} + +func (v *EventKey) State() uint { + c := v.native().state + return uint(c) +} + +/* + * GdkEventMotion + */ + +type EventMotion struct { + *Event +} + +func EventMotionNew() *EventMotion { + ee := (*C.GdkEvent)(unsafe.Pointer(&C.GdkEventMotion{})) + ev := Event{ee} + return &EventMotion{&ev} +} + +// EventMotionNewFromEvent returns an EventMotion from an Event. +// +// Using widget.Connect() for a key related signal such as +// "button-press-event" results in a *Event being passed as +// the callback's second argument. The argument is actually a +// *EventMotion. EventMotionNewFromEvent provides a means of creating +// an EventKey from the Event. +func EventMotionNewFromEvent(event *Event) *EventMotion { + ee := (*C.GdkEvent)(unsafe.Pointer(event.native())) + ev := Event{ee} + return &EventMotion{&ev} +} + +// Native returns a pointer to the underlying GdkEventMotion. +func (v *EventMotion) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *EventMotion) native() *C.GdkEventMotion { + return (*C.GdkEventMotion)(unsafe.Pointer(v.Event.native())) +} + +func (v *EventMotion) MotionVal() (float64, float64) { + x := v.native().x + y := v.native().y + return float64(x), float64(y) +} + +func (v *EventMotion) MotionValRoot() (float64, float64) { + x := v.native().x_root + y := v.native().y_root + return float64(x), float64(y) +} + +// Time returns the time of the event in milliseconds. +func (v *EventMotion) Time() uint32 { + c := v.native().time + return uint32(c) +} + +func (v *EventMotion) Type() EventType { + c := v.native()._type + return EventType(c) +} + +// A bit-mask representing the state of the modifier keys (e.g. Control, Shift +// and Alt) and the pointer buttons. See gdk.ModifierType constants. +func (v *EventMotion) State() ModifierType { + c := v.native().state + return ModifierType(c) +} + +/* + * GdkEventCrossing + */ + +// EventCrossing is a representation of GDK's GdkEventCrossing. +type EventCrossing struct { + *Event +} + +func EventCrossingNew() *EventCrossing { + ee := (*C.GdkEvent)(unsafe.Pointer(&C.GdkEventCrossing{})) + ev := Event{ee} + return &EventCrossing{&ev} +} + +// EventCrossingNewFromEvent returns an EventCrossing from an Event. +// +// Using widget.Connect() for a key related signal such as +// "enter-notify-event" results in a *Event being passed as +// the callback's second argument. The argument is actually a +// *EventCrossing. EventCrossingNewFromEvent provides a means of creating +// an EventCrossing from the Event. +func EventCrossingNewFromEvent(event *Event) *EventCrossing { + ee := (*C.GdkEvent)(unsafe.Pointer(event.native())) + ev := Event{ee} + return &EventCrossing{&ev} +} + +// Native returns a pointer to the underlying GdkEventCrossing. +func (v *EventCrossing) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *EventCrossing) native() *C.GdkEventCrossing { + return (*C.GdkEventCrossing)(unsafe.Pointer(v.Event.native())) +} + +func (v *EventCrossing) X() float64 { + c := v.native().x + return float64(c) +} + +func (v *EventCrossing) Y() float64 { + c := v.native().y + return float64(c) +} + +// XRoot returns the x coordinate of the pointer relative to the root of the screen. +func (v *EventCrossing) XRoot() float64 { + c := v.native().x_root + return float64(c) +} + +// YRoot returns the y coordinate of the pointer relative to the root of the screen. +func (v *EventCrossing) YRoot() float64 { + c := v.native().y_root + return float64(c) +} + +func (v *EventCrossing) State() uint { + c := v.native().state + return uint(c) +} + +// Time returns the time of the event in milliseconds. +func (v *EventCrossing) Time() uint32 { + c := v.native().time + return uint32(c) +} + +func (v *EventCrossing) Type() EventType { + c := v.native()._type + return EventType(c) +} + +func (v *EventCrossing) MotionVal() (float64, float64) { + x := v.native().x + y := v.native().y + return float64(x), float64(y) +} + +func (v *EventCrossing) MotionValRoot() (float64, float64) { + x := v.native().x_root + y := v.native().y_root + return float64(x), float64(y) +} + +func (v *EventCrossing) Mode() CrossingMode { + c := v.native().mode + return CrossingMode(c) +} + +func (v *EventCrossing) Detail() NotifyType { + c := v.native().detail + return NotifyType(c) +} + +func (v *EventCrossing) Focus() bool { + c := v.native().focus + return gobool(c) +} + +/* + * GdkEventScroll + */ + +// EventScroll is a representation of GDK's GdkEventScroll. +type EventScroll struct { + *Event +} + +func EventScrollNew() *EventScroll { + ee := (*C.GdkEvent)(unsafe.Pointer(&C.GdkEventScroll{})) + ev := Event{ee} + return &EventScroll{&ev} +} + +// EventScrollNewFromEvent returns an EventScroll from an Event. +// +// Using widget.Connect() for a key related signal such as +// "button-press-event" results in a *Event being passed as +// the callback's second argument. The argument is actually a +// *EventScroll. EventScrollNewFromEvent provides a means of creating +// an EventKey from the Event. +func EventScrollNewFromEvent(event *Event) *EventScroll { + ee := (*C.GdkEvent)(unsafe.Pointer(event.native())) + ev := Event{ee} + return &EventScroll{&ev} +} + +// Native returns a pointer to the underlying GdkEventScroll. +func (v *EventScroll) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *EventScroll) native() *C.GdkEventScroll { + return (*C.GdkEventScroll)(unsafe.Pointer(v.Event.native())) +} + +func (v *EventScroll) DeltaX() float64 { + return float64(v.native().delta_x) +} + +func (v *EventScroll) DeltaY() float64 { + return float64(v.native().delta_y) +} + +func (v *EventScroll) X() float64 { + return float64(v.native().x) +} + +func (v *EventScroll) Y() float64 { + return float64(v.native().y) +} + +func (v *EventScroll) Type() EventType { + c := v.native()._type + return EventType(c) +} + +func (v *EventScroll) Direction() ScrollDirection { + c := v.native().direction + return ScrollDirection(c) +} + +// A bit-mask representing the state of the modifier keys (e.g. Control, Shift +// and Alt) and the pointer buttons. See gdk.ModifierType constants. +func (v *EventScroll) State() ModifierType { + c := v.native().state + return ModifierType(c) +} + +/* + * GdkEventWindowState + */ + +// EventWindowState is a representation of GDK's GdkEventWindowState. +type EventWindowState struct { + *Event +} + +func EventWindowStateNew() *EventWindowState { + ee := (*C.GdkEvent)(unsafe.Pointer(&C.GdkEventWindowState{})) + ev := Event{ee} + return &EventWindowState{&ev} +} + +// EventWindowStateNewFromEvent returns an EventWindowState from an Event. +// +// Using widget.Connect() for the +// "window-state-event" signal results in a *Event being passed as +// the callback's second argument. The argument is actually a +// *EventWindowState. EventWindowStateNewFromEvent provides a means of creating +// an EventWindowState from the Event. +func EventWindowStateNewFromEvent(event *Event) *EventWindowState { + ee := (*C.GdkEvent)(unsafe.Pointer(event.native())) + ev := Event{ee} + return &EventWindowState{&ev} +} + +// Native returns a pointer to the underlying GdkEventWindowState. +func (v *EventWindowState) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *EventWindowState) native() *C.GdkEventWindowState { + return (*C.GdkEventWindowState)(unsafe.Pointer(v.Event.native())) +} + +func (v *EventWindowState) Type() EventType { + c := v.native()._type + return EventType(c) +} + +func (v *EventWindowState) ChangedMask() WindowState { + c := v.native().changed_mask + return WindowState(c) +} + +func (v *EventWindowState) NewWindowState() WindowState { + c := v.native().new_window_state + return WindowState(c) +} + +/* + * GdkEventConfigure + */ + +// EventConfigure is a representation of GDK's GdkEventConfigure. +type EventConfigure struct { + *Event +} + +func EventConfigureNew() *EventConfigure { + ee := (*C.GdkEvent)(unsafe.Pointer(&C.GdkEventConfigure{})) + ev := Event{ee} + return &EventConfigure{&ev} +} + +// EventConfigureNewFromEvent returns an EventConfigure from an Event. +// +// Using widget.Connect() for the +// "configure-event" signal results in a *Event being passed as +// the callback's second argument. The argument is actually a +// *EventConfigure. EventConfigureNewFromEvent provides a means of creating +// an EventConfigure from the Event. +func EventConfigureNewFromEvent(event *Event) *EventConfigure { + ee := (*C.GdkEvent)(unsafe.Pointer(event.native())) + ev := Event{ee} + return &EventConfigure{&ev} +} + +// Native returns a pointer to the underlying GdkEventConfigure. +func (v *EventConfigure) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *EventConfigure) native() *C.GdkEventConfigure { + return (*C.GdkEventConfigure)(unsafe.Pointer(v.Event.native())) +} + +func (v *EventConfigure) Type() EventType { + c := v.native()._type + return EventType(c) +} + +func (v *EventConfigure) X() int { + c := v.native().x + return int(c) +} + +func (v *EventConfigure) Y() int { + c := v.native().y + return int(c) +} + +func (v *EventConfigure) Width() int { + c := v.native().width + return int(c) +} + +func (v *EventConfigure) Height() int { + c := v.native().height + return int(c) +} + +/* + * GdkGravity + */ + +type Gravity int + +const ( + GDK_GRAVITY_NORTH_WEST = C.GDK_GRAVITY_NORTH_WEST + GDK_GRAVITY_NORTH = C.GDK_GRAVITY_NORTH + GDK_GRAVITY_NORTH_EAST = C.GDK_GRAVITY_NORTH_EAST + GDK_GRAVITY_WEST = C.GDK_GRAVITY_WEST + GDK_GRAVITY_CENTER = C.GDK_GRAVITY_CENTER + GDK_GRAVITY_EAST = C.GDK_GRAVITY_EAST + GDK_GRAVITY_SOUTH_WEST = C.GDK_GRAVITY_SOUTH_WEST + GDK_GRAVITY_SOUTH = C.GDK_GRAVITY_SOUTH + GDK_GRAVITY_SOUTH_EAST = C.GDK_GRAVITY_SOUTH_EAST + GDK_GRAVITY_STATIC = C.GDK_GRAVITY_STATIC +) + +func marshalGravity(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Gravity(c), nil +} + +/* + * GdkRGBA + */ +// To create a GdkRGBA you have to use NewRGBA function. +type RGBA struct { + rgba *C.GdkRGBA +} + +func marshalRGBA(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + return WrapRGBA(unsafe.Pointer(c)), nil +} + +func WrapRGBA(p unsafe.Pointer) *RGBA { + return wrapRGBA((*C.GdkRGBA)(p)) +} + +func wrapRGBA(cRgba *C.GdkRGBA) *RGBA { + if cRgba == nil { + return nil + } + return &RGBA{cRgba} +} + +func NewRGBA(values ...float64) *RGBA { + cRgba := new(C.GdkRGBA) + for i, value := range values { + switch i { + case 0: + cRgba.red = C.gdouble(value) + case 1: + cRgba.green = C.gdouble(value) + case 2: + cRgba.blue = C.gdouble(value) + case 3: + cRgba.alpha = C.gdouble(value) + } + } + return wrapRGBA(cRgba) +} + +func (c *RGBA) Floats() []float64 { + return []float64{ + float64(c.rgba.red), + float64(c.rgba.green), + float64(c.rgba.blue), + float64(c.rgba.alpha)} +} + +func (c *RGBA) Native() uintptr { + return uintptr(unsafe.Pointer(c.rgba)) +} + +// SetColors sets all colors values in the RGBA. +func (c *RGBA) SetColors(r, g, b, a float64) { + c.rgba.red = C.gdouble(r) + c.rgba.green = C.gdouble(g) + c.rgba.blue = C.gdouble(b) + c.rgba.alpha = C.gdouble(a) +} + +/* + * The following methods (Get/Set) are made for + * more convenient use of the GdkRGBA object + */ +// GetRed get red value from the RGBA. +func (c *RGBA) GetRed() float64 { + return float64(c.rgba.red) +} + +// GetGreen get green value from the RGBA. +func (c *RGBA) GetGreen() float64 { + return float64(c.rgba.green) +} + +// GetBlue get blue value from the RGBA. +func (c *RGBA) GetBlue() float64 { + return float64(c.rgba.blue) +} + +// GetAlpha get alpha value from the RGBA. +func (c *RGBA) GetAlpha() float64 { + return float64(c.rgba.alpha) +} + +// SetRed set red value in the RGBA. +func (c *RGBA) SetRed(red float64) { + c.rgba.red = C.gdouble(red) +} + +// SetGreen set green value in the RGBA. +func (c *RGBA) SetGreen(green float64) { + c.rgba.green = C.gdouble(green) +} + +// SetBlue set blue value in the RGBA. +func (c *RGBA) SetBlue(blue float64) { + c.rgba.blue = C.gdouble(blue) +} + +// SetAlpha set alpha value in the RGBA. +func (c *RGBA) SetAlpha(alpha float64) { + c.rgba.alpha = C.gdouble(alpha) +} + +// Parse is a representation of gdk_rgba_parse(). +func (c *RGBA) Parse(spec string) bool { + cstr := (*C.gchar)(C.CString(spec)) + defer C.free(unsafe.Pointer(cstr)) + + return gobool(C.gdk_rgba_parse(c.rgba, cstr)) +} + +// String is a representation of gdk_rgba_to_string(). +func (c *RGBA) String() string { + return C.GoString((*C.char)(C.gdk_rgba_to_string(c.rgba))) +} + +// free is a representation of gdk_rgba_free(). +func (c *RGBA) free() { + C.gdk_rgba_free(c.rgba) +} + +// Copy is a representation of gdk_rgba_copy(). +func (c *RGBA) Copy() (*RGBA, error) { + cRgba := C.gdk_rgba_copy(c.rgba) + + if c == nil { + return nil, nilPtrErr + } + obj := wrapRGBA(cRgba) + + runtime.SetFinalizer(obj, (*RGBA).free) + return obj, nil +} + +// Equal is a representation of gdk_rgba_equal(). +func (c *RGBA) Equal(rgba *RGBA) bool { + return gobool(C.gdk_rgba_equal( + C.gconstpointer(c.rgba), + C.gconstpointer(rgba.rgba))) +} + +// Hash is a representation of gdk_rgba_hash(). +func (c *RGBA) Hash() uint { + return uint(C.gdk_rgba_hash(C.gconstpointer(c.rgba))) +} + +/* + * GdkPoint + */ + +// Point is a representation of GDK's GdkPoint type. +type Point struct { + GdkPoint C.GdkPoint +} + +func WrapPoint(p uintptr) *Point { + return wrapPoint((*C.GdkPoint)(unsafe.Pointer(p))) +} + +func wrapPoint(obj *C.GdkPoint) *Point { + if obj == nil { + return nil + } + return &Point{*obj} +} + +// Native() returns a pointer to the underlying GdkPoint. +func (v *Point) native() *C.GdkPoint { + return &v.GdkPoint +} + +// PointNew helper function to create a GdkPoint +func PointNew(x, y int) *Point { + var p C.GdkPoint + p.x = C.gint(x) + p.y = C.gint(y) + return &Point{p} +} + +// GetPointInt helper function to get GdkPoint values +func (v *Point) GetPointInt() (x, y int) { + return int(v.native().x), int(v.native().y) +} + +// SetPointInt helper function to set GdkPoint values +func (v *Point) SetPointInt(x, y int) { + v.native().x = C.gint(x) + v.native().y = C.gint(y) +} + +// GetX returns x field of the underlying GdkPoint. +func (v *Point) GetX() int { + return int(v.native().x) +} + +// SetX sets x field of the underlying GdkPoint. +func (v *Point) SetX(x int) { + v.native().x = C.gint(x) +} + +// GetY returns y field of the underlying GdkPoint. +func (v *Point) GetY() int { + return int(v.native().y) +} + +// SetY sets y field of the underlying GdkPoint. +func (v *Point) SetY(y int) { + v.native().y = C.gint(y) +} + +/* + * GdkRectangle + */ + +// Rectangle is a representation of GDK's GdkRectangle type. +type Rectangle struct { + GdkRectangle C.GdkRectangle +} + +func WrapRectangle(p uintptr) *Rectangle { + return wrapRectangle((*C.GdkRectangle)(unsafe.Pointer(p))) +} + +func wrapRectangle(obj *C.GdkRectangle) *Rectangle { + if obj == nil { + return nil + } + return &Rectangle{*obj} +} + +// Native() returns a pointer to the underlying GdkRectangle. +func (r *Rectangle) native() *C.GdkRectangle { + return &r.GdkRectangle +} + +// RectangleIntersect is a wrapper around gdk_rectangle_intersect(). +func (v *Rectangle) RectangleIntersect(rect *Rectangle) (*Rectangle, bool) { + r := new(C.GdkRectangle) + c := C.gdk_rectangle_intersect(v.native(), rect.native(), r) + return wrapRectangle(r), gobool(c) +} + +// RectangleUnion is a wrapper around gdk_rectangle_union(). +func (v *Rectangle) RectangleUnion(rect *Rectangle) *Rectangle { + r := new(C.GdkRectangle) + C.gdk_rectangle_union(v.native(), rect.native(), r) + return wrapRectangle(r) +} + +// RectangleNew helper function to create a GdkRectanlge +func RectangleNew(x, y, width, height int) *Rectangle { + var r C.GdkRectangle + r.x = C.int(x) + r.y = C.int(y) + r.width = C.int(width) + r.height = C.int(height) + return &Rectangle{r} +} + +// SetRectangleInt helper function to set GdkRectanlge values +func (v *Rectangle) SetRectangleInt(x, y, width, height int) { + v.native().x = C.int(x) + v.native().y = C.int(y) + v.native().width = C.int(width) + v.native().height = C.int(height) +} + +// GetRectangleInt helper function to get GdkRectanlge values +func (v *Rectangle) GetRectangleInt() (x, y, width, height int) { + return int(v.native().x), + int(v.native().y), + int(v.native().width), + int(v.native().height) +} + +// GetX returns x field of the underlying GdkRectangle. +func (r *Rectangle) GetX() int { + return int(r.native().x) +} + +// SetX sets x field of the underlying GdkRectangle. +func (r *Rectangle) SetX(x int) { + r.native().x = C.int(x) +} + +// GetY returns y field of the underlying GdkRectangle. +func (r *Rectangle) GetY() int { + return int(r.native().y) +} + +// SetY sets y field of the underlying GdkRectangle. +func (r *Rectangle) SetY(y int) { + r.native().y = C.int(y) +} + +// GetWidth returns width field of the underlying GdkRectangle. +func (r *Rectangle) GetWidth() int { + return int(r.native().width) +} + +// SetWidth sets width field of the underlying GdkRectangle. +func (r *Rectangle) SetWidth(width int) { + r.native().width = C.int(width) +} + +// GetHeight returns height field of the underlying GdkRectangle. +func (r *Rectangle) GetHeight() int { + return int(r.native().height) +} + +// SetHeight sets height field of the underlying GdkRectangle. +func (r *Rectangle) SetHeight(height int) { + r.native().height = C.int(height) +} + +/* + * GdkGeometry + */ + +type Geometry struct { + GdkGeometry C.GdkGeometry +} + +func WrapGeometry(p uintptr) *Geometry { + return wrapGeometry((*C.GdkGeometry)(unsafe.Pointer(p))) +} + +func wrapGeometry(obj *C.GdkGeometry) *Geometry { + if obj == nil { + return nil + } + return &Geometry{*obj} +} + +// native returns a pointer to the underlying GdkGeometry. +func (r *Geometry) native() *C.GdkGeometry { + return &r.GdkGeometry +} + +// GetMinWidth returns min_width field of the underlying GdkGeometry. +func (r *Geometry) GetMinWidth() int { + return int(r.native().min_width) +} + +// SetMinWidth sets min_width field of the underlying GdkGeometry. +func (r *Geometry) SetMinWidth(minWidth int) { + r.native().min_width = C.gint(minWidth) +} + +// GetMinHeight returns min_height field of the underlying GdkGeometry. +func (r *Geometry) GetMinHeight() int { + return int(r.native().min_height) +} + +// SetMinHeight sets min_height field of the underlying GdkGeometry. +func (r *Geometry) SetMinHeight(minHeight int) { + r.native().min_height = C.gint(minHeight) +} + +// GetMaxWidth returns max_width field of the underlying GdkGeometry. +func (r *Geometry) GetMaxWidth() int { + return int(r.native().max_width) +} + +// SetMaxWidth sets max_width field of the underlying GdkGeometry. +func (r *Geometry) SetMaxWidth(maxWidth int) { + r.native().max_width = C.gint(maxWidth) +} + +// GetMaxHeight returns max_height field of the underlying GdkGeometry. +func (r *Geometry) GetMaxHeight() int { + return int(r.native().max_height) +} + +// SetMaxHeight sets max_height field of the underlying GdkGeometry. +func (r *Geometry) SetMaxHeight(maxHeight int) { + r.native().max_height = C.gint(maxHeight) +} + +// GetBaseWidth returns base_width field of the underlying GdkGeometry. +func (r *Geometry) GetBaseWidth() int { + return int(r.native().base_width) +} + +// SetBaseWidth sets base_width field of the underlying GdkGeometry. +func (r *Geometry) SetBaseWidth(baseWidth int) { + r.native().base_width = C.gint(baseWidth) +} + +// GetBaseHeight returns base_height field of the underlying GdkGeometry. +func (r *Geometry) GetBaseHeight() int { + return int(r.native().base_height) +} + +// SetBaseHeight sets base_height field of the underlying GdkGeometry. +func (r *Geometry) SetBaseHeight(baseHeight int) { + r.native().base_height = C.gint(baseHeight) +} + +// GetWidthInc returns width_inc field of the underlying GdkGeometry. +func (r *Geometry) GetWidthInc() int { + return int(r.native().width_inc) +} + +// SetWidthInc sets width_inc field of the underlying GdkGeometry. +func (r *Geometry) SetWidthInc(widthInc int) { + r.native().width_inc = C.gint(widthInc) +} + +// GetHeightInc returns height_inc field of the underlying GdkGeometry. +func (r *Geometry) GetHeightInc() int { + return int(r.native().height_inc) +} + +// SetHeightInc sets height_inc field of the underlying GdkGeometry. +func (r *Geometry) SetHeightInc(heightInc int) { + r.native().height_inc = C.gint(heightInc) +} + +// GetMinAspect returns min_aspect field of the underlying GdkGeometry. +func (r *Geometry) GetMinAspect() float64 { + return float64(r.native().min_aspect) +} + +// SetMinAspect sets min_aspect field of the underlying GdkGeometry. +func (r *Geometry) SetMinAspect(minAspect float64) { + r.native().min_aspect = C.gdouble(minAspect) +} + +// GetMaxAspect returns max_aspect field of the underlying GdkGeometry. +func (r *Geometry) GetMaxAspect() float64 { + return float64(r.native().max_aspect) +} + +// SetMaxAspect sets max_aspect field of the underlying GdkGeometry. +func (r *Geometry) SetMaxAspect(maxAspect float64) { + r.native().max_aspect = C.gdouble(maxAspect) +} + +// GetWinGravity returns win_gravity field of the underlying GdkGeometry. +func (r *Geometry) GetWinGravity() Gravity { + return Gravity(r.native().win_gravity) +} + +// SetWinGravity sets win_gravity field of the underlying GdkGeometry. +func (r *Geometry) SetWinGravity(winGravity Gravity) { + r.native().win_gravity = C.GdkGravity(winGravity) +} + +/* + * GdkVisual + */ + +// Visual is a representation of GDK's GdkVisual. +type Visual struct { + *glib.Object +} + +func (v *Visual) native() *C.GdkVisual { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkVisual(p) +} + +func (v *Visual) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalVisual(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Visual{obj}, nil +} + +// GetBluePixelDetails is a wrapper around gdk_visual_get_blue_pixel_details(). +func (v *Visual) GetBluePixelDetails() (*uint32, *int, *int) { + var ( + m *uint32 = nil + s, p *int = nil, nil + mask C.guint32 + shift, precision C.gint + ) + C.gdk_visual_get_blue_pixel_details(v.native(), &mask, &shift, &precision) + if &mask != nil { + m = new(uint32) + *m = uint32(mask) + } + if &shift != nil { + s = new(int) + *s = int(shift) + } + if &precision != nil { + p = new(int) + *p = int(precision) + } + return m, s, p +} + +// GetDepth is a wrapper around gdk_visual_get_depth(). +func (v *Visual) GetDepth() int { + return int(C.gdk_visual_get_depth(v.native())) +} + +// GetGreenPixelDetails is a wrapper around gdk_visual_get_green_pixel_details(). +func (v *Visual) GetGreenPixelDetails() (*uint32, *int, *int) { + var ( + m *uint32 = nil + s, p *int = nil, nil + mask C.guint32 + shift, precision C.gint + ) + C.gdk_visual_get_green_pixel_details(v.native(), &mask, &shift, &precision) + if &mask != nil { + m = new(uint32) + *m = uint32(mask) + } + if &shift != nil { + s = new(int) + *s = int(shift) + } + if &precision != nil { + p = new(int) + *p = int(precision) + } + return m, s, p +} + +// GetRedPixelDetails is a wrapper around gdk_visual_get_red_pixel_details(). +func (v *Visual) GetRedPixelDetails() (*uint32, *int, *int) { + var ( + m *uint32 = nil + s, p *int = nil, nil + mask C.guint32 + shift, precision C.gint + ) + C.gdk_visual_get_red_pixel_details(v.native(), &mask, &shift, &precision) + if &mask != nil { + m = new(uint32) + *m = uint32(mask) + } + if &shift != nil { + s = new(int) + *s = int(shift) + } + if &precision != nil { + p = new(int) + *p = int(precision) + } + return m, s, p +} + +// GetVisualType is a wrapper around gdk_visual_get_visual_type(). +func (v *Visual) GetVisualType() VisualType { + return VisualType(C.gdk_visual_get_visual_type(v.native())) +} + +// GetScreen is a wrapper around gdk_visual_get_screen(). +func (v *Visual) GetScreen() (*Screen, error) { + return toScreen(C.gdk_visual_get_screen(v.native())) +} + +/* + * GdkWindow + */ + +// Window is a representation of GDK's GdkWindow. +type Window struct { + *glib.Object +} + +// SetCursor is a wrapper around gdk_window_set_cursor(). +func (v *Window) SetCursor(cursor *Cursor) { + C.gdk_window_set_cursor(v.native(), cursor.native()) +} + +// native returns a pointer to the underlying GdkWindow. +func (v *Window) native() *C.GdkWindow { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkWindow(p) +} + +// Native returns a pointer to the underlying GdkWindow. +func (v *Window) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +// WindowGetWidth is a wrapper around gdk_window_get_width() +func (v *Window) WindowGetWidth() (width int) { + return int(C.gdk_window_get_width(v.native())) +} + +// WindowGetHeight is a wrapper around gdk_window_get_height() +func (v *Window) WindowGetHeight() (height int) { + return int(C.gdk_window_get_height(v.native())) +} + +// CreateSimilarSurface is a wrapper around gdk_window_create_similar_surface(). +func (v *Window) CreateSimilarSurface(content cairo.Content, w, h int) (*cairo.Surface, error) { + surface := C.gdk_window_create_similar_surface(v.native(), C.cairo_content_t(content), C.gint(w), C.gint(h)) + + status := cairo.Status(C.cairo_surface_status(surface)) + if status != cairo.STATUS_SUCCESS { + return nil, cairo.ErrorStatus(status) + } + + return cairo.NewSurface(uintptr(unsafe.Pointer(surface)), false), nil +} + +//PixbufGetFromWindow is a wrapper around gdk_pixbuf_get_from_window() +func (v *Window) PixbufGetFromWindow(x, y, w, h int) (*Pixbuf, error) { + c := C.gdk_pixbuf_get_from_window(v.native(), C.gint(x), C.gint(y), C.gint(w), C.gint(h)) + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} + +// GetDevicePosition is a wrapper around gdk_window_get_device_position() +func (v *Window) GetDevicePosition(d *Device) (*Window, int, int, ModifierType) { + var x C.gint + var y C.gint + var mt C.GdkModifierType + underneathWindow := C.gdk_window_get_device_position(v.native(), d.native(), &x, &y, &mt) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(underneathWindow))} + rw := &Window{obj} + runtime.SetFinalizer(rw, func(_ interface{}) { obj.Unref() }) + return rw, int(x), int(y), ModifierType(mt) +} + +func PixbufGetFromSurface(surface *cairo.Surface, src_x, src_y, width, height int) (*Pixbuf, error) { + c := C.gdk_pixbuf_get_from_surface((*C.cairo_surface_t)(unsafe.Pointer(surface.Native())), C.gint(src_x), C.gint(src_y), C.gint(width), C.gint(height)) + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} + +func marshalWindow(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Window{obj}, nil +} + +func toWindow(s *C.GdkWindow) (*Window, error) { + if s == nil { + return nil, nilPtrErr + } + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(s))} + return &Window{obj}, nil +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk.go.h b/vendor/github.com/gotk3/gotk3/gdk/gdk.go.h new file mode 100644 index 0000000..cfa1a34 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk.go.h @@ -0,0 +1,48 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include + +// Type Casting +static GdkAtom toGdkAtom(void *p) { return ((GdkAtom)p); } + +static GdkDevice *toGdkDevice(void *p) { return (GDK_DEVICE(p)); } + +static GdkCursor *toGdkCursor(void *p) { return (GDK_CURSOR(p)); } + +static GdkDeviceManager *toGdkDeviceManager(void *p) { + return (GDK_DEVICE_MANAGER(p)); +} + +static GdkDisplay *toGdkDisplay(void *p) { return (GDK_DISPLAY(p)); } + +static GdkDisplayManager *toGdkDisplayManager(void *p) { return (GDK_DISPLAY_MANAGER(p)); } + +static GdkKeymap *toGdkKeymap(void *p) { return (GDK_KEYMAP(p)); } + +static GdkDragContext *toGdkDragContext(void *p) { + return (GDK_DRAG_CONTEXT(p)); +} + +static GdkScreen *toGdkScreen(void *p) { return (GDK_SCREEN(p)); } + +static GdkVisual *toGdkVisual(void *p) { return (GDK_VISUAL(p)); } + +static GdkWindow *toGdkWindow(void *p) { return (GDK_WINDOW(p)); } + +static inline gchar **next_gcharptr(gchar **s) { return (s + 1); } diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_10.go b/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_10.go new file mode 100644 index 0000000..a969098 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_10.go @@ -0,0 +1,33 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// This file includes wrappers for symbols deprecated beginning with GTK 3.10, +// and should only be included in a build targeted intended to target GTK +// 3.8 or earlier. To target an earlier build build, use the build tag +// gtk_MAJOR_MINOR. For example, to target GTK 3.8, run +// 'go build -tags gtk_3_8'. +// +build gtk_3_6 gtk_3_8 gtk_deprecated + +package gdk + +// #include +import "C" + +// GetNScreens is a wrapper around gdk_display_get_n_screens(). +func (v *Display) GetNScreens() int { + c := C.gdk_display_get_n_screens(v.native()) + return int(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_16.go b/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_16.go new file mode 100644 index 0000000..091d015 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_16.go @@ -0,0 +1,12 @@ +//+build gtk_3_6 gtk_3_8 gtk_3_10 gtk_3_12 gtk_3_14 gtk_deprecated + +package gdk + +// #include +import "C" + +// SupportsComposite() is a wrapper around gdk_display_supports_composite(). +func (v *Display) SupportsComposite() bool { + c := C.gdk_display_supports_composite(v.native()) + return gobool(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_20.go b/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_20.go new file mode 100644 index 0000000..07fc74a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_20.go @@ -0,0 +1,79 @@ +//+build gtk_3_6 gtk_3_8 gtk_3_10 gtk_3_12 gtk_3_14 gtk_3_16 gtk_3_18 gtk_deprecated + +package gdk + +// #include +import "C" +import ( + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// Grab() is a wrapper around gdk_device_grab(). +func (v *Device) Grab(w *Window, ownership GrabOwnership, owner_events bool, event_mask EventMask, cursor *Cursor, time uint32) GrabStatus { + ret := C.gdk_device_grab( + v.native(), + w.native(), + C.GdkGrabOwnership(ownership), + gbool(owner_events), + C.GdkEventMask(event_mask), + cursor.native(), + C.guint32(time), + ) + return GrabStatus(ret) +} + +// GetClientPointer() is a wrapper around gdk_device_manager_get_client_pointer(). +func (v *DeviceManager) GetClientPointer() (*Device, error) { + c := C.gdk_device_manager_get_client_pointer(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &Device{glib.Take(unsafe.Pointer(c))}, nil +} + +// ListDevices() is a wrapper around gdk_device_manager_list_devices(). +func (v *DeviceManager) ListDevices(tp DeviceType) *glib.List { + clist := C.gdk_device_manager_list_devices(v.native(), C.GdkDeviceType(tp)) + if clist == nil { + return nil + } + + //TODO: WrapList should set the finalizer + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return &Device{&glib.Object{glib.ToGObject(ptr)}} + }) + runtime.SetFinalizer(glist, func(glist *glib.List) { + glist.Free() + }) + return glist +} + +// Ungrab() is a wrapper around gdk_device_ungrab(). +func (v *Device) Ungrab(time uint32) { + C.gdk_device_ungrab(v.native(), C.guint32(time)) +} + +// GetDeviceManager() is a wrapper around gdk_display_get_device_manager(). +func (v *Display) GetDeviceManager() (*DeviceManager, error) { + c := C.gdk_display_get_device_manager(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &DeviceManager{glib.Take(unsafe.Pointer(c))}, nil +} + +// GetScreen() is a wrapper around gdk_display_get_screen(). +func (v *Display) GetScreen(screenNum int) (*Screen, error) { + c := C.gdk_display_get_screen(v.native(), C.gint(screenNum)) + if c == nil { + return nil, nilPtrErr + } + + return &Screen{glib.Take(unsafe.Pointer(c))}, nil +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_22.go b/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_22.go new file mode 100644 index 0000000..fabcaf6 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_deprecated_since_3_22.go @@ -0,0 +1,113 @@ +//+build gtk_3_6 gtk_3_8 gtk_3_10 gtk_3_12 gtk_3_14 gtk_3_16 gtk_3_18 gtk_3_20 gtk_deprecated + +package gdk + +// #include +import "C" + +/* + * Constants + */ + +// TODO: +// GdkByteOrder + +/* + * GdkScreen + */ + +// GetActiveWindow is a wrapper around gdk_screen_get_active_window(). +func (v *Screen) GetActiveWindow() (*Window, error) { + return toWindow(C.gdk_screen_get_active_window(v.native())) +} + +// GetHeight is a wrapper around gdk_screen_get_height(). +func (v *Screen) GetHeight() int { + c := C.gdk_screen_get_height(v.native()) + return int(c) +} + +// GetHeightMM is a wrapper around gdk_screen_get_height_mm(). +func (v *Screen) GetHeightMM() int { + return int(C.gdk_screen_get_height_mm(v.native())) +} + +// GetMonitorAtPoint is a wrapper around gdk_screen_get_monitor_at_point(). +func (v *Screen) GetMonitorAtPoint(x, y int) int { + return int(C.gdk_screen_get_monitor_at_point(v.native(), C.gint(x), C.gint(y))) +} + +// GetMonitorAtWindow is a wrapper around gdk_screen_get_monitor_at_window(). +func (v *Screen) GetMonitorAtWindow(w *Window) int { + return int(C.gdk_screen_get_monitor_at_window(v.native(), w.native())) +} + +// GetMonitorHeightMM is a wrapper around gdk_screen_get_monitor_height_mm(). +func (v *Screen) GetMonitorHeightMM(m int) int { + return int(C.gdk_screen_get_monitor_height_mm(v.native(), C.gint(m))) +} + +// GetMonitorPlugName is a wrapper around gdk_screen_get_monitor_plug_name(). +func (v *Screen) GetMonitorPlugName(m int) (string, error) { + return toString(C.gdk_screen_get_monitor_plug_name(v.native(), C.gint(m))) +} + +// GetMonitorScaleFactor is a wrapper around gdk_screen_get_monitor_scale_factor(). +func (v *Screen) GetMonitorScaleFactor(m int) int { + return int(C.gdk_screen_get_monitor_scale_factor(v.native(), C.gint(m))) +} + +// GetMonitorWidthMM is a wrapper around gdk_screen_get_monitor_width_mm(). +func (v *Screen) GetMonitorWidthMM(m int) int { + return int(C.gdk_screen_get_monitor_width_mm(v.native(), C.gint(m))) +} + +// GetNMonitors is a wrapper around gdk_screen_get_n_monitors(). +func (v *Screen) GetNMonitors() int { + return int(C.gdk_screen_get_n_monitors(v.native())) +} + +// GetNumber is a wrapper around gdk_screen_get_number(). +func (v *Screen) GetNumber() int { + return int(C.gdk_screen_get_number(v.native())) +} + +// GetPrimaryMonitor is a wrapper around gdk_screen_get_primary_monitor(). +func (v *Screen) GetPrimaryMonitor() int { + return int(C.gdk_screen_get_primary_monitor(v.native())) +} + +// GetWidth is a wrapper around gdk_screen_get_width(). +func (v *Screen) GetWidth() int { + c := C.gdk_screen_get_width(v.native()) + return int(c) +} + +// GetWidthMM is a wrapper around gdk_screen_get_width_mm(). +func (v *Screen) GetWidthMM() int { + return int(C.gdk_screen_get_width_mm(v.native())) +} + +// MakeDisplayName is a wrapper around gdk_screen_make_display_name(). +func (v *Screen) MakeDisplayName() (string, error) { + return toString(C.gdk_screen_make_display_name(v.native())) +} + +/* + * GdkVisuals + */ + +// TODO: +// gdk_query_depths(). +// gdk_query_visual_types(). +// gdk_list_visuals(). +// gdk_visual_get_bits_per_rgb(). +// gdk_visual_get_byte_order(). +// gdk_visual_get_colormap_size(). +// gdk_visual_get_best_depth(). +// gdk_visual_get_best_type(). +// gdk_visual_get_system(). +// gdk_visual_get_best(). +// gdk_visual_get_best_with_depth(). +// gdk_visual_get_best_with_type(). +// gdk_visual_get_best_with_both(). diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_10.go b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_10.go new file mode 100644 index 0000000..f941b0a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_10.go @@ -0,0 +1,50 @@ +// +build !gtk_3_6,!gtk_3_8 +// Supports building with gtk 3.10+ + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +import "C" +import ( + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/cairo" +) + +// TODO: +// gdk_device_get_position_double(). + +// GetScaleFactor is a wrapper around gdk_window_get_scale_factor(). +func (v *Window) GetScaleFactor() int { + return int(C.gdk_window_get_scale_factor(v.native())) +} + +// CreateSimilarImageSurface is a wrapper around gdk_window_create_similar_image_surface(). +func (v *Window) CreateSimilarImageSurface(format cairo.Format, w, h, scale int) (*cairo.Surface, error) { + surface := C.gdk_window_create_similar_image_surface(v.native(), C.cairo_format_t(format), C.gint(w), C.gint(h), C.gint(scale)) + + status := cairo.Status(C.cairo_surface_status(surface)) + if status != cairo.STATUS_SUCCESS { + return nil, cairo.ErrorStatus(status) + } + + return cairo.NewSurface(uintptr(unsafe.Pointer(surface)), false), nil +} + +// CairoSurfaceCreateFromPixbuf is a wrapper around gdk_cairo_surface_create_from_pixbuf(). +func CairoSurfaceCreateFromPixbuf(pixbuf *Pixbuf, scale int, window *Window) (*cairo.Surface, error) { + v := C.gdk_cairo_surface_create_from_pixbuf(pixbuf.native(), C.gint(scale), window.native()) + + status := cairo.Status(C.cairo_surface_status(v)) + if status != cairo.STATUS_SUCCESS { + return nil, cairo.ErrorStatus(status) + } + + surface := cairo.WrapSurface(uintptr(unsafe.Pointer(v))) + runtime.SetFinalizer(surface, (*cairo.Surface).Close) + + return surface, nil +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_12.go b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_12.go new file mode 100644 index 0000000..d828f26 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_12.go @@ -0,0 +1,7 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10 +// Supports building with gtk 3.12+ + +package gdk + +// TODO: +// gdk_device_get_last_event_window(). diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_16.go b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_16.go new file mode 100644 index 0000000..b53e166 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_16.go @@ -0,0 +1,197 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14 +// Supports building with gtk 3.16+ + +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package gdk + +// #include +// #include "gdk_since_3_16.go.h" +import "C" +import ( + "errors" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + + tm := []glib.TypeMarshaler{ + {glib.Type(C.gdk_gl_context_get_type()), marshalGLContext}, + } + + glib.RegisterGValueMarshalers(tm) +} + +/* + * Constants + */ + +const ( + GRAB_FAILED GrabStatus = C.GDK_GRAB_FAILED +) + +/* + * GdkDevice + */ + +// TODO: +// gdk_device_get_vendor_id(). +// gdk_device_get_product_id(). + +/* + * GdkGLContext + */ + +// GLContext is a representation of GDK's GdkGLContext. +type GLContext struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkGLContext. +func (v *GLContext) native() *C.GdkGLContext { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkGLContext(p) +} + +// Native returns a pointer to the underlying GdkGLContext. +func (v *GLContext) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalGLContext(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &GLContext{obj}, nil +} + +// GetDisplay is a wrapper around gdk_gl_context_get_display(). +func (v *GLContext) GetDisplay() (*Display, error) { + c := C.gdk_gl_context_get_display(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &Display{glib.Take(unsafe.Pointer(c))}, nil +} + +// GetWindow is a wrapper around gdk_gl_context_get_window(). +func (v *GLContext) GetSurface() (*Window, error) { + c := C.gdk_gl_context_get_window(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &Window{glib.Take(unsafe.Pointer(c))}, nil +} + +// GetSharedContext is a wrapper around gdk_gl_context_get_shared_context(). +func (v *GLContext) GetSharedContext() (*GLContext, error) { + c := C.gdk_gl_context_get_shared_context(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &GLContext{glib.Take(unsafe.Pointer(c))}, nil +} + +// MajorVersion is a representation of OpenGL major version. +type MajorVersion int + +// MinorVersion is a representation of OpenGL minor version. +type MinorVersion int + +// GetVersion is a wrapper around gdk_gl_context_get_version(). +func (v *GLContext) GetVersion() (MajorVersion, MinorVersion) { + var major, minor int + C.gdk_gl_context_get_version(v.native(), + (*C.int)(unsafe.Pointer(&major)), (*C.int)(unsafe.Pointer(&minor))) + + return MajorVersion(major), MinorVersion(minor) +} + +// GetRequiredVersion is a wrapper around gdk_gl_context_get_required_version(). +func (v *GLContext) GetRequiredVersion() (MajorVersion, MinorVersion) { + var major, minor int + C.gdk_gl_context_get_required_version(v.native(), + (*C.int)(unsafe.Pointer(&major)), (*C.int)(unsafe.Pointer(&minor))) + + return MajorVersion(major), MinorVersion(minor) +} + +// SetRequiredVersion is a wrapper around gdk_gl_context_set_required_version(). +func (v *GLContext) SetRequiredVersion(major, minor int) { + C.gdk_gl_context_set_required_version(v.native(), (C.int)(major), (C.int)(minor)) +} + +// GetDebugEnabled is a wrapper around gdk_gl_context_get_debug_enabled(). +func (v *GLContext) GetDebugEnabled() bool { + return gobool(C.gdk_gl_context_get_debug_enabled(v.native())) +} + +// SetDebugEnabled is a wrapper around gdk_gl_context_set_debug_enabled(). +func (v *GLContext) SetDebugEnabled(enabled bool) { + C.gdk_gl_context_set_debug_enabled(v.native(), gbool(enabled)) +} + +// GetForwardCompatible is a wrapper around gdk_gl_context_get_forward_compatible(). +func (v *GLContext) GetForwardCompatible() bool { + return gobool(C.gdk_gl_context_get_forward_compatible(v.native())) +} + +// SetForwardCompatible is a wrapper around gdk_gl_context_set_forward_compatible(). +func (v *GLContext) SetForwardCompatible(compatible bool) { + C.gdk_gl_context_set_forward_compatible(v.native(), gbool(compatible)) +} + +// Realize is a wrapper around gdk_gl_context_realize(). +func (v *GLContext) Realize() (bool, error) { + var err *C.GError + r := gobool(C.gdk_gl_context_realize(v.native(), &err)) + if !r { + defer C.g_error_free(err) + return r, errors.New(C.GoString((*C.char)(err.message))) + } + + return r, nil +} + +// MakeCurrent is a wrapper around gdk_gl_context_make_current(). +func (v *GLContext) MakeCurrent() { + C.gdk_gl_context_make_current(v.native()) +} + +// GetCurrent is a wrapper around gdk_gl_context_get_current(). +func GetCurrent() (*GLContext, error) { + c := C.gdk_gl_context_get_current() + if c == nil { + return nil, nilPtrErr + } + + return &GLContext{glib.Take(unsafe.Pointer(c))}, nil +} + +// ClearCurrent is a wrapper around gdk_gl_context_clear_current(). +func ClearCurrent() { + C.gdk_gl_context_clear_current() +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_16.go.h b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_16.go.h new file mode 100644 index 0000000..03add62 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_16.go.h @@ -0,0 +1,22 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include + +// Type Casting +static GdkGLContext *toGdkGLContext(void *p) { return (GDK_GL_CONTEXT(p)); } \ No newline at end of file diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_18.go b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_18.go new file mode 100644 index 0000000..b26ebf2 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_18.go @@ -0,0 +1,32 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16 +// Supports building with gtk 3.18+ + +package gdk + +// #include +import "C" + +/* + * GdkKeymap + */ + +// GetScrollLockState is a wrapper around gdk_keymap_get_scroll_lock_state(). +func (v *Keymap) GetScrollLockState() bool { + return gobool(C.gdk_keymap_get_scroll_lock_state(v.native())) +} + +/* + * GdkWindow + */ + +// SetPassThrough is a wrapper around gdk_window_set_pass_through(). +func (v *Window) SetPassThrough(passThrough bool) { + C.gdk_window_set_pass_through(v.native(), gbool(passThrough)) +} + +// GetPassThrough is a wrapper around gdk_window_get_pass_through(). +func (v *Window) GetPassThrough() bool { + return gobool(C.gdk_window_get_pass_through(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_20.go b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_20.go new file mode 100644 index 0000000..15fc6d9 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_20.go @@ -0,0 +1,89 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16,!gtk_3_18 +// Supports building with gtk 3.20+ + +package gdk + +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// #include +// #include "gdk_since_3_20.go.h" +import "C" + +/* + * GdkGLContext + */ + +// IsLegacy is a wrapper around gdk_gl_context_is_legacy(). +func (v *GLContext) IsLegacy() bool { + return gobool(C.gdk_gl_context_is_legacy(v.native())) +} + +/* + * GdkDisplay + */ + +func (v *Display) GetDefaultSeat() (*Seat, error) { + return toSeat(C.gdk_display_get_default_seat(v.native())) +} + +// gdk_display_list_seats(). + +/* + * GdkDevice + */ + +// TODO: +// gdk_device_get_axes(). +// gdk_device_get_seat(). + +/* + * GdkSeat + */ + +type Seat struct { + *glib.Object +} + +func (v *Seat) native() *C.GdkSeat { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkSeat(p) +} + +// Native returns a pointer to the underlying GdkCursor. +func (v *Seat) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalSeat(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Seat{obj}, nil +} + +func toSeat(s *C.GdkSeat) (*Seat, error) { + if s == nil { + return nil, nilPtrErr + } + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(s))} + return &Seat{obj}, nil +} + +func (v *Seat) GetPointer() (*Device, error) { + return toDevice(C.gdk_seat_get_pointer(v.native())) +} + +/* + * GdkRectangle + */ + +// RectangleEqual is a wrapper around gdk_rectangle_equal(). +func (v *Rectangle) RectangleEqual(rect *Rectangle) bool { + return gobool(C.gdk_rectangle_equal(v.native(), rect.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_20.go.h b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_20.go.h new file mode 100644 index 0000000..8475e5f --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_20.go.h @@ -0,0 +1,21 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +//#include + +static GdkSeat *toGdkSeat(void *p) { return ((GdkSeat *)p); } \ No newline at end of file diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_22.go b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_22.go new file mode 100644 index 0000000..f07e963 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_22.go @@ -0,0 +1,248 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16,!gtk_3_18,!gtk_3_20 +// Supports building with gtk 3.22+ + +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +package gdk + +// #include +// #include "gdk_since_3_22.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + + tm := []glib.TypeMarshaler{ + {glib.Type(C.gdk_subpixel_layout_get_type()), marshalSubpixelLayout}, + } + + glib.RegisterGValueMarshalers(tm) +} + +/* + * Constants + */ + +// TODO: +// GdkSeatCapabilities + +// SubpixelLayout is a representation of GDK's GdkSubpixelLayout. +type SubpixelLayout int + +const ( + SUBPIXEL_LAYOUT_UNKNOWN SubpixelLayout = C.GDK_SUBPIXEL_LAYOUT_UNKNOWN + SUBPIXEL_LAYOUT_NONE SubpixelLayout = C.GDK_SUBPIXEL_LAYOUT_NONE + SUBPIXEL_LAYOUT_HORIZONTAL_RGB SubpixelLayout = C.GDK_SUBPIXEL_LAYOUT_HORIZONTAL_RGB + SUBPIXEL_LAYOUT_HORIZONTAL_BGR SubpixelLayout = C.GDK_SUBPIXEL_LAYOUT_HORIZONTAL_BGR + SUBPIXEL_LAYOUT_VERTICAL_RGB SubpixelLayout = C.GDK_SUBPIXEL_LAYOUT_VERTICAL_RGB + SUBPIXEL_LAYOUT_VERTICAL_BGR SubpixelLayout = C.GDK_SUBPIXEL_LAYOUT_VERTICAL_BGR +) + +func marshalSubpixelLayout(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return SubpixelLayout(c), nil +} + +/* + * GdkDisplay + */ + +// GetNMonitors is a wrapper around gdk_display_get_n_monitors(). +func (v *Display) GetNMonitors() int { + c := C.gdk_display_get_n_monitors(v.native()) + return int(c) +} + +// GetPrimaryMonitor is a wrapper around gdk_display_get_primary_monitor(). +func (v *Display) GetPrimaryMonitor() (*Monitor, error) { + c := C.gdk_display_get_primary_monitor(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &Monitor{glib.Take(unsafe.Pointer(c))}, nil +} + +// GetMonitor is a wrapper around gdk_display_get_monitor(). +func (v *Display) GetMonitor(num int) (*Monitor, error) { + c := C.gdk_display_get_monitor(v.native(), C.int(num)) + if c == nil { + return nil, nilPtrErr + } + return &Monitor{glib.Take(unsafe.Pointer(c))}, nil +} + +// GetMonitorAtWindow is a wrapper around gdk_display_get_monitor_at_window(). +func (v *Display) GetMonitorAtWindow(w *Window) (*Monitor, error) { + c := C.gdk_display_get_monitor_at_window(v.native(), w.native()) + if c == nil { + return nil, nilPtrErr + } + return &Monitor{glib.Take(unsafe.Pointer(c))}, nil +} + +// GetMonitorAtPoint is a wrapper around gdk_display_get_monitor_at_point(). +func (v *Display) GetMonitorAtPoint(x int, y int) (*Monitor, error) { + c := C.gdk_display_get_monitor_at_point(v.native(), C.int(x), C.int(y)) + if c == nil { + return nil, nilPtrErr + } + return &Monitor{glib.Take(unsafe.Pointer(c))}, nil +} + +/* + * GdkSeat + */ + +// TODO: +// GdkSeatGrabPrepareFunc +// gdk_seat_get_display(). +// gdk_seat_grab(). +// gdk_seat_ungrab(). +// gdk_seat_get_capabilities(). +// gdk_seat_get_pointer(). +// gdk_seat_get_keyboard(). +// gdk_seat_get_slaves(). + +/* + * GdkMonitor + */ + +// Monitor is a representation of GDK's GdkMonitor. +type Monitor struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkMonitor. +func (v *Monitor) native() *C.GdkMonitor { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkMonitor(p) +} + +// Native returns a pointer to the underlying GdkMonitor. +func (v *Monitor) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalMonitor(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Monitor{obj}, nil +} + +func toMonitor(s *C.GdkMonitor) (*Monitor, error) { + if s == nil { + return nil, nilPtrErr + } + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(s))} + return &Monitor{obj}, nil +} + +// GetDisplay is a wrapper around gdk_monitor_get_display(). +func (v *Monitor) GetDisplay() (*Display, error) { + return toDisplay(C.gdk_monitor_get_display(v.native())) +} + +// GetGeometry is a wrapper around gdk_monitor_get_geometry(). +func (v *Monitor) GetGeometry() *Rectangle { + var rect C.GdkRectangle + + C.gdk_monitor_get_geometry(v.native(), &rect) + + return wrapRectangle(&rect) +} + +// GetWorkarea is a wrapper around gdk_monitor_get_workarea(). +func (v *Monitor) GetWorkarea() *Rectangle { + var rect C.GdkRectangle + + C.gdk_monitor_get_workarea(v.native(), &rect) + + return wrapRectangle(&rect) +} + +// GetWidthMM is a wrapper around gdk_monitor_get_width_mm(). +func (v *Monitor) GetWidthMM() int { + return int(C.gdk_monitor_get_width_mm(v.native())) +} + +// GetHeightMM is a wrapper around gdk_monitor_get_height_mm(). +func (v *Monitor) GetHeightMM() int { + return int(C.gdk_monitor_get_height_mm(v.native())) +} + +// GetManufacturer is a wrapper around gdk_monitor_get_manufacturer(). +func (v *Monitor) GetManufacturer() string { + // transfer none: don't free data after the code is done. + return C.GoString(C.gdk_monitor_get_manufacturer(v.native())) +} + +// GetModel is a wrapper around gdk_monitor_get_model(). +func (v *Monitor) GetModel() string { + // transfer none: don't free data after the code is done. + return C.GoString(C.gdk_monitor_get_model(v.native())) +} + +// GetScaleFactor is a wrapper around gdk_monitor_get_scale_factor(). +func (v *Monitor) GetScaleFactor() int { + return int(C.gdk_monitor_get_scale_factor(v.native())) +} + +// GetRefreshRate is a wrapper around gdk_monitor_get_refresh_rate(). +func (v *Monitor) GetRefreshRate() int { + return int(C.gdk_monitor_get_refresh_rate(v.native())) +} + +// GetSubpixelLayout is a wrapper around gdk_monitor_get_subpixel_layout(). +func (v *Monitor) GetSubpixelLayout() SubpixelLayout { + return SubpixelLayout(C.gdk_monitor_get_subpixel_layout(v.native())) +} + +// IsPrimary is a wrapper around gdk_monitor_is_primary(). +func (v *Monitor) IsPrimary() bool { + return gobool(C.gdk_monitor_is_primary(v.native())) +} + +/* + * GdkDevice + */ + +// TODO: +// gdk_device_get_axes(). +// gdk_device_tool_get_serial(). +// gdk_device_tool_get_tool_type(). + +/* + * GdkGLContext + */ + +// GetUseES is a wrapper around gdk_gl_context_get_use_es(). +func (v *GLContext) GetUseES() bool { + return gobool(C.gdk_gl_context_get_use_es(v.native())) +} + +// SetUseES is a wrapper around gdk_gl_context_set_use_es(). +func (v *GLContext) SetUseES(es int) { + C.gdk_gl_context_set_use_es(v.native(), (C.int)(es)) +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_22.go.h b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_22.go.h new file mode 100644 index 0000000..c065b67 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_22.go.h @@ -0,0 +1,22 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +//#include + +// Type Casting +static GdkMonitor *toGdkMonitor(void *p) { return (GDK_MONITOR(p)); } diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_8.go b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_8.go new file mode 100644 index 0000000..0cfa802 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_8.go @@ -0,0 +1,231 @@ +// +build !gtk_3_6 +// Supports building with gtk 3.8+ + +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package gdk + +// #include +// #include "gdk_since_3_8.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.gdk_frame_clock_phase_get_type()), marshalClockPhase}, + + // Objects/Interfaces + {glib.Type(C.gdk_frame_clock_get_type()), marshalFrameClock}, + {glib.Type(C.gdk_frame_timings_get_type()), marshalFrameTimings}, + } + + glib.RegisterGValueMarshalers(tm) +} + +// ClockPhase is a representation of GDK's GdkFrameClockPhase. +type ClockPhase int + +const ( + PHASE_NONE ClockPhase = C.GDK_FRAME_CLOCK_PHASE_NONE + PHASE_FLUSH_EVENTS ClockPhase = C.GDK_FRAME_CLOCK_PHASE_FLUSH_EVENTS + PHASE_BEFORE_PAINT ClockPhase = C.GDK_FRAME_CLOCK_PHASE_BEFORE_PAINT + PHASE_UPDATE ClockPhase = C.GDK_FRAME_CLOCK_PHASE_UPDATE + PHASE_LAYOUT ClockPhase = C.GDK_FRAME_CLOCK_PHASE_LAYOUT + PHASE_PAINT ClockPhase = C.GDK_FRAME_CLOCK_PHASE_PAINT + PHASE_RESUME_EVENTS ClockPhase = C.GDK_FRAME_CLOCK_PHASE_RESUME_EVENTS + PHASE_AFTER_PAINT ClockPhase = C.GDK_FRAME_CLOCK_PHASE_AFTER_PAINT +) + +func marshalClockPhase(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ClockPhase(c), nil +} + +/* + * GdkFrameClock + */ + +// FrameClock is a representation of GDK's GdkFrameClock. +type FrameClock struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkFrameClock. +func (v *FrameClock) native() *C.GdkFrameClock { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkFrameClock(p) +} + +// Native returns a pointer to the underlying GdkFrameClock. +func (v *FrameClock) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalFrameClock(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return WrapFrameClock(unsafe.Pointer(c)), nil +} + +func WrapFrameClock(ptr unsafe.Pointer) *FrameClock { + obj := &glib.Object{glib.ToGObject(ptr)} + return &FrameClock{obj} +} + +// BeginUpdating is a wrapper around gdk_frame_clock_begin_updating(). +func (v *FrameClock) BeginUpdating() { + C.gdk_frame_clock_begin_updating(v.native()) +} + +// EndUpdating is a wrapper around gdk_frame_clock_end_updating(). +func (v *FrameClock) EndUpdating() { + C.gdk_frame_clock_end_updating(v.native()) +} + +// GetFrameTime is a wrapper around gdk_frame_clock_get_frame_time(). +func (v *FrameClock) GetFrameTime() int64 { + return int64(C.gdk_frame_clock_get_frame_time(v.native())) +} + +// GetFrameCounter is a wrapper around gdk_frame_clock_get_frame_counter(). +func (v *FrameClock) GetFrameCounter() int64 { + return int64(C.gdk_frame_clock_get_frame_counter(v.native())) +} + +// GetHistoryStart is a wrapper around gdk_frame_clock_get_history_start(). +func (v *FrameClock) GetHistoryStart() int64 { + return int64(C.gdk_frame_clock_get_history_start(v.native())) +} + +// GetTimings is a wrapper around gdk_frame_clock_get_timings(). +func (v *FrameClock) GetTimings(frameCounter int64) (*FrameTimings, error) { + c := C.gdk_frame_clock_get_timings(v.native(), C.gint64(frameCounter)) + if c == nil { + return nil, nilPtrErr + } + return wrapFrameTimings(unsafe.Pointer(c)), nil +} + +// GetCurrentTimings is a wrapper around dk_frame_clock_get_current_timings(). +func (v *FrameClock) GetCurrentTimings() (*FrameTimings, error) { + c := C.gdk_frame_clock_get_current_timings(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapFrameTimings(unsafe.Pointer(c)), nil +} + +// GetRefreshInfo is a wrapper around gdk_frame_clock_get_refresh_info(). +func (v *FrameClock) GetRefreshInfo(baseTime int64) (int64, int64) { + var cr, cp (*C.gint64) + defer C.free(unsafe.Pointer(cr)) + defer C.free(unsafe.Pointer(cp)) + b := C.gint64(baseTime) + + C.gdk_frame_clock_get_refresh_info(v.native(), b, cr, cp) + r, p := int64(*cr), int64(*cp) + return r, p +} + +// RequestPhase is a wrapper around gdk_frame_clock_request_phase(). +func (v *FrameClock) RequestPhase(phase ClockPhase) { + C.gdk_frame_clock_request_phase(v.native(), C.GdkFrameClockPhase(phase)) +} + +/* + * GdkFrameTimings + */ + +// FrameTimings is a representation of GDK's GdkFrameTimings. +type FrameTimings struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkFrameTimings. +func (v *FrameTimings) native() *C.GdkFrameTimings { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkFrameTimings(p) +} + +// Native returns a pointer to the underlying GdkFrameTimings. +func (v *FrameTimings) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func wrapFrameTimings(ptr unsafe.Pointer) *FrameTimings { + obj := &glib.Object{glib.ToGObject(ptr)} + return &FrameTimings{obj} +} + +func marshalFrameTimings(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapFrameTimings(unsafe.Pointer(c)), nil +} + +// Ref is a wrapper around gdk_frame_timings_ref(). +func (v *FrameTimings) Ref() { + c := C.gdk_frame_timings_ref(v.native()) + v = wrapFrameTimings(unsafe.Pointer(c)) +} + +// Unref is a wrapper around gdk_frame_timings_unref(). +func (v *FrameTimings) Unref() { + C.gdk_frame_timings_unref(v.native()) +} + +// GetFrameCounter is a wrapper around gdk_frame_timings_get_frame_counter(). +func (v *FrameTimings) GetFrameCounter() int64 { + return int64(C.gdk_frame_timings_get_frame_counter(v.native())) +} + +// GetComplete is a wrapper around gdk_frame_timings_get_complete(). +func (v *FrameTimings) GetComplete() bool { + return gobool(C.gdk_frame_timings_get_complete(v.native())) +} + +// GetFrameTime is a wrapper around gdk_frame_timings_get_frame_time(). +func (v *FrameTimings) GetFrameTime() int64 { + return int64(C.gdk_frame_timings_get_frame_time(v.native())) +} + +// GetPresentationTime is a wrapper around gdk_frame_timings_get_presentation_time(). +func (v *FrameTimings) GetPresentationTime() int64 { + return int64(C.gdk_frame_timings_get_presentation_time(v.native())) +} + +// GetRefreshInterval is a wrapper around gdk_frame_timings_get_refresh_interval(). +func (v *FrameTimings) GetRefreshInterval() int64 { + return int64(C.gdk_frame_timings_get_refresh_interval(v.native())) +} + +// GetPredictedPresentationTime is a wrapper around gdk_frame_timings_get_predicted_presentation_time(). +func (v *FrameTimings) GetPredictedPresentationTime() int64 { + return int64(C.gdk_frame_timings_get_predicted_presentation_time(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_8.go.h b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_8.go.h new file mode 100644 index 0000000..3417821 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/gdk_since_3_8.go.h @@ -0,0 +1,26 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include + +// Type Casting +static GdkFrameClock *toGdkFrameClock(void *p) { return (GDK_FRAME_CLOCK(p)); } + +static GdkFrameTimings *toGdkFrameTimings(void *p) { + return ((GdkFrameTimings *)p); +} \ No newline at end of file diff --git a/vendor/github.com/gotk3/gotk3/gdk/keys.go b/vendor/github.com/gotk3/gotk3/gdk/keys.go new file mode 100644 index 0000000..bd4536e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/keys.go @@ -0,0 +1,2278 @@ +package gdk + +// #include +// #include "gdk.go.h" +import "C" + +const ( + KEY_VoidSymbol = uint(C.GDK_KEY_VoidSymbol) + KEY_BackSpace = uint(C.GDK_KEY_BackSpace) + KEY_Tab = uint(C.GDK_KEY_Tab) + KEY_Linefeed = uint(C.GDK_KEY_Linefeed) + KEY_Clear = uint(C.GDK_KEY_Clear) + KEY_Return = uint(C.GDK_KEY_Return) + KEY_Pause = uint(C.GDK_KEY_Pause) + KEY_Scroll_Lock = uint(C.GDK_KEY_Scroll_Lock) + KEY_Sys_Req = uint(C.GDK_KEY_Sys_Req) + KEY_Escape = uint(C.GDK_KEY_Escape) + KEY_Delete = uint(C.GDK_KEY_Delete) + KEY_Multi_key = uint(C.GDK_KEY_Multi_key) + KEY_Codeinput = uint(C.GDK_KEY_Codeinput) + KEY_SingleCandidate = uint(C.GDK_KEY_SingleCandidate) + KEY_MultipleCandidate = uint(C.GDK_KEY_MultipleCandidate) + KEY_PreviousCandidate = uint(C.GDK_KEY_PreviousCandidate) + KEY_Kanji = uint(C.GDK_KEY_Kanji) + KEY_Muhenkan = uint(C.GDK_KEY_Muhenkan) + KEY_Henkan_Mode = uint(C.GDK_KEY_Henkan_Mode) + KEY_Henkan = uint(C.GDK_KEY_Henkan) + KEY_Romaji = uint(C.GDK_KEY_Romaji) + KEY_Hiragana = uint(C.GDK_KEY_Hiragana) + KEY_Katakana = uint(C.GDK_KEY_Katakana) + KEY_Hiragana_Katakana = uint(C.GDK_KEY_Hiragana_Katakana) + KEY_Zenkaku = uint(C.GDK_KEY_Zenkaku) + KEY_Hankaku = uint(C.GDK_KEY_Hankaku) + KEY_Zenkaku_Hankaku = uint(C.GDK_KEY_Zenkaku_Hankaku) + KEY_Touroku = uint(C.GDK_KEY_Touroku) + KEY_Massyo = uint(C.GDK_KEY_Massyo) + KEY_Kana_Lock = uint(C.GDK_KEY_Kana_Lock) + KEY_Kana_Shift = uint(C.GDK_KEY_Kana_Shift) + KEY_Eisu_Shift = uint(C.GDK_KEY_Eisu_Shift) + KEY_Eisu_toggle = uint(C.GDK_KEY_Eisu_toggle) + KEY_Kanji_Bangou = uint(C.GDK_KEY_Kanji_Bangou) + KEY_Zen_Koho = uint(C.GDK_KEY_Zen_Koho) + KEY_Mae_Koho = uint(C.GDK_KEY_Mae_Koho) + KEY_Home = uint(C.GDK_KEY_Home) + KEY_Left = uint(C.GDK_KEY_Left) + KEY_Up = uint(C.GDK_KEY_Up) + KEY_Right = uint(C.GDK_KEY_Right) + KEY_Down = uint(C.GDK_KEY_Down) + KEY_Prior = uint(C.GDK_KEY_Prior) + KEY_Page_Up = uint(C.GDK_KEY_Page_Up) + KEY_Next = uint(C.GDK_KEY_Next) + KEY_Page_Down = uint(C.GDK_KEY_Page_Down) + KEY_End = uint(C.GDK_KEY_End) + KEY_Begin = uint(C.GDK_KEY_Begin) + KEY_Select = uint(C.GDK_KEY_Select) + KEY_Print = uint(C.GDK_KEY_Print) + KEY_Execute = uint(C.GDK_KEY_Execute) + KEY_Insert = uint(C.GDK_KEY_Insert) + KEY_Undo = uint(C.GDK_KEY_Undo) + KEY_Redo = uint(C.GDK_KEY_Redo) + KEY_Menu = uint(C.GDK_KEY_Menu) + KEY_Find = uint(C.GDK_KEY_Find) + KEY_Cancel = uint(C.GDK_KEY_Cancel) + KEY_Help = uint(C.GDK_KEY_Help) + KEY_Break = uint(C.GDK_KEY_Break) + KEY_Mode_switch = uint(C.GDK_KEY_Mode_switch) + KEY_script_switch = uint(C.GDK_KEY_script_switch) + KEY_Num_Lock = uint(C.GDK_KEY_Num_Lock) + KEY_KP_Space = uint(C.GDK_KEY_KP_Space) + KEY_KP_Tab = uint(C.GDK_KEY_KP_Tab) + KEY_KP_Enter = uint(C.GDK_KEY_KP_Enter) + KEY_KP_F1 = uint(C.GDK_KEY_KP_F1) + KEY_KP_F2 = uint(C.GDK_KEY_KP_F2) + KEY_KP_F3 = uint(C.GDK_KEY_KP_F3) + KEY_KP_F4 = uint(C.GDK_KEY_KP_F4) + KEY_KP_Home = uint(C.GDK_KEY_KP_Home) + KEY_KP_Left = uint(C.GDK_KEY_KP_Left) + KEY_KP_Up = uint(C.GDK_KEY_KP_Up) + KEY_KP_Right = uint(C.GDK_KEY_KP_Right) + KEY_KP_Down = uint(C.GDK_KEY_KP_Down) + KEY_KP_Prior = uint(C.GDK_KEY_KP_Prior) + KEY_KP_Page_Up = uint(C.GDK_KEY_KP_Page_Up) + KEY_KP_Next = uint(C.GDK_KEY_KP_Next) + KEY_KP_Page_Down = uint(C.GDK_KEY_KP_Page_Down) + KEY_KP_End = uint(C.GDK_KEY_KP_End) + KEY_KP_Begin = uint(C.GDK_KEY_KP_Begin) + KEY_KP_Insert = uint(C.GDK_KEY_KP_Insert) + KEY_KP_Delete = uint(C.GDK_KEY_KP_Delete) + KEY_KP_Equal = uint(C.GDK_KEY_KP_Equal) + KEY_KP_Multiply = uint(C.GDK_KEY_KP_Multiply) + KEY_KP_Add = uint(C.GDK_KEY_KP_Add) + KEY_KP_Separator = uint(C.GDK_KEY_KP_Separator) + KEY_KP_Subtract = uint(C.GDK_KEY_KP_Subtract) + KEY_KP_Decimal = uint(C.GDK_KEY_KP_Decimal) + KEY_KP_Divide = uint(C.GDK_KEY_KP_Divide) + KEY_KP_0 = uint(C.GDK_KEY_KP_0) + KEY_KP_1 = uint(C.GDK_KEY_KP_1) + KEY_KP_2 = uint(C.GDK_KEY_KP_2) + KEY_KP_3 = uint(C.GDK_KEY_KP_3) + KEY_KP_4 = uint(C.GDK_KEY_KP_4) + KEY_KP_5 = uint(C.GDK_KEY_KP_5) + KEY_KP_6 = uint(C.GDK_KEY_KP_6) + KEY_KP_7 = uint(C.GDK_KEY_KP_7) + KEY_KP_8 = uint(C.GDK_KEY_KP_8) + KEY_KP_9 = uint(C.GDK_KEY_KP_9) + KEY_F1 = uint(C.GDK_KEY_F1) + KEY_F2 = uint(C.GDK_KEY_F2) + KEY_F3 = uint(C.GDK_KEY_F3) + KEY_F4 = uint(C.GDK_KEY_F4) + KEY_F5 = uint(C.GDK_KEY_F5) + KEY_F6 = uint(C.GDK_KEY_F6) + KEY_F7 = uint(C.GDK_KEY_F7) + KEY_F8 = uint(C.GDK_KEY_F8) + KEY_F9 = uint(C.GDK_KEY_F9) + KEY_F10 = uint(C.GDK_KEY_F10) + KEY_F11 = uint(C.GDK_KEY_F11) + KEY_L1 = uint(C.GDK_KEY_L1) + KEY_F12 = uint(C.GDK_KEY_F12) + KEY_L2 = uint(C.GDK_KEY_L2) + KEY_F13 = uint(C.GDK_KEY_F13) + KEY_L3 = uint(C.GDK_KEY_L3) + KEY_F14 = uint(C.GDK_KEY_F14) + KEY_L4 = uint(C.GDK_KEY_L4) + KEY_F15 = uint(C.GDK_KEY_F15) + KEY_L5 = uint(C.GDK_KEY_L5) + KEY_F16 = uint(C.GDK_KEY_F16) + KEY_L6 = uint(C.GDK_KEY_L6) + KEY_F17 = uint(C.GDK_KEY_F17) + KEY_L7 = uint(C.GDK_KEY_L7) + KEY_F18 = uint(C.GDK_KEY_F18) + KEY_L8 = uint(C.GDK_KEY_L8) + KEY_F19 = uint(C.GDK_KEY_F19) + KEY_L9 = uint(C.GDK_KEY_L9) + KEY_F20 = uint(C.GDK_KEY_F20) + KEY_L10 = uint(C.GDK_KEY_L10) + KEY_F21 = uint(C.GDK_KEY_F21) + KEY_R1 = uint(C.GDK_KEY_R1) + KEY_F22 = uint(C.GDK_KEY_F22) + KEY_R2 = uint(C.GDK_KEY_R2) + KEY_F23 = uint(C.GDK_KEY_F23) + KEY_R3 = uint(C.GDK_KEY_R3) + KEY_F24 = uint(C.GDK_KEY_F24) + KEY_R4 = uint(C.GDK_KEY_R4) + KEY_F25 = uint(C.GDK_KEY_F25) + KEY_R5 = uint(C.GDK_KEY_R5) + KEY_F26 = uint(C.GDK_KEY_F26) + KEY_R6 = uint(C.GDK_KEY_R6) + KEY_F27 = uint(C.GDK_KEY_F27) + KEY_R7 = uint(C.GDK_KEY_R7) + KEY_F28 = uint(C.GDK_KEY_F28) + KEY_R8 = uint(C.GDK_KEY_R8) + KEY_F29 = uint(C.GDK_KEY_F29) + KEY_R9 = uint(C.GDK_KEY_R9) + KEY_F30 = uint(C.GDK_KEY_F30) + KEY_R10 = uint(C.GDK_KEY_R10) + KEY_F31 = uint(C.GDK_KEY_F31) + KEY_R11 = uint(C.GDK_KEY_R11) + KEY_F32 = uint(C.GDK_KEY_F32) + KEY_R12 = uint(C.GDK_KEY_R12) + KEY_F33 = uint(C.GDK_KEY_F33) + KEY_R13 = uint(C.GDK_KEY_R13) + KEY_F34 = uint(C.GDK_KEY_F34) + KEY_R14 = uint(C.GDK_KEY_R14) + KEY_F35 = uint(C.GDK_KEY_F35) + KEY_R15 = uint(C.GDK_KEY_R15) + KEY_Shift_L = uint(C.GDK_KEY_Shift_L) + KEY_Shift_R = uint(C.GDK_KEY_Shift_R) + KEY_Control_L = uint(C.GDK_KEY_Control_L) + KEY_Control_R = uint(C.GDK_KEY_Control_R) + KEY_Caps_Lock = uint(C.GDK_KEY_Caps_Lock) + KEY_Shift_Lock = uint(C.GDK_KEY_Shift_Lock) + KEY_Meta_L = uint(C.GDK_KEY_Meta_L) + KEY_Meta_R = uint(C.GDK_KEY_Meta_R) + KEY_Alt_L = uint(C.GDK_KEY_Alt_L) + KEY_Alt_R = uint(C.GDK_KEY_Alt_R) + KEY_Super_L = uint(C.GDK_KEY_Super_L) + KEY_Super_R = uint(C.GDK_KEY_Super_R) + KEY_Hyper_L = uint(C.GDK_KEY_Hyper_L) + KEY_Hyper_R = uint(C.GDK_KEY_Hyper_R) + KEY_ISO_Lock = uint(C.GDK_KEY_ISO_Lock) + KEY_ISO_Level2_Latch = uint(C.GDK_KEY_ISO_Level2_Latch) + KEY_ISO_Level3_Shift = uint(C.GDK_KEY_ISO_Level3_Shift) + KEY_ISO_Level3_Latch = uint(C.GDK_KEY_ISO_Level3_Latch) + KEY_ISO_Level3_Lock = uint(C.GDK_KEY_ISO_Level3_Lock) + KEY_ISO_Level5_Shift = uint(C.GDK_KEY_ISO_Level5_Shift) + KEY_ISO_Level5_Latch = uint(C.GDK_KEY_ISO_Level5_Latch) + KEY_ISO_Level5_Lock = uint(C.GDK_KEY_ISO_Level5_Lock) + KEY_ISO_Group_Shift = uint(C.GDK_KEY_ISO_Group_Shift) + KEY_ISO_Group_Latch = uint(C.GDK_KEY_ISO_Group_Latch) + KEY_ISO_Group_Lock = uint(C.GDK_KEY_ISO_Group_Lock) + KEY_ISO_Next_Group = uint(C.GDK_KEY_ISO_Next_Group) + KEY_ISO_Next_Group_Lock = uint(C.GDK_KEY_ISO_Next_Group_Lock) + KEY_ISO_Prev_Group = uint(C.GDK_KEY_ISO_Prev_Group) + KEY_ISO_Prev_Group_Lock = uint(C.GDK_KEY_ISO_Prev_Group_Lock) + KEY_ISO_First_Group = uint(C.GDK_KEY_ISO_First_Group) + KEY_ISO_First_Group_Lock = uint(C.GDK_KEY_ISO_First_Group_Lock) + KEY_ISO_Last_Group = uint(C.GDK_KEY_ISO_Last_Group) + KEY_ISO_Last_Group_Lock = uint(C.GDK_KEY_ISO_Last_Group_Lock) + KEY_ISO_Left_Tab = uint(C.GDK_KEY_ISO_Left_Tab) + KEY_ISO_Move_Line_Up = uint(C.GDK_KEY_ISO_Move_Line_Up) + KEY_ISO_Move_Line_Down = uint(C.GDK_KEY_ISO_Move_Line_Down) + KEY_ISO_Partial_Line_Up = uint(C.GDK_KEY_ISO_Partial_Line_Up) + KEY_ISO_Partial_Line_Down = uint(C.GDK_KEY_ISO_Partial_Line_Down) + KEY_ISO_Partial_Space_Left = uint(C.GDK_KEY_ISO_Partial_Space_Left) + KEY_ISO_Partial_Space_Right = uint(C.GDK_KEY_ISO_Partial_Space_Right) + KEY_ISO_Set_Margin_Left = uint(C.GDK_KEY_ISO_Set_Margin_Left) + KEY_ISO_Set_Margin_Right = uint(C.GDK_KEY_ISO_Set_Margin_Right) + KEY_ISO_Release_Margin_Left = uint(C.GDK_KEY_ISO_Release_Margin_Left) + KEY_ISO_Release_Margin_Right = uint(C.GDK_KEY_ISO_Release_Margin_Right) + KEY_ISO_Release_Both_Margins = uint(C.GDK_KEY_ISO_Release_Both_Margins) + KEY_ISO_Fast_Cursor_Left = uint(C.GDK_KEY_ISO_Fast_Cursor_Left) + KEY_ISO_Fast_Cursor_Right = uint(C.GDK_KEY_ISO_Fast_Cursor_Right) + KEY_ISO_Fast_Cursor_Up = uint(C.GDK_KEY_ISO_Fast_Cursor_Up) + KEY_ISO_Fast_Cursor_Down = uint(C.GDK_KEY_ISO_Fast_Cursor_Down) + KEY_ISO_Continuous_Underline = uint(C.GDK_KEY_ISO_Continuous_Underline) + KEY_ISO_Discontinuous_Underline = uint(C.GDK_KEY_ISO_Discontinuous_Underline) + KEY_ISO_Emphasize = uint(C.GDK_KEY_ISO_Emphasize) + KEY_ISO_Center_Object = uint(C.GDK_KEY_ISO_Center_Object) + KEY_ISO_Enter = uint(C.GDK_KEY_ISO_Enter) + KEY_dead_grave = uint(C.GDK_KEY_dead_grave) + KEY_dead_acute = uint(C.GDK_KEY_dead_acute) + KEY_dead_circumflex = uint(C.GDK_KEY_dead_circumflex) + KEY_dead_tilde = uint(C.GDK_KEY_dead_tilde) + KEY_dead_perispomeni = uint(C.GDK_KEY_dead_perispomeni) + KEY_dead_macron = uint(C.GDK_KEY_dead_macron) + KEY_dead_breve = uint(C.GDK_KEY_dead_breve) + KEY_dead_abovedot = uint(C.GDK_KEY_dead_abovedot) + KEY_dead_diaeresis = uint(C.GDK_KEY_dead_diaeresis) + KEY_dead_abovering = uint(C.GDK_KEY_dead_abovering) + KEY_dead_doubleacute = uint(C.GDK_KEY_dead_doubleacute) + KEY_dead_caron = uint(C.GDK_KEY_dead_caron) + KEY_dead_cedilla = uint(C.GDK_KEY_dead_cedilla) + KEY_dead_ogonek = uint(C.GDK_KEY_dead_ogonek) + KEY_dead_iota = uint(C.GDK_KEY_dead_iota) + KEY_dead_voiced_sound = uint(C.GDK_KEY_dead_voiced_sound) + KEY_dead_semivoiced_sound = uint(C.GDK_KEY_dead_semivoiced_sound) + KEY_dead_belowdot = uint(C.GDK_KEY_dead_belowdot) + KEY_dead_hook = uint(C.GDK_KEY_dead_hook) + KEY_dead_horn = uint(C.GDK_KEY_dead_horn) + KEY_dead_stroke = uint(C.GDK_KEY_dead_stroke) + KEY_dead_abovecomma = uint(C.GDK_KEY_dead_abovecomma) + KEY_dead_psili = uint(C.GDK_KEY_dead_psili) + KEY_dead_abovereversedcomma = uint(C.GDK_KEY_dead_abovereversedcomma) + KEY_dead_dasia = uint(C.GDK_KEY_dead_dasia) + KEY_dead_doublegrave = uint(C.GDK_KEY_dead_doublegrave) + KEY_dead_belowring = uint(C.GDK_KEY_dead_belowring) + KEY_dead_belowmacron = uint(C.GDK_KEY_dead_belowmacron) + KEY_dead_belowcircumflex = uint(C.GDK_KEY_dead_belowcircumflex) + KEY_dead_belowtilde = uint(C.GDK_KEY_dead_belowtilde) + KEY_dead_belowbreve = uint(C.GDK_KEY_dead_belowbreve) + KEY_dead_belowdiaeresis = uint(C.GDK_KEY_dead_belowdiaeresis) + KEY_dead_invertedbreve = uint(C.GDK_KEY_dead_invertedbreve) + KEY_dead_belowcomma = uint(C.GDK_KEY_dead_belowcomma) + KEY_dead_currency = uint(C.GDK_KEY_dead_currency) + KEY_dead_a = uint(C.GDK_KEY_dead_a) + KEY_dead_A = uint(C.GDK_KEY_dead_A) + KEY_dead_e = uint(C.GDK_KEY_dead_e) + KEY_dead_E = uint(C.GDK_KEY_dead_E) + KEY_dead_i = uint(C.GDK_KEY_dead_i) + KEY_dead_I = uint(C.GDK_KEY_dead_I) + KEY_dead_o = uint(C.GDK_KEY_dead_o) + KEY_dead_O = uint(C.GDK_KEY_dead_O) + KEY_dead_u = uint(C.GDK_KEY_dead_u) + KEY_dead_U = uint(C.GDK_KEY_dead_U) + KEY_dead_small_schwa = uint(C.GDK_KEY_dead_small_schwa) + KEY_dead_capital_schwa = uint(C.GDK_KEY_dead_capital_schwa) + KEY_dead_greek = uint(C.GDK_KEY_dead_greek) + KEY_First_Virtual_Screen = uint(C.GDK_KEY_First_Virtual_Screen) + KEY_Prev_Virtual_Screen = uint(C.GDK_KEY_Prev_Virtual_Screen) + KEY_Next_Virtual_Screen = uint(C.GDK_KEY_Next_Virtual_Screen) + KEY_Last_Virtual_Screen = uint(C.GDK_KEY_Last_Virtual_Screen) + KEY_Terminate_Server = uint(C.GDK_KEY_Terminate_Server) + KEY_AccessX_Enable = uint(C.GDK_KEY_AccessX_Enable) + KEY_AccessX_Feedback_Enable = uint(C.GDK_KEY_AccessX_Feedback_Enable) + KEY_RepeatKeys_Enable = uint(C.GDK_KEY_RepeatKeys_Enable) + KEY_SlowKeys_Enable = uint(C.GDK_KEY_SlowKeys_Enable) + KEY_BounceKeys_Enable = uint(C.GDK_KEY_BounceKeys_Enable) + KEY_StickyKeys_Enable = uint(C.GDK_KEY_StickyKeys_Enable) + KEY_MouseKeys_Enable = uint(C.GDK_KEY_MouseKeys_Enable) + KEY_MouseKeys_Accel_Enable = uint(C.GDK_KEY_MouseKeys_Accel_Enable) + KEY_Overlay1_Enable = uint(C.GDK_KEY_Overlay1_Enable) + KEY_Overlay2_Enable = uint(C.GDK_KEY_Overlay2_Enable) + KEY_AudibleBell_Enable = uint(C.GDK_KEY_AudibleBell_Enable) + KEY_Pointer_Left = uint(C.GDK_KEY_Pointer_Left) + KEY_Pointer_Right = uint(C.GDK_KEY_Pointer_Right) + KEY_Pointer_Up = uint(C.GDK_KEY_Pointer_Up) + KEY_Pointer_Down = uint(C.GDK_KEY_Pointer_Down) + KEY_Pointer_UpLeft = uint(C.GDK_KEY_Pointer_UpLeft) + KEY_Pointer_UpRight = uint(C.GDK_KEY_Pointer_UpRight) + KEY_Pointer_DownLeft = uint(C.GDK_KEY_Pointer_DownLeft) + KEY_Pointer_DownRight = uint(C.GDK_KEY_Pointer_DownRight) + KEY_Pointer_Button_Dflt = uint(C.GDK_KEY_Pointer_Button_Dflt) + KEY_Pointer_Button1 = uint(C.GDK_KEY_Pointer_Button1) + KEY_Pointer_Button2 = uint(C.GDK_KEY_Pointer_Button2) + KEY_Pointer_Button3 = uint(C.GDK_KEY_Pointer_Button3) + KEY_Pointer_Button4 = uint(C.GDK_KEY_Pointer_Button4) + KEY_Pointer_Button5 = uint(C.GDK_KEY_Pointer_Button5) + KEY_Pointer_DblClick_Dflt = uint(C.GDK_KEY_Pointer_DblClick_Dflt) + KEY_Pointer_DblClick1 = uint(C.GDK_KEY_Pointer_DblClick1) + KEY_Pointer_DblClick2 = uint(C.GDK_KEY_Pointer_DblClick2) + KEY_Pointer_DblClick3 = uint(C.GDK_KEY_Pointer_DblClick3) + KEY_Pointer_DblClick4 = uint(C.GDK_KEY_Pointer_DblClick4) + KEY_Pointer_DblClick5 = uint(C.GDK_KEY_Pointer_DblClick5) + KEY_Pointer_Drag_Dflt = uint(C.GDK_KEY_Pointer_Drag_Dflt) + KEY_Pointer_Drag1 = uint(C.GDK_KEY_Pointer_Drag1) + KEY_Pointer_Drag2 = uint(C.GDK_KEY_Pointer_Drag2) + KEY_Pointer_Drag3 = uint(C.GDK_KEY_Pointer_Drag3) + KEY_Pointer_Drag4 = uint(C.GDK_KEY_Pointer_Drag4) + KEY_Pointer_Drag5 = uint(C.GDK_KEY_Pointer_Drag5) + KEY_Pointer_EnableKeys = uint(C.GDK_KEY_Pointer_EnableKeys) + KEY_Pointer_Accelerate = uint(C.GDK_KEY_Pointer_Accelerate) + KEY_Pointer_DfltBtnNext = uint(C.GDK_KEY_Pointer_DfltBtnNext) + KEY_Pointer_DfltBtnPrev = uint(C.GDK_KEY_Pointer_DfltBtnPrev) + KEY_ch = uint(C.GDK_KEY_ch) + KEY_Ch = uint(C.GDK_KEY_Ch) + KEY_CH = uint(C.GDK_KEY_CH) + KEY_c_h = uint(C.GDK_KEY_c_h) + KEY_C_h = uint(C.GDK_KEY_C_h) + KEY_C_H = uint(C.GDK_KEY_C_H) + KEY_3270_Duplicate = uint(C.GDK_KEY_3270_Duplicate) + KEY_3270_FieldMark = uint(C.GDK_KEY_3270_FieldMark) + KEY_3270_Right2 = uint(C.GDK_KEY_3270_Right2) + KEY_3270_Left2 = uint(C.GDK_KEY_3270_Left2) + KEY_3270_BackTab = uint(C.GDK_KEY_3270_BackTab) + KEY_3270_EraseEOF = uint(C.GDK_KEY_3270_EraseEOF) + KEY_3270_EraseInput = uint(C.GDK_KEY_3270_EraseInput) + KEY_3270_Reset = uint(C.GDK_KEY_3270_Reset) + KEY_3270_Quit = uint(C.GDK_KEY_3270_Quit) + KEY_3270_PA1 = uint(C.GDK_KEY_3270_PA1) + KEY_3270_PA2 = uint(C.GDK_KEY_3270_PA2) + KEY_3270_PA3 = uint(C.GDK_KEY_3270_PA3) + KEY_3270_Test = uint(C.GDK_KEY_3270_Test) + KEY_3270_Attn = uint(C.GDK_KEY_3270_Attn) + KEY_3270_CursorBlink = uint(C.GDK_KEY_3270_CursorBlink) + KEY_3270_AltCursor = uint(C.GDK_KEY_3270_AltCursor) + KEY_3270_KeyClick = uint(C.GDK_KEY_3270_KeyClick) + KEY_3270_Jump = uint(C.GDK_KEY_3270_Jump) + KEY_3270_Ident = uint(C.GDK_KEY_3270_Ident) + KEY_3270_Rule = uint(C.GDK_KEY_3270_Rule) + KEY_3270_Copy = uint(C.GDK_KEY_3270_Copy) + KEY_3270_Play = uint(C.GDK_KEY_3270_Play) + KEY_3270_Setup = uint(C.GDK_KEY_3270_Setup) + KEY_3270_Record = uint(C.GDK_KEY_3270_Record) + KEY_3270_ChangeScreen = uint(C.GDK_KEY_3270_ChangeScreen) + KEY_3270_DeleteWord = uint(C.GDK_KEY_3270_DeleteWord) + KEY_3270_ExSelect = uint(C.GDK_KEY_3270_ExSelect) + KEY_3270_CursorSelect = uint(C.GDK_KEY_3270_CursorSelect) + KEY_3270_PrintScreen = uint(C.GDK_KEY_3270_PrintScreen) + KEY_3270_Enter = uint(C.GDK_KEY_3270_Enter) + KEY_space = uint(C.GDK_KEY_space) + KEY_exclam = uint(C.GDK_KEY_exclam) + KEY_quotedbl = uint(C.GDK_KEY_quotedbl) + KEY_numbersign = uint(C.GDK_KEY_numbersign) + KEY_dollar = uint(C.GDK_KEY_dollar) + KEY_percent = uint(C.GDK_KEY_percent) + KEY_ampersand = uint(C.GDK_KEY_ampersand) + KEY_apostrophe = uint(C.GDK_KEY_apostrophe) + KEY_quoteright = uint(C.GDK_KEY_quoteright) + KEY_parenleft = uint(C.GDK_KEY_parenleft) + KEY_parenright = uint(C.GDK_KEY_parenright) + KEY_asterisk = uint(C.GDK_KEY_asterisk) + KEY_plus = uint(C.GDK_KEY_plus) + KEY_comma = uint(C.GDK_KEY_comma) + KEY_minus = uint(C.GDK_KEY_minus) + KEY_period = uint(C.GDK_KEY_period) + KEY_slash = uint(C.GDK_KEY_slash) + KEY_0 = uint(C.GDK_KEY_0) + KEY_1 = uint(C.GDK_KEY_1) + KEY_2 = uint(C.GDK_KEY_2) + KEY_3 = uint(C.GDK_KEY_3) + KEY_4 = uint(C.GDK_KEY_4) + KEY_5 = uint(C.GDK_KEY_5) + KEY_6 = uint(C.GDK_KEY_6) + KEY_7 = uint(C.GDK_KEY_7) + KEY_8 = uint(C.GDK_KEY_8) + KEY_9 = uint(C.GDK_KEY_9) + KEY_colon = uint(C.GDK_KEY_colon) + KEY_semicolon = uint(C.GDK_KEY_semicolon) + KEY_less = uint(C.GDK_KEY_less) + KEY_equal = uint(C.GDK_KEY_equal) + KEY_greater = uint(C.GDK_KEY_greater) + KEY_question = uint(C.GDK_KEY_question) + KEY_at = uint(C.GDK_KEY_at) + KEY_A = uint(C.GDK_KEY_A) + KEY_B = uint(C.GDK_KEY_B) + KEY_C = uint(C.GDK_KEY_C) + KEY_D = uint(C.GDK_KEY_D) + KEY_E = uint(C.GDK_KEY_E) + KEY_F = uint(C.GDK_KEY_F) + KEY_G = uint(C.GDK_KEY_G) + KEY_H = uint(C.GDK_KEY_H) + KEY_I = uint(C.GDK_KEY_I) + KEY_J = uint(C.GDK_KEY_J) + KEY_K = uint(C.GDK_KEY_K) + KEY_L = uint(C.GDK_KEY_L) + KEY_M = uint(C.GDK_KEY_M) + KEY_N = uint(C.GDK_KEY_N) + KEY_O = uint(C.GDK_KEY_O) + KEY_P = uint(C.GDK_KEY_P) + KEY_Q = uint(C.GDK_KEY_Q) + KEY_R = uint(C.GDK_KEY_R) + KEY_S = uint(C.GDK_KEY_S) + KEY_T = uint(C.GDK_KEY_T) + KEY_U = uint(C.GDK_KEY_U) + KEY_V = uint(C.GDK_KEY_V) + KEY_W = uint(C.GDK_KEY_W) + KEY_X = uint(C.GDK_KEY_X) + KEY_Y = uint(C.GDK_KEY_Y) + KEY_Z = uint(C.GDK_KEY_Z) + KEY_bracketleft = uint(C.GDK_KEY_bracketleft) + KEY_backslash = uint(C.GDK_KEY_backslash) + KEY_bracketright = uint(C.GDK_KEY_bracketright) + KEY_asciicircum = uint(C.GDK_KEY_asciicircum) + KEY_underscore = uint(C.GDK_KEY_underscore) + KEY_grave = uint(C.GDK_KEY_grave) + KEY_quoteleft = uint(C.GDK_KEY_quoteleft) + KEY_a = uint(C.GDK_KEY_a) + KEY_b = uint(C.GDK_KEY_b) + KEY_c = uint(C.GDK_KEY_c) + KEY_d = uint(C.GDK_KEY_d) + KEY_e = uint(C.GDK_KEY_e) + KEY_f = uint(C.GDK_KEY_f) + KEY_g = uint(C.GDK_KEY_g) + KEY_h = uint(C.GDK_KEY_h) + KEY_i = uint(C.GDK_KEY_i) + KEY_j = uint(C.GDK_KEY_j) + KEY_k = uint(C.GDK_KEY_k) + KEY_l = uint(C.GDK_KEY_l) + KEY_m = uint(C.GDK_KEY_m) + KEY_n = uint(C.GDK_KEY_n) + KEY_o = uint(C.GDK_KEY_o) + KEY_p = uint(C.GDK_KEY_p) + KEY_q = uint(C.GDK_KEY_q) + KEY_r = uint(C.GDK_KEY_r) + KEY_s = uint(C.GDK_KEY_s) + KEY_t = uint(C.GDK_KEY_t) + KEY_u = uint(C.GDK_KEY_u) + KEY_v = uint(C.GDK_KEY_v) + KEY_w = uint(C.GDK_KEY_w) + KEY_x = uint(C.GDK_KEY_x) + KEY_y = uint(C.GDK_KEY_y) + KEY_z = uint(C.GDK_KEY_z) + KEY_braceleft = uint(C.GDK_KEY_braceleft) + KEY_bar = uint(C.GDK_KEY_bar) + KEY_braceright = uint(C.GDK_KEY_braceright) + KEY_asciitilde = uint(C.GDK_KEY_asciitilde) + KEY_nobreakspace = uint(C.GDK_KEY_nobreakspace) + KEY_exclamdown = uint(C.GDK_KEY_exclamdown) + KEY_cent = uint(C.GDK_KEY_cent) + KEY_sterling = uint(C.GDK_KEY_sterling) + KEY_currency = uint(C.GDK_KEY_currency) + KEY_yen = uint(C.GDK_KEY_yen) + KEY_brokenbar = uint(C.GDK_KEY_brokenbar) + KEY_section = uint(C.GDK_KEY_section) + KEY_diaeresis = uint(C.GDK_KEY_diaeresis) + KEY_copyright = uint(C.GDK_KEY_copyright) + KEY_ordfeminine = uint(C.GDK_KEY_ordfeminine) + KEY_guillemotleft = uint(C.GDK_KEY_guillemotleft) + KEY_notsign = uint(C.GDK_KEY_notsign) + KEY_hyphen = uint(C.GDK_KEY_hyphen) + KEY_registered = uint(C.GDK_KEY_registered) + KEY_macron = uint(C.GDK_KEY_macron) + KEY_degree = uint(C.GDK_KEY_degree) + KEY_plusminus = uint(C.GDK_KEY_plusminus) + KEY_twosuperior = uint(C.GDK_KEY_twosuperior) + KEY_threesuperior = uint(C.GDK_KEY_threesuperior) + KEY_acute = uint(C.GDK_KEY_acute) + KEY_mu = uint(C.GDK_KEY_mu) + KEY_paragraph = uint(C.GDK_KEY_paragraph) + KEY_periodcentered = uint(C.GDK_KEY_periodcentered) + KEY_cedilla = uint(C.GDK_KEY_cedilla) + KEY_onesuperior = uint(C.GDK_KEY_onesuperior) + KEY_masculine = uint(C.GDK_KEY_masculine) + KEY_guillemotright = uint(C.GDK_KEY_guillemotright) + KEY_onequarter = uint(C.GDK_KEY_onequarter) + KEY_onehalf = uint(C.GDK_KEY_onehalf) + KEY_threequarters = uint(C.GDK_KEY_threequarters) + KEY_questiondown = uint(C.GDK_KEY_questiondown) + KEY_Agrave = uint(C.GDK_KEY_Agrave) + KEY_Aacute = uint(C.GDK_KEY_Aacute) + KEY_Acircumflex = uint(C.GDK_KEY_Acircumflex) + KEY_Atilde = uint(C.GDK_KEY_Atilde) + KEY_Adiaeresis = uint(C.GDK_KEY_Adiaeresis) + KEY_Aring = uint(C.GDK_KEY_Aring) + KEY_AE = uint(C.GDK_KEY_AE) + KEY_Ccedilla = uint(C.GDK_KEY_Ccedilla) + KEY_Egrave = uint(C.GDK_KEY_Egrave) + KEY_Eacute = uint(C.GDK_KEY_Eacute) + KEY_Ecircumflex = uint(C.GDK_KEY_Ecircumflex) + KEY_Ediaeresis = uint(C.GDK_KEY_Ediaeresis) + KEY_Igrave = uint(C.GDK_KEY_Igrave) + KEY_Iacute = uint(C.GDK_KEY_Iacute) + KEY_Icircumflex = uint(C.GDK_KEY_Icircumflex) + KEY_Idiaeresis = uint(C.GDK_KEY_Idiaeresis) + KEY_ETH = uint(C.GDK_KEY_ETH) + KEY_Eth = uint(C.GDK_KEY_Eth) + KEY_Ntilde = uint(C.GDK_KEY_Ntilde) + KEY_Ograve = uint(C.GDK_KEY_Ograve) + KEY_Oacute = uint(C.GDK_KEY_Oacute) + KEY_Ocircumflex = uint(C.GDK_KEY_Ocircumflex) + KEY_Otilde = uint(C.GDK_KEY_Otilde) + KEY_Odiaeresis = uint(C.GDK_KEY_Odiaeresis) + KEY_multiply = uint(C.GDK_KEY_multiply) + KEY_Oslash = uint(C.GDK_KEY_Oslash) + KEY_Ooblique = uint(C.GDK_KEY_Ooblique) + KEY_Ugrave = uint(C.GDK_KEY_Ugrave) + KEY_Uacute = uint(C.GDK_KEY_Uacute) + KEY_Ucircumflex = uint(C.GDK_KEY_Ucircumflex) + KEY_Udiaeresis = uint(C.GDK_KEY_Udiaeresis) + KEY_Yacute = uint(C.GDK_KEY_Yacute) + KEY_THORN = uint(C.GDK_KEY_THORN) + KEY_Thorn = uint(C.GDK_KEY_Thorn) + KEY_ssharp = uint(C.GDK_KEY_ssharp) + KEY_agrave = uint(C.GDK_KEY_agrave) + KEY_aacute = uint(C.GDK_KEY_aacute) + KEY_acircumflex = uint(C.GDK_KEY_acircumflex) + KEY_atilde = uint(C.GDK_KEY_atilde) + KEY_adiaeresis = uint(C.GDK_KEY_adiaeresis) + KEY_aring = uint(C.GDK_KEY_aring) + KEY_ae = uint(C.GDK_KEY_ae) + KEY_ccedilla = uint(C.GDK_KEY_ccedilla) + KEY_egrave = uint(C.GDK_KEY_egrave) + KEY_eacute = uint(C.GDK_KEY_eacute) + KEY_ecircumflex = uint(C.GDK_KEY_ecircumflex) + KEY_ediaeresis = uint(C.GDK_KEY_ediaeresis) + KEY_igrave = uint(C.GDK_KEY_igrave) + KEY_iacute = uint(C.GDK_KEY_iacute) + KEY_icircumflex = uint(C.GDK_KEY_icircumflex) + KEY_idiaeresis = uint(C.GDK_KEY_idiaeresis) + KEY_eth = uint(C.GDK_KEY_eth) + KEY_ntilde = uint(C.GDK_KEY_ntilde) + KEY_ograve = uint(C.GDK_KEY_ograve) + KEY_oacute = uint(C.GDK_KEY_oacute) + KEY_ocircumflex = uint(C.GDK_KEY_ocircumflex) + KEY_otilde = uint(C.GDK_KEY_otilde) + KEY_odiaeresis = uint(C.GDK_KEY_odiaeresis) + KEY_division = uint(C.GDK_KEY_division) + KEY_oslash = uint(C.GDK_KEY_oslash) + KEY_ooblique = uint(C.GDK_KEY_ooblique) + KEY_ugrave = uint(C.GDK_KEY_ugrave) + KEY_uacute = uint(C.GDK_KEY_uacute) + KEY_ucircumflex = uint(C.GDK_KEY_ucircumflex) + KEY_udiaeresis = uint(C.GDK_KEY_udiaeresis) + KEY_yacute = uint(C.GDK_KEY_yacute) + KEY_thorn = uint(C.GDK_KEY_thorn) + KEY_ydiaeresis = uint(C.GDK_KEY_ydiaeresis) + KEY_Aogonek = uint(C.GDK_KEY_Aogonek) + KEY_breve = uint(C.GDK_KEY_breve) + KEY_Lstroke = uint(C.GDK_KEY_Lstroke) + KEY_Lcaron = uint(C.GDK_KEY_Lcaron) + KEY_Sacute = uint(C.GDK_KEY_Sacute) + KEY_Scaron = uint(C.GDK_KEY_Scaron) + KEY_Scedilla = uint(C.GDK_KEY_Scedilla) + KEY_Tcaron = uint(C.GDK_KEY_Tcaron) + KEY_Zacute = uint(C.GDK_KEY_Zacute) + KEY_Zcaron = uint(C.GDK_KEY_Zcaron) + KEY_Zabovedot = uint(C.GDK_KEY_Zabovedot) + KEY_aogonek = uint(C.GDK_KEY_aogonek) + KEY_ogonek = uint(C.GDK_KEY_ogonek) + KEY_lstroke = uint(C.GDK_KEY_lstroke) + KEY_lcaron = uint(C.GDK_KEY_lcaron) + KEY_sacute = uint(C.GDK_KEY_sacute) + KEY_caron = uint(C.GDK_KEY_caron) + KEY_scaron = uint(C.GDK_KEY_scaron) + KEY_scedilla = uint(C.GDK_KEY_scedilla) + KEY_tcaron = uint(C.GDK_KEY_tcaron) + KEY_zacute = uint(C.GDK_KEY_zacute) + KEY_doubleacute = uint(C.GDK_KEY_doubleacute) + KEY_zcaron = uint(C.GDK_KEY_zcaron) + KEY_zabovedot = uint(C.GDK_KEY_zabovedot) + KEY_Racute = uint(C.GDK_KEY_Racute) + KEY_Abreve = uint(C.GDK_KEY_Abreve) + KEY_Lacute = uint(C.GDK_KEY_Lacute) + KEY_Cacute = uint(C.GDK_KEY_Cacute) + KEY_Ccaron = uint(C.GDK_KEY_Ccaron) + KEY_Eogonek = uint(C.GDK_KEY_Eogonek) + KEY_Ecaron = uint(C.GDK_KEY_Ecaron) + KEY_Dcaron = uint(C.GDK_KEY_Dcaron) + KEY_Dstroke = uint(C.GDK_KEY_Dstroke) + KEY_Nacute = uint(C.GDK_KEY_Nacute) + KEY_Ncaron = uint(C.GDK_KEY_Ncaron) + KEY_Odoubleacute = uint(C.GDK_KEY_Odoubleacute) + KEY_Rcaron = uint(C.GDK_KEY_Rcaron) + KEY_Uring = uint(C.GDK_KEY_Uring) + KEY_Udoubleacute = uint(C.GDK_KEY_Udoubleacute) + KEY_Tcedilla = uint(C.GDK_KEY_Tcedilla) + KEY_racute = uint(C.GDK_KEY_racute) + KEY_abreve = uint(C.GDK_KEY_abreve) + KEY_lacute = uint(C.GDK_KEY_lacute) + KEY_cacute = uint(C.GDK_KEY_cacute) + KEY_ccaron = uint(C.GDK_KEY_ccaron) + KEY_eogonek = uint(C.GDK_KEY_eogonek) + KEY_ecaron = uint(C.GDK_KEY_ecaron) + KEY_dcaron = uint(C.GDK_KEY_dcaron) + KEY_dstroke = uint(C.GDK_KEY_dstroke) + KEY_nacute = uint(C.GDK_KEY_nacute) + KEY_ncaron = uint(C.GDK_KEY_ncaron) + KEY_odoubleacute = uint(C.GDK_KEY_odoubleacute) + KEY_rcaron = uint(C.GDK_KEY_rcaron) + KEY_uring = uint(C.GDK_KEY_uring) + KEY_udoubleacute = uint(C.GDK_KEY_udoubleacute) + KEY_tcedilla = uint(C.GDK_KEY_tcedilla) + KEY_abovedot = uint(C.GDK_KEY_abovedot) + KEY_Hstroke = uint(C.GDK_KEY_Hstroke) + KEY_Hcircumflex = uint(C.GDK_KEY_Hcircumflex) + KEY_Iabovedot = uint(C.GDK_KEY_Iabovedot) + KEY_Gbreve = uint(C.GDK_KEY_Gbreve) + KEY_Jcircumflex = uint(C.GDK_KEY_Jcircumflex) + KEY_hstroke = uint(C.GDK_KEY_hstroke) + KEY_hcircumflex = uint(C.GDK_KEY_hcircumflex) + KEY_idotless = uint(C.GDK_KEY_idotless) + KEY_gbreve = uint(C.GDK_KEY_gbreve) + KEY_jcircumflex = uint(C.GDK_KEY_jcircumflex) + KEY_Cabovedot = uint(C.GDK_KEY_Cabovedot) + KEY_Ccircumflex = uint(C.GDK_KEY_Ccircumflex) + KEY_Gabovedot = uint(C.GDK_KEY_Gabovedot) + KEY_Gcircumflex = uint(C.GDK_KEY_Gcircumflex) + KEY_Ubreve = uint(C.GDK_KEY_Ubreve) + KEY_Scircumflex = uint(C.GDK_KEY_Scircumflex) + KEY_cabovedot = uint(C.GDK_KEY_cabovedot) + KEY_ccircumflex = uint(C.GDK_KEY_ccircumflex) + KEY_gabovedot = uint(C.GDK_KEY_gabovedot) + KEY_gcircumflex = uint(C.GDK_KEY_gcircumflex) + KEY_ubreve = uint(C.GDK_KEY_ubreve) + KEY_scircumflex = uint(C.GDK_KEY_scircumflex) + KEY_kra = uint(C.GDK_KEY_kra) + KEY_kappa = uint(C.GDK_KEY_kappa) + KEY_Rcedilla = uint(C.GDK_KEY_Rcedilla) + KEY_Itilde = uint(C.GDK_KEY_Itilde) + KEY_Lcedilla = uint(C.GDK_KEY_Lcedilla) + KEY_Emacron = uint(C.GDK_KEY_Emacron) + KEY_Gcedilla = uint(C.GDK_KEY_Gcedilla) + KEY_Tslash = uint(C.GDK_KEY_Tslash) + KEY_rcedilla = uint(C.GDK_KEY_rcedilla) + KEY_itilde = uint(C.GDK_KEY_itilde) + KEY_lcedilla = uint(C.GDK_KEY_lcedilla) + KEY_emacron = uint(C.GDK_KEY_emacron) + KEY_gcedilla = uint(C.GDK_KEY_gcedilla) + KEY_tslash = uint(C.GDK_KEY_tslash) + KEY_ENG = uint(C.GDK_KEY_ENG) + KEY_eng = uint(C.GDK_KEY_eng) + KEY_Amacron = uint(C.GDK_KEY_Amacron) + KEY_Iogonek = uint(C.GDK_KEY_Iogonek) + KEY_Eabovedot = uint(C.GDK_KEY_Eabovedot) + KEY_Imacron = uint(C.GDK_KEY_Imacron) + KEY_Ncedilla = uint(C.GDK_KEY_Ncedilla) + KEY_Omacron = uint(C.GDK_KEY_Omacron) + KEY_Kcedilla = uint(C.GDK_KEY_Kcedilla) + KEY_Uogonek = uint(C.GDK_KEY_Uogonek) + KEY_Utilde = uint(C.GDK_KEY_Utilde) + KEY_Umacron = uint(C.GDK_KEY_Umacron) + KEY_amacron = uint(C.GDK_KEY_amacron) + KEY_iogonek = uint(C.GDK_KEY_iogonek) + KEY_eabovedot = uint(C.GDK_KEY_eabovedot) + KEY_imacron = uint(C.GDK_KEY_imacron) + KEY_ncedilla = uint(C.GDK_KEY_ncedilla) + KEY_omacron = uint(C.GDK_KEY_omacron) + KEY_kcedilla = uint(C.GDK_KEY_kcedilla) + KEY_uogonek = uint(C.GDK_KEY_uogonek) + KEY_utilde = uint(C.GDK_KEY_utilde) + KEY_umacron = uint(C.GDK_KEY_umacron) + KEY_Wcircumflex = uint(C.GDK_KEY_Wcircumflex) + KEY_wcircumflex = uint(C.GDK_KEY_wcircumflex) + KEY_Ycircumflex = uint(C.GDK_KEY_Ycircumflex) + KEY_ycircumflex = uint(C.GDK_KEY_ycircumflex) + KEY_Babovedot = uint(C.GDK_KEY_Babovedot) + KEY_babovedot = uint(C.GDK_KEY_babovedot) + KEY_Dabovedot = uint(C.GDK_KEY_Dabovedot) + KEY_dabovedot = uint(C.GDK_KEY_dabovedot) + KEY_Fabovedot = uint(C.GDK_KEY_Fabovedot) + KEY_fabovedot = uint(C.GDK_KEY_fabovedot) + KEY_Mabovedot = uint(C.GDK_KEY_Mabovedot) + KEY_mabovedot = uint(C.GDK_KEY_mabovedot) + KEY_Pabovedot = uint(C.GDK_KEY_Pabovedot) + KEY_pabovedot = uint(C.GDK_KEY_pabovedot) + KEY_Sabovedot = uint(C.GDK_KEY_Sabovedot) + KEY_sabovedot = uint(C.GDK_KEY_sabovedot) + KEY_Tabovedot = uint(C.GDK_KEY_Tabovedot) + KEY_tabovedot = uint(C.GDK_KEY_tabovedot) + KEY_Wgrave = uint(C.GDK_KEY_Wgrave) + KEY_wgrave = uint(C.GDK_KEY_wgrave) + KEY_Wacute = uint(C.GDK_KEY_Wacute) + KEY_wacute = uint(C.GDK_KEY_wacute) + KEY_Wdiaeresis = uint(C.GDK_KEY_Wdiaeresis) + KEY_wdiaeresis = uint(C.GDK_KEY_wdiaeresis) + KEY_Ygrave = uint(C.GDK_KEY_Ygrave) + KEY_ygrave = uint(C.GDK_KEY_ygrave) + KEY_OE = uint(C.GDK_KEY_OE) + KEY_oe = uint(C.GDK_KEY_oe) + KEY_Ydiaeresis = uint(C.GDK_KEY_Ydiaeresis) + KEY_overline = uint(C.GDK_KEY_overline) + KEY_kana_fullstop = uint(C.GDK_KEY_kana_fullstop) + KEY_kana_openingbracket = uint(C.GDK_KEY_kana_openingbracket) + KEY_kana_closingbracket = uint(C.GDK_KEY_kana_closingbracket) + KEY_kana_comma = uint(C.GDK_KEY_kana_comma) + KEY_kana_conjunctive = uint(C.GDK_KEY_kana_conjunctive) + KEY_kana_middledot = uint(C.GDK_KEY_kana_middledot) + KEY_kana_WO = uint(C.GDK_KEY_kana_WO) + KEY_kana_a = uint(C.GDK_KEY_kana_a) + KEY_kana_i = uint(C.GDK_KEY_kana_i) + KEY_kana_u = uint(C.GDK_KEY_kana_u) + KEY_kana_e = uint(C.GDK_KEY_kana_e) + KEY_kana_o = uint(C.GDK_KEY_kana_o) + KEY_kana_ya = uint(C.GDK_KEY_kana_ya) + KEY_kana_yu = uint(C.GDK_KEY_kana_yu) + KEY_kana_yo = uint(C.GDK_KEY_kana_yo) + KEY_kana_tsu = uint(C.GDK_KEY_kana_tsu) + KEY_kana_tu = uint(C.GDK_KEY_kana_tu) + KEY_prolongedsound = uint(C.GDK_KEY_prolongedsound) + KEY_kana_A = uint(C.GDK_KEY_kana_A) + KEY_kana_I = uint(C.GDK_KEY_kana_I) + KEY_kana_U = uint(C.GDK_KEY_kana_U) + KEY_kana_E = uint(C.GDK_KEY_kana_E) + KEY_kana_O = uint(C.GDK_KEY_kana_O) + KEY_kana_KA = uint(C.GDK_KEY_kana_KA) + KEY_kana_KI = uint(C.GDK_KEY_kana_KI) + KEY_kana_KU = uint(C.GDK_KEY_kana_KU) + KEY_kana_KE = uint(C.GDK_KEY_kana_KE) + KEY_kana_KO = uint(C.GDK_KEY_kana_KO) + KEY_kana_SA = uint(C.GDK_KEY_kana_SA) + KEY_kana_SHI = uint(C.GDK_KEY_kana_SHI) + KEY_kana_SU = uint(C.GDK_KEY_kana_SU) + KEY_kana_SE = uint(C.GDK_KEY_kana_SE) + KEY_kana_SO = uint(C.GDK_KEY_kana_SO) + KEY_kana_TA = uint(C.GDK_KEY_kana_TA) + KEY_kana_CHI = uint(C.GDK_KEY_kana_CHI) + KEY_kana_TI = uint(C.GDK_KEY_kana_TI) + KEY_kana_TSU = uint(C.GDK_KEY_kana_TSU) + KEY_kana_TU = uint(C.GDK_KEY_kana_TU) + KEY_kana_TE = uint(C.GDK_KEY_kana_TE) + KEY_kana_TO = uint(C.GDK_KEY_kana_TO) + KEY_kana_NA = uint(C.GDK_KEY_kana_NA) + KEY_kana_NI = uint(C.GDK_KEY_kana_NI) + KEY_kana_NU = uint(C.GDK_KEY_kana_NU) + KEY_kana_NE = uint(C.GDK_KEY_kana_NE) + KEY_kana_NO = uint(C.GDK_KEY_kana_NO) + KEY_kana_HA = uint(C.GDK_KEY_kana_HA) + KEY_kana_HI = uint(C.GDK_KEY_kana_HI) + KEY_kana_FU = uint(C.GDK_KEY_kana_FU) + KEY_kana_HU = uint(C.GDK_KEY_kana_HU) + KEY_kana_HE = uint(C.GDK_KEY_kana_HE) + KEY_kana_HO = uint(C.GDK_KEY_kana_HO) + KEY_kana_MA = uint(C.GDK_KEY_kana_MA) + KEY_kana_MI = uint(C.GDK_KEY_kana_MI) + KEY_kana_MU = uint(C.GDK_KEY_kana_MU) + KEY_kana_ME = uint(C.GDK_KEY_kana_ME) + KEY_kana_MO = uint(C.GDK_KEY_kana_MO) + KEY_kana_YA = uint(C.GDK_KEY_kana_YA) + KEY_kana_YU = uint(C.GDK_KEY_kana_YU) + KEY_kana_YO = uint(C.GDK_KEY_kana_YO) + KEY_kana_RA = uint(C.GDK_KEY_kana_RA) + KEY_kana_RI = uint(C.GDK_KEY_kana_RI) + KEY_kana_RU = uint(C.GDK_KEY_kana_RU) + KEY_kana_RE = uint(C.GDK_KEY_kana_RE) + KEY_kana_RO = uint(C.GDK_KEY_kana_RO) + KEY_kana_WA = uint(C.GDK_KEY_kana_WA) + KEY_kana_N = uint(C.GDK_KEY_kana_N) + KEY_voicedsound = uint(C.GDK_KEY_voicedsound) + KEY_semivoicedsound = uint(C.GDK_KEY_semivoicedsound) + KEY_kana_switch = uint(C.GDK_KEY_kana_switch) + KEY_Farsi_0 = uint(C.GDK_KEY_Farsi_0) + KEY_Farsi_1 = uint(C.GDK_KEY_Farsi_1) + KEY_Farsi_2 = uint(C.GDK_KEY_Farsi_2) + KEY_Farsi_3 = uint(C.GDK_KEY_Farsi_3) + KEY_Farsi_4 = uint(C.GDK_KEY_Farsi_4) + KEY_Farsi_5 = uint(C.GDK_KEY_Farsi_5) + KEY_Farsi_6 = uint(C.GDK_KEY_Farsi_6) + KEY_Farsi_7 = uint(C.GDK_KEY_Farsi_7) + KEY_Farsi_8 = uint(C.GDK_KEY_Farsi_8) + KEY_Farsi_9 = uint(C.GDK_KEY_Farsi_9) + KEY_Arabic_percent = uint(C.GDK_KEY_Arabic_percent) + KEY_Arabic_superscript_alef = uint(C.GDK_KEY_Arabic_superscript_alef) + KEY_Arabic_tteh = uint(C.GDK_KEY_Arabic_tteh) + KEY_Arabic_peh = uint(C.GDK_KEY_Arabic_peh) + KEY_Arabic_tcheh = uint(C.GDK_KEY_Arabic_tcheh) + KEY_Arabic_ddal = uint(C.GDK_KEY_Arabic_ddal) + KEY_Arabic_rreh = uint(C.GDK_KEY_Arabic_rreh) + KEY_Arabic_comma = uint(C.GDK_KEY_Arabic_comma) + KEY_Arabic_fullstop = uint(C.GDK_KEY_Arabic_fullstop) + KEY_Arabic_0 = uint(C.GDK_KEY_Arabic_0) + KEY_Arabic_1 = uint(C.GDK_KEY_Arabic_1) + KEY_Arabic_2 = uint(C.GDK_KEY_Arabic_2) + KEY_Arabic_3 = uint(C.GDK_KEY_Arabic_3) + KEY_Arabic_4 = uint(C.GDK_KEY_Arabic_4) + KEY_Arabic_5 = uint(C.GDK_KEY_Arabic_5) + KEY_Arabic_6 = uint(C.GDK_KEY_Arabic_6) + KEY_Arabic_7 = uint(C.GDK_KEY_Arabic_7) + KEY_Arabic_8 = uint(C.GDK_KEY_Arabic_8) + KEY_Arabic_9 = uint(C.GDK_KEY_Arabic_9) + KEY_Arabic_semicolon = uint(C.GDK_KEY_Arabic_semicolon) + KEY_Arabic_question_mark = uint(C.GDK_KEY_Arabic_question_mark) + KEY_Arabic_hamza = uint(C.GDK_KEY_Arabic_hamza) + KEY_Arabic_maddaonalef = uint(C.GDK_KEY_Arabic_maddaonalef) + KEY_Arabic_hamzaonalef = uint(C.GDK_KEY_Arabic_hamzaonalef) + KEY_Arabic_hamzaonwaw = uint(C.GDK_KEY_Arabic_hamzaonwaw) + KEY_Arabic_hamzaunderalef = uint(C.GDK_KEY_Arabic_hamzaunderalef) + KEY_Arabic_hamzaonyeh = uint(C.GDK_KEY_Arabic_hamzaonyeh) + KEY_Arabic_alef = uint(C.GDK_KEY_Arabic_alef) + KEY_Arabic_beh = uint(C.GDK_KEY_Arabic_beh) + KEY_Arabic_tehmarbuta = uint(C.GDK_KEY_Arabic_tehmarbuta) + KEY_Arabic_teh = uint(C.GDK_KEY_Arabic_teh) + KEY_Arabic_theh = uint(C.GDK_KEY_Arabic_theh) + KEY_Arabic_jeem = uint(C.GDK_KEY_Arabic_jeem) + KEY_Arabic_hah = uint(C.GDK_KEY_Arabic_hah) + KEY_Arabic_khah = uint(C.GDK_KEY_Arabic_khah) + KEY_Arabic_dal = uint(C.GDK_KEY_Arabic_dal) + KEY_Arabic_thal = uint(C.GDK_KEY_Arabic_thal) + KEY_Arabic_ra = uint(C.GDK_KEY_Arabic_ra) + KEY_Arabic_zain = uint(C.GDK_KEY_Arabic_zain) + KEY_Arabic_seen = uint(C.GDK_KEY_Arabic_seen) + KEY_Arabic_sheen = uint(C.GDK_KEY_Arabic_sheen) + KEY_Arabic_sad = uint(C.GDK_KEY_Arabic_sad) + KEY_Arabic_dad = uint(C.GDK_KEY_Arabic_dad) + KEY_Arabic_tah = uint(C.GDK_KEY_Arabic_tah) + KEY_Arabic_zah = uint(C.GDK_KEY_Arabic_zah) + KEY_Arabic_ain = uint(C.GDK_KEY_Arabic_ain) + KEY_Arabic_ghain = uint(C.GDK_KEY_Arabic_ghain) + KEY_Arabic_tatweel = uint(C.GDK_KEY_Arabic_tatweel) + KEY_Arabic_feh = uint(C.GDK_KEY_Arabic_feh) + KEY_Arabic_qaf = uint(C.GDK_KEY_Arabic_qaf) + KEY_Arabic_kaf = uint(C.GDK_KEY_Arabic_kaf) + KEY_Arabic_lam = uint(C.GDK_KEY_Arabic_lam) + KEY_Arabic_meem = uint(C.GDK_KEY_Arabic_meem) + KEY_Arabic_noon = uint(C.GDK_KEY_Arabic_noon) + KEY_Arabic_ha = uint(C.GDK_KEY_Arabic_ha) + KEY_Arabic_heh = uint(C.GDK_KEY_Arabic_heh) + KEY_Arabic_waw = uint(C.GDK_KEY_Arabic_waw) + KEY_Arabic_alefmaksura = uint(C.GDK_KEY_Arabic_alefmaksura) + KEY_Arabic_yeh = uint(C.GDK_KEY_Arabic_yeh) + KEY_Arabic_fathatan = uint(C.GDK_KEY_Arabic_fathatan) + KEY_Arabic_dammatan = uint(C.GDK_KEY_Arabic_dammatan) + KEY_Arabic_kasratan = uint(C.GDK_KEY_Arabic_kasratan) + KEY_Arabic_fatha = uint(C.GDK_KEY_Arabic_fatha) + KEY_Arabic_damma = uint(C.GDK_KEY_Arabic_damma) + KEY_Arabic_kasra = uint(C.GDK_KEY_Arabic_kasra) + KEY_Arabic_shadda = uint(C.GDK_KEY_Arabic_shadda) + KEY_Arabic_sukun = uint(C.GDK_KEY_Arabic_sukun) + KEY_Arabic_madda_above = uint(C.GDK_KEY_Arabic_madda_above) + KEY_Arabic_hamza_above = uint(C.GDK_KEY_Arabic_hamza_above) + KEY_Arabic_hamza_below = uint(C.GDK_KEY_Arabic_hamza_below) + KEY_Arabic_jeh = uint(C.GDK_KEY_Arabic_jeh) + KEY_Arabic_veh = uint(C.GDK_KEY_Arabic_veh) + KEY_Arabic_keheh = uint(C.GDK_KEY_Arabic_keheh) + KEY_Arabic_gaf = uint(C.GDK_KEY_Arabic_gaf) + KEY_Arabic_noon_ghunna = uint(C.GDK_KEY_Arabic_noon_ghunna) + KEY_Arabic_heh_doachashmee = uint(C.GDK_KEY_Arabic_heh_doachashmee) + KEY_Farsi_yeh = uint(C.GDK_KEY_Farsi_yeh) + KEY_Arabic_farsi_yeh = uint(C.GDK_KEY_Arabic_farsi_yeh) + KEY_Arabic_yeh_baree = uint(C.GDK_KEY_Arabic_yeh_baree) + KEY_Arabic_heh_goal = uint(C.GDK_KEY_Arabic_heh_goal) + KEY_Arabic_switch = uint(C.GDK_KEY_Arabic_switch) + KEY_Cyrillic_GHE_bar = uint(C.GDK_KEY_Cyrillic_GHE_bar) + KEY_Cyrillic_ghe_bar = uint(C.GDK_KEY_Cyrillic_ghe_bar) + KEY_Cyrillic_ZHE_descender = uint(C.GDK_KEY_Cyrillic_ZHE_descender) + KEY_Cyrillic_zhe_descender = uint(C.GDK_KEY_Cyrillic_zhe_descender) + KEY_Cyrillic_KA_descender = uint(C.GDK_KEY_Cyrillic_KA_descender) + KEY_Cyrillic_ka_descender = uint(C.GDK_KEY_Cyrillic_ka_descender) + KEY_Cyrillic_KA_vertstroke = uint(C.GDK_KEY_Cyrillic_KA_vertstroke) + KEY_Cyrillic_ka_vertstroke = uint(C.GDK_KEY_Cyrillic_ka_vertstroke) + KEY_Cyrillic_EN_descender = uint(C.GDK_KEY_Cyrillic_EN_descender) + KEY_Cyrillic_en_descender = uint(C.GDK_KEY_Cyrillic_en_descender) + KEY_Cyrillic_U_straight = uint(C.GDK_KEY_Cyrillic_U_straight) + KEY_Cyrillic_u_straight = uint(C.GDK_KEY_Cyrillic_u_straight) + KEY_Cyrillic_U_straight_bar = uint(C.GDK_KEY_Cyrillic_U_straight_bar) + KEY_Cyrillic_u_straight_bar = uint(C.GDK_KEY_Cyrillic_u_straight_bar) + KEY_Cyrillic_HA_descender = uint(C.GDK_KEY_Cyrillic_HA_descender) + KEY_Cyrillic_ha_descender = uint(C.GDK_KEY_Cyrillic_ha_descender) + KEY_Cyrillic_CHE_descender = uint(C.GDK_KEY_Cyrillic_CHE_descender) + KEY_Cyrillic_che_descender = uint(C.GDK_KEY_Cyrillic_che_descender) + KEY_Cyrillic_CHE_vertstroke = uint(C.GDK_KEY_Cyrillic_CHE_vertstroke) + KEY_Cyrillic_che_vertstroke = uint(C.GDK_KEY_Cyrillic_che_vertstroke) + KEY_Cyrillic_SHHA = uint(C.GDK_KEY_Cyrillic_SHHA) + KEY_Cyrillic_shha = uint(C.GDK_KEY_Cyrillic_shha) + KEY_Cyrillic_SCHWA = uint(C.GDK_KEY_Cyrillic_SCHWA) + KEY_Cyrillic_schwa = uint(C.GDK_KEY_Cyrillic_schwa) + KEY_Cyrillic_I_macron = uint(C.GDK_KEY_Cyrillic_I_macron) + KEY_Cyrillic_i_macron = uint(C.GDK_KEY_Cyrillic_i_macron) + KEY_Cyrillic_O_bar = uint(C.GDK_KEY_Cyrillic_O_bar) + KEY_Cyrillic_o_bar = uint(C.GDK_KEY_Cyrillic_o_bar) + KEY_Cyrillic_U_macron = uint(C.GDK_KEY_Cyrillic_U_macron) + KEY_Cyrillic_u_macron = uint(C.GDK_KEY_Cyrillic_u_macron) + KEY_Serbian_dje = uint(C.GDK_KEY_Serbian_dje) + KEY_Macedonia_gje = uint(C.GDK_KEY_Macedonia_gje) + KEY_Cyrillic_io = uint(C.GDK_KEY_Cyrillic_io) + KEY_Ukrainian_ie = uint(C.GDK_KEY_Ukrainian_ie) + KEY_Ukranian_je = uint(C.GDK_KEY_Ukranian_je) + KEY_Macedonia_dse = uint(C.GDK_KEY_Macedonia_dse) + KEY_Ukrainian_i = uint(C.GDK_KEY_Ukrainian_i) + KEY_Ukranian_i = uint(C.GDK_KEY_Ukranian_i) + KEY_Ukrainian_yi = uint(C.GDK_KEY_Ukrainian_yi) + KEY_Ukranian_yi = uint(C.GDK_KEY_Ukranian_yi) + KEY_Cyrillic_je = uint(C.GDK_KEY_Cyrillic_je) + KEY_Serbian_je = uint(C.GDK_KEY_Serbian_je) + KEY_Cyrillic_lje = uint(C.GDK_KEY_Cyrillic_lje) + KEY_Serbian_lje = uint(C.GDK_KEY_Serbian_lje) + KEY_Cyrillic_nje = uint(C.GDK_KEY_Cyrillic_nje) + KEY_Serbian_nje = uint(C.GDK_KEY_Serbian_nje) + KEY_Serbian_tshe = uint(C.GDK_KEY_Serbian_tshe) + KEY_Macedonia_kje = uint(C.GDK_KEY_Macedonia_kje) + KEY_Ukrainian_ghe_with_upturn = uint(C.GDK_KEY_Ukrainian_ghe_with_upturn) + KEY_Byelorussian_shortu = uint(C.GDK_KEY_Byelorussian_shortu) + KEY_Cyrillic_dzhe = uint(C.GDK_KEY_Cyrillic_dzhe) + KEY_Serbian_dze = uint(C.GDK_KEY_Serbian_dze) + KEY_numerosign = uint(C.GDK_KEY_numerosign) + KEY_Serbian_DJE = uint(C.GDK_KEY_Serbian_DJE) + KEY_Macedonia_GJE = uint(C.GDK_KEY_Macedonia_GJE) + KEY_Cyrillic_IO = uint(C.GDK_KEY_Cyrillic_IO) + KEY_Ukrainian_IE = uint(C.GDK_KEY_Ukrainian_IE) + KEY_Ukranian_JE = uint(C.GDK_KEY_Ukranian_JE) + KEY_Macedonia_DSE = uint(C.GDK_KEY_Macedonia_DSE) + KEY_Ukrainian_I = uint(C.GDK_KEY_Ukrainian_I) + KEY_Ukranian_I = uint(C.GDK_KEY_Ukranian_I) + KEY_Ukrainian_YI = uint(C.GDK_KEY_Ukrainian_YI) + KEY_Ukranian_YI = uint(C.GDK_KEY_Ukranian_YI) + KEY_Cyrillic_JE = uint(C.GDK_KEY_Cyrillic_JE) + KEY_Serbian_JE = uint(C.GDK_KEY_Serbian_JE) + KEY_Cyrillic_LJE = uint(C.GDK_KEY_Cyrillic_LJE) + KEY_Serbian_LJE = uint(C.GDK_KEY_Serbian_LJE) + KEY_Cyrillic_NJE = uint(C.GDK_KEY_Cyrillic_NJE) + KEY_Serbian_NJE = uint(C.GDK_KEY_Serbian_NJE) + KEY_Serbian_TSHE = uint(C.GDK_KEY_Serbian_TSHE) + KEY_Macedonia_KJE = uint(C.GDK_KEY_Macedonia_KJE) + KEY_Ukrainian_GHE_WITH_UPTURN = uint(C.GDK_KEY_Ukrainian_GHE_WITH_UPTURN) + KEY_Byelorussian_SHORTU = uint(C.GDK_KEY_Byelorussian_SHORTU) + KEY_Cyrillic_DZHE = uint(C.GDK_KEY_Cyrillic_DZHE) + KEY_Serbian_DZE = uint(C.GDK_KEY_Serbian_DZE) + KEY_Cyrillic_yu = uint(C.GDK_KEY_Cyrillic_yu) + KEY_Cyrillic_a = uint(C.GDK_KEY_Cyrillic_a) + KEY_Cyrillic_be = uint(C.GDK_KEY_Cyrillic_be) + KEY_Cyrillic_tse = uint(C.GDK_KEY_Cyrillic_tse) + KEY_Cyrillic_de = uint(C.GDK_KEY_Cyrillic_de) + KEY_Cyrillic_ie = uint(C.GDK_KEY_Cyrillic_ie) + KEY_Cyrillic_ef = uint(C.GDK_KEY_Cyrillic_ef) + KEY_Cyrillic_ghe = uint(C.GDK_KEY_Cyrillic_ghe) + KEY_Cyrillic_ha = uint(C.GDK_KEY_Cyrillic_ha) + KEY_Cyrillic_i = uint(C.GDK_KEY_Cyrillic_i) + KEY_Cyrillic_shorti = uint(C.GDK_KEY_Cyrillic_shorti) + KEY_Cyrillic_ka = uint(C.GDK_KEY_Cyrillic_ka) + KEY_Cyrillic_el = uint(C.GDK_KEY_Cyrillic_el) + KEY_Cyrillic_em = uint(C.GDK_KEY_Cyrillic_em) + KEY_Cyrillic_en = uint(C.GDK_KEY_Cyrillic_en) + KEY_Cyrillic_o = uint(C.GDK_KEY_Cyrillic_o) + KEY_Cyrillic_pe = uint(C.GDK_KEY_Cyrillic_pe) + KEY_Cyrillic_ya = uint(C.GDK_KEY_Cyrillic_ya) + KEY_Cyrillic_er = uint(C.GDK_KEY_Cyrillic_er) + KEY_Cyrillic_es = uint(C.GDK_KEY_Cyrillic_es) + KEY_Cyrillic_te = uint(C.GDK_KEY_Cyrillic_te) + KEY_Cyrillic_u = uint(C.GDK_KEY_Cyrillic_u) + KEY_Cyrillic_zhe = uint(C.GDK_KEY_Cyrillic_zhe) + KEY_Cyrillic_ve = uint(C.GDK_KEY_Cyrillic_ve) + KEY_Cyrillic_softsign = uint(C.GDK_KEY_Cyrillic_softsign) + KEY_Cyrillic_yeru = uint(C.GDK_KEY_Cyrillic_yeru) + KEY_Cyrillic_ze = uint(C.GDK_KEY_Cyrillic_ze) + KEY_Cyrillic_sha = uint(C.GDK_KEY_Cyrillic_sha) + KEY_Cyrillic_e = uint(C.GDK_KEY_Cyrillic_e) + KEY_Cyrillic_shcha = uint(C.GDK_KEY_Cyrillic_shcha) + KEY_Cyrillic_che = uint(C.GDK_KEY_Cyrillic_che) + KEY_Cyrillic_hardsign = uint(C.GDK_KEY_Cyrillic_hardsign) + KEY_Cyrillic_YU = uint(C.GDK_KEY_Cyrillic_YU) + KEY_Cyrillic_A = uint(C.GDK_KEY_Cyrillic_A) + KEY_Cyrillic_BE = uint(C.GDK_KEY_Cyrillic_BE) + KEY_Cyrillic_TSE = uint(C.GDK_KEY_Cyrillic_TSE) + KEY_Cyrillic_DE = uint(C.GDK_KEY_Cyrillic_DE) + KEY_Cyrillic_IE = uint(C.GDK_KEY_Cyrillic_IE) + KEY_Cyrillic_EF = uint(C.GDK_KEY_Cyrillic_EF) + KEY_Cyrillic_GHE = uint(C.GDK_KEY_Cyrillic_GHE) + KEY_Cyrillic_HA = uint(C.GDK_KEY_Cyrillic_HA) + KEY_Cyrillic_I = uint(C.GDK_KEY_Cyrillic_I) + KEY_Cyrillic_SHORTI = uint(C.GDK_KEY_Cyrillic_SHORTI) + KEY_Cyrillic_KA = uint(C.GDK_KEY_Cyrillic_KA) + KEY_Cyrillic_EL = uint(C.GDK_KEY_Cyrillic_EL) + KEY_Cyrillic_EM = uint(C.GDK_KEY_Cyrillic_EM) + KEY_Cyrillic_EN = uint(C.GDK_KEY_Cyrillic_EN) + KEY_Cyrillic_O = uint(C.GDK_KEY_Cyrillic_O) + KEY_Cyrillic_PE = uint(C.GDK_KEY_Cyrillic_PE) + KEY_Cyrillic_YA = uint(C.GDK_KEY_Cyrillic_YA) + KEY_Cyrillic_ER = uint(C.GDK_KEY_Cyrillic_ER) + KEY_Cyrillic_ES = uint(C.GDK_KEY_Cyrillic_ES) + KEY_Cyrillic_TE = uint(C.GDK_KEY_Cyrillic_TE) + KEY_Cyrillic_U = uint(C.GDK_KEY_Cyrillic_U) + KEY_Cyrillic_ZHE = uint(C.GDK_KEY_Cyrillic_ZHE) + KEY_Cyrillic_VE = uint(C.GDK_KEY_Cyrillic_VE) + KEY_Cyrillic_SOFTSIGN = uint(C.GDK_KEY_Cyrillic_SOFTSIGN) + KEY_Cyrillic_YERU = uint(C.GDK_KEY_Cyrillic_YERU) + KEY_Cyrillic_ZE = uint(C.GDK_KEY_Cyrillic_ZE) + KEY_Cyrillic_SHA = uint(C.GDK_KEY_Cyrillic_SHA) + KEY_Cyrillic_E = uint(C.GDK_KEY_Cyrillic_E) + KEY_Cyrillic_SHCHA = uint(C.GDK_KEY_Cyrillic_SHCHA) + KEY_Cyrillic_CHE = uint(C.GDK_KEY_Cyrillic_CHE) + KEY_Cyrillic_HARDSIGN = uint(C.GDK_KEY_Cyrillic_HARDSIGN) + KEY_Greek_ALPHAaccent = uint(C.GDK_KEY_Greek_ALPHAaccent) + KEY_Greek_EPSILONaccent = uint(C.GDK_KEY_Greek_EPSILONaccent) + KEY_Greek_ETAaccent = uint(C.GDK_KEY_Greek_ETAaccent) + KEY_Greek_IOTAaccent = uint(C.GDK_KEY_Greek_IOTAaccent) + KEY_Greek_IOTAdieresis = uint(C.GDK_KEY_Greek_IOTAdieresis) + KEY_Greek_IOTAdiaeresis = uint(C.GDK_KEY_Greek_IOTAdiaeresis) + KEY_Greek_OMICRONaccent = uint(C.GDK_KEY_Greek_OMICRONaccent) + KEY_Greek_UPSILONaccent = uint(C.GDK_KEY_Greek_UPSILONaccent) + KEY_Greek_UPSILONdieresis = uint(C.GDK_KEY_Greek_UPSILONdieresis) + KEY_Greek_OMEGAaccent = uint(C.GDK_KEY_Greek_OMEGAaccent) + KEY_Greek_accentdieresis = uint(C.GDK_KEY_Greek_accentdieresis) + KEY_Greek_horizbar = uint(C.GDK_KEY_Greek_horizbar) + KEY_Greek_alphaaccent = uint(C.GDK_KEY_Greek_alphaaccent) + KEY_Greek_epsilonaccent = uint(C.GDK_KEY_Greek_epsilonaccent) + KEY_Greek_etaaccent = uint(C.GDK_KEY_Greek_etaaccent) + KEY_Greek_iotaaccent = uint(C.GDK_KEY_Greek_iotaaccent) + KEY_Greek_iotadieresis = uint(C.GDK_KEY_Greek_iotadieresis) + KEY_Greek_iotaaccentdieresis = uint(C.GDK_KEY_Greek_iotaaccentdieresis) + KEY_Greek_omicronaccent = uint(C.GDK_KEY_Greek_omicronaccent) + KEY_Greek_upsilonaccent = uint(C.GDK_KEY_Greek_upsilonaccent) + KEY_Greek_upsilondieresis = uint(C.GDK_KEY_Greek_upsilondieresis) + KEY_Greek_upsilonaccentdieresis = uint(C.GDK_KEY_Greek_upsilonaccentdieresis) + KEY_Greek_omegaaccent = uint(C.GDK_KEY_Greek_omegaaccent) + KEY_Greek_ALPHA = uint(C.GDK_KEY_Greek_ALPHA) + KEY_Greek_BETA = uint(C.GDK_KEY_Greek_BETA) + KEY_Greek_GAMMA = uint(C.GDK_KEY_Greek_GAMMA) + KEY_Greek_DELTA = uint(C.GDK_KEY_Greek_DELTA) + KEY_Greek_EPSILON = uint(C.GDK_KEY_Greek_EPSILON) + KEY_Greek_ZETA = uint(C.GDK_KEY_Greek_ZETA) + KEY_Greek_ETA = uint(C.GDK_KEY_Greek_ETA) + KEY_Greek_THETA = uint(C.GDK_KEY_Greek_THETA) + KEY_Greek_IOTA = uint(C.GDK_KEY_Greek_IOTA) + KEY_Greek_KAPPA = uint(C.GDK_KEY_Greek_KAPPA) + KEY_Greek_LAMDA = uint(C.GDK_KEY_Greek_LAMDA) + KEY_Greek_LAMBDA = uint(C.GDK_KEY_Greek_LAMBDA) + KEY_Greek_MU = uint(C.GDK_KEY_Greek_MU) + KEY_Greek_NU = uint(C.GDK_KEY_Greek_NU) + KEY_Greek_XI = uint(C.GDK_KEY_Greek_XI) + KEY_Greek_OMICRON = uint(C.GDK_KEY_Greek_OMICRON) + KEY_Greek_PI = uint(C.GDK_KEY_Greek_PI) + KEY_Greek_RHO = uint(C.GDK_KEY_Greek_RHO) + KEY_Greek_SIGMA = uint(C.GDK_KEY_Greek_SIGMA) + KEY_Greek_TAU = uint(C.GDK_KEY_Greek_TAU) + KEY_Greek_UPSILON = uint(C.GDK_KEY_Greek_UPSILON) + KEY_Greek_PHI = uint(C.GDK_KEY_Greek_PHI) + KEY_Greek_CHI = uint(C.GDK_KEY_Greek_CHI) + KEY_Greek_PSI = uint(C.GDK_KEY_Greek_PSI) + KEY_Greek_OMEGA = uint(C.GDK_KEY_Greek_OMEGA) + KEY_Greek_alpha = uint(C.GDK_KEY_Greek_alpha) + KEY_Greek_beta = uint(C.GDK_KEY_Greek_beta) + KEY_Greek_gamma = uint(C.GDK_KEY_Greek_gamma) + KEY_Greek_delta = uint(C.GDK_KEY_Greek_delta) + KEY_Greek_epsilon = uint(C.GDK_KEY_Greek_epsilon) + KEY_Greek_zeta = uint(C.GDK_KEY_Greek_zeta) + KEY_Greek_eta = uint(C.GDK_KEY_Greek_eta) + KEY_Greek_theta = uint(C.GDK_KEY_Greek_theta) + KEY_Greek_iota = uint(C.GDK_KEY_Greek_iota) + KEY_Greek_kappa = uint(C.GDK_KEY_Greek_kappa) + KEY_Greek_lamda = uint(C.GDK_KEY_Greek_lamda) + KEY_Greek_lambda = uint(C.GDK_KEY_Greek_lambda) + KEY_Greek_mu = uint(C.GDK_KEY_Greek_mu) + KEY_Greek_nu = uint(C.GDK_KEY_Greek_nu) + KEY_Greek_xi = uint(C.GDK_KEY_Greek_xi) + KEY_Greek_omicron = uint(C.GDK_KEY_Greek_omicron) + KEY_Greek_pi = uint(C.GDK_KEY_Greek_pi) + KEY_Greek_rho = uint(C.GDK_KEY_Greek_rho) + KEY_Greek_sigma = uint(C.GDK_KEY_Greek_sigma) + KEY_Greek_finalsmallsigma = uint(C.GDK_KEY_Greek_finalsmallsigma) + KEY_Greek_tau = uint(C.GDK_KEY_Greek_tau) + KEY_Greek_upsilon = uint(C.GDK_KEY_Greek_upsilon) + KEY_Greek_phi = uint(C.GDK_KEY_Greek_phi) + KEY_Greek_chi = uint(C.GDK_KEY_Greek_chi) + KEY_Greek_psi = uint(C.GDK_KEY_Greek_psi) + KEY_Greek_omega = uint(C.GDK_KEY_Greek_omega) + KEY_Greek_switch = uint(C.GDK_KEY_Greek_switch) + KEY_leftradical = uint(C.GDK_KEY_leftradical) + KEY_topleftradical = uint(C.GDK_KEY_topleftradical) + KEY_horizconnector = uint(C.GDK_KEY_horizconnector) + KEY_topintegral = uint(C.GDK_KEY_topintegral) + KEY_botintegral = uint(C.GDK_KEY_botintegral) + KEY_vertconnector = uint(C.GDK_KEY_vertconnector) + KEY_topleftsqbracket = uint(C.GDK_KEY_topleftsqbracket) + KEY_botleftsqbracket = uint(C.GDK_KEY_botleftsqbracket) + KEY_toprightsqbracket = uint(C.GDK_KEY_toprightsqbracket) + KEY_botrightsqbracket = uint(C.GDK_KEY_botrightsqbracket) + KEY_topleftparens = uint(C.GDK_KEY_topleftparens) + KEY_botleftparens = uint(C.GDK_KEY_botleftparens) + KEY_toprightparens = uint(C.GDK_KEY_toprightparens) + KEY_botrightparens = uint(C.GDK_KEY_botrightparens) + KEY_leftmiddlecurlybrace = uint(C.GDK_KEY_leftmiddlecurlybrace) + KEY_rightmiddlecurlybrace = uint(C.GDK_KEY_rightmiddlecurlybrace) + KEY_topleftsummation = uint(C.GDK_KEY_topleftsummation) + KEY_botleftsummation = uint(C.GDK_KEY_botleftsummation) + KEY_topvertsummationconnector = uint(C.GDK_KEY_topvertsummationconnector) + KEY_botvertsummationconnector = uint(C.GDK_KEY_botvertsummationconnector) + KEY_toprightsummation = uint(C.GDK_KEY_toprightsummation) + KEY_botrightsummation = uint(C.GDK_KEY_botrightsummation) + KEY_rightmiddlesummation = uint(C.GDK_KEY_rightmiddlesummation) + KEY_lessthanequal = uint(C.GDK_KEY_lessthanequal) + KEY_notequal = uint(C.GDK_KEY_notequal) + KEY_greaterthanequal = uint(C.GDK_KEY_greaterthanequal) + KEY_integral = uint(C.GDK_KEY_integral) + KEY_therefore = uint(C.GDK_KEY_therefore) + KEY_variation = uint(C.GDK_KEY_variation) + KEY_infinity = uint(C.GDK_KEY_infinity) + KEY_nabla = uint(C.GDK_KEY_nabla) + KEY_approximate = uint(C.GDK_KEY_approximate) + KEY_similarequal = uint(C.GDK_KEY_similarequal) + KEY_ifonlyif = uint(C.GDK_KEY_ifonlyif) + KEY_implies = uint(C.GDK_KEY_implies) + KEY_identical = uint(C.GDK_KEY_identical) + KEY_radical = uint(C.GDK_KEY_radical) + KEY_includedin = uint(C.GDK_KEY_includedin) + KEY_includes = uint(C.GDK_KEY_includes) + KEY_intersection = uint(C.GDK_KEY_intersection) + KEY_union = uint(C.GDK_KEY_union) + KEY_logicaland = uint(C.GDK_KEY_logicaland) + KEY_logicalor = uint(C.GDK_KEY_logicalor) + KEY_partialderivative = uint(C.GDK_KEY_partialderivative) + KEY_function = uint(C.GDK_KEY_function) + KEY_leftarrow = uint(C.GDK_KEY_leftarrow) + KEY_uparrow = uint(C.GDK_KEY_uparrow) + KEY_rightarrow = uint(C.GDK_KEY_rightarrow) + KEY_downarrow = uint(C.GDK_KEY_downarrow) + KEY_blank = uint(C.GDK_KEY_blank) + KEY_soliddiamond = uint(C.GDK_KEY_soliddiamond) + KEY_checkerboard = uint(C.GDK_KEY_checkerboard) + KEY_ht = uint(C.GDK_KEY_ht) + KEY_ff = uint(C.GDK_KEY_ff) + KEY_cr = uint(C.GDK_KEY_cr) + KEY_lf = uint(C.GDK_KEY_lf) + KEY_nl = uint(C.GDK_KEY_nl) + KEY_vt = uint(C.GDK_KEY_vt) + KEY_lowrightcorner = uint(C.GDK_KEY_lowrightcorner) + KEY_uprightcorner = uint(C.GDK_KEY_uprightcorner) + KEY_upleftcorner = uint(C.GDK_KEY_upleftcorner) + KEY_lowleftcorner = uint(C.GDK_KEY_lowleftcorner) + KEY_crossinglines = uint(C.GDK_KEY_crossinglines) + KEY_horizlinescan1 = uint(C.GDK_KEY_horizlinescan1) + KEY_horizlinescan3 = uint(C.GDK_KEY_horizlinescan3) + KEY_horizlinescan5 = uint(C.GDK_KEY_horizlinescan5) + KEY_horizlinescan7 = uint(C.GDK_KEY_horizlinescan7) + KEY_horizlinescan9 = uint(C.GDK_KEY_horizlinescan9) + KEY_leftt = uint(C.GDK_KEY_leftt) + KEY_rightt = uint(C.GDK_KEY_rightt) + KEY_bott = uint(C.GDK_KEY_bott) + KEY_topt = uint(C.GDK_KEY_topt) + KEY_vertbar = uint(C.GDK_KEY_vertbar) + KEY_emspace = uint(C.GDK_KEY_emspace) + KEY_enspace = uint(C.GDK_KEY_enspace) + KEY_em3space = uint(C.GDK_KEY_em3space) + KEY_em4space = uint(C.GDK_KEY_em4space) + KEY_digitspace = uint(C.GDK_KEY_digitspace) + KEY_punctspace = uint(C.GDK_KEY_punctspace) + KEY_thinspace = uint(C.GDK_KEY_thinspace) + KEY_hairspace = uint(C.GDK_KEY_hairspace) + KEY_emdash = uint(C.GDK_KEY_emdash) + KEY_endash = uint(C.GDK_KEY_endash) + KEY_signifblank = uint(C.GDK_KEY_signifblank) + KEY_ellipsis = uint(C.GDK_KEY_ellipsis) + KEY_doubbaselinedot = uint(C.GDK_KEY_doubbaselinedot) + KEY_onethird = uint(C.GDK_KEY_onethird) + KEY_twothirds = uint(C.GDK_KEY_twothirds) + KEY_onefifth = uint(C.GDK_KEY_onefifth) + KEY_twofifths = uint(C.GDK_KEY_twofifths) + KEY_threefifths = uint(C.GDK_KEY_threefifths) + KEY_fourfifths = uint(C.GDK_KEY_fourfifths) + KEY_onesixth = uint(C.GDK_KEY_onesixth) + KEY_fivesixths = uint(C.GDK_KEY_fivesixths) + KEY_careof = uint(C.GDK_KEY_careof) + KEY_figdash = uint(C.GDK_KEY_figdash) + KEY_leftanglebracket = uint(C.GDK_KEY_leftanglebracket) + KEY_decimalpoint = uint(C.GDK_KEY_decimalpoint) + KEY_rightanglebracket = uint(C.GDK_KEY_rightanglebracket) + KEY_marker = uint(C.GDK_KEY_marker) + KEY_oneeighth = uint(C.GDK_KEY_oneeighth) + KEY_threeeighths = uint(C.GDK_KEY_threeeighths) + KEY_fiveeighths = uint(C.GDK_KEY_fiveeighths) + KEY_seveneighths = uint(C.GDK_KEY_seveneighths) + KEY_trademark = uint(C.GDK_KEY_trademark) + KEY_signaturemark = uint(C.GDK_KEY_signaturemark) + KEY_trademarkincircle = uint(C.GDK_KEY_trademarkincircle) + KEY_leftopentriangle = uint(C.GDK_KEY_leftopentriangle) + KEY_rightopentriangle = uint(C.GDK_KEY_rightopentriangle) + KEY_emopencircle = uint(C.GDK_KEY_emopencircle) + KEY_emopenrectangle = uint(C.GDK_KEY_emopenrectangle) + KEY_leftsinglequotemark = uint(C.GDK_KEY_leftsinglequotemark) + KEY_rightsinglequotemark = uint(C.GDK_KEY_rightsinglequotemark) + KEY_leftdoublequotemark = uint(C.GDK_KEY_leftdoublequotemark) + KEY_rightdoublequotemark = uint(C.GDK_KEY_rightdoublequotemark) + KEY_prescription = uint(C.GDK_KEY_prescription) + KEY_permille = uint(C.GDK_KEY_permille) + KEY_minutes = uint(C.GDK_KEY_minutes) + KEY_seconds = uint(C.GDK_KEY_seconds) + KEY_latincross = uint(C.GDK_KEY_latincross) + KEY_hexagram = uint(C.GDK_KEY_hexagram) + KEY_filledrectbullet = uint(C.GDK_KEY_filledrectbullet) + KEY_filledlefttribullet = uint(C.GDK_KEY_filledlefttribullet) + KEY_filledrighttribullet = uint(C.GDK_KEY_filledrighttribullet) + KEY_emfilledcircle = uint(C.GDK_KEY_emfilledcircle) + KEY_emfilledrect = uint(C.GDK_KEY_emfilledrect) + KEY_enopencircbullet = uint(C.GDK_KEY_enopencircbullet) + KEY_enopensquarebullet = uint(C.GDK_KEY_enopensquarebullet) + KEY_openrectbullet = uint(C.GDK_KEY_openrectbullet) + KEY_opentribulletup = uint(C.GDK_KEY_opentribulletup) + KEY_opentribulletdown = uint(C.GDK_KEY_opentribulletdown) + KEY_openstar = uint(C.GDK_KEY_openstar) + KEY_enfilledcircbullet = uint(C.GDK_KEY_enfilledcircbullet) + KEY_enfilledsqbullet = uint(C.GDK_KEY_enfilledsqbullet) + KEY_filledtribulletup = uint(C.GDK_KEY_filledtribulletup) + KEY_filledtribulletdown = uint(C.GDK_KEY_filledtribulletdown) + KEY_leftpointer = uint(C.GDK_KEY_leftpointer) + KEY_rightpointer = uint(C.GDK_KEY_rightpointer) + KEY_club = uint(C.GDK_KEY_club) + KEY_diamond = uint(C.GDK_KEY_diamond) + KEY_heart = uint(C.GDK_KEY_heart) + KEY_maltesecross = uint(C.GDK_KEY_maltesecross) + KEY_dagger = uint(C.GDK_KEY_dagger) + KEY_doubledagger = uint(C.GDK_KEY_doubledagger) + KEY_checkmark = uint(C.GDK_KEY_checkmark) + KEY_ballotcross = uint(C.GDK_KEY_ballotcross) + KEY_musicalsharp = uint(C.GDK_KEY_musicalsharp) + KEY_musicalflat = uint(C.GDK_KEY_musicalflat) + KEY_malesymbol = uint(C.GDK_KEY_malesymbol) + KEY_femalesymbol = uint(C.GDK_KEY_femalesymbol) + KEY_telephone = uint(C.GDK_KEY_telephone) + KEY_telephonerecorder = uint(C.GDK_KEY_telephonerecorder) + KEY_phonographcopyright = uint(C.GDK_KEY_phonographcopyright) + KEY_caret = uint(C.GDK_KEY_caret) + KEY_singlelowquotemark = uint(C.GDK_KEY_singlelowquotemark) + KEY_doublelowquotemark = uint(C.GDK_KEY_doublelowquotemark) + KEY_cursor = uint(C.GDK_KEY_cursor) + KEY_leftcaret = uint(C.GDK_KEY_leftcaret) + KEY_rightcaret = uint(C.GDK_KEY_rightcaret) + KEY_downcaret = uint(C.GDK_KEY_downcaret) + KEY_upcaret = uint(C.GDK_KEY_upcaret) + KEY_overbar = uint(C.GDK_KEY_overbar) + KEY_downtack = uint(C.GDK_KEY_downtack) + KEY_upshoe = uint(C.GDK_KEY_upshoe) + KEY_downstile = uint(C.GDK_KEY_downstile) + KEY_underbar = uint(C.GDK_KEY_underbar) + KEY_jot = uint(C.GDK_KEY_jot) + KEY_quad = uint(C.GDK_KEY_quad) + KEY_uptack = uint(C.GDK_KEY_uptack) + KEY_circle = uint(C.GDK_KEY_circle) + KEY_upstile = uint(C.GDK_KEY_upstile) + KEY_downshoe = uint(C.GDK_KEY_downshoe) + KEY_rightshoe = uint(C.GDK_KEY_rightshoe) + KEY_leftshoe = uint(C.GDK_KEY_leftshoe) + KEY_lefttack = uint(C.GDK_KEY_lefttack) + KEY_righttack = uint(C.GDK_KEY_righttack) + KEY_hebrew_doublelowline = uint(C.GDK_KEY_hebrew_doublelowline) + KEY_hebrew_aleph = uint(C.GDK_KEY_hebrew_aleph) + KEY_hebrew_bet = uint(C.GDK_KEY_hebrew_bet) + KEY_hebrew_beth = uint(C.GDK_KEY_hebrew_beth) + KEY_hebrew_gimel = uint(C.GDK_KEY_hebrew_gimel) + KEY_hebrew_gimmel = uint(C.GDK_KEY_hebrew_gimmel) + KEY_hebrew_dalet = uint(C.GDK_KEY_hebrew_dalet) + KEY_hebrew_daleth = uint(C.GDK_KEY_hebrew_daleth) + KEY_hebrew_he = uint(C.GDK_KEY_hebrew_he) + KEY_hebrew_waw = uint(C.GDK_KEY_hebrew_waw) + KEY_hebrew_zain = uint(C.GDK_KEY_hebrew_zain) + KEY_hebrew_zayin = uint(C.GDK_KEY_hebrew_zayin) + KEY_hebrew_chet = uint(C.GDK_KEY_hebrew_chet) + KEY_hebrew_het = uint(C.GDK_KEY_hebrew_het) + KEY_hebrew_tet = uint(C.GDK_KEY_hebrew_tet) + KEY_hebrew_teth = uint(C.GDK_KEY_hebrew_teth) + KEY_hebrew_yod = uint(C.GDK_KEY_hebrew_yod) + KEY_hebrew_finalkaph = uint(C.GDK_KEY_hebrew_finalkaph) + KEY_hebrew_kaph = uint(C.GDK_KEY_hebrew_kaph) + KEY_hebrew_lamed = uint(C.GDK_KEY_hebrew_lamed) + KEY_hebrew_finalmem = uint(C.GDK_KEY_hebrew_finalmem) + KEY_hebrew_mem = uint(C.GDK_KEY_hebrew_mem) + KEY_hebrew_finalnun = uint(C.GDK_KEY_hebrew_finalnun) + KEY_hebrew_nun = uint(C.GDK_KEY_hebrew_nun) + KEY_hebrew_samech = uint(C.GDK_KEY_hebrew_samech) + KEY_hebrew_samekh = uint(C.GDK_KEY_hebrew_samekh) + KEY_hebrew_ayin = uint(C.GDK_KEY_hebrew_ayin) + KEY_hebrew_finalpe = uint(C.GDK_KEY_hebrew_finalpe) + KEY_hebrew_pe = uint(C.GDK_KEY_hebrew_pe) + KEY_hebrew_finalzade = uint(C.GDK_KEY_hebrew_finalzade) + KEY_hebrew_finalzadi = uint(C.GDK_KEY_hebrew_finalzadi) + KEY_hebrew_zade = uint(C.GDK_KEY_hebrew_zade) + KEY_hebrew_zadi = uint(C.GDK_KEY_hebrew_zadi) + KEY_hebrew_qoph = uint(C.GDK_KEY_hebrew_qoph) + KEY_hebrew_kuf = uint(C.GDK_KEY_hebrew_kuf) + KEY_hebrew_resh = uint(C.GDK_KEY_hebrew_resh) + KEY_hebrew_shin = uint(C.GDK_KEY_hebrew_shin) + KEY_hebrew_taw = uint(C.GDK_KEY_hebrew_taw) + KEY_hebrew_taf = uint(C.GDK_KEY_hebrew_taf) + KEY_Hebrew_switch = uint(C.GDK_KEY_Hebrew_switch) + KEY_Thai_kokai = uint(C.GDK_KEY_Thai_kokai) + KEY_Thai_khokhai = uint(C.GDK_KEY_Thai_khokhai) + KEY_Thai_khokhuat = uint(C.GDK_KEY_Thai_khokhuat) + KEY_Thai_khokhwai = uint(C.GDK_KEY_Thai_khokhwai) + KEY_Thai_khokhon = uint(C.GDK_KEY_Thai_khokhon) + KEY_Thai_khorakhang = uint(C.GDK_KEY_Thai_khorakhang) + KEY_Thai_ngongu = uint(C.GDK_KEY_Thai_ngongu) + KEY_Thai_chochan = uint(C.GDK_KEY_Thai_chochan) + KEY_Thai_choching = uint(C.GDK_KEY_Thai_choching) + KEY_Thai_chochang = uint(C.GDK_KEY_Thai_chochang) + KEY_Thai_soso = uint(C.GDK_KEY_Thai_soso) + KEY_Thai_chochoe = uint(C.GDK_KEY_Thai_chochoe) + KEY_Thai_yoying = uint(C.GDK_KEY_Thai_yoying) + KEY_Thai_dochada = uint(C.GDK_KEY_Thai_dochada) + KEY_Thai_topatak = uint(C.GDK_KEY_Thai_topatak) + KEY_Thai_thothan = uint(C.GDK_KEY_Thai_thothan) + KEY_Thai_thonangmontho = uint(C.GDK_KEY_Thai_thonangmontho) + KEY_Thai_thophuthao = uint(C.GDK_KEY_Thai_thophuthao) + KEY_Thai_nonen = uint(C.GDK_KEY_Thai_nonen) + KEY_Thai_dodek = uint(C.GDK_KEY_Thai_dodek) + KEY_Thai_totao = uint(C.GDK_KEY_Thai_totao) + KEY_Thai_thothung = uint(C.GDK_KEY_Thai_thothung) + KEY_Thai_thothahan = uint(C.GDK_KEY_Thai_thothahan) + KEY_Thai_thothong = uint(C.GDK_KEY_Thai_thothong) + KEY_Thai_nonu = uint(C.GDK_KEY_Thai_nonu) + KEY_Thai_bobaimai = uint(C.GDK_KEY_Thai_bobaimai) + KEY_Thai_popla = uint(C.GDK_KEY_Thai_popla) + KEY_Thai_phophung = uint(C.GDK_KEY_Thai_phophung) + KEY_Thai_fofa = uint(C.GDK_KEY_Thai_fofa) + KEY_Thai_phophan = uint(C.GDK_KEY_Thai_phophan) + KEY_Thai_fofan = uint(C.GDK_KEY_Thai_fofan) + KEY_Thai_phosamphao = uint(C.GDK_KEY_Thai_phosamphao) + KEY_Thai_moma = uint(C.GDK_KEY_Thai_moma) + KEY_Thai_yoyak = uint(C.GDK_KEY_Thai_yoyak) + KEY_Thai_rorua = uint(C.GDK_KEY_Thai_rorua) + KEY_Thai_ru = uint(C.GDK_KEY_Thai_ru) + KEY_Thai_loling = uint(C.GDK_KEY_Thai_loling) + KEY_Thai_lu = uint(C.GDK_KEY_Thai_lu) + KEY_Thai_wowaen = uint(C.GDK_KEY_Thai_wowaen) + KEY_Thai_sosala = uint(C.GDK_KEY_Thai_sosala) + KEY_Thai_sorusi = uint(C.GDK_KEY_Thai_sorusi) + KEY_Thai_sosua = uint(C.GDK_KEY_Thai_sosua) + KEY_Thai_hohip = uint(C.GDK_KEY_Thai_hohip) + KEY_Thai_lochula = uint(C.GDK_KEY_Thai_lochula) + KEY_Thai_oang = uint(C.GDK_KEY_Thai_oang) + KEY_Thai_honokhuk = uint(C.GDK_KEY_Thai_honokhuk) + KEY_Thai_paiyannoi = uint(C.GDK_KEY_Thai_paiyannoi) + KEY_Thai_saraa = uint(C.GDK_KEY_Thai_saraa) + KEY_Thai_maihanakat = uint(C.GDK_KEY_Thai_maihanakat) + KEY_Thai_saraaa = uint(C.GDK_KEY_Thai_saraaa) + KEY_Thai_saraam = uint(C.GDK_KEY_Thai_saraam) + KEY_Thai_sarai = uint(C.GDK_KEY_Thai_sarai) + KEY_Thai_saraii = uint(C.GDK_KEY_Thai_saraii) + KEY_Thai_saraue = uint(C.GDK_KEY_Thai_saraue) + KEY_Thai_sarauee = uint(C.GDK_KEY_Thai_sarauee) + KEY_Thai_sarau = uint(C.GDK_KEY_Thai_sarau) + KEY_Thai_sarauu = uint(C.GDK_KEY_Thai_sarauu) + KEY_Thai_phinthu = uint(C.GDK_KEY_Thai_phinthu) + KEY_Thai_maihanakat_maitho = uint(C.GDK_KEY_Thai_maihanakat_maitho) + KEY_Thai_baht = uint(C.GDK_KEY_Thai_baht) + KEY_Thai_sarae = uint(C.GDK_KEY_Thai_sarae) + KEY_Thai_saraae = uint(C.GDK_KEY_Thai_saraae) + KEY_Thai_sarao = uint(C.GDK_KEY_Thai_sarao) + KEY_Thai_saraaimaimuan = uint(C.GDK_KEY_Thai_saraaimaimuan) + KEY_Thai_saraaimaimalai = uint(C.GDK_KEY_Thai_saraaimaimalai) + KEY_Thai_lakkhangyao = uint(C.GDK_KEY_Thai_lakkhangyao) + KEY_Thai_maiyamok = uint(C.GDK_KEY_Thai_maiyamok) + KEY_Thai_maitaikhu = uint(C.GDK_KEY_Thai_maitaikhu) + KEY_Thai_maiek = uint(C.GDK_KEY_Thai_maiek) + KEY_Thai_maitho = uint(C.GDK_KEY_Thai_maitho) + KEY_Thai_maitri = uint(C.GDK_KEY_Thai_maitri) + KEY_Thai_maichattawa = uint(C.GDK_KEY_Thai_maichattawa) + KEY_Thai_thanthakhat = uint(C.GDK_KEY_Thai_thanthakhat) + KEY_Thai_nikhahit = uint(C.GDK_KEY_Thai_nikhahit) + KEY_Thai_leksun = uint(C.GDK_KEY_Thai_leksun) + KEY_Thai_leknung = uint(C.GDK_KEY_Thai_leknung) + KEY_Thai_leksong = uint(C.GDK_KEY_Thai_leksong) + KEY_Thai_leksam = uint(C.GDK_KEY_Thai_leksam) + KEY_Thai_leksi = uint(C.GDK_KEY_Thai_leksi) + KEY_Thai_lekha = uint(C.GDK_KEY_Thai_lekha) + KEY_Thai_lekhok = uint(C.GDK_KEY_Thai_lekhok) + KEY_Thai_lekchet = uint(C.GDK_KEY_Thai_lekchet) + KEY_Thai_lekpaet = uint(C.GDK_KEY_Thai_lekpaet) + KEY_Thai_lekkao = uint(C.GDK_KEY_Thai_lekkao) + KEY_Hangul = uint(C.GDK_KEY_Hangul) + KEY_Hangul_Start = uint(C.GDK_KEY_Hangul_Start) + KEY_Hangul_End = uint(C.GDK_KEY_Hangul_End) + KEY_Hangul_Hanja = uint(C.GDK_KEY_Hangul_Hanja) + KEY_Hangul_Jamo = uint(C.GDK_KEY_Hangul_Jamo) + KEY_Hangul_Romaja = uint(C.GDK_KEY_Hangul_Romaja) + KEY_Hangul_Codeinput = uint(C.GDK_KEY_Hangul_Codeinput) + KEY_Hangul_Jeonja = uint(C.GDK_KEY_Hangul_Jeonja) + KEY_Hangul_Banja = uint(C.GDK_KEY_Hangul_Banja) + KEY_Hangul_PreHanja = uint(C.GDK_KEY_Hangul_PreHanja) + KEY_Hangul_PostHanja = uint(C.GDK_KEY_Hangul_PostHanja) + KEY_Hangul_SingleCandidate = uint(C.GDK_KEY_Hangul_SingleCandidate) + KEY_Hangul_MultipleCandidate = uint(C.GDK_KEY_Hangul_MultipleCandidate) + KEY_Hangul_PreviousCandidate = uint(C.GDK_KEY_Hangul_PreviousCandidate) + KEY_Hangul_Special = uint(C.GDK_KEY_Hangul_Special) + KEY_Hangul_switch = uint(C.GDK_KEY_Hangul_switch) + KEY_Hangul_Kiyeog = uint(C.GDK_KEY_Hangul_Kiyeog) + KEY_Hangul_SsangKiyeog = uint(C.GDK_KEY_Hangul_SsangKiyeog) + KEY_Hangul_KiyeogSios = uint(C.GDK_KEY_Hangul_KiyeogSios) + KEY_Hangul_Nieun = uint(C.GDK_KEY_Hangul_Nieun) + KEY_Hangul_NieunJieuj = uint(C.GDK_KEY_Hangul_NieunJieuj) + KEY_Hangul_NieunHieuh = uint(C.GDK_KEY_Hangul_NieunHieuh) + KEY_Hangul_Dikeud = uint(C.GDK_KEY_Hangul_Dikeud) + KEY_Hangul_SsangDikeud = uint(C.GDK_KEY_Hangul_SsangDikeud) + KEY_Hangul_Rieul = uint(C.GDK_KEY_Hangul_Rieul) + KEY_Hangul_RieulKiyeog = uint(C.GDK_KEY_Hangul_RieulKiyeog) + KEY_Hangul_RieulMieum = uint(C.GDK_KEY_Hangul_RieulMieum) + KEY_Hangul_RieulPieub = uint(C.GDK_KEY_Hangul_RieulPieub) + KEY_Hangul_RieulSios = uint(C.GDK_KEY_Hangul_RieulSios) + KEY_Hangul_RieulTieut = uint(C.GDK_KEY_Hangul_RieulTieut) + KEY_Hangul_RieulPhieuf = uint(C.GDK_KEY_Hangul_RieulPhieuf) + KEY_Hangul_RieulHieuh = uint(C.GDK_KEY_Hangul_RieulHieuh) + KEY_Hangul_Mieum = uint(C.GDK_KEY_Hangul_Mieum) + KEY_Hangul_Pieub = uint(C.GDK_KEY_Hangul_Pieub) + KEY_Hangul_SsangPieub = uint(C.GDK_KEY_Hangul_SsangPieub) + KEY_Hangul_PieubSios = uint(C.GDK_KEY_Hangul_PieubSios) + KEY_Hangul_Sios = uint(C.GDK_KEY_Hangul_Sios) + KEY_Hangul_SsangSios = uint(C.GDK_KEY_Hangul_SsangSios) + KEY_Hangul_Ieung = uint(C.GDK_KEY_Hangul_Ieung) + KEY_Hangul_Jieuj = uint(C.GDK_KEY_Hangul_Jieuj) + KEY_Hangul_SsangJieuj = uint(C.GDK_KEY_Hangul_SsangJieuj) + KEY_Hangul_Cieuc = uint(C.GDK_KEY_Hangul_Cieuc) + KEY_Hangul_Khieuq = uint(C.GDK_KEY_Hangul_Khieuq) + KEY_Hangul_Tieut = uint(C.GDK_KEY_Hangul_Tieut) + KEY_Hangul_Phieuf = uint(C.GDK_KEY_Hangul_Phieuf) + KEY_Hangul_Hieuh = uint(C.GDK_KEY_Hangul_Hieuh) + KEY_Hangul_A = uint(C.GDK_KEY_Hangul_A) + KEY_Hangul_AE = uint(C.GDK_KEY_Hangul_AE) + KEY_Hangul_YA = uint(C.GDK_KEY_Hangul_YA) + KEY_Hangul_YAE = uint(C.GDK_KEY_Hangul_YAE) + KEY_Hangul_EO = uint(C.GDK_KEY_Hangul_EO) + KEY_Hangul_E = uint(C.GDK_KEY_Hangul_E) + KEY_Hangul_YEO = uint(C.GDK_KEY_Hangul_YEO) + KEY_Hangul_YE = uint(C.GDK_KEY_Hangul_YE) + KEY_Hangul_O = uint(C.GDK_KEY_Hangul_O) + KEY_Hangul_WA = uint(C.GDK_KEY_Hangul_WA) + KEY_Hangul_WAE = uint(C.GDK_KEY_Hangul_WAE) + KEY_Hangul_OE = uint(C.GDK_KEY_Hangul_OE) + KEY_Hangul_YO = uint(C.GDK_KEY_Hangul_YO) + KEY_Hangul_U = uint(C.GDK_KEY_Hangul_U) + KEY_Hangul_WEO = uint(C.GDK_KEY_Hangul_WEO) + KEY_Hangul_WE = uint(C.GDK_KEY_Hangul_WE) + KEY_Hangul_WI = uint(C.GDK_KEY_Hangul_WI) + KEY_Hangul_YU = uint(C.GDK_KEY_Hangul_YU) + KEY_Hangul_EU = uint(C.GDK_KEY_Hangul_EU) + KEY_Hangul_YI = uint(C.GDK_KEY_Hangul_YI) + KEY_Hangul_I = uint(C.GDK_KEY_Hangul_I) + KEY_Hangul_J_Kiyeog = uint(C.GDK_KEY_Hangul_J_Kiyeog) + KEY_Hangul_J_SsangKiyeog = uint(C.GDK_KEY_Hangul_J_SsangKiyeog) + KEY_Hangul_J_KiyeogSios = uint(C.GDK_KEY_Hangul_J_KiyeogSios) + KEY_Hangul_J_Nieun = uint(C.GDK_KEY_Hangul_J_Nieun) + KEY_Hangul_J_NieunJieuj = uint(C.GDK_KEY_Hangul_J_NieunJieuj) + KEY_Hangul_J_NieunHieuh = uint(C.GDK_KEY_Hangul_J_NieunHieuh) + KEY_Hangul_J_Dikeud = uint(C.GDK_KEY_Hangul_J_Dikeud) + KEY_Hangul_J_Rieul = uint(C.GDK_KEY_Hangul_J_Rieul) + KEY_Hangul_J_RieulKiyeog = uint(C.GDK_KEY_Hangul_J_RieulKiyeog) + KEY_Hangul_J_RieulMieum = uint(C.GDK_KEY_Hangul_J_RieulMieum) + KEY_Hangul_J_RieulPieub = uint(C.GDK_KEY_Hangul_J_RieulPieub) + KEY_Hangul_J_RieulSios = uint(C.GDK_KEY_Hangul_J_RieulSios) + KEY_Hangul_J_RieulTieut = uint(C.GDK_KEY_Hangul_J_RieulTieut) + KEY_Hangul_J_RieulPhieuf = uint(C.GDK_KEY_Hangul_J_RieulPhieuf) + KEY_Hangul_J_RieulHieuh = uint(C.GDK_KEY_Hangul_J_RieulHieuh) + KEY_Hangul_J_Mieum = uint(C.GDK_KEY_Hangul_J_Mieum) + KEY_Hangul_J_Pieub = uint(C.GDK_KEY_Hangul_J_Pieub) + KEY_Hangul_J_PieubSios = uint(C.GDK_KEY_Hangul_J_PieubSios) + KEY_Hangul_J_Sios = uint(C.GDK_KEY_Hangul_J_Sios) + KEY_Hangul_J_SsangSios = uint(C.GDK_KEY_Hangul_J_SsangSios) + KEY_Hangul_J_Ieung = uint(C.GDK_KEY_Hangul_J_Ieung) + KEY_Hangul_J_Jieuj = uint(C.GDK_KEY_Hangul_J_Jieuj) + KEY_Hangul_J_Cieuc = uint(C.GDK_KEY_Hangul_J_Cieuc) + KEY_Hangul_J_Khieuq = uint(C.GDK_KEY_Hangul_J_Khieuq) + KEY_Hangul_J_Tieut = uint(C.GDK_KEY_Hangul_J_Tieut) + KEY_Hangul_J_Phieuf = uint(C.GDK_KEY_Hangul_J_Phieuf) + KEY_Hangul_J_Hieuh = uint(C.GDK_KEY_Hangul_J_Hieuh) + KEY_Hangul_RieulYeorinHieuh = uint(C.GDK_KEY_Hangul_RieulYeorinHieuh) + KEY_Hangul_SunkyeongeumMieum = uint(C.GDK_KEY_Hangul_SunkyeongeumMieum) + KEY_Hangul_SunkyeongeumPieub = uint(C.GDK_KEY_Hangul_SunkyeongeumPieub) + KEY_Hangul_PanSios = uint(C.GDK_KEY_Hangul_PanSios) + KEY_Hangul_KkogjiDalrinIeung = uint(C.GDK_KEY_Hangul_KkogjiDalrinIeung) + KEY_Hangul_SunkyeongeumPhieuf = uint(C.GDK_KEY_Hangul_SunkyeongeumPhieuf) + KEY_Hangul_YeorinHieuh = uint(C.GDK_KEY_Hangul_YeorinHieuh) + KEY_Hangul_AraeA = uint(C.GDK_KEY_Hangul_AraeA) + KEY_Hangul_AraeAE = uint(C.GDK_KEY_Hangul_AraeAE) + KEY_Hangul_J_PanSios = uint(C.GDK_KEY_Hangul_J_PanSios) + KEY_Hangul_J_KkogjiDalrinIeung = uint(C.GDK_KEY_Hangul_J_KkogjiDalrinIeung) + KEY_Hangul_J_YeorinHieuh = uint(C.GDK_KEY_Hangul_J_YeorinHieuh) + KEY_Korean_Won = uint(C.GDK_KEY_Korean_Won) + KEY_Armenian_ligature_ew = uint(C.GDK_KEY_Armenian_ligature_ew) + KEY_Armenian_full_stop = uint(C.GDK_KEY_Armenian_full_stop) + KEY_Armenian_verjaket = uint(C.GDK_KEY_Armenian_verjaket) + KEY_Armenian_separation_mark = uint(C.GDK_KEY_Armenian_separation_mark) + KEY_Armenian_but = uint(C.GDK_KEY_Armenian_but) + KEY_Armenian_hyphen = uint(C.GDK_KEY_Armenian_hyphen) + KEY_Armenian_yentamna = uint(C.GDK_KEY_Armenian_yentamna) + KEY_Armenian_exclam = uint(C.GDK_KEY_Armenian_exclam) + KEY_Armenian_amanak = uint(C.GDK_KEY_Armenian_amanak) + KEY_Armenian_accent = uint(C.GDK_KEY_Armenian_accent) + KEY_Armenian_shesht = uint(C.GDK_KEY_Armenian_shesht) + KEY_Armenian_question = uint(C.GDK_KEY_Armenian_question) + KEY_Armenian_paruyk = uint(C.GDK_KEY_Armenian_paruyk) + KEY_Armenian_AYB = uint(C.GDK_KEY_Armenian_AYB) + KEY_Armenian_ayb = uint(C.GDK_KEY_Armenian_ayb) + KEY_Armenian_BEN = uint(C.GDK_KEY_Armenian_BEN) + KEY_Armenian_ben = uint(C.GDK_KEY_Armenian_ben) + KEY_Armenian_GIM = uint(C.GDK_KEY_Armenian_GIM) + KEY_Armenian_gim = uint(C.GDK_KEY_Armenian_gim) + KEY_Armenian_DA = uint(C.GDK_KEY_Armenian_DA) + KEY_Armenian_da = uint(C.GDK_KEY_Armenian_da) + KEY_Armenian_YECH = uint(C.GDK_KEY_Armenian_YECH) + KEY_Armenian_yech = uint(C.GDK_KEY_Armenian_yech) + KEY_Armenian_ZA = uint(C.GDK_KEY_Armenian_ZA) + KEY_Armenian_za = uint(C.GDK_KEY_Armenian_za) + KEY_Armenian_E = uint(C.GDK_KEY_Armenian_E) + KEY_Armenian_e = uint(C.GDK_KEY_Armenian_e) + KEY_Armenian_AT = uint(C.GDK_KEY_Armenian_AT) + KEY_Armenian_at = uint(C.GDK_KEY_Armenian_at) + KEY_Armenian_TO = uint(C.GDK_KEY_Armenian_TO) + KEY_Armenian_to = uint(C.GDK_KEY_Armenian_to) + KEY_Armenian_ZHE = uint(C.GDK_KEY_Armenian_ZHE) + KEY_Armenian_zhe = uint(C.GDK_KEY_Armenian_zhe) + KEY_Armenian_INI = uint(C.GDK_KEY_Armenian_INI) + KEY_Armenian_ini = uint(C.GDK_KEY_Armenian_ini) + KEY_Armenian_LYUN = uint(C.GDK_KEY_Armenian_LYUN) + KEY_Armenian_lyun = uint(C.GDK_KEY_Armenian_lyun) + KEY_Armenian_KHE = uint(C.GDK_KEY_Armenian_KHE) + KEY_Armenian_khe = uint(C.GDK_KEY_Armenian_khe) + KEY_Armenian_TSA = uint(C.GDK_KEY_Armenian_TSA) + KEY_Armenian_tsa = uint(C.GDK_KEY_Armenian_tsa) + KEY_Armenian_KEN = uint(C.GDK_KEY_Armenian_KEN) + KEY_Armenian_ken = uint(C.GDK_KEY_Armenian_ken) + KEY_Armenian_HO = uint(C.GDK_KEY_Armenian_HO) + KEY_Armenian_ho = uint(C.GDK_KEY_Armenian_ho) + KEY_Armenian_DZA = uint(C.GDK_KEY_Armenian_DZA) + KEY_Armenian_dza = uint(C.GDK_KEY_Armenian_dza) + KEY_Armenian_GHAT = uint(C.GDK_KEY_Armenian_GHAT) + KEY_Armenian_ghat = uint(C.GDK_KEY_Armenian_ghat) + KEY_Armenian_TCHE = uint(C.GDK_KEY_Armenian_TCHE) + KEY_Armenian_tche = uint(C.GDK_KEY_Armenian_tche) + KEY_Armenian_MEN = uint(C.GDK_KEY_Armenian_MEN) + KEY_Armenian_men = uint(C.GDK_KEY_Armenian_men) + KEY_Armenian_HI = uint(C.GDK_KEY_Armenian_HI) + KEY_Armenian_hi = uint(C.GDK_KEY_Armenian_hi) + KEY_Armenian_NU = uint(C.GDK_KEY_Armenian_NU) + KEY_Armenian_nu = uint(C.GDK_KEY_Armenian_nu) + KEY_Armenian_SHA = uint(C.GDK_KEY_Armenian_SHA) + KEY_Armenian_sha = uint(C.GDK_KEY_Armenian_sha) + KEY_Armenian_VO = uint(C.GDK_KEY_Armenian_VO) + KEY_Armenian_vo = uint(C.GDK_KEY_Armenian_vo) + KEY_Armenian_CHA = uint(C.GDK_KEY_Armenian_CHA) + KEY_Armenian_cha = uint(C.GDK_KEY_Armenian_cha) + KEY_Armenian_PE = uint(C.GDK_KEY_Armenian_PE) + KEY_Armenian_pe = uint(C.GDK_KEY_Armenian_pe) + KEY_Armenian_JE = uint(C.GDK_KEY_Armenian_JE) + KEY_Armenian_je = uint(C.GDK_KEY_Armenian_je) + KEY_Armenian_RA = uint(C.GDK_KEY_Armenian_RA) + KEY_Armenian_ra = uint(C.GDK_KEY_Armenian_ra) + KEY_Armenian_SE = uint(C.GDK_KEY_Armenian_SE) + KEY_Armenian_se = uint(C.GDK_KEY_Armenian_se) + KEY_Armenian_VEV = uint(C.GDK_KEY_Armenian_VEV) + KEY_Armenian_vev = uint(C.GDK_KEY_Armenian_vev) + KEY_Armenian_TYUN = uint(C.GDK_KEY_Armenian_TYUN) + KEY_Armenian_tyun = uint(C.GDK_KEY_Armenian_tyun) + KEY_Armenian_RE = uint(C.GDK_KEY_Armenian_RE) + KEY_Armenian_re = uint(C.GDK_KEY_Armenian_re) + KEY_Armenian_TSO = uint(C.GDK_KEY_Armenian_TSO) + KEY_Armenian_tso = uint(C.GDK_KEY_Armenian_tso) + KEY_Armenian_VYUN = uint(C.GDK_KEY_Armenian_VYUN) + KEY_Armenian_vyun = uint(C.GDK_KEY_Armenian_vyun) + KEY_Armenian_PYUR = uint(C.GDK_KEY_Armenian_PYUR) + KEY_Armenian_pyur = uint(C.GDK_KEY_Armenian_pyur) + KEY_Armenian_KE = uint(C.GDK_KEY_Armenian_KE) + KEY_Armenian_ke = uint(C.GDK_KEY_Armenian_ke) + KEY_Armenian_O = uint(C.GDK_KEY_Armenian_O) + KEY_Armenian_o = uint(C.GDK_KEY_Armenian_o) + KEY_Armenian_FE = uint(C.GDK_KEY_Armenian_FE) + KEY_Armenian_fe = uint(C.GDK_KEY_Armenian_fe) + KEY_Armenian_apostrophe = uint(C.GDK_KEY_Armenian_apostrophe) + KEY_Georgian_an = uint(C.GDK_KEY_Georgian_an) + KEY_Georgian_ban = uint(C.GDK_KEY_Georgian_ban) + KEY_Georgian_gan = uint(C.GDK_KEY_Georgian_gan) + KEY_Georgian_don = uint(C.GDK_KEY_Georgian_don) + KEY_Georgian_en = uint(C.GDK_KEY_Georgian_en) + KEY_Georgian_vin = uint(C.GDK_KEY_Georgian_vin) + KEY_Georgian_zen = uint(C.GDK_KEY_Georgian_zen) + KEY_Georgian_tan = uint(C.GDK_KEY_Georgian_tan) + KEY_Georgian_in = uint(C.GDK_KEY_Georgian_in) + KEY_Georgian_kan = uint(C.GDK_KEY_Georgian_kan) + KEY_Georgian_las = uint(C.GDK_KEY_Georgian_las) + KEY_Georgian_man = uint(C.GDK_KEY_Georgian_man) + KEY_Georgian_nar = uint(C.GDK_KEY_Georgian_nar) + KEY_Georgian_on = uint(C.GDK_KEY_Georgian_on) + KEY_Georgian_par = uint(C.GDK_KEY_Georgian_par) + KEY_Georgian_zhar = uint(C.GDK_KEY_Georgian_zhar) + KEY_Georgian_rae = uint(C.GDK_KEY_Georgian_rae) + KEY_Georgian_san = uint(C.GDK_KEY_Georgian_san) + KEY_Georgian_tar = uint(C.GDK_KEY_Georgian_tar) + KEY_Georgian_un = uint(C.GDK_KEY_Georgian_un) + KEY_Georgian_phar = uint(C.GDK_KEY_Georgian_phar) + KEY_Georgian_khar = uint(C.GDK_KEY_Georgian_khar) + KEY_Georgian_ghan = uint(C.GDK_KEY_Georgian_ghan) + KEY_Georgian_qar = uint(C.GDK_KEY_Georgian_qar) + KEY_Georgian_shin = uint(C.GDK_KEY_Georgian_shin) + KEY_Georgian_chin = uint(C.GDK_KEY_Georgian_chin) + KEY_Georgian_can = uint(C.GDK_KEY_Georgian_can) + KEY_Georgian_jil = uint(C.GDK_KEY_Georgian_jil) + KEY_Georgian_cil = uint(C.GDK_KEY_Georgian_cil) + KEY_Georgian_char = uint(C.GDK_KEY_Georgian_char) + KEY_Georgian_xan = uint(C.GDK_KEY_Georgian_xan) + KEY_Georgian_jhan = uint(C.GDK_KEY_Georgian_jhan) + KEY_Georgian_hae = uint(C.GDK_KEY_Georgian_hae) + KEY_Georgian_he = uint(C.GDK_KEY_Georgian_he) + KEY_Georgian_hie = uint(C.GDK_KEY_Georgian_hie) + KEY_Georgian_we = uint(C.GDK_KEY_Georgian_we) + KEY_Georgian_har = uint(C.GDK_KEY_Georgian_har) + KEY_Georgian_hoe = uint(C.GDK_KEY_Georgian_hoe) + KEY_Georgian_fi = uint(C.GDK_KEY_Georgian_fi) + KEY_Xabovedot = uint(C.GDK_KEY_Xabovedot) + KEY_Ibreve = uint(C.GDK_KEY_Ibreve) + KEY_Zstroke = uint(C.GDK_KEY_Zstroke) + KEY_Gcaron = uint(C.GDK_KEY_Gcaron) + KEY_Ocaron = uint(C.GDK_KEY_Ocaron) + KEY_Obarred = uint(C.GDK_KEY_Obarred) + KEY_xabovedot = uint(C.GDK_KEY_xabovedot) + KEY_ibreve = uint(C.GDK_KEY_ibreve) + KEY_zstroke = uint(C.GDK_KEY_zstroke) + KEY_gcaron = uint(C.GDK_KEY_gcaron) + KEY_ocaron = uint(C.GDK_KEY_ocaron) + KEY_obarred = uint(C.GDK_KEY_obarred) + KEY_SCHWA = uint(C.GDK_KEY_SCHWA) + KEY_schwa = uint(C.GDK_KEY_schwa) + KEY_EZH = uint(C.GDK_KEY_EZH) + KEY_ezh = uint(C.GDK_KEY_ezh) + KEY_Lbelowdot = uint(C.GDK_KEY_Lbelowdot) + KEY_lbelowdot = uint(C.GDK_KEY_lbelowdot) + KEY_Abelowdot = uint(C.GDK_KEY_Abelowdot) + KEY_abelowdot = uint(C.GDK_KEY_abelowdot) + KEY_Ahook = uint(C.GDK_KEY_Ahook) + KEY_ahook = uint(C.GDK_KEY_ahook) + KEY_Acircumflexacute = uint(C.GDK_KEY_Acircumflexacute) + KEY_acircumflexacute = uint(C.GDK_KEY_acircumflexacute) + KEY_Acircumflexgrave = uint(C.GDK_KEY_Acircumflexgrave) + KEY_acircumflexgrave = uint(C.GDK_KEY_acircumflexgrave) + KEY_Acircumflexhook = uint(C.GDK_KEY_Acircumflexhook) + KEY_acircumflexhook = uint(C.GDK_KEY_acircumflexhook) + KEY_Acircumflextilde = uint(C.GDK_KEY_Acircumflextilde) + KEY_acircumflextilde = uint(C.GDK_KEY_acircumflextilde) + KEY_Acircumflexbelowdot = uint(C.GDK_KEY_Acircumflexbelowdot) + KEY_acircumflexbelowdot = uint(C.GDK_KEY_acircumflexbelowdot) + KEY_Abreveacute = uint(C.GDK_KEY_Abreveacute) + KEY_abreveacute = uint(C.GDK_KEY_abreveacute) + KEY_Abrevegrave = uint(C.GDK_KEY_Abrevegrave) + KEY_abrevegrave = uint(C.GDK_KEY_abrevegrave) + KEY_Abrevehook = uint(C.GDK_KEY_Abrevehook) + KEY_abrevehook = uint(C.GDK_KEY_abrevehook) + KEY_Abrevetilde = uint(C.GDK_KEY_Abrevetilde) + KEY_abrevetilde = uint(C.GDK_KEY_abrevetilde) + KEY_Abrevebelowdot = uint(C.GDK_KEY_Abrevebelowdot) + KEY_abrevebelowdot = uint(C.GDK_KEY_abrevebelowdot) + KEY_Ebelowdot = uint(C.GDK_KEY_Ebelowdot) + KEY_ebelowdot = uint(C.GDK_KEY_ebelowdot) + KEY_Ehook = uint(C.GDK_KEY_Ehook) + KEY_ehook = uint(C.GDK_KEY_ehook) + KEY_Etilde = uint(C.GDK_KEY_Etilde) + KEY_etilde = uint(C.GDK_KEY_etilde) + KEY_Ecircumflexacute = uint(C.GDK_KEY_Ecircumflexacute) + KEY_ecircumflexacute = uint(C.GDK_KEY_ecircumflexacute) + KEY_Ecircumflexgrave = uint(C.GDK_KEY_Ecircumflexgrave) + KEY_ecircumflexgrave = uint(C.GDK_KEY_ecircumflexgrave) + KEY_Ecircumflexhook = uint(C.GDK_KEY_Ecircumflexhook) + KEY_ecircumflexhook = uint(C.GDK_KEY_ecircumflexhook) + KEY_Ecircumflextilde = uint(C.GDK_KEY_Ecircumflextilde) + KEY_ecircumflextilde = uint(C.GDK_KEY_ecircumflextilde) + KEY_Ecircumflexbelowdot = uint(C.GDK_KEY_Ecircumflexbelowdot) + KEY_ecircumflexbelowdot = uint(C.GDK_KEY_ecircumflexbelowdot) + KEY_Ihook = uint(C.GDK_KEY_Ihook) + KEY_ihook = uint(C.GDK_KEY_ihook) + KEY_Ibelowdot = uint(C.GDK_KEY_Ibelowdot) + KEY_ibelowdot = uint(C.GDK_KEY_ibelowdot) + KEY_Obelowdot = uint(C.GDK_KEY_Obelowdot) + KEY_obelowdot = uint(C.GDK_KEY_obelowdot) + KEY_Ohook = uint(C.GDK_KEY_Ohook) + KEY_ohook = uint(C.GDK_KEY_ohook) + KEY_Ocircumflexacute = uint(C.GDK_KEY_Ocircumflexacute) + KEY_ocircumflexacute = uint(C.GDK_KEY_ocircumflexacute) + KEY_Ocircumflexgrave = uint(C.GDK_KEY_Ocircumflexgrave) + KEY_ocircumflexgrave = uint(C.GDK_KEY_ocircumflexgrave) + KEY_Ocircumflexhook = uint(C.GDK_KEY_Ocircumflexhook) + KEY_ocircumflexhook = uint(C.GDK_KEY_ocircumflexhook) + KEY_Ocircumflextilde = uint(C.GDK_KEY_Ocircumflextilde) + KEY_ocircumflextilde = uint(C.GDK_KEY_ocircumflextilde) + KEY_Ocircumflexbelowdot = uint(C.GDK_KEY_Ocircumflexbelowdot) + KEY_ocircumflexbelowdot = uint(C.GDK_KEY_ocircumflexbelowdot) + KEY_Ohornacute = uint(C.GDK_KEY_Ohornacute) + KEY_ohornacute = uint(C.GDK_KEY_ohornacute) + KEY_Ohorngrave = uint(C.GDK_KEY_Ohorngrave) + KEY_ohorngrave = uint(C.GDK_KEY_ohorngrave) + KEY_Ohornhook = uint(C.GDK_KEY_Ohornhook) + KEY_ohornhook = uint(C.GDK_KEY_ohornhook) + KEY_Ohorntilde = uint(C.GDK_KEY_Ohorntilde) + KEY_ohorntilde = uint(C.GDK_KEY_ohorntilde) + KEY_Ohornbelowdot = uint(C.GDK_KEY_Ohornbelowdot) + KEY_ohornbelowdot = uint(C.GDK_KEY_ohornbelowdot) + KEY_Ubelowdot = uint(C.GDK_KEY_Ubelowdot) + KEY_ubelowdot = uint(C.GDK_KEY_ubelowdot) + KEY_Uhook = uint(C.GDK_KEY_Uhook) + KEY_uhook = uint(C.GDK_KEY_uhook) + KEY_Uhornacute = uint(C.GDK_KEY_Uhornacute) + KEY_uhornacute = uint(C.GDK_KEY_uhornacute) + KEY_Uhorngrave = uint(C.GDK_KEY_Uhorngrave) + KEY_uhorngrave = uint(C.GDK_KEY_uhorngrave) + KEY_Uhornhook = uint(C.GDK_KEY_Uhornhook) + KEY_uhornhook = uint(C.GDK_KEY_uhornhook) + KEY_Uhorntilde = uint(C.GDK_KEY_Uhorntilde) + KEY_uhorntilde = uint(C.GDK_KEY_uhorntilde) + KEY_Uhornbelowdot = uint(C.GDK_KEY_Uhornbelowdot) + KEY_uhornbelowdot = uint(C.GDK_KEY_uhornbelowdot) + KEY_Ybelowdot = uint(C.GDK_KEY_Ybelowdot) + KEY_ybelowdot = uint(C.GDK_KEY_ybelowdot) + KEY_Yhook = uint(C.GDK_KEY_Yhook) + KEY_yhook = uint(C.GDK_KEY_yhook) + KEY_Ytilde = uint(C.GDK_KEY_Ytilde) + KEY_ytilde = uint(C.GDK_KEY_ytilde) + KEY_Ohorn = uint(C.GDK_KEY_Ohorn) + KEY_ohorn = uint(C.GDK_KEY_ohorn) + KEY_Uhorn = uint(C.GDK_KEY_Uhorn) + KEY_uhorn = uint(C.GDK_KEY_uhorn) + KEY_EcuSign = uint(C.GDK_KEY_EcuSign) + KEY_ColonSign = uint(C.GDK_KEY_ColonSign) + KEY_CruzeiroSign = uint(C.GDK_KEY_CruzeiroSign) + KEY_FFrancSign = uint(C.GDK_KEY_FFrancSign) + KEY_LiraSign = uint(C.GDK_KEY_LiraSign) + KEY_MillSign = uint(C.GDK_KEY_MillSign) + KEY_NairaSign = uint(C.GDK_KEY_NairaSign) + KEY_PesetaSign = uint(C.GDK_KEY_PesetaSign) + KEY_RupeeSign = uint(C.GDK_KEY_RupeeSign) + KEY_WonSign = uint(C.GDK_KEY_WonSign) + KEY_NewSheqelSign = uint(C.GDK_KEY_NewSheqelSign) + KEY_DongSign = uint(C.GDK_KEY_DongSign) + KEY_EuroSign = uint(C.GDK_KEY_EuroSign) + KEY_zerosuperior = uint(C.GDK_KEY_zerosuperior) + KEY_foursuperior = uint(C.GDK_KEY_foursuperior) + KEY_fivesuperior = uint(C.GDK_KEY_fivesuperior) + KEY_sixsuperior = uint(C.GDK_KEY_sixsuperior) + KEY_sevensuperior = uint(C.GDK_KEY_sevensuperior) + KEY_eightsuperior = uint(C.GDK_KEY_eightsuperior) + KEY_ninesuperior = uint(C.GDK_KEY_ninesuperior) + KEY_zerosubscript = uint(C.GDK_KEY_zerosubscript) + KEY_onesubscript = uint(C.GDK_KEY_onesubscript) + KEY_twosubscript = uint(C.GDK_KEY_twosubscript) + KEY_threesubscript = uint(C.GDK_KEY_threesubscript) + KEY_foursubscript = uint(C.GDK_KEY_foursubscript) + KEY_fivesubscript = uint(C.GDK_KEY_fivesubscript) + KEY_sixsubscript = uint(C.GDK_KEY_sixsubscript) + KEY_sevensubscript = uint(C.GDK_KEY_sevensubscript) + KEY_eightsubscript = uint(C.GDK_KEY_eightsubscript) + KEY_ninesubscript = uint(C.GDK_KEY_ninesubscript) + KEY_partdifferential = uint(C.GDK_KEY_partdifferential) + KEY_emptyset = uint(C.GDK_KEY_emptyset) + KEY_elementof = uint(C.GDK_KEY_elementof) + KEY_notelementof = uint(C.GDK_KEY_notelementof) + KEY_containsas = uint(C.GDK_KEY_containsas) + KEY_squareroot = uint(C.GDK_KEY_squareroot) + KEY_cuberoot = uint(C.GDK_KEY_cuberoot) + KEY_fourthroot = uint(C.GDK_KEY_fourthroot) + KEY_dintegral = uint(C.GDK_KEY_dintegral) + KEY_tintegral = uint(C.GDK_KEY_tintegral) + KEY_because = uint(C.GDK_KEY_because) + KEY_approxeq = uint(C.GDK_KEY_approxeq) + KEY_notapproxeq = uint(C.GDK_KEY_notapproxeq) + KEY_notidentical = uint(C.GDK_KEY_notidentical) + KEY_stricteq = uint(C.GDK_KEY_stricteq) + KEY_braille_dot_1 = uint(C.GDK_KEY_braille_dot_1) + KEY_braille_dot_2 = uint(C.GDK_KEY_braille_dot_2) + KEY_braille_dot_3 = uint(C.GDK_KEY_braille_dot_3) + KEY_braille_dot_4 = uint(C.GDK_KEY_braille_dot_4) + KEY_braille_dot_5 = uint(C.GDK_KEY_braille_dot_5) + KEY_braille_dot_6 = uint(C.GDK_KEY_braille_dot_6) + KEY_braille_dot_7 = uint(C.GDK_KEY_braille_dot_7) + KEY_braille_dot_8 = uint(C.GDK_KEY_braille_dot_8) + KEY_braille_dot_9 = uint(C.GDK_KEY_braille_dot_9) + KEY_braille_dot_10 = uint(C.GDK_KEY_braille_dot_10) + KEY_braille_blank = uint(C.GDK_KEY_braille_blank) + KEY_braille_dots_1 = uint(C.GDK_KEY_braille_dots_1) + KEY_braille_dots_2 = uint(C.GDK_KEY_braille_dots_2) + KEY_braille_dots_12 = uint(C.GDK_KEY_braille_dots_12) + KEY_braille_dots_3 = uint(C.GDK_KEY_braille_dots_3) + KEY_braille_dots_13 = uint(C.GDK_KEY_braille_dots_13) + KEY_braille_dots_23 = uint(C.GDK_KEY_braille_dots_23) + KEY_braille_dots_123 = uint(C.GDK_KEY_braille_dots_123) + KEY_braille_dots_4 = uint(C.GDK_KEY_braille_dots_4) + KEY_braille_dots_14 = uint(C.GDK_KEY_braille_dots_14) + KEY_braille_dots_24 = uint(C.GDK_KEY_braille_dots_24) + KEY_braille_dots_124 = uint(C.GDK_KEY_braille_dots_124) + KEY_braille_dots_34 = uint(C.GDK_KEY_braille_dots_34) + KEY_braille_dots_134 = uint(C.GDK_KEY_braille_dots_134) + KEY_braille_dots_234 = uint(C.GDK_KEY_braille_dots_234) + KEY_braille_dots_1234 = uint(C.GDK_KEY_braille_dots_1234) + KEY_braille_dots_5 = uint(C.GDK_KEY_braille_dots_5) + KEY_braille_dots_15 = uint(C.GDK_KEY_braille_dots_15) + KEY_braille_dots_25 = uint(C.GDK_KEY_braille_dots_25) + KEY_braille_dots_125 = uint(C.GDK_KEY_braille_dots_125) + KEY_braille_dots_35 = uint(C.GDK_KEY_braille_dots_35) + KEY_braille_dots_135 = uint(C.GDK_KEY_braille_dots_135) + KEY_braille_dots_235 = uint(C.GDK_KEY_braille_dots_235) + KEY_braille_dots_1235 = uint(C.GDK_KEY_braille_dots_1235) + KEY_braille_dots_45 = uint(C.GDK_KEY_braille_dots_45) + KEY_braille_dots_145 = uint(C.GDK_KEY_braille_dots_145) + KEY_braille_dots_245 = uint(C.GDK_KEY_braille_dots_245) + KEY_braille_dots_1245 = uint(C.GDK_KEY_braille_dots_1245) + KEY_braille_dots_345 = uint(C.GDK_KEY_braille_dots_345) + KEY_braille_dots_1345 = uint(C.GDK_KEY_braille_dots_1345) + KEY_braille_dots_2345 = uint(C.GDK_KEY_braille_dots_2345) + KEY_braille_dots_12345 = uint(C.GDK_KEY_braille_dots_12345) + KEY_braille_dots_6 = uint(C.GDK_KEY_braille_dots_6) + KEY_braille_dots_16 = uint(C.GDK_KEY_braille_dots_16) + KEY_braille_dots_26 = uint(C.GDK_KEY_braille_dots_26) + KEY_braille_dots_126 = uint(C.GDK_KEY_braille_dots_126) + KEY_braille_dots_36 = uint(C.GDK_KEY_braille_dots_36) + KEY_braille_dots_136 = uint(C.GDK_KEY_braille_dots_136) + KEY_braille_dots_236 = uint(C.GDK_KEY_braille_dots_236) + KEY_braille_dots_1236 = uint(C.GDK_KEY_braille_dots_1236) + KEY_braille_dots_46 = uint(C.GDK_KEY_braille_dots_46) + KEY_braille_dots_146 = uint(C.GDK_KEY_braille_dots_146) + KEY_braille_dots_246 = uint(C.GDK_KEY_braille_dots_246) + KEY_braille_dots_1246 = uint(C.GDK_KEY_braille_dots_1246) + KEY_braille_dots_346 = uint(C.GDK_KEY_braille_dots_346) + KEY_braille_dots_1346 = uint(C.GDK_KEY_braille_dots_1346) + KEY_braille_dots_2346 = uint(C.GDK_KEY_braille_dots_2346) + KEY_braille_dots_12346 = uint(C.GDK_KEY_braille_dots_12346) + KEY_braille_dots_56 = uint(C.GDK_KEY_braille_dots_56) + KEY_braille_dots_156 = uint(C.GDK_KEY_braille_dots_156) + KEY_braille_dots_256 = uint(C.GDK_KEY_braille_dots_256) + KEY_braille_dots_1256 = uint(C.GDK_KEY_braille_dots_1256) + KEY_braille_dots_356 = uint(C.GDK_KEY_braille_dots_356) + KEY_braille_dots_1356 = uint(C.GDK_KEY_braille_dots_1356) + KEY_braille_dots_2356 = uint(C.GDK_KEY_braille_dots_2356) + KEY_braille_dots_12356 = uint(C.GDK_KEY_braille_dots_12356) + KEY_braille_dots_456 = uint(C.GDK_KEY_braille_dots_456) + KEY_braille_dots_1456 = uint(C.GDK_KEY_braille_dots_1456) + KEY_braille_dots_2456 = uint(C.GDK_KEY_braille_dots_2456) + KEY_braille_dots_12456 = uint(C.GDK_KEY_braille_dots_12456) + KEY_braille_dots_3456 = uint(C.GDK_KEY_braille_dots_3456) + KEY_braille_dots_13456 = uint(C.GDK_KEY_braille_dots_13456) + KEY_braille_dots_23456 = uint(C.GDK_KEY_braille_dots_23456) + KEY_braille_dots_123456 = uint(C.GDK_KEY_braille_dots_123456) + KEY_braille_dots_7 = uint(C.GDK_KEY_braille_dots_7) + KEY_braille_dots_17 = uint(C.GDK_KEY_braille_dots_17) + KEY_braille_dots_27 = uint(C.GDK_KEY_braille_dots_27) + KEY_braille_dots_127 = uint(C.GDK_KEY_braille_dots_127) + KEY_braille_dots_37 = uint(C.GDK_KEY_braille_dots_37) + KEY_braille_dots_137 = uint(C.GDK_KEY_braille_dots_137) + KEY_braille_dots_237 = uint(C.GDK_KEY_braille_dots_237) + KEY_braille_dots_1237 = uint(C.GDK_KEY_braille_dots_1237) + KEY_braille_dots_47 = uint(C.GDK_KEY_braille_dots_47) + KEY_braille_dots_147 = uint(C.GDK_KEY_braille_dots_147) + KEY_braille_dots_247 = uint(C.GDK_KEY_braille_dots_247) + KEY_braille_dots_1247 = uint(C.GDK_KEY_braille_dots_1247) + KEY_braille_dots_347 = uint(C.GDK_KEY_braille_dots_347) + KEY_braille_dots_1347 = uint(C.GDK_KEY_braille_dots_1347) + KEY_braille_dots_2347 = uint(C.GDK_KEY_braille_dots_2347) + KEY_braille_dots_12347 = uint(C.GDK_KEY_braille_dots_12347) + KEY_braille_dots_57 = uint(C.GDK_KEY_braille_dots_57) + KEY_braille_dots_157 = uint(C.GDK_KEY_braille_dots_157) + KEY_braille_dots_257 = uint(C.GDK_KEY_braille_dots_257) + KEY_braille_dots_1257 = uint(C.GDK_KEY_braille_dots_1257) + KEY_braille_dots_357 = uint(C.GDK_KEY_braille_dots_357) + KEY_braille_dots_1357 = uint(C.GDK_KEY_braille_dots_1357) + KEY_braille_dots_2357 = uint(C.GDK_KEY_braille_dots_2357) + KEY_braille_dots_12357 = uint(C.GDK_KEY_braille_dots_12357) + KEY_braille_dots_457 = uint(C.GDK_KEY_braille_dots_457) + KEY_braille_dots_1457 = uint(C.GDK_KEY_braille_dots_1457) + KEY_braille_dots_2457 = uint(C.GDK_KEY_braille_dots_2457) + KEY_braille_dots_12457 = uint(C.GDK_KEY_braille_dots_12457) + KEY_braille_dots_3457 = uint(C.GDK_KEY_braille_dots_3457) + KEY_braille_dots_13457 = uint(C.GDK_KEY_braille_dots_13457) + KEY_braille_dots_23457 = uint(C.GDK_KEY_braille_dots_23457) + KEY_braille_dots_123457 = uint(C.GDK_KEY_braille_dots_123457) + KEY_braille_dots_67 = uint(C.GDK_KEY_braille_dots_67) + KEY_braille_dots_167 = uint(C.GDK_KEY_braille_dots_167) + KEY_braille_dots_267 = uint(C.GDK_KEY_braille_dots_267) + KEY_braille_dots_1267 = uint(C.GDK_KEY_braille_dots_1267) + KEY_braille_dots_367 = uint(C.GDK_KEY_braille_dots_367) + KEY_braille_dots_1367 = uint(C.GDK_KEY_braille_dots_1367) + KEY_braille_dots_2367 = uint(C.GDK_KEY_braille_dots_2367) + KEY_braille_dots_12367 = uint(C.GDK_KEY_braille_dots_12367) + KEY_braille_dots_467 = uint(C.GDK_KEY_braille_dots_467) + KEY_braille_dots_1467 = uint(C.GDK_KEY_braille_dots_1467) + KEY_braille_dots_2467 = uint(C.GDK_KEY_braille_dots_2467) + KEY_braille_dots_12467 = uint(C.GDK_KEY_braille_dots_12467) + KEY_braille_dots_3467 = uint(C.GDK_KEY_braille_dots_3467) + KEY_braille_dots_13467 = uint(C.GDK_KEY_braille_dots_13467) + KEY_braille_dots_23467 = uint(C.GDK_KEY_braille_dots_23467) + KEY_braille_dots_123467 = uint(C.GDK_KEY_braille_dots_123467) + KEY_braille_dots_567 = uint(C.GDK_KEY_braille_dots_567) + KEY_braille_dots_1567 = uint(C.GDK_KEY_braille_dots_1567) + KEY_braille_dots_2567 = uint(C.GDK_KEY_braille_dots_2567) + KEY_braille_dots_12567 = uint(C.GDK_KEY_braille_dots_12567) + KEY_braille_dots_3567 = uint(C.GDK_KEY_braille_dots_3567) + KEY_braille_dots_13567 = uint(C.GDK_KEY_braille_dots_13567) + KEY_braille_dots_23567 = uint(C.GDK_KEY_braille_dots_23567) + KEY_braille_dots_123567 = uint(C.GDK_KEY_braille_dots_123567) + KEY_braille_dots_4567 = uint(C.GDK_KEY_braille_dots_4567) + KEY_braille_dots_14567 = uint(C.GDK_KEY_braille_dots_14567) + KEY_braille_dots_24567 = uint(C.GDK_KEY_braille_dots_24567) + KEY_braille_dots_124567 = uint(C.GDK_KEY_braille_dots_124567) + KEY_braille_dots_34567 = uint(C.GDK_KEY_braille_dots_34567) + KEY_braille_dots_134567 = uint(C.GDK_KEY_braille_dots_134567) + KEY_braille_dots_234567 = uint(C.GDK_KEY_braille_dots_234567) + KEY_braille_dots_1234567 = uint(C.GDK_KEY_braille_dots_1234567) + KEY_braille_dots_8 = uint(C.GDK_KEY_braille_dots_8) + KEY_braille_dots_18 = uint(C.GDK_KEY_braille_dots_18) + KEY_braille_dots_28 = uint(C.GDK_KEY_braille_dots_28) + KEY_braille_dots_128 = uint(C.GDK_KEY_braille_dots_128) + KEY_braille_dots_38 = uint(C.GDK_KEY_braille_dots_38) + KEY_braille_dots_138 = uint(C.GDK_KEY_braille_dots_138) + KEY_braille_dots_238 = uint(C.GDK_KEY_braille_dots_238) + KEY_braille_dots_1238 = uint(C.GDK_KEY_braille_dots_1238) + KEY_braille_dots_48 = uint(C.GDK_KEY_braille_dots_48) + KEY_braille_dots_148 = uint(C.GDK_KEY_braille_dots_148) + KEY_braille_dots_248 = uint(C.GDK_KEY_braille_dots_248) + KEY_braille_dots_1248 = uint(C.GDK_KEY_braille_dots_1248) + KEY_braille_dots_348 = uint(C.GDK_KEY_braille_dots_348) + KEY_braille_dots_1348 = uint(C.GDK_KEY_braille_dots_1348) + KEY_braille_dots_2348 = uint(C.GDK_KEY_braille_dots_2348) + KEY_braille_dots_12348 = uint(C.GDK_KEY_braille_dots_12348) + KEY_braille_dots_58 = uint(C.GDK_KEY_braille_dots_58) + KEY_braille_dots_158 = uint(C.GDK_KEY_braille_dots_158) + KEY_braille_dots_258 = uint(C.GDK_KEY_braille_dots_258) + KEY_braille_dots_1258 = uint(C.GDK_KEY_braille_dots_1258) + KEY_braille_dots_358 = uint(C.GDK_KEY_braille_dots_358) + KEY_braille_dots_1358 = uint(C.GDK_KEY_braille_dots_1358) + KEY_braille_dots_2358 = uint(C.GDK_KEY_braille_dots_2358) + KEY_braille_dots_12358 = uint(C.GDK_KEY_braille_dots_12358) + KEY_braille_dots_458 = uint(C.GDK_KEY_braille_dots_458) + KEY_braille_dots_1458 = uint(C.GDK_KEY_braille_dots_1458) + KEY_braille_dots_2458 = uint(C.GDK_KEY_braille_dots_2458) + KEY_braille_dots_12458 = uint(C.GDK_KEY_braille_dots_12458) + KEY_braille_dots_3458 = uint(C.GDK_KEY_braille_dots_3458) + KEY_braille_dots_13458 = uint(C.GDK_KEY_braille_dots_13458) + KEY_braille_dots_23458 = uint(C.GDK_KEY_braille_dots_23458) + KEY_braille_dots_123458 = uint(C.GDK_KEY_braille_dots_123458) + KEY_braille_dots_68 = uint(C.GDK_KEY_braille_dots_68) + KEY_braille_dots_168 = uint(C.GDK_KEY_braille_dots_168) + KEY_braille_dots_268 = uint(C.GDK_KEY_braille_dots_268) + KEY_braille_dots_1268 = uint(C.GDK_KEY_braille_dots_1268) + KEY_braille_dots_368 = uint(C.GDK_KEY_braille_dots_368) + KEY_braille_dots_1368 = uint(C.GDK_KEY_braille_dots_1368) + KEY_braille_dots_2368 = uint(C.GDK_KEY_braille_dots_2368) + KEY_braille_dots_12368 = uint(C.GDK_KEY_braille_dots_12368) + KEY_braille_dots_468 = uint(C.GDK_KEY_braille_dots_468) + KEY_braille_dots_1468 = uint(C.GDK_KEY_braille_dots_1468) + KEY_braille_dots_2468 = uint(C.GDK_KEY_braille_dots_2468) + KEY_braille_dots_12468 = uint(C.GDK_KEY_braille_dots_12468) + KEY_braille_dots_3468 = uint(C.GDK_KEY_braille_dots_3468) + KEY_braille_dots_13468 = uint(C.GDK_KEY_braille_dots_13468) + KEY_braille_dots_23468 = uint(C.GDK_KEY_braille_dots_23468) + KEY_braille_dots_123468 = uint(C.GDK_KEY_braille_dots_123468) + KEY_braille_dots_568 = uint(C.GDK_KEY_braille_dots_568) + KEY_braille_dots_1568 = uint(C.GDK_KEY_braille_dots_1568) + KEY_braille_dots_2568 = uint(C.GDK_KEY_braille_dots_2568) + KEY_braille_dots_12568 = uint(C.GDK_KEY_braille_dots_12568) + KEY_braille_dots_3568 = uint(C.GDK_KEY_braille_dots_3568) + KEY_braille_dots_13568 = uint(C.GDK_KEY_braille_dots_13568) + KEY_braille_dots_23568 = uint(C.GDK_KEY_braille_dots_23568) + KEY_braille_dots_123568 = uint(C.GDK_KEY_braille_dots_123568) + KEY_braille_dots_4568 = uint(C.GDK_KEY_braille_dots_4568) + KEY_braille_dots_14568 = uint(C.GDK_KEY_braille_dots_14568) + KEY_braille_dots_24568 = uint(C.GDK_KEY_braille_dots_24568) + KEY_braille_dots_124568 = uint(C.GDK_KEY_braille_dots_124568) + KEY_braille_dots_34568 = uint(C.GDK_KEY_braille_dots_34568) + KEY_braille_dots_134568 = uint(C.GDK_KEY_braille_dots_134568) + KEY_braille_dots_234568 = uint(C.GDK_KEY_braille_dots_234568) + KEY_braille_dots_1234568 = uint(C.GDK_KEY_braille_dots_1234568) + KEY_braille_dots_78 = uint(C.GDK_KEY_braille_dots_78) + KEY_braille_dots_178 = uint(C.GDK_KEY_braille_dots_178) + KEY_braille_dots_278 = uint(C.GDK_KEY_braille_dots_278) + KEY_braille_dots_1278 = uint(C.GDK_KEY_braille_dots_1278) + KEY_braille_dots_378 = uint(C.GDK_KEY_braille_dots_378) + KEY_braille_dots_1378 = uint(C.GDK_KEY_braille_dots_1378) + KEY_braille_dots_2378 = uint(C.GDK_KEY_braille_dots_2378) + KEY_braille_dots_12378 = uint(C.GDK_KEY_braille_dots_12378) + KEY_braille_dots_478 = uint(C.GDK_KEY_braille_dots_478) + KEY_braille_dots_1478 = uint(C.GDK_KEY_braille_dots_1478) + KEY_braille_dots_2478 = uint(C.GDK_KEY_braille_dots_2478) + KEY_braille_dots_12478 = uint(C.GDK_KEY_braille_dots_12478) + KEY_braille_dots_3478 = uint(C.GDK_KEY_braille_dots_3478) + KEY_braille_dots_13478 = uint(C.GDK_KEY_braille_dots_13478) + KEY_braille_dots_23478 = uint(C.GDK_KEY_braille_dots_23478) + KEY_braille_dots_123478 = uint(C.GDK_KEY_braille_dots_123478) + KEY_braille_dots_578 = uint(C.GDK_KEY_braille_dots_578) + KEY_braille_dots_1578 = uint(C.GDK_KEY_braille_dots_1578) + KEY_braille_dots_2578 = uint(C.GDK_KEY_braille_dots_2578) + KEY_braille_dots_12578 = uint(C.GDK_KEY_braille_dots_12578) + KEY_braille_dots_3578 = uint(C.GDK_KEY_braille_dots_3578) + KEY_braille_dots_13578 = uint(C.GDK_KEY_braille_dots_13578) + KEY_braille_dots_23578 = uint(C.GDK_KEY_braille_dots_23578) + KEY_braille_dots_123578 = uint(C.GDK_KEY_braille_dots_123578) + KEY_braille_dots_4578 = uint(C.GDK_KEY_braille_dots_4578) + KEY_braille_dots_14578 = uint(C.GDK_KEY_braille_dots_14578) + KEY_braille_dots_24578 = uint(C.GDK_KEY_braille_dots_24578) + KEY_braille_dots_124578 = uint(C.GDK_KEY_braille_dots_124578) + KEY_braille_dots_34578 = uint(C.GDK_KEY_braille_dots_34578) + KEY_braille_dots_134578 = uint(C.GDK_KEY_braille_dots_134578) + KEY_braille_dots_234578 = uint(C.GDK_KEY_braille_dots_234578) + KEY_braille_dots_1234578 = uint(C.GDK_KEY_braille_dots_1234578) + KEY_braille_dots_678 = uint(C.GDK_KEY_braille_dots_678) + KEY_braille_dots_1678 = uint(C.GDK_KEY_braille_dots_1678) + KEY_braille_dots_2678 = uint(C.GDK_KEY_braille_dots_2678) + KEY_braille_dots_12678 = uint(C.GDK_KEY_braille_dots_12678) + KEY_braille_dots_3678 = uint(C.GDK_KEY_braille_dots_3678) + KEY_braille_dots_13678 = uint(C.GDK_KEY_braille_dots_13678) + KEY_braille_dots_23678 = uint(C.GDK_KEY_braille_dots_23678) + KEY_braille_dots_123678 = uint(C.GDK_KEY_braille_dots_123678) + KEY_braille_dots_4678 = uint(C.GDK_KEY_braille_dots_4678) + KEY_braille_dots_14678 = uint(C.GDK_KEY_braille_dots_14678) + KEY_braille_dots_24678 = uint(C.GDK_KEY_braille_dots_24678) + KEY_braille_dots_124678 = uint(C.GDK_KEY_braille_dots_124678) + KEY_braille_dots_34678 = uint(C.GDK_KEY_braille_dots_34678) + KEY_braille_dots_134678 = uint(C.GDK_KEY_braille_dots_134678) + KEY_braille_dots_234678 = uint(C.GDK_KEY_braille_dots_234678) + KEY_braille_dots_1234678 = uint(C.GDK_KEY_braille_dots_1234678) + KEY_braille_dots_5678 = uint(C.GDK_KEY_braille_dots_5678) + KEY_braille_dots_15678 = uint(C.GDK_KEY_braille_dots_15678) + KEY_braille_dots_25678 = uint(C.GDK_KEY_braille_dots_25678) + KEY_braille_dots_125678 = uint(C.GDK_KEY_braille_dots_125678) + KEY_braille_dots_35678 = uint(C.GDK_KEY_braille_dots_35678) + KEY_braille_dots_135678 = uint(C.GDK_KEY_braille_dots_135678) + KEY_braille_dots_235678 = uint(C.GDK_KEY_braille_dots_235678) + KEY_braille_dots_1235678 = uint(C.GDK_KEY_braille_dots_1235678) + KEY_braille_dots_45678 = uint(C.GDK_KEY_braille_dots_45678) + KEY_braille_dots_145678 = uint(C.GDK_KEY_braille_dots_145678) + KEY_braille_dots_245678 = uint(C.GDK_KEY_braille_dots_245678) + KEY_braille_dots_1245678 = uint(C.GDK_KEY_braille_dots_1245678) + KEY_braille_dots_345678 = uint(C.GDK_KEY_braille_dots_345678) + KEY_braille_dots_1345678 = uint(C.GDK_KEY_braille_dots_1345678) + KEY_braille_dots_2345678 = uint(C.GDK_KEY_braille_dots_2345678) + KEY_braille_dots_12345678 = uint(C.GDK_KEY_braille_dots_12345678) + KEY_Sinh_ng = uint(C.GDK_KEY_Sinh_ng) + KEY_Sinh_h2 = uint(C.GDK_KEY_Sinh_h2) + KEY_Sinh_a = uint(C.GDK_KEY_Sinh_a) + KEY_Sinh_aa = uint(C.GDK_KEY_Sinh_aa) + KEY_Sinh_ae = uint(C.GDK_KEY_Sinh_ae) + KEY_Sinh_aee = uint(C.GDK_KEY_Sinh_aee) + KEY_Sinh_i = uint(C.GDK_KEY_Sinh_i) + KEY_Sinh_ii = uint(C.GDK_KEY_Sinh_ii) + KEY_Sinh_u = uint(C.GDK_KEY_Sinh_u) + KEY_Sinh_uu = uint(C.GDK_KEY_Sinh_uu) + KEY_Sinh_ri = uint(C.GDK_KEY_Sinh_ri) + KEY_Sinh_rii = uint(C.GDK_KEY_Sinh_rii) + KEY_Sinh_lu = uint(C.GDK_KEY_Sinh_lu) + KEY_Sinh_luu = uint(C.GDK_KEY_Sinh_luu) + KEY_Sinh_e = uint(C.GDK_KEY_Sinh_e) + KEY_Sinh_ee = uint(C.GDK_KEY_Sinh_ee) + KEY_Sinh_ai = uint(C.GDK_KEY_Sinh_ai) + KEY_Sinh_o = uint(C.GDK_KEY_Sinh_o) + KEY_Sinh_oo = uint(C.GDK_KEY_Sinh_oo) + KEY_Sinh_au = uint(C.GDK_KEY_Sinh_au) + KEY_Sinh_ka = uint(C.GDK_KEY_Sinh_ka) + KEY_Sinh_kha = uint(C.GDK_KEY_Sinh_kha) + KEY_Sinh_ga = uint(C.GDK_KEY_Sinh_ga) + KEY_Sinh_gha = uint(C.GDK_KEY_Sinh_gha) + KEY_Sinh_ng2 = uint(C.GDK_KEY_Sinh_ng2) + KEY_Sinh_nga = uint(C.GDK_KEY_Sinh_nga) + KEY_Sinh_ca = uint(C.GDK_KEY_Sinh_ca) + KEY_Sinh_cha = uint(C.GDK_KEY_Sinh_cha) + KEY_Sinh_ja = uint(C.GDK_KEY_Sinh_ja) + KEY_Sinh_jha = uint(C.GDK_KEY_Sinh_jha) + KEY_Sinh_nya = uint(C.GDK_KEY_Sinh_nya) + KEY_Sinh_jnya = uint(C.GDK_KEY_Sinh_jnya) + KEY_Sinh_nja = uint(C.GDK_KEY_Sinh_nja) + KEY_Sinh_tta = uint(C.GDK_KEY_Sinh_tta) + KEY_Sinh_ttha = uint(C.GDK_KEY_Sinh_ttha) + KEY_Sinh_dda = uint(C.GDK_KEY_Sinh_dda) + KEY_Sinh_ddha = uint(C.GDK_KEY_Sinh_ddha) + KEY_Sinh_nna = uint(C.GDK_KEY_Sinh_nna) + KEY_Sinh_ndda = uint(C.GDK_KEY_Sinh_ndda) + KEY_Sinh_tha = uint(C.GDK_KEY_Sinh_tha) + KEY_Sinh_thha = uint(C.GDK_KEY_Sinh_thha) + KEY_Sinh_dha = uint(C.GDK_KEY_Sinh_dha) + KEY_Sinh_dhha = uint(C.GDK_KEY_Sinh_dhha) + KEY_Sinh_na = uint(C.GDK_KEY_Sinh_na) + KEY_Sinh_ndha = uint(C.GDK_KEY_Sinh_ndha) + KEY_Sinh_pa = uint(C.GDK_KEY_Sinh_pa) + KEY_Sinh_pha = uint(C.GDK_KEY_Sinh_pha) + KEY_Sinh_ba = uint(C.GDK_KEY_Sinh_ba) + KEY_Sinh_bha = uint(C.GDK_KEY_Sinh_bha) + KEY_Sinh_ma = uint(C.GDK_KEY_Sinh_ma) + KEY_Sinh_mba = uint(C.GDK_KEY_Sinh_mba) + KEY_Sinh_ya = uint(C.GDK_KEY_Sinh_ya) + KEY_Sinh_ra = uint(C.GDK_KEY_Sinh_ra) + KEY_Sinh_la = uint(C.GDK_KEY_Sinh_la) + KEY_Sinh_va = uint(C.GDK_KEY_Sinh_va) + KEY_Sinh_sha = uint(C.GDK_KEY_Sinh_sha) + KEY_Sinh_ssha = uint(C.GDK_KEY_Sinh_ssha) + KEY_Sinh_sa = uint(C.GDK_KEY_Sinh_sa) + KEY_Sinh_ha = uint(C.GDK_KEY_Sinh_ha) + KEY_Sinh_lla = uint(C.GDK_KEY_Sinh_lla) + KEY_Sinh_fa = uint(C.GDK_KEY_Sinh_fa) + KEY_Sinh_al = uint(C.GDK_KEY_Sinh_al) + KEY_Sinh_aa2 = uint(C.GDK_KEY_Sinh_aa2) + KEY_Sinh_ae2 = uint(C.GDK_KEY_Sinh_ae2) + KEY_Sinh_aee2 = uint(C.GDK_KEY_Sinh_aee2) + KEY_Sinh_i2 = uint(C.GDK_KEY_Sinh_i2) + KEY_Sinh_ii2 = uint(C.GDK_KEY_Sinh_ii2) + KEY_Sinh_u2 = uint(C.GDK_KEY_Sinh_u2) + KEY_Sinh_uu2 = uint(C.GDK_KEY_Sinh_uu2) + KEY_Sinh_ru2 = uint(C.GDK_KEY_Sinh_ru2) + KEY_Sinh_e2 = uint(C.GDK_KEY_Sinh_e2) + KEY_Sinh_ee2 = uint(C.GDK_KEY_Sinh_ee2) + KEY_Sinh_ai2 = uint(C.GDK_KEY_Sinh_ai2) + KEY_Sinh_o2 = uint(C.GDK_KEY_Sinh_o2) + KEY_Sinh_oo2 = uint(C.GDK_KEY_Sinh_oo2) + KEY_Sinh_au2 = uint(C.GDK_KEY_Sinh_au2) + KEY_Sinh_lu2 = uint(C.GDK_KEY_Sinh_lu2) + KEY_Sinh_ruu2 = uint(C.GDK_KEY_Sinh_ruu2) + KEY_Sinh_luu2 = uint(C.GDK_KEY_Sinh_luu2) + KEY_Sinh_kunddaliya = uint(C.GDK_KEY_Sinh_kunddaliya) + KEY_ModeLock = uint(C.GDK_KEY_ModeLock) + KEY_MonBrightnessUp = uint(C.GDK_KEY_MonBrightnessUp) + KEY_MonBrightnessDown = uint(C.GDK_KEY_MonBrightnessDown) + KEY_KbdLightOnOff = uint(C.GDK_KEY_KbdLightOnOff) + KEY_KbdBrightnessUp = uint(C.GDK_KEY_KbdBrightnessUp) + KEY_KbdBrightnessDown = uint(C.GDK_KEY_KbdBrightnessDown) + KEY_Standby = uint(C.GDK_KEY_Standby) + KEY_AudioLowerVolume = uint(C.GDK_KEY_AudioLowerVolume) + KEY_AudioMute = uint(C.GDK_KEY_AudioMute) + KEY_AudioRaiseVolume = uint(C.GDK_KEY_AudioRaiseVolume) + KEY_AudioPlay = uint(C.GDK_KEY_AudioPlay) + KEY_AudioStop = uint(C.GDK_KEY_AudioStop) + KEY_AudioPrev = uint(C.GDK_KEY_AudioPrev) + KEY_AudioNext = uint(C.GDK_KEY_AudioNext) + KEY_HomePage = uint(C.GDK_KEY_HomePage) + KEY_Mail = uint(C.GDK_KEY_Mail) + KEY_Start = uint(C.GDK_KEY_Start) + KEY_Search = uint(C.GDK_KEY_Search) + KEY_AudioRecord = uint(C.GDK_KEY_AudioRecord) + KEY_Calculator = uint(C.GDK_KEY_Calculator) + KEY_Memo = uint(C.GDK_KEY_Memo) + KEY_ToDoList = uint(C.GDK_KEY_ToDoList) + KEY_Calendar = uint(C.GDK_KEY_Calendar) + KEY_PowerDown = uint(C.GDK_KEY_PowerDown) + KEY_ContrastAdjust = uint(C.GDK_KEY_ContrastAdjust) + KEY_RockerUp = uint(C.GDK_KEY_RockerUp) + KEY_RockerDown = uint(C.GDK_KEY_RockerDown) + KEY_RockerEnter = uint(C.GDK_KEY_RockerEnter) + KEY_Back = uint(C.GDK_KEY_Back) + KEY_Forward = uint(C.GDK_KEY_Forward) + KEY_Stop = uint(C.GDK_KEY_Stop) + KEY_Refresh = uint(C.GDK_KEY_Refresh) + KEY_PowerOff = uint(C.GDK_KEY_PowerOff) + KEY_WakeUp = uint(C.GDK_KEY_WakeUp) + KEY_Eject = uint(C.GDK_KEY_Eject) + KEY_ScreenSaver = uint(C.GDK_KEY_ScreenSaver) + KEY_WWW = uint(C.GDK_KEY_WWW) + KEY_Sleep = uint(C.GDK_KEY_Sleep) + KEY_Favorites = uint(C.GDK_KEY_Favorites) + KEY_AudioPause = uint(C.GDK_KEY_AudioPause) + KEY_AudioMedia = uint(C.GDK_KEY_AudioMedia) + KEY_MyComputer = uint(C.GDK_KEY_MyComputer) + KEY_VendorHome = uint(C.GDK_KEY_VendorHome) + KEY_LightBulb = uint(C.GDK_KEY_LightBulb) + KEY_Shop = uint(C.GDK_KEY_Shop) + KEY_History = uint(C.GDK_KEY_History) + KEY_OpenURL = uint(C.GDK_KEY_OpenURL) + KEY_AddFavorite = uint(C.GDK_KEY_AddFavorite) + KEY_HotLinks = uint(C.GDK_KEY_HotLinks) + KEY_BrightnessAdjust = uint(C.GDK_KEY_BrightnessAdjust) + KEY_Finance = uint(C.GDK_KEY_Finance) + KEY_Community = uint(C.GDK_KEY_Community) + KEY_AudioRewind = uint(C.GDK_KEY_AudioRewind) + KEY_BackForward = uint(C.GDK_KEY_BackForward) + KEY_Launch0 = uint(C.GDK_KEY_Launch0) + KEY_Launch1 = uint(C.GDK_KEY_Launch1) + KEY_Launch2 = uint(C.GDK_KEY_Launch2) + KEY_Launch3 = uint(C.GDK_KEY_Launch3) + KEY_Launch4 = uint(C.GDK_KEY_Launch4) + KEY_Launch5 = uint(C.GDK_KEY_Launch5) + KEY_Launch6 = uint(C.GDK_KEY_Launch6) + KEY_Launch7 = uint(C.GDK_KEY_Launch7) + KEY_Launch8 = uint(C.GDK_KEY_Launch8) + KEY_Launch9 = uint(C.GDK_KEY_Launch9) + KEY_LaunchA = uint(C.GDK_KEY_LaunchA) + KEY_LaunchB = uint(C.GDK_KEY_LaunchB) + KEY_LaunchC = uint(C.GDK_KEY_LaunchC) + KEY_LaunchD = uint(C.GDK_KEY_LaunchD) + KEY_LaunchE = uint(C.GDK_KEY_LaunchE) + KEY_LaunchF = uint(C.GDK_KEY_LaunchF) + KEY_ApplicationLeft = uint(C.GDK_KEY_ApplicationLeft) + KEY_ApplicationRight = uint(C.GDK_KEY_ApplicationRight) + KEY_Book = uint(C.GDK_KEY_Book) + KEY_CD = uint(C.GDK_KEY_CD) + KEY_WindowClear = uint(C.GDK_KEY_WindowClear) + KEY_Close = uint(C.GDK_KEY_Close) + KEY_Copy = uint(C.GDK_KEY_Copy) + KEY_Cut = uint(C.GDK_KEY_Cut) + KEY_Display = uint(C.GDK_KEY_Display) + KEY_DOS = uint(C.GDK_KEY_DOS) + KEY_Documents = uint(C.GDK_KEY_Documents) + KEY_Excel = uint(C.GDK_KEY_Excel) + KEY_Explorer = uint(C.GDK_KEY_Explorer) + KEY_Game = uint(C.GDK_KEY_Game) + KEY_Go = uint(C.GDK_KEY_Go) + KEY_iTouch = uint(C.GDK_KEY_iTouch) + KEY_LogOff = uint(C.GDK_KEY_LogOff) + KEY_Market = uint(C.GDK_KEY_Market) + KEY_Meeting = uint(C.GDK_KEY_Meeting) + KEY_MenuKB = uint(C.GDK_KEY_MenuKB) + KEY_MenuPB = uint(C.GDK_KEY_MenuPB) + KEY_MySites = uint(C.GDK_KEY_MySites) + KEY_New = uint(C.GDK_KEY_New) + KEY_News = uint(C.GDK_KEY_News) + KEY_OfficeHome = uint(C.GDK_KEY_OfficeHome) + KEY_Open = uint(C.GDK_KEY_Open) + KEY_Option = uint(C.GDK_KEY_Option) + KEY_Paste = uint(C.GDK_KEY_Paste) + KEY_Phone = uint(C.GDK_KEY_Phone) + KEY_Reply = uint(C.GDK_KEY_Reply) + KEY_Reload = uint(C.GDK_KEY_Reload) + KEY_RotateWindows = uint(C.GDK_KEY_RotateWindows) + KEY_RotationPB = uint(C.GDK_KEY_RotationPB) + KEY_RotationKB = uint(C.GDK_KEY_RotationKB) + KEY_Save = uint(C.GDK_KEY_Save) + KEY_ScrollUp = uint(C.GDK_KEY_ScrollUp) + KEY_ScrollDown = uint(C.GDK_KEY_ScrollDown) + KEY_ScrollClick = uint(C.GDK_KEY_ScrollClick) + KEY_Send = uint(C.GDK_KEY_Send) + KEY_Spell = uint(C.GDK_KEY_Spell) + KEY_SplitScreen = uint(C.GDK_KEY_SplitScreen) + KEY_Support = uint(C.GDK_KEY_Support) + KEY_TaskPane = uint(C.GDK_KEY_TaskPane) + KEY_Terminal = uint(C.GDK_KEY_Terminal) + KEY_Tools = uint(C.GDK_KEY_Tools) + KEY_Travel = uint(C.GDK_KEY_Travel) + KEY_UserPB = uint(C.GDK_KEY_UserPB) + KEY_User1KB = uint(C.GDK_KEY_User1KB) + KEY_User2KB = uint(C.GDK_KEY_User2KB) + KEY_Video = uint(C.GDK_KEY_Video) + KEY_WheelButton = uint(C.GDK_KEY_WheelButton) + KEY_Word = uint(C.GDK_KEY_Word) + KEY_Xfer = uint(C.GDK_KEY_Xfer) + KEY_ZoomIn = uint(C.GDK_KEY_ZoomIn) + KEY_ZoomOut = uint(C.GDK_KEY_ZoomOut) + KEY_Away = uint(C.GDK_KEY_Away) + KEY_Messenger = uint(C.GDK_KEY_Messenger) + KEY_WebCam = uint(C.GDK_KEY_WebCam) + KEY_MailForward = uint(C.GDK_KEY_MailForward) + KEY_Pictures = uint(C.GDK_KEY_Pictures) + KEY_Music = uint(C.GDK_KEY_Music) + KEY_Battery = uint(C.GDK_KEY_Battery) + KEY_Bluetooth = uint(C.GDK_KEY_Bluetooth) + KEY_WLAN = uint(C.GDK_KEY_WLAN) + KEY_UWB = uint(C.GDK_KEY_UWB) + KEY_AudioForward = uint(C.GDK_KEY_AudioForward) + KEY_AudioRepeat = uint(C.GDK_KEY_AudioRepeat) + KEY_AudioRandomPlay = uint(C.GDK_KEY_AudioRandomPlay) + KEY_Subtitle = uint(C.GDK_KEY_Subtitle) + KEY_AudioCycleTrack = uint(C.GDK_KEY_AudioCycleTrack) + KEY_CycleAngle = uint(C.GDK_KEY_CycleAngle) + KEY_FrameBack = uint(C.GDK_KEY_FrameBack) + KEY_FrameForward = uint(C.GDK_KEY_FrameForward) + KEY_Time = uint(C.GDK_KEY_Time) + KEY_SelectButton = uint(C.GDK_KEY_SelectButton) + KEY_View = uint(C.GDK_KEY_View) + KEY_TopMenu = uint(C.GDK_KEY_TopMenu) + KEY_Red = uint(C.GDK_KEY_Red) + KEY_Green = uint(C.GDK_KEY_Green) + KEY_Yellow = uint(C.GDK_KEY_Yellow) + KEY_Blue = uint(C.GDK_KEY_Blue) + KEY_Suspend = uint(C.GDK_KEY_Suspend) + KEY_Hibernate = uint(C.GDK_KEY_Hibernate) + KEY_TouchpadToggle = uint(C.GDK_KEY_TouchpadToggle) + KEY_TouchpadOn = uint(C.GDK_KEY_TouchpadOn) + KEY_TouchpadOff = uint(C.GDK_KEY_TouchpadOff) + KEY_AudioMicMute = uint(C.GDK_KEY_AudioMicMute) + KEY_Switch_VT_1 = uint(C.GDK_KEY_Switch_VT_1) + KEY_Switch_VT_2 = uint(C.GDK_KEY_Switch_VT_2) + KEY_Switch_VT_3 = uint(C.GDK_KEY_Switch_VT_3) + KEY_Switch_VT_4 = uint(C.GDK_KEY_Switch_VT_4) + KEY_Switch_VT_5 = uint(C.GDK_KEY_Switch_VT_5) + KEY_Switch_VT_6 = uint(C.GDK_KEY_Switch_VT_6) + KEY_Switch_VT_7 = uint(C.GDK_KEY_Switch_VT_7) + KEY_Switch_VT_8 = uint(C.GDK_KEY_Switch_VT_8) + KEY_Switch_VT_9 = uint(C.GDK_KEY_Switch_VT_9) + KEY_Switch_VT_10 = uint(C.GDK_KEY_Switch_VT_10) + KEY_Switch_VT_11 = uint(C.GDK_KEY_Switch_VT_11) + KEY_Switch_VT_12 = uint(C.GDK_KEY_Switch_VT_12) + KEY_Ungrab = uint(C.GDK_KEY_Ungrab) + KEY_ClearGrab = uint(C.GDK_KEY_ClearGrab) + KEY_Next_VMode = uint(C.GDK_KEY_Next_VMode) + KEY_Prev_VMode = uint(C.GDK_KEY_Prev_VMode) + KEY_LogWindowTree = uint(C.GDK_KEY_LogWindowTree) + KEY_LogGrabInfo = uint(C.GDK_KEY_LogGrabInfo) +) diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf.go new file mode 100644 index 0000000..4fc8357 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf.go @@ -0,0 +1,668 @@ +// Same copyright and license as the rest of the files in this project + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +import "C" +import ( + "errors" + "reflect" + "runtime" + "strconv" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.gdk_pixbuf_alpha_mode_get_type()), marshalPixbufAlphaMode}, + + // Objects/Interfaces + {glib.Type(C.gdk_pixbuf_get_type()), marshalPixbuf}, + {glib.Type(C.gdk_pixbuf_animation_get_type()), marshalPixbufAnimation}, + {glib.Type(C.gdk_pixbuf_loader_get_type()), marshalPixbufLoader}, + } + glib.RegisterGValueMarshalers(tm) +} + +/* + * Constants + */ + +// TODO: +// GdkPixbufError + +// PixbufRotation is a representation of GDK's GdkPixbufRotation. +type PixbufRotation int + +const ( + PIXBUF_ROTATE_NONE PixbufRotation = C.GDK_PIXBUF_ROTATE_NONE + PIXBUF_ROTATE_COUNTERCLOCKWISE PixbufRotation = C.GDK_PIXBUF_ROTATE_COUNTERCLOCKWISE + PIXBUF_ROTATE_UPSIDEDOWN PixbufRotation = C.GDK_PIXBUF_ROTATE_UPSIDEDOWN + PIXBUF_ROTATE_CLOCKWISE PixbufRotation = C.GDK_PIXBUF_ROTATE_CLOCKWISE +) + +// PixbufAlphaMode is a representation of GDK's GdkPixbufAlphaMode. +type PixbufAlphaMode int + +const ( + GDK_PIXBUF_ALPHA_BILEVEL PixbufAlphaMode = C.GDK_PIXBUF_ALPHA_BILEVEL + GDK_PIXBUF_ALPHA_FULL PixbufAlphaMode = C.GDK_PIXBUF_ALPHA_FULL +) + +func marshalPixbufAlphaMode(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PixbufAlphaMode(c), nil +} + +/* + * GdkPixbuf + */ + +// PixbufGetType is a wrapper around gdk_pixbuf_get_type(). +func PixbufGetType() glib.Type { + return glib.Type(C.gdk_pixbuf_get_type()) +} + +// Pixbuf is a representation of GDK's GdkPixbuf. +type Pixbuf struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkPixbuf. +func (v *Pixbuf) native() *C.GdkPixbuf { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkPixbuf(p) +} + +// Native returns a pointer to the underlying GdkPixbuf. +func (v *Pixbuf) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *Pixbuf) NativePrivate() *C.GdkPixbuf { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkPixbuf(p) +} + +func marshalPixbuf(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Pixbuf{obj}, nil +} + +// PixbufNew is a wrapper around gdk_pixbuf_new(). +func PixbufNew(colorspace Colorspace, hasAlpha bool, bitsPerSample, width, height int) (*Pixbuf, error) { + c := C.gdk_pixbuf_new(C.GdkColorspace(colorspace), gbool(hasAlpha), + C.int(bitsPerSample), C.int(width), C.int(height)) + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} + +// File Loading + +// PixbufNewFromFile is a wrapper around gdk_pixbuf_new_from_file(). +func PixbufNewFromFile(filename string) (*Pixbuf, error) { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + + var err *C.GError + c := C.gdk_pixbuf_new_from_file((*C.char)(cstr), &err) + if c == nil { + defer C.g_error_free(err) + return nil, errors.New(C.GoString((*C.char)(err.message))) + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} + +// Image Data in Memory + +// PixbufNewFromData is a wrapper around gdk_pixbuf_new_from_data(). +func PixbufNewFromData(pixbufData []byte, cs Colorspace, hasAlpha bool, bitsPerSample, width, height, rowStride int) (*Pixbuf, error) { + arrayPtr := (*C.guchar)(unsafe.Pointer(&pixbufData[0])) + + c := C.gdk_pixbuf_new_from_data( + arrayPtr, + C.GdkColorspace(cs), + gbool(hasAlpha), + C.int(bitsPerSample), + C.int(width), + C.int(height), + C.int(rowStride), + nil, // TODO: missing support for GdkPixbufDestroyNotify + nil, + ) + + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + + return p, nil +} + +// PixbufNewFromDataOnly is a convenient alternative to PixbufNewFromData() and also a wrapper around gdk_pixbuf_new_from_data(). +func PixbufNewFromDataOnly(pixbufData []byte) (*Pixbuf, error) { + pixbufLoader, err := PixbufLoaderNew() + if err == nil { + return nil, err + } + return pixbufLoader.WriteAndReturnPixbuf(pixbufData) +} + +// PixbufNewFromResource is a wrapper around gdk_pixbuf_new_from_resource() +func PixbufNewFromResource(resourcePath string) (*Pixbuf, error) { + var gerr *C.GError + + cstr := C.CString(resourcePath) + defer C.free(unsafe.Pointer(cstr)) + + c := C.gdk_pixbuf_new_from_resource((*C.gchar)(cstr), &gerr) + + if gerr != nil { + defer C.g_error_free(gerr) + return nil, errors.New(C.GoString(gerr.message)) + } + + obj := glib.Take(unsafe.Pointer(c)) + return &Pixbuf{obj}, nil +} + +// PixbufNewFromResourceAtScale is a wrapper around gdk_pixbuf_new_from_resource_at_scale() +func PixbufNewFromResourceAtScale(resourcePath string, width, height int, preserveAspectRatio bool) (*Pixbuf, error) { + var gerr *C.GError + + cstr := C.CString(resourcePath) + defer C.free(unsafe.Pointer(cstr)) + + cPreserveAspectRatio := gbool(preserveAspectRatio) + + c := C.gdk_pixbuf_new_from_resource_at_scale( + (*C.gchar)(cstr), + C.gint(width), + C.gint(height), + C.gboolean(cPreserveAspectRatio), + &gerr, + ) + + if gerr != nil { + defer C.g_error_free(gerr) + return nil, errors.New(C.GoString(gerr.message)) + } + + obj := glib.Take(unsafe.Pointer(c)) + return &Pixbuf{obj}, nil +} + +// TODO: +// gdk_pixbuf_new_from_xpm_data(). +// gdk_pixbuf_new_subpixbuf() + +// PixbufCopy is a wrapper around gdk_pixbuf_copy(). +func PixbufCopy(v *Pixbuf) (*Pixbuf, error) { + c := C.gdk_pixbuf_copy(v.native()) + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} + +// The GdkPixbuf Structure + +// GetColorspace is a wrapper around gdk_pixbuf_get_colorspace(). +func (v *Pixbuf) GetColorspace() Colorspace { + c := C.gdk_pixbuf_get_colorspace(v.native()) + return Colorspace(c) +} + +// GetNChannels is a wrapper around gdk_pixbuf_get_n_channels(). +func (v *Pixbuf) GetNChannels() int { + c := C.gdk_pixbuf_get_n_channels(v.native()) + return int(c) +} + +// GetHasAlpha is a wrapper around gdk_pixbuf_get_has_alpha(). +func (v *Pixbuf) GetHasAlpha() bool { + c := C.gdk_pixbuf_get_has_alpha(v.native()) + return gobool(c) +} + +// GetBitsPerSample is a wrapper around gdk_pixbuf_get_bits_per_sample(). +func (v *Pixbuf) GetBitsPerSample() int { + c := C.gdk_pixbuf_get_bits_per_sample(v.native()) + return int(c) +} + +// GetPixels is a wrapper around gdk_pixbuf_get_pixels_with_length(). +// A Go slice is used to represent the underlying Pixbuf data array, one +// byte per channel. +func (v *Pixbuf) GetPixels() (channels []byte) { + var length C.guint + c := C.gdk_pixbuf_get_pixels_with_length(v.native(), &length) + sliceHeader := (*reflect.SliceHeader)(unsafe.Pointer(&channels)) + sliceHeader.Data = uintptr(unsafe.Pointer(c)) + sliceHeader.Len = int(length) + sliceHeader.Cap = int(length) + + // To make sure the slice doesn't outlive the Pixbuf, add a reference + v.Ref() + runtime.SetFinalizer(&channels, func(_ *[]byte) { + v.Unref() + }) + return +} + +// GetWidth is a wrapper around gdk_pixbuf_get_width(). +func (v *Pixbuf) GetWidth() int { + c := C.gdk_pixbuf_get_width(v.native()) + return int(c) +} + +// GetHeight is a wrapper around gdk_pixbuf_get_height(). +func (v *Pixbuf) GetHeight() int { + c := C.gdk_pixbuf_get_height(v.native()) + return int(c) +} + +// GetRowstride is a wrapper around gdk_pixbuf_get_rowstride(). +func (v *Pixbuf) GetRowstride() int { + c := C.gdk_pixbuf_get_rowstride(v.native()) + return int(c) +} + +// GetOption is a wrapper around gdk_pixbuf_get_option(). ok is true if +// the key has an associated value. +func (v *Pixbuf) GetOption(key string) (value string, ok bool) { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + c := C.gdk_pixbuf_get_option(v.native(), (*C.gchar)(cstr)) + if c == nil { + return "", false + } + return C.GoString((*C.char)(c)), true +} + +// Scaling + +// ScaleSimple is a wrapper around gdk_pixbuf_scale_simple(). +func (v *Pixbuf) ScaleSimple(destWidth, destHeight int, interpType InterpType) (*Pixbuf, error) { + c := C.gdk_pixbuf_scale_simple(v.native(), C.int(destWidth), + C.int(destHeight), C.GdkInterpType(interpType)) + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} + +// Scale is a wrapper around gdk_pixbuf_scale(). +func (v *Pixbuf) Scale(dest *Pixbuf, destX, destY, destWidth, destHeight int, offsetX, offsetY, scaleX, scaleY float64, interpType InterpType) { + C.gdk_pixbuf_scale( + v.native(), + dest.native(), + C.int(destX), + C.int(destY), + C.int(destWidth), + C.int(destHeight), + C.double(offsetX), + C.double(offsetY), + C.double(scaleX), + C.double(scaleY), + C.GdkInterpType(interpType), + ) +} + +// Composite is a wrapper around gdk_pixbuf_composite(). +func (v *Pixbuf) Composite(dest *Pixbuf, destX, destY, destWidth, destHeight int, offsetX, offsetY, scaleX, scaleY float64, interpType InterpType, overallAlpha int) { + C.gdk_pixbuf_composite( + v.native(), + dest.native(), + C.int(destX), + C.int(destY), + C.int(destWidth), + C.int(destHeight), + C.double(offsetX), + C.double(offsetY), + C.double(scaleX), + C.double(scaleY), + C.GdkInterpType(interpType), + C.int(overallAlpha), + ) +} + +// TODO: +// gdk_pixbuf_composite_color_simple(). +// gdk_pixbuf_composite_color(). + +// Utilities + +// TODO: +// gdk_pixbuf_copy_area(). +// gdk_pixbuf_saturate_and_pixelate(). + +// Fill is a wrapper around gdk_pixbuf_fill(). The given pixel is an RGBA value. +func (v *Pixbuf) Fill(pixel uint32) { + C.gdk_pixbuf_fill(v.native(), C.guint32(pixel)) +} + +// AddAlpha is a wrapper around gdk_pixbuf_add_alpha(). If substituteColor is +// true, then the color specified by r, g and b will be assigned zero opacity. +func (v *Pixbuf) AddAlpha(substituteColor bool, r, g, b uint8) *Pixbuf { + c := C.gdk_pixbuf_add_alpha(v.native(), gbool(substituteColor), C.guchar(r), C.guchar(g), C.guchar(b)) + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + + return p +} + +// File saving + +// TODO: +// gdk_pixbuf_savev(). +// gdk_pixbuf_save(). + +// SaveJPEG is a convenience wrapper around gdk_pixbuf_save() for saving image as jpeg file. +// Quality is a number between 0...100 +func (v *Pixbuf) SaveJPEG(path string, quality int) error { + cpath := C.CString(path) + cquality := C.CString(strconv.Itoa(quality)) + defer C.free(unsafe.Pointer(cpath)) + defer C.free(unsafe.Pointer(cquality)) + + var err *C.GError + c := C._gdk_pixbuf_save_jpeg(v.native(), cpath, &err, cquality) + if !gobool(c) { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + + return nil +} + +// SavePNG is a convenience wrapper around gdk_pixbuf_save() for saving image as png file. +// Compression is a number between 0...9 +func (v *Pixbuf) SavePNG(path string, compression int) error { + cpath := C.CString(path) + ccompression := C.CString(strconv.Itoa(compression)) + defer C.free(unsafe.Pointer(cpath)) + defer C.free(unsafe.Pointer(ccompression)) + + var err *C.GError + c := C._gdk_pixbuf_save_png(v.native(), cpath, &err, ccompression) + if !gobool(c) { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +/* + * PixbufFormat + */ + +type PixbufFormat struct { + format *C.GdkPixbufFormat +} + +// native returns a pointer to the underlying GdkPixbuf. +func (v *PixbufFormat) native() *C.GdkPixbufFormat { + if v == nil { + return nil + } + + return v.format +} + +func wrapPixbufFormat(obj *C.GdkPixbufFormat) *PixbufFormat { + return &PixbufFormat{obj} +} + +// Native returns a pointer to the underlying GdkPixbuf. +func (v *PixbufFormat) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +/* + * GdkPixbufAnimation + */ + +// PixbufAnimation is a representation of GDK's GdkPixbufAnimation. +type PixbufAnimation struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkPixbufAnimation. +func (v *PixbufAnimation) native() *C.GdkPixbufAnimation { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkPixbufAnimation(p) +} + +func (v *PixbufAnimation) NativePrivate() *C.GdkPixbufAnimation { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkPixbufAnimation(p) +} + +func (v *PixbufAnimation) GetStaticImage() *Pixbuf { + c := C.gdk_pixbuf_animation_get_static_image(v.native()) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + + // Add a reference so the pixbuf doesn't outlive the parent pixbuf + // animation. + v.Ref() + runtime.SetFinalizer(p, func(*Pixbuf) { v.Unref() }) + + return p +} + +func marshalPixbufAnimation(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &PixbufAnimation{obj}, nil +} + +// PixbufAnimationNewFromFile is a wrapper around gdk_pixbuf_animation_new_from_file(). +func PixbufAnimationNewFromFile(filename string) (*PixbufAnimation, error) { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + + var err *C.GError + c := C.gdk_pixbuf_animation_new_from_file((*C.char)(cstr), &err) + if c == nil { + defer C.g_error_free(err) + return nil, errors.New(C.GoString((*C.char)(err.message))) + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &PixbufAnimation{obj} + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} + +// TODO: +// gdk_pixbuf_animation_new_from_resource(). + +/* + * GdkPixbufLoader + */ + +// PixbufLoader is a representation of GDK's GdkPixbufLoader. +// Users of PixbufLoader are expected to call Close() when they are finished. +type PixbufLoader struct { + *glib.Object +} + +// native() returns a pointer to the underlying GdkPixbufLoader. +func (v *PixbufLoader) native() *C.GdkPixbufLoader { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkPixbufLoader(p) +} + +func marshalPixbufLoader(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &PixbufLoader{obj}, nil +} + +// PixbufLoaderNew() is a wrapper around gdk_pixbuf_loader_new(). +func PixbufLoaderNew() (*PixbufLoader, error) { + c := C.gdk_pixbuf_loader_new() + if c == nil { + return nil, nilPtrErr + } + return &PixbufLoader{glib.AssumeOwnership(unsafe.Pointer(c))}, nil +} + +// PixbufLoaderNewWithType() is a wrapper around gdk_pixbuf_loader_new_with_type(). +func PixbufLoaderNewWithType(t string) (*PixbufLoader, error) { + var err *C.GError + + cstr := C.CString(t) + defer C.free(unsafe.Pointer(cstr)) + + c := C.gdk_pixbuf_loader_new_with_type((*C.char)(cstr), &err) + if err != nil { + defer C.g_error_free(err) + return nil, errors.New(C.GoString((*C.char)(err.message))) + } + + if c == nil { + return nil, nilPtrErr + } + + return &PixbufLoader{glib.AssumeOwnership(unsafe.Pointer(c))}, nil +} + +// Write() is a wrapper around gdk_pixbuf_loader_write(). The +// function signature differs from the C equivalent to satisify the +// io.Writer interface. +func (v *PixbufLoader) Write(data []byte) (int, error) { + // n is set to 0 on error, and set to len(data) otherwise. + // This is a tiny hacky to satisfy io.Writer and io.WriteCloser, + // which would allow access to all io and ioutil goodies, + // and play along nice with go environment. + + if len(data) == 0 { + return 0, nil + } + + var err *C.GError + c := C.gdk_pixbuf_loader_write(v.native(), + (*C.guchar)(unsafe.Pointer(&data[0])), C.gsize(len(data)), + &err) + + if !gobool(c) { + defer C.g_error_free(err) + return 0, errors.New(C.GoString((*C.char)(err.message))) + } + + return len(data), nil +} + +// Convenient function like above for Pixbuf. Write data, close loader and return Pixbuf. +func (v *PixbufLoader) WriteAndReturnPixbuf(data []byte) (*Pixbuf, error) { + _, err := v.Write(data) + if err != nil { + return nil, err + } + + if err := v.Close(); err != nil { + return nil, err + } + + return v.GetPixbuf() +} + +// Close is a wrapper around gdk_pixbuf_loader_close(). An error is +// returned instead of a bool like the native C function to support the +// io.Closer interface. +func (v *PixbufLoader) Close() error { + var err *C.GError + + if ok := gobool(C.gdk_pixbuf_loader_close(v.native(), &err)); !ok { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// GetPixbuf is a wrapper around gdk_pixbuf_loader_get_pixbuf(). +func (v *PixbufLoader) GetPixbuf() (*Pixbuf, error) { + c := C.gdk_pixbuf_loader_get_pixbuf(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &Pixbuf{glib.Take(unsafe.Pointer(c))}, nil +} + +// GetAnimation is a wrapper around gdk_pixbuf_loader_get_animation(). +func (v *PixbufLoader) GetAnimation() (*PixbufAnimation, error) { + c := C.gdk_pixbuf_loader_get_animation(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &PixbufAnimation{glib.Take(unsafe.Pointer(c))}, nil +} + +// Convenient function like above for Pixbuf. Write data, close loader and return PixbufAnimation. +func (v *PixbufLoader) WriteAndReturnPixbufAnimation(data []byte) (*PixbufAnimation, error) { + _, err := v.Write(data) + if err != nil { + return nil, err + } + + if err := v.Close(); err != nil { + return nil, err + } + + return v.GetAnimation() +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf.go.h b/vendor/github.com/gotk3/gotk3/gdk/pixbuf.go.h new file mode 100644 index 0000000..618b34e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf.go.h @@ -0,0 +1,26 @@ +// Same copyright and license as the rest of the files in this project + +#include + +static GdkPixbuf *toGdkPixbuf(void *p) { return (GDK_PIXBUF(p)); } + +static GdkPixbufAnimation *toGdkPixbufAnimation(void *p) { + return (GDK_PIXBUF_ANIMATION(p)); +} +static gboolean + +_gdk_pixbuf_save_png(GdkPixbuf *pixbuf, const char *filename, GError **err, + const char *compression) { + return gdk_pixbuf_save(pixbuf, filename, "png", err, "compression", + compression, NULL); +} + +static gboolean _gdk_pixbuf_save_jpeg(GdkPixbuf *pixbuf, const char *filename, + GError **err, const char *quality) { + return gdk_pixbuf_save(pixbuf, filename, "jpeg", err, "quality", quality, + NULL); +} + +static GdkPixbufLoader *toGdkPixbufLoader(void *p) { + return (GDK_PIXBUF_LOADER(p)); +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_deprecated_since_2_32.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_deprecated_since_2_32.go new file mode 100644 index 0000000..9bed35a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_deprecated_since_2_32.go @@ -0,0 +1,16 @@ +// Same copyright and license as the rest of the files in this project + +//+build gdk_pixbuf_2_2 gdk_pixbuf_2_4 gdk_pixbuf_2_6 gdk_pixbuf_2_8 gdk_pixbuf_2_12 gdk_pixbuf_2_14 gdk_pixbuf_2_24 gdk_pixbuf_2_26 gdk_pixbuf_2_28 gdk_pixbuf_2_30 gdk_pixbuf_deprecated + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +import "C" + +// Image Data in Memory + +// TODO: +// gdk_pixbuf_new_from_inline(). diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_12.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_12.go new file mode 100644 index 0000000..1c67505 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_12.go @@ -0,0 +1,33 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gdk_pixbuf_2_2,!gdk_pixbuf_2_4,!gdk_pixbuf_2_6,!gdk_pixbuf_2_8 + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +import "C" +import ( + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// Utilities + +// ApplyEmbeddedOrientation is a wrapper around gdk_pixbuf_apply_embedded_orientation(). +func (v *Pixbuf) ApplyEmbeddedOrientation() (*Pixbuf, error) { + c := C.gdk_pixbuf_apply_embedded_orientation(v.native()) + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_14.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_14.go new file mode 100644 index 0000000..bd5030d --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_14.go @@ -0,0 +1,23 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gdk_pixbuf_2_2,!gdk_pixbuf_2_4,!gdk_pixbuf_2_6,!gdk_pixbuf_2_8,!gdk_pixbuf_2_12 + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +import "C" + +// File Loading + +// TODO: +// gdk_pixbuf_new_from_stream(). +// gdk_pixbuf_new_from_stream_async(). +// gdk_pixbuf_new_from_stream_at_scale(). + +// File saving + +// TODO: +// gdk_pixbuf_save_to_stream(). diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_2.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_2.go new file mode 100644 index 0000000..8c1a8ea --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_2.go @@ -0,0 +1,97 @@ +// Same copyright and license as the rest of the files in this project + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// The GdkPixbuf Structure + +// TODO: +// gdk_pixbuf_set_option(). + +/* + * GdkPixbufLoader + */ + +// SetSize is a wrapper around gdk_pixbuf_loader_set_size(). +func (v *PixbufLoader) SetSize(width, height int) { + C.gdk_pixbuf_loader_set_size(v.native(), C.int(width), C.int(height)) +} + +/* + * PixbufFormat + */ + +// PixbufGetFormats is a wrapper around gdk_pixbuf_get_formats(). +func PixbufGetFormats() []*PixbufFormat { + l := (*C.struct__GSList)(C.gdk_pixbuf_get_formats()) + formats := glib.WrapSList(uintptr(unsafe.Pointer(l))) + if formats == nil { + return nil // no error. A nil list is considered to be empty. + } + + // "The structures themselves are owned by GdkPixbuf". Free the list only. + defer formats.Free() + + ret := make([]*PixbufFormat, 0, formats.Length()) + formats.Foreach(func(item interface{}) { + ret = append(ret, &PixbufFormat{item.(*C.GdkPixbufFormat)}) + }) + + return ret +} + +// GetName is a wrapper around gdk_pixbuf_format_get_name(). +func (f *PixbufFormat) GetName() (string, error) { + c := C.gdk_pixbuf_format_get_name(f.native()) + return C.GoString((*C.char)(c)), nil +} + +// GetDescription is a wrapper around gdk_pixbuf_format_get_description(). +func (f *PixbufFormat) GetDescription() (string, error) { + c := C.gdk_pixbuf_format_get_description(f.native()) + return C.GoString((*C.char)(c)), nil +} + +// GetMimeTypes is a wrapper around gdk_pixbuf_format_get_mime_types(). +func (f *PixbufFormat) GetMimeTypes() []string { + var types []string + c := C.gdk_pixbuf_format_get_mime_types(f.native()) + if c == nil { + return nil + } + for *c != nil { + types = append(types, C.GoString((*C.char)(*c))) + c = C.next_gcharptr(c) + } + return types +} + +// GetExtensions is a wrapper around gdk_pixbuf_format_get_extensions(). +func (f *PixbufFormat) GetExtensions() []string { + var extensions []string + c := C.gdk_pixbuf_format_get_extensions(f.native()) + if c == nil { + return nil + } + for *c != nil { + extensions = append(extensions, C.GoString((*C.char)(*c))) + c = C.next_gcharptr(c) + } + return extensions +} + +// GetLicense is a wrapper around gdk_pixbuf_format_get_license(). +func (f *PixbufFormat) GetLicense() (string, error) { + c := C.gdk_pixbuf_format_get_license(f.native()) + return C.GoString((*C.char)(c)), nil +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_22.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_22.go new file mode 100644 index 0000000..3446ad0 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_22.go @@ -0,0 +1,18 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gdk_pixbuf_2_2,!gdk_pixbuf_2_4,!gdk_pixbuf_2_6,!gdk_pixbuf_2_8,!gdk_pixbuf_2_12,!gdk_pixbuf_2_14 + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +import "C" + +/* + * PixbufFormat + */ + +// TODO: +// gdk_pixbuf_format_copy(). diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_24.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_24.go new file mode 100644 index 0000000..c94d523 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_24.go @@ -0,0 +1,23 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gdk_pixbuf_2_2,!gdk_pixbuf_2_4,!gdk_pixbuf_2_6,!gdk_pixbuf_2_8,!gdk_pixbuf_2_12,!gdk_pixbuf_2_14,!gdk_pixbuf_2_22 + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +import "C" + +// File Loading + +// TODO: +// gdk_pixbuf_new_from_stream_finish(). +// gdk_pixbuf_new_from_stream_at_scale_async(). + +// File saving + +// TODO: +// gdk_pixbuf_save_to_stream_async(). +// gdk_pixbuf_save_to_stream_finish(). diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_26.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_26.go new file mode 100644 index 0000000..1a17a12 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_26.go @@ -0,0 +1,25 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gdk_pixbuf_2_2,!gdk_pixbuf_2_4,!gdk_pixbuf_2_6,!gdk_pixbuf_2_8,!gdk_pixbuf_2_12,!gdk_pixbuf_2_14,!gdk_pixbuf_2_22,!gdk_pixbuf_2_24 + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +import "C" + +// File Loading + +// TODO: +// gdk_pixbuf_new_from_resource(). +// gdk_pixbuf_new_from_resource_at_scale(). + +// The GdkPixbuf Structure + +// GetByteLength is a wrapper around gdk_pixbuf_get_byte_length(). +func (v *Pixbuf) GetByteLength() int { + c := C.gdk_pixbuf_get_byte_length(v.native()) + return int(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_32.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_32.go new file mode 100644 index 0000000..2fced1f --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_32.go @@ -0,0 +1,68 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gdk_pixbuf_2_2,!gdk_pixbuf_2_4,!gdk_pixbuf_2_6,!gdk_pixbuf_2_8,!gdk_pixbuf_2_12,!gdk_pixbuf_2_14,!gdk_pixbuf_2_22,!gdk_pixbuf_2_24,!gdk_pixbuf_2_26,!gdk_pixbuf_2_28,!gdk_pixbuf_2_30 + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +import "C" +import ( + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// Image Data in Memory + +// PixbufNewFromBytes is a wrapper around gdk_pixbuf_new_from_bytes(). +// see go package "encoding/base64" +func PixbufNewFromBytes(pixbufData []byte, cs Colorspace, hasAlpha bool, bitsPerSample, width, height, rowStride int) (*Pixbuf, error) { + arrayPtr := (*C.GBytes)(unsafe.Pointer(&pixbufData[0])) + + c := C.gdk_pixbuf_new_from_bytes( + arrayPtr, + C.GdkColorspace(cs), + gbool(hasAlpha), + C.int(bitsPerSample), + C.int(width), + C.int(height), + C.int(rowStride), + ) + + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + + return p, nil +} + +// PixbufNewFromBytesOnly is a convenient alternative to PixbufNewFromBytes() and also a wrapper around gdk_pixbuf_new_from_bytes(). +// see go package "encoding/base64" +func PixbufNewFromBytesOnly(pixbufData []byte) (*Pixbuf, error) { + pixbufLoader, err := PixbufLoaderNew() + if err != nil { + return nil, err + } + return pixbufLoader.WriteAndReturnPixbuf(pixbufData) +} + +// File loading + +// TODO: +// gdk_pixbuf_get_file_info_async(). +// gdk_pixbuf_get_file_info_finish(). + +// The GdkPixbuf Structure + +// TODO: +// gdk_pixbuf_get_options(). +// gdk_pixbuf_read_pixels(). diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_36.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_36.go new file mode 100644 index 0000000..d423582 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_36.go @@ -0,0 +1,23 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gdk_pixbuf_2_2,!gdk_pixbuf_2_4,!gdk_pixbuf_2_6,!gdk_pixbuf_2_8,!gdk_pixbuf_2_12,!gdk_pixbuf_2_14,!gdk_pixbuf_2_22,!gdk_pixbuf_2_24,!gdk_pixbuf_2_26,!gdk_pixbuf_2_28,!gdk_pixbuf_2_30,!gdk_pixbuf_2_32 + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +import "C" + +// File saving + +// TODO: +// gdk_pixbuf_save_to_streamv(). +// gdk_pixbuf_save_to_streamv_async(). + +// The GdkPixbuf Structure + +// TODO: +// gdk_pixbuf_remove_option(). +// gdk_pixbuf_copy_options(). diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_4.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_4.go new file mode 100644 index 0000000..b0e90cf --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_4.go @@ -0,0 +1,143 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gdk_pixbuf_2_2 + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 gmodule-2.0 +// #include +// #include +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +// #include "pixbuf_since_2_4.go.h" +import "C" +import ( + "errors" + "io" + "reflect" + "runtime" + "strconv" + "unsafe" + + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/internal/callback" +) + +// File saving + +//export goPixbufSaveCallback +func goPixbufSaveCallback(buf *C.gchar, count C.gsize, gerr **C.GError, id C.gpointer) C.gboolean { + v := callback.Get(uintptr(id)) + + if v == nil { + C._pixbuf_error_set_callback_not_found(gerr) + return C.FALSE + } + + var bytes []byte + header := (*reflect.SliceHeader)((unsafe.Pointer(&bytes))) + header.Cap = int(count) + header.Len = int(count) + header.Data = uintptr(unsafe.Pointer(buf)) + + _, err := v.(io.Writer).Write(bytes) + if err != nil { + cerr := C.CString(err.Error()) + defer C.free(unsafe.Pointer(cerr)) + + C._pixbuf_error_set(gerr, cerr) + return C.FALSE + } + + return C.TRUE +} + +// WritePNG is a convenience wrapper around gdk_pixbuf_save_to_callback() for +// saving images using a streaming callback API. Compression is a number from 0 +// to 9. +func (v *Pixbuf) WritePNG(w io.Writer, compression int) error { + ccompression := C.CString(strconv.Itoa(compression)) + defer C.free(unsafe.Pointer(ccompression)) + + id := callback.Assign(w) + + var err *C.GError + c := C._gdk_pixbuf_save_png_writer(v.native(), C.gpointer(id), &err, ccompression) + + callback.Delete(id) + + if !gobool(c) { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + + return nil +} + +// WriteJPEG is a convenience wrapper around gdk_pixbuf_save_to_callback() for +// saving images using a streaming callback API. Quality is a number from 0 to +// 100. +func (v *Pixbuf) WriteJPEG(w io.Writer, quality int) error { + cquality := C.CString(strconv.Itoa(quality)) + defer C.free(unsafe.Pointer(cquality)) + + id := callback.Assign(w) + + var err *C.GError + c := C._gdk_pixbuf_save_jpeg_writer(v.native(), C.gpointer(id), &err, cquality) + + callback.Delete(id) + + if !gobool(c) { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + + return nil +} + +// TODO: +// GdkPixbufSaveFunc +// gdk_pixbuf_save_to_callback(). +// gdk_pixbuf_save_to_callbackv(). +// gdk_pixbuf_save_to_buffer(). +// gdk_pixbuf_save_to_bufferv(). + +// File Loading + +// PixbufNewFromFileAtSize is a wrapper around gdk_pixbuf_new_from_file_at_size(). +func PixbufNewFromFileAtSize(filename string, width, height int) (*Pixbuf, error) { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + + var err *C.GError = nil + c := C.gdk_pixbuf_new_from_file_at_size(cstr, C.int(width), C.int(height), &err) + if err != nil { + defer C.g_error_free(err) + return nil, errors.New(C.GoString((*C.char)(err.message))) + } + + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} + +// PixbufGetFileInfo is a wrapper around gdk_pixbuf_get_file_info(). +func PixbufGetFileInfo(filename string) (*PixbufFormat, int, int, error) { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + var cw, ch C.gint + format := C.gdk_pixbuf_get_file_info((*C.gchar)(cstr), &cw, &ch) + if format == nil { + return nil, -1, -1, nilPtrErr + } + // The returned PixbufFormat value is owned by Pixbuf and should not be freed. + return wrapPixbufFormat(format), int(cw), int(ch), nil +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_4.go.h b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_4.go.h new file mode 100644 index 0000000..f4f5ee9 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_4.go.h @@ -0,0 +1,34 @@ +// Same copyright and license as the rest of the files in this project + +#include + +extern gboolean goPixbufSaveCallback(gchar *buf, gsize count, GError **error, + gpointer data); + +static inline gboolean _gdk_pixbuf_save_png_writer(GdkPixbuf *pixbuf, + gpointer callback_id, + GError **err, + const char *compression) { + return gdk_pixbuf_save_to_callback( + pixbuf, (GdkPixbufSaveFunc)(goPixbufSaveCallback), callback_id, "png", + err, "compression", compression, NULL); +} + +static inline gboolean _gdk_pixbuf_save_jpeg_writer(GdkPixbuf *pixbuf, + gpointer callback_id, + GError **err, + const char *quality) { + return gdk_pixbuf_save_to_callback( + pixbuf, (GdkPixbufSaveFunc)(goPixbufSaveCallback), callback_id, "jpeg", + err, "quality", quality, NULL); +} + +static inline void _pixbuf_error_set_callback_not_found(GError **err) { + GQuark domain = g_quark_from_static_string("go error"); + g_set_error_literal(err, domain, 1, "pixbuf callback not found"); +} + +static inline void _pixbuf_error_set(GError **err, char *message) { + GQuark domain = g_quark_from_static_string("go error"); + g_set_error_literal(err, domain, 1, message); +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_6.go b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_6.go new file mode 100644 index 0000000..f52ade5 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/pixbuf_since_2_6.go @@ -0,0 +1,74 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gdk_pixbuf_2_2,!gdk_pixbuf_2_4 + +package gdk + +// #cgo pkg-config: gdk-3.0 glib-2.0 gobject-2.0 +// #include +// #include "gdk.go.h" +// #include "pixbuf.go.h" +import "C" +import ( + "errors" + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// File Loading + +// PixbufNewFromFileAtScale is a wrapper around gdk_pixbuf_new_from_file_at_scale(). +func PixbufNewFromFileAtScale(filename string, width, height int, preserveAspectRatio bool) (*Pixbuf, error) { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + + var err *C.GError = nil + c := C.gdk_pixbuf_new_from_file_at_scale(cstr, C.int(width), C.int(height), + gbool(preserveAspectRatio), &err) + if err != nil { + defer C.g_error_free(err) + return nil, errors.New(C.GoString((*C.char)(err.message))) + } + + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} + +// Scaling + +// RotateSimple is a wrapper around gdk_pixbuf_rotate_simple(). +func (v *Pixbuf) RotateSimple(angle PixbufRotation) (*Pixbuf, error) { + c := C.gdk_pixbuf_rotate_simple(v.native(), C.GdkPixbufRotation(angle)) + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} + +// Flip is a wrapper around gdk_pixbuf_flip(). +func (v *Pixbuf) Flip(horizontal bool) (*Pixbuf, error) { + c := C.gdk_pixbuf_flip(v.native(), gbool(horizontal)) + if c == nil { + return nil, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &Pixbuf{obj} + //obj.Ref() + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + return p, nil +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/screen.go b/vendor/github.com/gotk3/gotk3/gdk/screen.go new file mode 100644 index 0000000..858be77 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/screen.go @@ -0,0 +1,114 @@ +package gdk + +// #include +// #include "gdk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +/* + * GdkScreen + */ + +// Screen is a representation of GDK's GdkScreen. +type Screen struct { + *glib.Object +} + +// native returns a pointer to the underlying GdkScreen. +func (v *Screen) native() *C.GdkScreen { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkScreen(p) +} + +// Native returns a pointer to the underlying GdkScreen. +func (v *Screen) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalScreen(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &Screen{obj}, nil +} + +func toScreen(s *C.GdkScreen) (*Screen, error) { + if s == nil { + return nil, nilPtrErr + } + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(s))} + return &Screen{obj}, nil +} + +// GetRGBAVisual is a wrapper around gdk_screen_get_rgba_visual(). +func (v *Screen) GetRGBAVisual() (*Visual, error) { + c := C.gdk_screen_get_rgba_visual(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &Visual{glib.Take(unsafe.Pointer(c))}, nil +} + +// GetSystemVisual is a wrapper around gdk_screen_get_system_visual(). +func (v *Screen) GetSystemVisual() (*Visual, error) { + c := C.gdk_screen_get_system_visual(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return &Visual{glib.Take(unsafe.Pointer(c))}, nil +} + +// ScreenGetDefault is a wrapper around gdk_screen_get_default(). +func ScreenGetDefault() (*Screen, error) { + return toScreen(C.gdk_screen_get_default()) +} + +// IsComposited is a wrapper around gdk_screen_is_composited(). +func (v *Screen) IsComposited() bool { + return gobool(C.gdk_screen_is_composited(v.native())) +} + +// GetRootWindow is a wrapper around gdk_screen_get_root_window(). +func (v *Screen) GetRootWindow() (*Window, error) { + return toWindow(C.gdk_screen_get_root_window(v.native())) +} + +// GetDisplay is a wrapper around gdk_screen_get_display(). +func (v *Screen) GetDisplay() (*Display, error) { + return toDisplay(C.gdk_screen_get_display(v.native())) +} + +func toString(c *C.gchar) (string, error) { + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +// GetResolution is a wrapper around gdk_screen_get_resolution(). +func (v *Screen) GetResolution() float64 { + return float64(C.gdk_screen_get_resolution(v.native())) +} + +// SetResolution is a wrapper around gdk_screen_set_resolution(). +func (v *Screen) SetResolution(r float64) { + C.gdk_screen_set_resolution(v.native(), C.gdouble(r)) +} + +// TODO: +// void gdk_screen_set_font_options () +// gboolean gdk_screen_get_setting () +// const cairo_font_options_t * gdk_screen_get_font_options () +// GList * gdk_screen_get_window_stack () +// GList * gdk_screen_list_visuals () +// GList * gdk_screen_get_toplevel_windows () +// void gdk_screen_get_monitor_geometry () +// void gdk_screen_get_monitor_workarea () diff --git a/vendor/github.com/gotk3/gotk3/gdk/screen_no_x11.go b/vendor/github.com/gotk3/gotk3/gdk/screen_no_x11.go new file mode 100644 index 0000000..9551598 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/screen_no_x11.go @@ -0,0 +1,25 @@ +// +build !linux no_x11 + +package gdk + +func WorkspaceControlSupported() bool { + return false +} + +// GetScreenNumber is a wrapper around gdk_x11_screen_get_screen_number(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Screen) GetScreenNumber() int { + return -1 +} + +// GetNumberOfDesktops is a wrapper around gdk_x11_screen_get_number_of_desktops(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Screen) GetNumberOfDesktops() uint32 { + return 0 +} + +// GetCurrentDesktop is a wrapper around gdk_x11_screen_get_current_desktop(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Screen) GetCurrentDesktop() uint32 { + return 0 +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/screen_x11.go b/vendor/github.com/gotk3/gotk3/gdk/screen_x11.go new file mode 100644 index 0000000..ba17d1a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/screen_x11.go @@ -0,0 +1,30 @@ +// +build linux +// +build !no_x11 + +package gdk + +// #include +// #include +import "C" + +func WorkspaceControlSupported() bool { + return true +} + +// GetScreenNumber is a wrapper around gdk_x11_screen_get_screen_number(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Screen) GetScreenNumber() int { + return int(C.gdk_x11_screen_get_screen_number(v.native())) +} + +// GetNumberOfDesktops is a wrapper around gdk_x11_screen_get_number_of_desktops(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Screen) GetNumberOfDesktops() uint32 { + return uint32(C.gdk_x11_screen_get_number_of_desktops(v.native())) +} + +// GetCurrentDesktop is a wrapper around gdk_x11_screen_get_current_desktop(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Screen) GetCurrentDesktop() uint32 { + return uint32(C.gdk_x11_screen_get_current_desktop(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/testing.go b/vendor/github.com/gotk3/gotk3/gdk/testing.go new file mode 100644 index 0000000..be74a7a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/testing.go @@ -0,0 +1,38 @@ +package gdk + +// #include +import "C" + +// TestRenderSync retrieves a pixel from window to force the windowing system to carry out any pending rendering commands. +// This function is intended to be used to synchronize with rendering pipelines, to benchmark windowing system rendering operations. +// This is a wrapper around gdk_test_render_sync(). +func TestRenderSync(window *Window) { + C.gdk_test_render_sync(window.native()) +} + +// TestSimulateButton simulates a single mouse button event (press or release) at the given coordinates relative to the window. +// Hint: a single click of a button requires this method to be called twice, once for pressed and once for released. +// In most cases, gtk.TestWidgetClick() should be used. +// +// button: Mouse button number, starts with 0 +// modifiers: Keyboard modifiers for the button event +// buttonPressRelease: either GDK_BUTTON_PRESS or GDK_BUTTON_RELEASE +// +// This is a wrapper around gdk_test_simulate_button(). +func TestSimulateButton(window *Window, x, y int, button Button, modifiers ModifierType, buttonPressRelease EventType) bool { + return gobool(C.gdk_test_simulate_button(window.native(), C.gint(x), C.gint(y), C.guint(button), C.GdkModifierType(modifiers), C.GdkEventType(buttonPressRelease))) +} + +// TestSimulateButton simulates a keyboard event (press or release) at the given coordinates relative to the window. +// If the coordinates (-1, -1) are used, the window origin is used instead. +// Hint: a single key press requires this method to be called twice, once for pressed and once for released. +// In most cases, gtk.TestWidgetSendKey() should be used. +// +// keyval: A GDK keyboard value (See KeyvalFromName(), UnicodeToKeyval(), ...) +// modifiers: Keyboard modifiers for the key event +// buttonPressRelease: either GDK_BUTTON_PRESS or GDK_BUTTON_RELEASE +// +// This is a wrapper around gdk_test_simulate_key(). +func TestSimulateKey(window *Window, x, y int, keyval uint, modifiers ModifierType, buttonPressRelease EventType) bool { + return gobool(C.gdk_test_simulate_key(window.native(), C.gint(x), C.gint(y), C.guint(keyval), C.GdkModifierType(modifiers), C.GdkEventType(buttonPressRelease))) +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/window_no_x11.go b/vendor/github.com/gotk3/gotk3/gdk/window_no_x11.go new file mode 100644 index 0000000..72c5665 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/window_no_x11.go @@ -0,0 +1,17 @@ +// +build !linux no_x11 + +package gdk + +func (v *Window) MoveToCurrentDesktop() { +} + +// GetDesktop is a wrapper around gdk_x11_window_get_desktop(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Window) GetDesktop() uint32 { + return 0 +} + +// MoveToDesktop is a wrapper around gdk_x11_window_move_to_desktop(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Window) MoveToDesktop(d uint32) { +} diff --git a/vendor/github.com/gotk3/gotk3/gdk/window_x11.go b/vendor/github.com/gotk3/gotk3/gdk/window_x11.go new file mode 100644 index 0000000..16de7eb --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gdk/window_x11.go @@ -0,0 +1,47 @@ +// +build linux +// +build !no_x11 + +package gdk + +// #include +// #include +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// MoveToCurrentDesktop is a wrapper around gdk_x11_window_move_to_current_desktop(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Window) MoveToCurrentDesktop() { + C.gdk_x11_window_move_to_current_desktop(v.native()) +} + +// GetDesktop is a wrapper around gdk_x11_window_get_desktop(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Window) GetDesktop() uint32 { + return uint32(C.gdk_x11_window_get_desktop(v.native())) +} + +// MoveToDesktop is a wrapper around gdk_x11_window_move_to_desktop(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Window) MoveToDesktop(d uint32) { + C.gdk_x11_window_move_to_desktop(v.native(), C.guint32(d)) +} + +// GetXID is a wrapper around gdk_x11_window_get_xid(). +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Window) GetXID() uint32 { + return uint32(C.gdk_x11_window_get_xid(v.native())) +} + +//ForeignNewForDisplay is a wrapper around gdk_x11_window_foreign_new_for_display() +// It only works on GDK versions compiled with X11 support - its return value can't be used if WorkspaceControlSupported returns false +func (v *Display) ForeignNewForDisplay(xid uint32) (*Window, error) { + c := C.gdk_x11_window_foreign_new_for_display(v.native(), C.Window(xid)) + if c == nil { + return nil, nilPtrErr + } + return &Window{glib.Take(unsafe.Pointer(c))}, nil +} diff --git a/vendor/github.com/gotk3/gotk3/glib/application.go b/vendor/github.com/gotk3/gotk3/glib/application.go new file mode 100644 index 0000000..a60cdb9 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/application.go @@ -0,0 +1,196 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +// Application is a representation of GApplication. +type Application struct { + *Object + + // Interfaces + IActionMap + IActionGroup +} + +// native() returns a pointer to the underlying GApplication. +func (v *Application) native() *C.GApplication { + if v == nil || v.GObject == nil { + return nil + } + return C.toGApplication(unsafe.Pointer(v.GObject)) +} + +func (v *Application) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalApplication(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapApplication(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapApplication(obj *Object) *Application { + am := wrapActionMap(obj) + ag := wrapActionGroup(obj) + return &Application{obj, am, ag} +} + +// ApplicationIDIsValid is a wrapper around g_application_id_is_valid(). +func ApplicationIDIsValid(id string) bool { + cstr1 := (*C.gchar)(C.CString(id)) + defer C.free(unsafe.Pointer(cstr1)) + + return gobool(C.g_application_id_is_valid(cstr1)) +} + +// ApplicationNew is a wrapper around g_application_new(). +func ApplicationNew(appID string, flags ApplicationFlags) *Application { + cstr1 := (*C.gchar)(C.CString(appID)) + defer C.free(unsafe.Pointer(cstr1)) + + c := C.g_application_new(cstr1, C.GApplicationFlags(flags)) + if c == nil { + return nil + } + return wrapApplication(wrapObject(unsafe.Pointer(c))) +} + +// GetApplicationID is a wrapper around g_application_get_application_id(). +func (v *Application) GetApplicationID() string { + c := C.g_application_get_application_id(v.native()) + + return C.GoString((*C.char)(c)) +} + +// SetApplicationID is a wrapper around g_application_set_application_id(). +func (v *Application) SetApplicationID(id string) { + cstr1 := (*C.gchar)(C.CString(id)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_application_set_application_id(v.native(), cstr1) +} + +// GetInactivityTimeout is a wrapper around g_application_get_inactivity_timeout(). +func (v *Application) GetInactivityTimeout() uint { + return uint(C.g_application_get_inactivity_timeout(v.native())) +} + +// SetInactivityTimeout is a wrapper around g_application_set_inactivity_timeout(). +func (v *Application) SetInactivityTimeout(timeout uint) { + C.g_application_set_inactivity_timeout(v.native(), C.guint(timeout)) +} + +// GetFlags is a wrapper around g_application_get_flags(). +func (v *Application) GetFlags() ApplicationFlags { + return ApplicationFlags(C.g_application_get_flags(v.native())) +} + +// SetFlags is a wrapper around g_application_set_flags(). +func (v *Application) SetFlags(flags ApplicationFlags) { + C.g_application_set_flags(v.native(), C.GApplicationFlags(flags)) +} + +// GetDbusObjectPath is a wrapper around g_application_get_dbus_object_path(). +func (v *Application) GetDbusObjectPath() string { + c := C.g_application_get_dbus_object_path(v.native()) + + return C.GoString((*C.char)(c)) +} + +// GetIsRegistered is a wrapper around g_application_get_is_registered(). +func (v *Application) GetIsRegistered() bool { + return gobool(C.g_application_get_is_registered(v.native())) +} + +// GetIsRemote is a wrapper around g_application_get_is_remote(). +func (v *Application) GetIsRemote() bool { + return gobool(C.g_application_get_is_remote(v.native())) +} + +// Hold is a wrapper around g_application_hold(). +func (v *Application) Hold() { + C.g_application_hold(v.native()) +} + +// Release is a wrapper around g_application_release(). +func (v *Application) Release() { + C.g_application_release(v.native()) +} + +// Quit is a wrapper around g_application_quit(). +func (v *Application) Quit() { + C.g_application_quit(v.native()) +} + +// Activate is a wrapper around g_application_activate(). +func (v *Application) Activate() { + C.g_application_activate(v.native()) +} + +// SendNotification is a wrapper around g_application_send_notification(). +func (v *Application) SendNotification(id string, notification *Notification) { + cstr1 := (*C.gchar)(C.CString(id)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_application_send_notification(v.native(), cstr1, notification.native()) +} + +// WithdrawNotification is a wrapper around g_application_withdraw_notification(). +func (v *Application) WithdrawNotification(id string) { + cstr1 := (*C.gchar)(C.CString(id)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_application_withdraw_notification(v.native(), cstr1) +} + +// SetDefault is a wrapper around g_application_set_default(). +func (v *Application) SetDefault() { + C.g_application_set_default(v.native()) +} + +// ApplicationGetDefault is a wrapper around g_application_get_default(). +func ApplicationGetDefault() *Application { + c := C.g_application_get_default() + if c == nil { + return nil + } + return wrapApplication(wrapObject(unsafe.Pointer(c))) +} + +// MarkBusy is a wrapper around g_application_mark_busy(). +func (v *Application) MarkBusy() { + C.g_application_mark_busy(v.native()) +} + +// UnmarkBusy is a wrapper around g_application_unmark_busy(). +func (v *Application) UnmarkBusy() { + C.g_application_unmark_busy(v.native()) +} + +// Run is a wrapper around g_application_run(). +func (v *Application) Run(args []string) int { + cargs := C.make_strings(C.int(len(args))) + defer C.destroy_strings(cargs) + + for i, arg := range args { + cstr := C.CString(arg) + defer C.free(unsafe.Pointer(cstr)) + C.set_string(cargs, C.int(i), (*C.char)(cstr)) + } + + return int(C.g_application_run(v.native(), C.int(len(args)), cargs)) +} + +// void g_application_bind_busy_property () +// void g_application_unbind_busy_property () +// gboolean g_application_register () // requires GCancellable +// void g_application_set_action_group () // Deprecated since 2.32 +// GDBusConnection * g_application_get_dbus_connection () // No support for GDBusConnection +// void g_application_open () // Needs GFile +// void g_application_add_main_option_entries () //Needs GOptionEntry +// void g_application_add_main_option () //Needs GOptionFlags and GOptionArg +// void g_application_add_option_group () // Needs GOptionGroup diff --git a/vendor/github.com/gotk3/gotk3/glib/connect.go b/vendor/github.com/gotk3/gotk3/glib/connect.go new file mode 100644 index 0000000..e89ddb3 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/connect.go @@ -0,0 +1,153 @@ +package glib + +// #include +// #include +// #include "glib.go.h" +import "C" +import ( + "reflect" + "unsafe" + + "github.com/gotk3/gotk3/internal/closure" +) + +/* + * Events + */ + +// SignalHandle is the ID of a signal handler. +type SignalHandle uint + +// Connect is a wrapper around g_signal_connect_closure(). f must be a function +// with at least one parameter matching the type it is connected to. +// +// It is optional to list the rest of the required types from Gtk, as values +// that don't fit into the function parameter will simply be ignored; however, +// extraneous types will trigger a runtime panic. Arguments for f must be a +// matching Go equivalent type for the C callback, or an interface type which +// the value may be packed in. If the type is not suitable, a runtime panic will +// occur when the signal is emitted. +// +// Circular References +// +// To prevent circular references, prefer declaring Connect functions like so: +// +// obj.Connect(func(obj *ObjType) { obj.Do() }) +// +// Instead of directly referencing the object from outside like so: +// +// obj.Connect(func() { obj.Do() }) +// +// When using Connect, beware of referencing variables outside the closure that +// may cause a circular reference that prevents both Go from garbage collecting +// the callback and GTK from successfully unreferencing its values. +// +// Below is an example piece of code that is considered "leaky": +// +// type ChatBox struct { +// gtk.TextView +// Loader *gdk.PixbufLoader +// +// State State +// } +// +// func (box *ChatBox) Method() { +// box.Loader.Connect("size-allocate", func(loader *gdk.PixbufLoader) { +// // Here, we're dereferencing box to get the state, which might +// // keep box alive along with the PixbufLoader, causing a circular +// // reference. +// loader.SetSize(box.State.Width, box.State.Height) +// }) +// } +// +// There are many solutions to fix the above piece of code. For example, +// box.Loader could be discarded manually immediately after it's done by setting +// it to nil, or the signal handle could be disconnected manually, or box could +// be set to nil after its first call in the callback. +func (v *Object) Connect(detailedSignal string, f interface{}) SignalHandle { + return v.connectClosure(false, detailedSignal, f) +} + +// ConnectAfter is a wrapper around g_signal_connect_closure(). The difference +// between Connect and ConnectAfter is that the latter will be invoked after the +// default handler, not before. For more information, refer to Connect. +func (v *Object) ConnectAfter(detailedSignal string, f interface{}) SignalHandle { + return v.connectClosure(true, detailedSignal, f) +} + +// ClosureCheckReceiver, if true, will make GLib check for every single +// closure's first argument to ensure that it is correct, otherwise it will +// panic with a message warning about the possible circular references. The +// receiver in this case is most often the first argument of the callback. +// +// This constant can be changed by using go.mod's replace directive for +// debugging purposes. +const ClosureCheckReceiver = false + +func (v *Object) connectClosure(after bool, detailedSignal string, f interface{}) SignalHandle { + fs := closure.NewFuncStack(f, 2) + + if ClosureCheckReceiver { + // This is a bit slow, but we could be careful. + objValue, err := v.goValue() + if err == nil { + fsType := fs.Func.Type() + if fsType.NumIn() < 1 { + fs.Panicf("callback should have the object receiver to avoid circular references") + } + objType := reflect.TypeOf(objValue) + if first := fsType.In(0); !objType.ConvertibleTo(first) { + fs.Panicf("receiver not convertible to expected type %s, got %s", objType, first) + } + } + + // Allow the type check to fail if we can't get a value marshaler. This + // rarely happens, but it might, and we want to at least allow working + // around it. + } + + cstr := C.CString(detailedSignal) + defer C.free(unsafe.Pointer(cstr)) + + gclosure := ClosureNewFunc(fs) + c := C.g_signal_connect_closure(C.gpointer(v.native()), (*C.gchar)(cstr), gclosure, gbool(after)) + + // TODO: There's a slight race condition here, where + // g_signal_connect_closure may trigger signal callbacks before the signal + // is registered. It is therefore ideal to have another intermediate ID to + // pass into the connect function. This is not a big issue though, since + // there isn't really any guarantee that signals should arrive until after + // the Connect functions return successfully. + closure.RegisterSignal(uint(c), unsafe.Pointer(gclosure)) + + return SignalHandle(c) +} + +// ClosureNew creates a new GClosure and adds its callback function to the +// internal registry. It's exported for visibility to other gotk3 packages and +// should not be used in a regular application. +func ClosureNew(f interface{}) *C.GClosure { + return ClosureNewFunc(closure.NewFuncStack(f, 2)) +} + +// ClosureNewFunc creates a new GClosure and adds its callback function to the +// internal registry. It's exported for visibility to other gotk3 packages; it +// cannot be used in application code, as package closure is part of the +// internals. +func ClosureNewFunc(funcStack closure.FuncStack) *C.GClosure { + gclosure := C._g_closure_new() + C._g_closure_add_finalize_notifier(gclosure) + closure.Assign(unsafe.Pointer(gclosure), funcStack) + + return gclosure +} + +// removeClosure removes a closure from the internal closures map. This is +// needed to prevent a leak where Go code can access the closure context +// (along with rf and userdata) even after an object has been destroyed and +// the GClosure is invalidated and will never run. +// +//export removeClosure +func removeClosure(_ C.gpointer, gclosure *C.GClosure) { + closure.Delete(unsafe.Pointer(gclosure)) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gaction.go b/vendor/github.com/gotk3/gotk3/glib/gaction.go new file mode 100644 index 0000000..7fcfdcf --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gaction.go @@ -0,0 +1,227 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import ( + "unsafe" +) + +func init() { + tm := []TypeMarshaler{ + // Objects/Interfaces + {Type(C.g_simple_action_get_type()), marshalSimpleAction}, + {Type(C.g_action_get_type()), marshalAction}, + {Type(C.g_property_action_get_type()), marshalPropertyAction}, + } + RegisterGValueMarshalers(tm) +} + +// Action is a representation of glib's GAction GInterface. +type Action struct { + *Object +} + +// IAction is an interface type implemented by all structs +// embedding an Action. It is meant to be used as an argument type +// for wrapper functions that wrap around a C function taking a +// GAction. +type IAction interface { + toGAction() *C.GAction + toAction() *Action +} + +func (v *Action) toGAction() *C.GAction { + if v == nil { + return nil + } + return v.native() +} + +func (v *Action) toAction() *Action { + return v +} + +// gboolean g_action_parse_detailed_name (const gchar *detailed_name, gchar **action_name, GVariant **target_value, GError **error); + +// ActionPrintDetailedName is a wrapper around g_action_print_detailed_name(). +func ActionPrintDetailedName(action_name string, target_value *Variant) string { + cstr := C.CString(action_name) + defer C.free(unsafe.Pointer(cstr)) + return C.GoString((*C.char)(C.g_action_print_detailed_name((*C.gchar)(cstr), target_value.native()))) +} + +// native() returns a pointer to the underlying GAction. +func (v *Action) native() *C.GAction { + if v == nil || v.GObject == nil { + return nil + } + return C.toGAction(unsafe.Pointer(v.GObject)) +} + +func (v *Action) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalAction(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapAction(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapAction(obj *Object) *Action { + return &Action{obj} +} + +// ActionNameIsValid is a wrapper around g_action_name_is_valid +func ActionNameIsValid(actionName string) bool { + cstr := (*C.gchar)(C.CString(actionName)) + return gobool(C.g_action_name_is_valid(cstr)) +} + +// GetName is a wrapper around g_action_get_name +func (v *Action) GetName() string { + return C.GoString((*C.char)(C.g_action_get_name(v.native()))) +} + +// GetEnabled is a wrapper around g_action_get_enabled +func (v *Action) GetEnabled() bool { + return gobool(C.g_action_get_enabled(v.native())) +} + +// GetState is a wrapper around g_action_get_state +func (v *Action) GetState() *Variant { + c := C.g_action_get_state(v.native()) + if c == nil { + return nil + } + return newVariant((*C.GVariant)(c)) +} + +// GetStateHint is a wrapper around g_action_get_state_hint +func (v *Action) GetStateHint() *Variant { + c := C.g_action_get_state_hint(v.native()) + if c == nil { + return nil + } + return newVariant((*C.GVariant)(c)) +} + +// GetParameterType is a wrapper around g_action_get_parameter_type +func (v *Action) GetParameterType() *VariantType { + c := C.g_action_get_parameter_type(v.native()) + if c == nil { + return nil + } + return newVariantType((*C.GVariantType)(c)) +} + +// GetStateType is a wrapper around g_action_get_state_type +func (v *Action) GetStateType() *VariantType { + c := C.g_action_get_state_type(v.native()) + if c == nil { + return nil + } + return newVariantType((*C.GVariantType)(c)) +} + +// ChangeState is a wrapper around g_action_change_state +func (v *Action) ChangeState(value *Variant) { + C.g_action_change_state(v.native(), value.native()) +} + +// Activate is a wrapper around g_action_activate +func (v *Action) Activate(parameter *Variant) { + C.g_action_activate(v.native(), parameter.native()) +} + +// SimpleAction is a representation of GSimpleAction +type SimpleAction struct { + Action +} + +func (v *SimpleAction) native() *C.GSimpleAction { + if v == nil || v.GObject == nil { + return nil + } + return C.toGSimpleAction(unsafe.Pointer(v.GObject)) +} + +func (v *SimpleAction) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalSimpleAction(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapSimpleAction(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapSimpleAction(obj *Object) *SimpleAction { + return &SimpleAction{Action{obj}} +} + +// SimpleActionNew is a wrapper around g_simple_action_new +func SimpleActionNew(name string, parameterType *VariantType) *SimpleAction { + c := C.g_simple_action_new((*C.gchar)(C.CString(name)), parameterType.native()) + if c == nil { + return nil + } + return wrapSimpleAction(wrapObject(unsafe.Pointer(c))) +} + +// SimpleActionNewStateful is a wrapper around g_simple_action_new_stateful +func SimpleActionNewStateful(name string, parameterType *VariantType, state *Variant) *SimpleAction { + c := C.g_simple_action_new_stateful((*C.gchar)(C.CString(name)), parameterType.native(), state.native()) + if c == nil { + return nil + } + return wrapSimpleAction(wrapObject(unsafe.Pointer(c))) +} + +// SetEnabled is a wrapper around g_simple_action_set_enabled +func (v *SimpleAction) SetEnabled(enabled bool) { + C.g_simple_action_set_enabled(v.native(), gbool(enabled)) +} + +// SetState is a wrapper around g_simple_action_set_state +// This should only be called by the implementor of the action. +// Users of the action should not attempt to directly modify the 'state' property. +// Instead, they should call ChangeState [g_action_change_state()] to request the change. +func (v *SimpleAction) SetState(value *Variant) { + C.g_simple_action_set_state(v.native(), value.native()) +} + +// PropertyAction is a representation of GPropertyAction +type PropertyAction struct { + Action +} + +func (v *PropertyAction) native() *C.GPropertyAction { + if v == nil || v.GObject == nil { + return nil + } + return C.toGPropertyAction(unsafe.Pointer(v.GObject)) +} + +func (v *PropertyAction) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalPropertyAction(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapPropertyAction(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapPropertyAction(obj *Object) *PropertyAction { + return &PropertyAction{Action{obj}} +} + +// PropertyActionNew is a wrapper around g_property_action_new +func PropertyActionNew(name string, object *Object, propertyName string) *PropertyAction { + c := C.g_property_action_new((*C.gchar)(C.CString(name)), C.gpointer(unsafe.Pointer(object.native())), (*C.gchar)(C.CString(propertyName))) + if c == nil { + return nil + } + return wrapPropertyAction(wrapObject(unsafe.Pointer(c))) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gactiongroup.go b/vendor/github.com/gotk3/gotk3/glib/gactiongroup.go new file mode 100644 index 0000000..4c1c654 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gactiongroup.go @@ -0,0 +1,113 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +// IActionGroup is an interface representation of ActionGroup, +// used to avoid duplication when embedding the type in a wrapper of another GObject-based type. +type IActionGroup interface { + Native() uintptr + + HasAction(actionName string) bool + GetActionEnabled(actionName string) bool + GetActionParameterType(actionName string) *VariantType + GetActionStateType(actionName string) *VariantType + GetActionState(actionName string) *Variant + GetActionStateHint(actionName string) *Variant + ChangeActionState(actionName string, value *Variant) + Activate(actionName string, parameter *Variant) +} + +// ActionGroup is a representation of glib's GActionGroup GInterface +type ActionGroup struct { + *Object +} + +// g_action_group_list_actions() +// g_action_group_query_action() +// should only called from implementations: +// g_action_group_action_added +// g_action_group_action_removed +// g_action_group_action_enabled_changed +// g_action_group_action_state_changed + +// native() returns a pointer to the underlying GActionGroup. +func (v *ActionGroup) native() *C.GActionGroup { + if v == nil || v.GObject == nil { + return nil + } + return C.toGActionGroup(unsafe.Pointer(v.GObject)) +} + +func (v *ActionGroup) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalActionGroup(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapActionGroup(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapActionGroup(obj *Object) *ActionGroup { + return &ActionGroup{obj} +} + +// HasAction is a wrapper around g_action_group_has_action(). +func (v *ActionGroup) HasAction(actionName string) bool { + return gobool(C.g_action_group_has_action(v.native(), (*C.gchar)(C.CString(actionName)))) +} + +// GetActionEnabled is a wrapper around g_action_group_get_action_enabled(). +func (v *ActionGroup) GetActionEnabled(actionName string) bool { + return gobool(C.g_action_group_get_action_enabled(v.native(), (*C.gchar)(C.CString(actionName)))) +} + +// GetActionParameterType is a wrapper around g_action_group_get_action_parameter_type(). +func (v *ActionGroup) GetActionParameterType(actionName string) *VariantType { + c := C.g_action_group_get_action_parameter_type(v.native(), (*C.gchar)(C.CString(actionName))) + if c == nil { + return nil + } + return newVariantType((*C.GVariantType)(c)) +} + +// GetActionStateType is a wrapper around g_action_group_get_action_state_type(). +func (v *ActionGroup) GetActionStateType(actionName string) *VariantType { + c := C.g_action_group_get_action_state_type(v.native(), (*C.gchar)(C.CString(actionName))) + if c == nil { + return nil + } + return newVariantType((*C.GVariantType)(c)) +} + +// GetActionState is a wrapper around g_action_group_get_action_state(). +func (v *ActionGroup) GetActionState(actionName string) *Variant { + c := C.g_action_group_get_action_state(v.native(), (*C.gchar)(C.CString(actionName))) + if c == nil { + return nil + } + return newVariant((*C.GVariant)(c)) +} + +// GetActionStateHint is a wrapper around g_action_group_get_action_state_hint(). +func (v *ActionGroup) GetActionStateHint(actionName string) *Variant { + c := C.g_action_group_get_action_state_hint(v.native(), (*C.gchar)(C.CString(actionName))) + if c == nil { + return nil + } + return newVariant((*C.GVariant)(c)) +} + +// ChangeActionState is a wrapper around g_action_group_change_action_state +func (v *ActionGroup) ChangeActionState(actionName string, value *Variant) { + C.g_action_group_change_action_state(v.native(), (*C.gchar)(C.CString(actionName)), value.native()) +} + +// Activate is a wrapper around g_action_group_activate_action +func (v *ActionGroup) Activate(actionName string, parameter *Variant) { + C.g_action_group_activate_action(v.native(), (*C.gchar)(C.CString(actionName)), parameter.native()) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gactionmap.go b/vendor/github.com/gotk3/gotk3/glib/gactionmap.go new file mode 100644 index 0000000..f5b8998 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gactionmap.go @@ -0,0 +1,66 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +// IActionMap is an interface representation of ActionMap, +// used to avoid duplication when embedding the type in a wrapper of another GObject-based type. +type IActionMap interface { + Native() uintptr + + LookupAction(actionName string) *Action + AddAction(action IAction) + RemoveAction(actionName string) +} + +// ActionMap is a representation of glib's GActionMap GInterface +type ActionMap struct { + *Object +} + +// void g_action_map_add_action_entries (GActionMap *action_map, const GActionEntry *entries, gint n_entries, gpointer user_data); +// struct GActionEntry + +// native() returns a pointer to the underlying GActionMap. +func (v *ActionMap) native() *C.GActionMap { + if v == nil || v.GObject == nil { + return nil + } + return C.toGActionMap(unsafe.Pointer(v.GObject)) +} + +func (v *ActionMap) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalActionMap(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapActionMap(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapActionMap(obj *Object) *ActionMap { + return &ActionMap{obj} +} + +// LookupAction is a wrapper around g_action_map_lookup_action +func (v *ActionMap) LookupAction(actionName string) *Action { + c := C.g_action_map_lookup_action(v.native(), (*C.gchar)(C.CString(actionName))) + if c == nil { + return nil + } + return wrapAction(wrapObject(unsafe.Pointer(c))) +} + +// AddAction is a wrapper around g_action_map_add_action +func (v *ActionMap) AddAction(action IAction) { + C.g_action_map_add_action(v.native(), action.toGAction()) +} + +// RemoveAction is a wrapper around g_action_map_remove_action +func (v *ActionMap) RemoveAction(actionName string) { + C.g_action_map_remove_action(v.native(), (*C.gchar)(C.CString(actionName))) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gasyncresult.go b/vendor/github.com/gotk3/gotk3/glib/gasyncresult.go new file mode 100644 index 0000000..e3826f0 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gasyncresult.go @@ -0,0 +1,73 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import ( + "errors" + "unsafe" +) + +// IAsyncResult is an interface representation of AsyncResult, +// used to avoid duplication when embedding the type in a wrapper of another GObject-based type. +type IAsyncResult interface { + GetUserData() uintptr + GetSourceObject() *Object + IsTagged(sourceTag uintptr) bool + LegacyPropagateError() error +} + +// AsyncReadyCallback is a representation of GAsyncReadyCallback +type AsyncReadyCallback func(object *Object, res *AsyncResult) + +// AsyncResult is a representation of GIO's GAsyncResult. +type AsyncResult struct { + *Object +} + +// native() returns a pointer to the underlying GAsyncResult. +func (v *AsyncResult) native() *C.GAsyncResult { + if v == nil || v.GObject == nil { + return nil + } + return C.toGAsyncResult(unsafe.Pointer(v.GObject)) +} + +func wrapAsyncResult(obj *Object) *AsyncResult { + return &AsyncResult{obj} +} + +// GetUserData is a wrapper around g_async_result_get_user_data() +func (v *AsyncResult) GetUserData() uintptr { + c := C.g_async_result_get_user_data(v.native()) + return uintptr(unsafe.Pointer(c)) +} + +// GetSourceObject is a wrapper around g_async_result_get_source_object +func (v *AsyncResult) GetSourceObject() *Object { + obj := C.g_async_result_get_source_object(v.native()) + if obj == nil { + return nil + } + return wrapObject(unsafe.Pointer(obj)) +} + +// IsTagged is a wrapper around g_async_result_is_tagged +func (v *AsyncResult) IsTagged(sourceTag uintptr) bool { + c := C.g_async_result_is_tagged(v.native(), C.gpointer(sourceTag)) + return gobool(c) +} + +// LegacyPropagateError is a wrapper around g_async_result_legacy_propagate_error +func (v *AsyncResult) LegacyPropagateError() error { + var err *C.GError + c := C.g_async_result_legacy_propagate_error(v.native(), &err) + isSimpleAsyncResult := gobool(c) + if isSimpleAsyncResult { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gbinding.go b/vendor/github.com/gotk3/gotk3/glib/gbinding.go new file mode 100644 index 0000000..133ce12 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gbinding.go @@ -0,0 +1,98 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +type BindingFlags int + +const ( + BINDING_DEFAULT BindingFlags = C.G_BINDING_DEFAULT + BINDING_BIDIRECTIONAL BindingFlags = C.G_BINDING_BIDIRECTIONAL + BINDING_SYNC_CREATE = C.G_BINDING_SYNC_CREATE + BINDING_INVERT_BOOLEAN = C.G_BINDING_INVERT_BOOLEAN +) + +type Binding struct { + *Object +} + +func (v *Binding) native() *C.GBinding { + if v == nil || v.GObject == nil { + return nil + } + return C.toGBinding(unsafe.Pointer(v.GObject)) +} + +func marshalBinding(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return &Binding{wrapObject(unsafe.Pointer(c))}, nil +} + +// Creates a binding between source property on source and target property on +// target . Whenever the source property is changed the target_property is +// updated using the same value. +func BindProperty(source *Object, sourceProperty string, + target *Object, targetProperty string, + flags BindingFlags) *Binding { + srcStr := (*C.gchar)(C.CString(sourceProperty)) + defer C.free(unsafe.Pointer(srcStr)) + tgtStr := (*C.gchar)(C.CString(targetProperty)) + defer C.free(unsafe.Pointer(tgtStr)) + obj := C.g_object_bind_property( + C.gpointer(source.GObject), srcStr, + C.gpointer(target.GObject), tgtStr, + C.GBindingFlags(flags), + ) + if obj == nil { + return nil + } + return &Binding{wrapObject(unsafe.Pointer(obj))} +} + +// Explicitly releases the binding between the source and the target property +// expressed by Binding +func (v *Binding) Unbind() { + C.g_binding_unbind(v.native()) +} + +// Retrieves the GObject instance used as the source of the binding +func (v *Binding) GetSource() *Object { + obj := C.g_binding_get_source(v.native()) + if obj == nil { + return nil + } + return wrapObject(unsafe.Pointer(obj)) +} + +// Retrieves the name of the property of “source” used as the source of +// the binding. +func (v *Binding) GetSourceProperty() string { + s := C.g_binding_get_source_property(v.native()) + return C.GoString((*C.char)(s)) +} + +// Retrieves the GObject instance used as the target of the binding. +func (v *Binding) GetTarget() *Object { + obj := C.g_binding_get_target(v.native()) + if obj == nil { + return nil + } + return wrapObject(unsafe.Pointer(obj)) +} + +// Retrieves the name of the property of “target” used as the target of +// the binding. +func (v *Binding) GetTargetProperty() string { + s := C.g_binding_get_target_property(v.native()) + return C.GoString((*C.char)(s)) +} + +// Retrieves the flags passed when constructing the GBinding. +func (v *Binding) GetFlags() BindingFlags { + flags := C.g_binding_get_flags(v.native()) + return BindingFlags(flags) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gcancellable.go b/vendor/github.com/gotk3/gotk3/glib/gcancellable.go new file mode 100644 index 0000000..097df4f --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gcancellable.go @@ -0,0 +1,83 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import ( + "errors" + "unsafe" +) + +// Cancellable is a representation of GIO's GCancellable. +type Cancellable struct { + *Object +} + +// native returns a pointer to the underlying GCancellable. +func (v *Cancellable) native() *C.GCancellable { + if v == nil || v.GObject == nil { + return nil + } + return C.toCancellable(unsafe.Pointer(v.GObject)) +} + +func marshalCancellable(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapCancellable(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapCancellable(obj *Object) *Cancellable { + return &Cancellable{obj} +} + +// CancellableNew is a wrapper around g_cancellable_new(). +func CancellableNew() (*Cancellable, error) { + c := C.g_cancellable_new() + if c == nil { + return nil, nilPtrErr + } + return wrapCancellable(wrapObject(unsafe.Pointer(c))), nil +} + +// IsCancelled is a wrapper around g_cancellable_is_cancelled(). +func (v *Cancellable) IsCancelled() bool { + c := C.g_cancellable_is_cancelled(v.native()) + return gobool(c) +} + +// SetErrorIfCancelled is a wrapper around g_cancellable_set_error_if_cancelled(). +func (v *Cancellable) SetErrorIfCancelled() error { + var err *C.GError + c := C.g_cancellable_set_error_if_cancelled(v.native(), &err) + cancelled := gobool(c) + if cancelled { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// GetFD is a wrapper around g_cancellable_get_fd(). +func (v *Cancellable) GetFD() int { + c := C.g_cancellable_get_fd(v.native()) + return int(c) +} + +// MakePollFD is a wrapper around g_cancellable_make_pollfd(). +// func (v *Cancellable) MakePollFD(pollFD *PollFD) bool { +// c := C.g_cancellable_make_pollfd(v.native(), ) +// return gobool(c) +// } + +// ReleaseFD is a wrapper around g_cancellable_release_fd(). +func (v *Cancellable) ReleaseFD() { + C.g_cancellable_release_fd(v.native()) +} + +// SourceNew is a wrapper around g_cancellable_source_new(). +func (v *Cancellable) SourceNew() *Source { + c := C.g_cancellable_source_new(v.native()) + return wrapSource(c) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gfile.go b/vendor/github.com/gotk3/gotk3/glib/gfile.go new file mode 100644 index 0000000..8b68ba3 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gfile.go @@ -0,0 +1,367 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +// #include "gfile.go.h" +import "C" +import ( + "errors" + "unsafe" +) + +func init() { + + tm := []TypeMarshaler{ + {Type(C.g_file_get_type()), marshalFile}, + {Type(C.g_file_input_stream_get_type()), marshalFileInputStream}, + {Type(C.g_file_output_stream_get_type()), marshalFileOutputStream}, + } + + RegisterGValueMarshalers(tm) +} + +func goString(cstr *C.gchar) string { + return C.GoString((*C.char)(cstr)) +} + +/* + * GFile + */ + +// File is a representation of GIO's GFile. +type File struct { + *Object +} + +// native returns a pointer to the underlying GFile. +func (v *File) native() *C.GFile { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGFile(p) +} + +// NativePrivate: to be used inside Gotk3 only. +func (v *File) NativePrivate() *C.GFile { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGFile(p) +} + +// Native returns a pointer to the underlying GFile. +func (v *File) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalFile(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := Take(unsafe.Pointer(c)) + return wrapFile(obj), nil +} + +func wrapFile(obj *Object) *File { + return &File{obj} +} + +// FileNew is a wrapper around g_file_new_for_path(). +// To avoid breaking previous implementation of GFile ... +func FileNew(path string) *File { + f, e := FileNewForPath(path) + if e != nil { + return nil + } + return f +} + +// FileNewForPath is a wrapper around g_file_new_for_path(). +func FileNewForPath(path string) (*File, error) { + cstr := (*C.char)(C.CString(path)) + defer C.free(unsafe.Pointer(cstr)) + + c := C.g_file_new_for_path(cstr) + if c == nil { + return nil, nilPtrErr + } + return wrapFile(Take(unsafe.Pointer(c))), nil +} + +// TODO g_file_*** and more +/* +void (*GFileProgressCallback) () +gboolean (*GFileReadMoreCallback) () +void (*GFileMeasureProgressCallback) () +GFile * g_file_new_for_uri () +GFile * g_file_new_for_commandline_arg () +GFile * g_file_new_for_commandline_arg_and_cwd () +GFile * g_file_new_tmp () +GFile * g_file_parse_name () +GFile * g_file_new_build_filename () +GFile * g_file_dup () +guint g_file_hash () +gboolean g_file_equal () +char * g_file_get_basename () +*/ + +/* +char * +g_file_get_path (GFile *file); +*/ +// GetPath is a wrapper around g_file_get_path(). +func (v *File) GetPath() string { + var s string + if c := C.g_file_get_path(v.native()); c != nil { + s = C.GoString(c) + defer C.g_free((C.gpointer)(c)) + } + + return s +} + +/* +const char * g_file_peek_path () +char * g_file_get_uri () +char * g_file_get_parse_name () +GFile * g_file_get_parent () +gboolean g_file_has_parent () +GFile * g_file_get_child () +GFile * g_file_get_child_for_display_name () +gboolean g_file_has_prefix () +char * g_file_get_relative_path () +GFile * g_file_resolve_relative_path () +gboolean g_file_is_native () +gboolean g_file_has_uri_scheme () +char * g_file_get_uri_scheme () +*/ + +/* +GFileInputStream * +g_file_read (GFile *file, + GCancellable *cancellable, + GError **error); +*/ +// Read is a wrapper around g_file_read(). +// Object.Unref() must be used after use +func (v *File) Read(cancellable *Cancellable) (*FileInputStream, error) { + var gerr *C.GError + c := C.g_file_read( + v.native(), + cancellable.native(), + &gerr) + if c == nil { + defer C.g_error_free(gerr) + return nil, errors.New(goString(gerr.message)) + } + return wrapFileInputStream(Take(unsafe.Pointer(c))), nil +} + +/* +void g_file_read_async () +GFileInputStream * g_file_read_finish () +GFileOutputStream * g_file_append_to () +GFileOutputStream * g_file_create () +GFileOutputStream * g_file_replace () +void g_file_append_to_async () +GFileOutputStream * g_file_append_to_finish () +void g_file_create_async () +GFileOutputStream * g_file_create_finish () +void g_file_replace_async () +GFileOutputStream * g_file_replace_finish () +GFileInfo * g_file_query_info () +void g_file_query_info_async () +GFileInfo * g_file_query_info_finish () +gboolean g_file_query_exists () +GFileType g_file_query_file_type () +GFileInfo * g_file_query_filesystem_info () +void g_file_query_filesystem_info_async () +GFileInfo * g_file_query_filesystem_info_finish () +GAppInfo * g_file_query_default_handler () +void g_file_query_default_handler_async () +GAppInfo * g_file_query_default_handler_finish () +gboolean g_file_measure_disk_usage () +void g_file_measure_disk_usage_async () +gboolean g_file_measure_disk_usage_finish () +GMount * g_file_find_enclosing_mount () +void g_file_find_enclosing_mount_async () +GMount * g_file_find_enclosing_mount_finish () +GFileEnumerator * g_file_enumerate_children () +void g_file_enumerate_children_async () +GFileEnumerator * g_file_enumerate_children_finish () +GFile * g_file_set_display_name () +void g_file_set_display_name_async () +GFile * g_file_set_display_name_finish () +gboolean g_file_delete () +void g_file_delete_async () +gboolean g_file_delete_finish () +gboolean g_file_trash () +void g_file_trash_async () +gboolean g_file_trash_finish () +gboolean g_file_copy () +void g_file_copy_async () +gboolean g_file_copy_finish () +gboolean g_file_move () +gboolean g_file_make_directory () +void g_file_make_directory_async () +gboolean g_file_make_directory_finish () +gboolean g_file_make_directory_with_parents () +gboolean g_file_make_symbolic_link () +GFileAttributeInfoList * g_file_query_settable_attributes () +GFileAttributeInfoList * g_file_query_writable_namespaces () +gboolean g_file_set_attribute () +gboolean g_file_set_attributes_from_info () +void g_file_set_attributes_async () +gboolean g_file_set_attributes_finish () +gboolean g_file_set_attribute_string () +gboolean g_file_set_attribute_byte_string () +gboolean g_file_set_attribute_uint32 () +gboolean g_file_set_attribute_int32 () +gboolean g_file_set_attribute_uint64 () +gboolean g_file_set_attribute_int64 () +void g_file_mount_mountable () +GFile * g_file_mount_mountable_finish () +void g_file_unmount_mountable () +gboolean g_file_unmount_mountable_finish () +void g_file_unmount_mountable_with_operation () +gboolean g_file_unmount_mountable_with_operation_finish () +void g_file_eject_mountable () +gboolean g_file_eject_mountable_finish () +void g_file_eject_mountable_with_operation () +gboolean g_file_eject_mountable_with_operation_finish () +void g_file_start_mountable () +gboolean g_file_start_mountable_finish () +void g_file_stop_mountable () +gboolean g_file_stop_mountable_finish () +void g_file_poll_mountable () +gboolean g_file_poll_mountable_finish () +void g_file_mount_enclosing_volume () +gboolean g_file_mount_enclosing_volume_finish () +GFileMonitor * g_file_monitor_directory () +GFileMonitor * g_file_monitor_file () +GFileMonitor * g_file_monitor () +GBytes * g_file_load_bytes () +void g_file_load_bytes_async () +GBytes * g_file_load_bytes_finish () +gboolean g_file_load_contents () +void g_file_load_contents_async () +gboolean g_file_load_contents_finish () +void g_file_load_partial_contents_async () +gboolean g_file_load_partial_contents_finish () +gboolean g_file_replace_contents () +void g_file_replace_contents_async () +void g_file_replace_contents_bytes_async () +gboolean g_file_replace_contents_finish () +gboolean g_file_copy_attributes () +GFileIOStream * g_file_create_readwrite () +void g_file_create_readwrite_async () +GFileIOStream * g_file_create_readwrite_finish () +GFileIOStream * g_file_open_readwrite () +void g_file_open_readwrite_async () +GFileIOStream * g_file_open_readwrite_finish () +GFileIOStream * g_file_replace_readwrite () +void g_file_replace_readwrite_async () +GFileIOStream * g_file_replace_readwrite_finish () +gboolean g_file_supports_thread_contexts () +*/ + +/* + * GFileInputStream + */ + +// FileInputStream is a representation of GIO's GFileInputStream. +type FileInputStream struct { + *InputStream +} + +// native returns a pointer to the underlying GFileInputStream. +func (v *FileInputStream) native() *C.GFileInputStream { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGFileInputStream(p) +} + +// NativePrivate: to be used inside Gotk3 only. +func (v *FileInputStream) NativePrivate() *C.GFileInputStream { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGFileInputStream(p) +} + +// Native returns a pointer to the underlying GFileInputStream. +func (v *FileInputStream) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalFileInputStream(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := Take(unsafe.Pointer(c)) + return wrapFileInputStream(obj), nil +} + +func wrapFileInputStream(obj *Object) *FileInputStream { + return &FileInputStream{wrapInputStream(obj)} +} + +// TODO g_file_input_stream_query_info and more +/* +GFileInfo * g_file_input_stream_query_info () +void g_file_input_stream_query_info_async () +GFileInfo * g_file_input_stream_query_info_finish () +*/ + +/* + * GFileOutputStream + */ + +// FileOutputStream is a representation of GIO's GFileOutputStream. +type FileOutputStream struct { + *OutputStream +} + +// native returns a pointer to the underlying GFileOutputStream. +func (v *FileOutputStream) native() *C.GFileOutputStream { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGFileOutputStream(p) +} + +// NativePrivate: to be used inside Gotk3 only. +func (v *FileOutputStream) NativePrivate() *C.GFileOutputStream { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGFileOutputStream(p) +} + +// Native returns a pointer to the underlying GFileOutputStream. +func (v *FileOutputStream) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalFileOutputStream(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := Take(unsafe.Pointer(c)) + return wrapFileOutputStream(obj), nil +} + +func wrapFileOutputStream(obj *Object) *FileOutputStream { + return &FileOutputStream{wrapOutputStream(obj)} +} + +// TODO g_file_output_stream_query_info and more +/* +GFileInfo * g_file_output_stream_query_info () +void g_file_output_stream_query_info_async () +GFileInfo * g_file_output_stream_query_info_finish () +char * g_file_output_stream_get_etag () +*/ diff --git a/vendor/github.com/gotk3/gotk3/glib/gfile.go.h b/vendor/github.com/gotk3/gotk3/glib/gfile.go.h new file mode 100644 index 0000000..8892344 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gfile.go.h @@ -0,0 +1,13 @@ +#include +#include +#include + +#include + +static GFileInputStream *toGFileInputStream(void *p) { + return (G_FILE_INPUT_STREAM(p)); +} + +static GFileOutputStream *toGFileOutputStream(void *p) { + return (G_FILE_OUTPUT_STREAM(p)); +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gicon.go b/vendor/github.com/gotk3/gotk3/glib/gicon.go new file mode 100644 index 0000000..0f178af --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gicon.go @@ -0,0 +1,177 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import ( + "errors" + "runtime" + "unsafe" +) + +func init() { + + tm := []TypeMarshaler{ + {Type(C.g_file_get_type()), marshalFile}, + {Type(C.g_file_icon_get_type()), marshalFileIcon}, + } + + RegisterGValueMarshalers(tm) +} + +/* + * GIcon + */ + +// Icon is a representation of GIO's GIcon. +// Interface for icons +type Icon struct { + *Object +} + +// native returns a pointer to the underlying GIcon. +func (v *Icon) native() *C.GIcon { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGIcon(p) +} + +// NativePrivate: to be used inside Gotk3 only. +func (v *Icon) NativePrivate() *C.GIcon { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGIcon(p) +} + +// Native returns a pointer to the underlying GIcon. +func (v *Icon) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalIcon(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := Take(unsafe.Pointer(c)) + return wrapIcon(obj), nil +} + +func wrapIcon(obj *Object) *Icon { + return &Icon{obj} +} + +// TODO I dont know how to handle it ... +/* +guint +g_icon_hash (gconstpointer icon); +*/ + +// Equal is a wrapper around g_icon_equal(). +func (v *Icon) Equal(icon *Icon) bool { + return gobool(C.g_icon_equal(v.native(), icon.native())) +} + +// ToString is a wrapper around g_icon_to_string(). +func (v *Icon) ToString() string { + var s string + if c := C.g_icon_to_string(v.native()); c != nil { + s = goString(c) + defer C.g_free((C.gpointer)(c)) + } + + return s +} + +// IconNewForString is a wrapper around g_icon_new_for_string(). +func IconNewForString(str string) (*Icon, error) { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + + var err *C.GError + c := C.g_icon_new_for_string((*C.gchar)(cstr), &err) + if c == nil { + defer C.g_error_free(err) + return nil, errors.New(C.GoString((*C.char)(err.message))) + } + + obj := &Object{ToGObject(unsafe.Pointer(c))} + i := &Icon{obj} + + runtime.SetFinalizer(i, func(_ interface{}) { obj.Unref() }) + return i, nil +} + +// TODO Requiere GVariant +/* +GVariant * g_icon_serialize () +GIcon * g_icon_deserialize () +*/ + +/* + * GFileIcon + */ + +// FileIcon is a representation of GIO's GFileIcon. +type FileIcon struct { + *Object +} + +// native returns a pointer to the underlying GFileIcon. +func (v *FileIcon) native() *C.GFileIcon { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGFileIcon(p) +} + +// NativePrivate: to be used inside Gotk3 only. +func (v *FileIcon) NativePrivate() *C.GFileIcon { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGFileIcon(p) +} + +// Native returns a pointer to the underlying GFileIcon. +func (v *FileIcon) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalFileIcon(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := Take(unsafe.Pointer(c)) + return wrapFileIcon(obj), nil +} + +func wrapFileIcon(obj *Object) *FileIcon { + return &FileIcon{obj} +} + +// FileIconNewN is a wrapper around g_file_icon_new(). +// This version respect Gtk3 documentation. +func FileIconNewN(file *File) (*Icon, error) { + + c := C.g_file_icon_new(file.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapIcon(Take(unsafe.Pointer(c))), nil +} + +// FileIconNew is a wrapper around g_file_icon_new(). +// To not break previous implementation of GFileIcon ... +func FileIconNew(path string) *Icon { + file := FileNew(path) + + c := C.g_file_icon_new(file.native()) + if c == nil { + return nil + } + return wrapIcon(Take(unsafe.Pointer(c))) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/giostream.go b/vendor/github.com/gotk3/gotk3/glib/giostream.go new file mode 100644 index 0000000..f91e5a6 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/giostream.go @@ -0,0 +1,437 @@ +package glib + +// #cgo pkg-config: gio-2.0 glib-2.0 gobject-2.0 +// #include +// #include +// #include "giostream.go.h" +import "C" +import ( + "bytes" + "errors" + "unsafe" +) + +func init() { + + tm := []TypeMarshaler{ + {Type(C.g_io_stream_get_type()), marshalIOStream}, + {Type(C.g_output_stream_get_type()), marshalOutputStream}, + {Type(C.g_input_stream_get_type()), marshalInputStream}, + } + + RegisterGValueMarshalers(tm) +} + +// OutputStreamSpliceFlags is a representation of GTK's GOutputStreamSpliceFlags. +type OutputStreamSpliceFlags int + +const ( + OUTPUT_STREAM_SPLICE_NONE OutputStreamSpliceFlags = C.G_OUTPUT_STREAM_SPLICE_NONE + OUTPUT_STREAM_SPLICE_CLOSE_SOURCE = C.G_OUTPUT_STREAM_SPLICE_CLOSE_SOURCE + OUTPUT_STREAM_SPLICE_CLOSE_TARGET = C.G_OUTPUT_STREAM_SPLICE_CLOSE_TARGET +) + +/* + * GIOStream + */ + +// IOStream is a representation of GIO's GIOStream. +// Base class for implementing read/write streams +type IOStream struct { + *Object +} + +// native returns a pointer to the underlying GIOStream. +func (v *IOStream) native() *C.GIOStream { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGIOStream(p) +} + +// NativePrivate: to be used inside Gotk3 only. +func (v *IOStream) NativePrivate() *C.GIOStream { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGIOStream(p) +} + +// Native returns a pointer to the underlying GIOStream. +func (v *IOStream) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalIOStream(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := Take(unsafe.Pointer(c)) + return wrapIOStream(obj), nil +} + +func wrapIOStream(obj *Object) *IOStream { + return &IOStream{obj} +} + +/* +GInputStream * g_io_stream_get_input_stream () +GOutputStream * g_io_stream_get_output_stream () +void g_io_stream_splice_async () +gboolean g_io_stream_splice_finish () +*/ + +// Close is a wrapper around g_io_stream_close(). +func (v *IOStream) Close(cancellable *Cancellable) (bool, error) { + var gerr *C.GError + ok := gobool(C.g_io_stream_close( + v.native(), + cancellable.native(), + &gerr)) + if !ok { + defer C.g_error_free(gerr) + return false, errors.New(goString(gerr.message)) + } + return ok, nil +} + +/* +void g_io_stream_close_async () +gboolean g_io_stream_close_finish () +gboolean g_io_stream_is_closed () +gboolean g_io_stream_has_pending () +gboolean g_io_stream_set_pending () +void g_io_stream_clear_pending () +*/ + +/* + * GInputStream + */ + +// InputStream is a representation of GIO's GInputStream. +// Base class for implementing streaming input +type InputStream struct { + *Object +} + +// native returns a pointer to the underlying GInputStream. +func (v *InputStream) native() *C.GInputStream { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGInputStream(p) +} + +// NativePrivate: to be used inside Gotk3 only. +func (v *InputStream) NativePrivate() *C.GInputStream { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGInputStream(p) +} + +// Native returns a pointer to the underlying GInputStream. +func (v *InputStream) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalInputStream(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := Take(unsafe.Pointer(c)) + return wrapInputStream(obj), nil +} + +func wrapInputStream(obj *Object) *InputStream { + return &InputStream{obj} +} + +// Read is a wrapper around g_input_stream_read(). +func (v *InputStream) Read(length uint, cancellable *Cancellable) (*bytes.Buffer, int, error) { + var gerr *C.GError + var buffer = bytes.NewBuffer(make([]byte, length)) + + c := C.g_input_stream_read( + v.native(), + unsafe.Pointer(&buffer.Bytes()[0]), + C.gsize(length), + cancellable.native(), + &gerr) + if c == -1 { + defer C.g_error_free(gerr) + return nil, -1, errors.New(goString(gerr.message)) + } + return buffer, int(c), nil +} + +// TODO find a way to get size to be read without asking for ... +/* +gboolean +g_input_stream_read_all (GInputStream *stream, + void *buffer, + gsize count, + gsize *bytes_read, + GCancellable *cancellable, + GError **error); +*/ + +/* +void g_input_stream_read_all_async () +gboolean g_input_stream_read_all_finish () +gssize g_input_stream_skip () +*/ + +// Close is a wrapper around g_input_stream_close(). +func (v *InputStream) Close(cancellable *Cancellable) (bool, error) { + var gerr *C.GError + ok := gobool(C.g_input_stream_close( + v.native(), + cancellable.native(), + &gerr)) + if !ok { + defer C.g_error_free(gerr) + return false, errors.New(goString(gerr.message)) + } + return ok, nil +} + +// TODO g_input_stream*** +/* +void g_input_stream_read_async () +gssize g_input_stream_read_finish () +void g_input_stream_skip_async () +gssize g_input_stream_skip_finish () +void g_input_stream_close_async () +gboolean g_input_stream_close_finish () +*/ + +// IsClosed is a wrapper around g_input_stream_is_closed(). +func (v *InputStream) IsClosed() bool { + return gobool(C.g_input_stream_is_closed(v.native())) +} + +// HasPending is a wrapper around g_input_stream_has_pending(). +func (v *InputStream) HasPending() bool { + return gobool(C.g_input_stream_has_pending(v.native())) +} + +// SetPending is a wrapper around g_input_stream_set_pending(). +func (v *InputStream) SetPending() (bool, error) { + var gerr *C.GError + ok := gobool(C.g_input_stream_set_pending( + v.native(), + &gerr)) + if !ok { + defer C.g_error_free(gerr) + return false, errors.New(goString(gerr.message)) + } + return ok, nil +} + +// ClearPending is a wrapper around g_input_stream_clear_pending(). +func (v *InputStream) ClearPending() { + C.g_input_stream_clear_pending(v.native()) +} + +/* Useless functions due to Go language specification and actual + implementation of (*InputStream).Read that do same thing. + +GBytes * g_input_stream_read_bytes () +void g_input_stream_read_bytes_async () +GBytes * g_input_stream_read_bytes_finish () +*/ + +/* + * GOutputStream + */ + +// OutputStream is a representation of GIO's GOutputStream. +// Base class for implementing streaming output +type OutputStream struct { + *Object +} + +// native returns a pointer to the underlying GOutputStream. +func (v *OutputStream) native() *C.GOutputStream { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGOutputStream(p) +} + +// NativePrivate: to be used inside Gotk3 only. +func (v *OutputStream) NativePrivate() *C.GOutputStream { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGOutputStream(p) +} + +// Native returns a pointer to the underlying GOutputStream. +func (v *OutputStream) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalOutputStream(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := Take(unsafe.Pointer(c)) + return wrapOutputStream(obj), nil +} + +func wrapOutputStream(obj *Object) *OutputStream { + return &OutputStream{obj} +} + +/* +gssize +g_output_stream_write (GOutputStream *stream, + const void *buffer, + gsize count, + GCancellable *cancellable, + GError **error); +*/ + +// Write is a wrapper around g_output_stream_write(). +// buffer := bytes.NewBuffer(make([]byte, length)) +func (v *OutputStream) Write(buffer *bytes.Buffer, cancellable *Cancellable) (int, error) { + var gerr *C.GError + length := buffer.Len() + + c := C.g_output_stream_write( + v.native(), + unsafe.Pointer(&buffer.Bytes()[0]), + C.gsize(length), + cancellable.native(), + &gerr) + if c == -1 { + defer C.g_error_free(gerr) + return -1, errors.New(goString(gerr.message)) + } + return int(c), nil +} + +// Write is a wrapper around g_output_stream_write(). +// func (v *OutputStream) Write(buffer *[]byte, cancellable *Cancellable) (int, error) { +// // cdata := C.CString(data) +// // defer C.free(unsafe.Pointer(cdata)) +// var gerr *C.GError +// c := C.g_output_stream_write( +// v.native(), +// unsafe.Pointer(buffer), +// C.gsize(len(*buffer)), +// cancellable.native(), +// &gerr) +// if c == -1 { +// defer C.g_error_free(gerr) +// return 0, errors.New(goString(gerr.message)) +// } +// return int(c), nil +// } + +/* +gboolean g_output_stream_write_all () +*/ + +// TODO outputStream asynch functions +/* +void g_output_stream_write_all_async () +gboolean g_output_stream_write_all_finish () +gboolean g_output_stream_writev () +gboolean g_output_stream_writev_all () +void g_output_stream_writev_async () +gboolean g_output_stream_writev_finish () +void g_output_stream_writev_all_async () +gboolean g_output_stream_writev_all_finish () +*/ +/* +gssize +g_output_stream_splice (GOutputStream *stream, + GInputStream *source, + GOutputStreamSpliceFlags flags, + GCancellable *cancellable, + GError **error); +*/ + +// Flush is a wrapper around g_output_stream_flush(). +func (v *OutputStream) Flush(cancellable *Cancellable) (bool, error) { + var gerr *C.GError + ok := gobool(C.g_output_stream_flush( + v.native(), + cancellable.native(), + &gerr)) + if !ok { + defer C.g_error_free(gerr) + return false, errors.New(goString(gerr.message)) + } + return ok, nil +} + +// Close is a wrapper around g_output_stream_close(). +func (v *OutputStream) Close(cancellable *Cancellable) (bool, error) { + var gerr *C.GError + ok := gobool(C.g_output_stream_close( + v.native(), + cancellable.native(), + &gerr)) + if !ok { + defer C.g_error_free(gerr) + return false, errors.New(goString(gerr.message)) + } + return ok, nil +} + +// TODO outputStream asynch functions +/* +void g_output_stream_write_async () +gssize g_output_stream_write_finish () +void g_output_stream_splice_async () +gssize g_output_stream_splice_finish () +void g_output_stream_flush_async () +gboolean g_output_stream_flush_finish () +void g_output_stream_close_async () +gboolean g_output_stream_close_finish () +*/ + +// IsClosing is a wrapper around g_output_stream_is_closing(). +func (v *OutputStream) IsClosing() bool { + return gobool(C.g_output_stream_is_closing(v.native())) +} + +// IsClosed is a wrapper around g_output_stream_is_closed(). +func (v *OutputStream) IsClosed() bool { + return gobool(C.g_output_stream_is_closed(v.native())) +} + +// HasPending is a wrapper around g_output_stream_has_pending(). +func (v *OutputStream) HasPending() bool { + return gobool(C.g_output_stream_has_pending(v.native())) +} + +// SetPending is a wrapper around g_output_stream_set_pending(). +func (v *OutputStream) SetPending() (bool, error) { + var gerr *C.GError + ok := gobool(C.g_output_stream_set_pending( + v.native(), + &gerr)) + if !ok { + defer C.g_error_free(gerr) + return false, errors.New(goString(gerr.message)) + } + return ok, nil +} + +// ClearPending is a wrapper around g_output_stream_clear_pending(). +func (v *OutputStream) ClearPending() { + C.g_output_stream_clear_pending(v.native()) +} + +/* +gssize g_output_stream_write_bytes () +void g_output_stream_write_bytes_async () +gssize g_output_stream_write_bytes_finish () +gboolean g_output_stream_printf () +gboolean g_output_stream_vprintf () +*/ diff --git a/vendor/github.com/gotk3/gotk3/glib/giostream.go.h b/vendor/github.com/gotk3/gotk3/glib/giostream.go.h new file mode 100644 index 0000000..44eba09 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/giostream.go.h @@ -0,0 +1,14 @@ +#pragma once + +#include +#include +#include +#include +#include +#include + +static GIOStream *toGIOStream(void *p) { return (G_IO_STREAM(p)); } + +static GInputStream *toGInputStream(void *p) { return (G_INPUT_STREAM(p)); } + +static GOutputStream *toGOutputStream(void *p) { return (G_OUTPUT_STREAM(p)); } diff --git a/vendor/github.com/gotk3/gotk3/glib/glib.go b/vendor/github.com/gotk3/gotk3/glib/glib.go new file mode 100644 index 0000000..b862b05 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glib.go @@ -0,0 +1,1403 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// Package glib provides Go bindings for GLib 2. It supports version 2.36 and +// later. +package glib + +// #cgo pkg-config: gio-2.0 glib-2.0 gobject-2.0 +// #include +// #include +// #include +// #include "glib.go.h" +import "C" + +import ( + "errors" + "fmt" + "reflect" + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/internal/closure" +) + +/* + * Type conversions + */ + +func gbool(b bool) C.gboolean { + if b { + return C.gboolean(1) + } + return C.gboolean(0) +} + +func gobool(b C.gboolean) bool { + if b != 0 { + return true + } + return false +} + +/* + * Unexported vars + */ + +var nilPtrErr = errors.New("cgo returned unexpected nil pointer") + +/* + * Constants + */ + +// Type is a representation of GLib's GType. +type Type uint + +const ( + TYPE_INVALID Type = C.G_TYPE_INVALID + TYPE_NONE Type = C.G_TYPE_NONE + TYPE_INTERFACE Type = C.G_TYPE_INTERFACE + TYPE_CHAR Type = C.G_TYPE_CHAR + TYPE_UCHAR Type = C.G_TYPE_UCHAR + TYPE_BOOLEAN Type = C.G_TYPE_BOOLEAN + TYPE_INT Type = C.G_TYPE_INT + TYPE_UINT Type = C.G_TYPE_UINT + TYPE_LONG Type = C.G_TYPE_LONG + TYPE_ULONG Type = C.G_TYPE_ULONG + TYPE_INT64 Type = C.G_TYPE_INT64 + TYPE_UINT64 Type = C.G_TYPE_UINT64 + TYPE_ENUM Type = C.G_TYPE_ENUM + TYPE_FLAGS Type = C.G_TYPE_FLAGS + TYPE_FLOAT Type = C.G_TYPE_FLOAT + TYPE_DOUBLE Type = C.G_TYPE_DOUBLE + TYPE_STRING Type = C.G_TYPE_STRING + TYPE_POINTER Type = C.G_TYPE_POINTER + TYPE_BOXED Type = C.G_TYPE_BOXED + TYPE_PARAM Type = C.G_TYPE_PARAM + TYPE_OBJECT Type = C.G_TYPE_OBJECT + TYPE_VARIANT Type = C.G_TYPE_VARIANT +) + +// IsValue checks whether the passed in type can be used for g_value_init(). +func (t Type) IsValue() bool { + return gobool(C._g_type_is_value(C.GType(t))) +} + +// Name is a wrapper around g_type_name(). +func (t Type) Name() string { + return C.GoString((*C.char)(C.g_type_name(C.GType(t)))) +} + +// Depth is a wrapper around g_type_depth(). +func (t Type) Depth() uint { + return uint(C.g_type_depth(C.GType(t))) +} + +// Parent is a wrapper around g_type_parent(). +func (t Type) Parent() Type { + return Type(C.g_type_parent(C.GType(t))) +} + +// IsA is a wrapper around g_type_is_a(). +func (t Type) IsA(isAType Type) bool { + return gobool(C.g_type_is_a(C.GType(t), C.GType(isAType))) +} + +// TypeFromName is a wrapper around g_type_from_name +func TypeFromName(typeName string) Type { + cstr := (*C.gchar)(C.CString(typeName)) + defer C.free(unsafe.Pointer(cstr)) + return Type(C.g_type_from_name(cstr)) +} + +//TypeNextBase is a wrapper around g_type_next_base +func TypeNextBase(leafType, rootType Type) Type { + return Type(C.g_type_next_base(C.GType(leafType), C.GType(rootType))) +} + +// SettingsBindFlags is a representation of GLib's GSettingsBindFlags. +type SettingsBindFlags int + +const ( + SETTINGS_BIND_DEFAULT SettingsBindFlags = C.G_SETTINGS_BIND_DEFAULT + SETTINGS_BIND_GET SettingsBindFlags = C.G_SETTINGS_BIND_GET + SETTINGS_BIND_SET SettingsBindFlags = C.G_SETTINGS_BIND_SET + SETTINGS_BIND_NO_SENSITIVITY SettingsBindFlags = C.G_SETTINGS_BIND_NO_SENSITIVITY + SETTINGS_BIND_GET_NO_CHANGES SettingsBindFlags = C.G_SETTINGS_BIND_GET_NO_CHANGES + SETTINGS_BIND_INVERT_BOOLEAN SettingsBindFlags = C.G_SETTINGS_BIND_INVERT_BOOLEAN +) + +// UserDirectory is a representation of GLib's GUserDirectory. +type UserDirectory int + +const ( + USER_DIRECTORY_DESKTOP UserDirectory = C.G_USER_DIRECTORY_DESKTOP + USER_DIRECTORY_DOCUMENTS UserDirectory = C.G_USER_DIRECTORY_DOCUMENTS + USER_DIRECTORY_DOWNLOAD UserDirectory = C.G_USER_DIRECTORY_DOWNLOAD + USER_DIRECTORY_MUSIC UserDirectory = C.G_USER_DIRECTORY_MUSIC + USER_DIRECTORY_PICTURES UserDirectory = C.G_USER_DIRECTORY_PICTURES + USER_DIRECTORY_PUBLIC_SHARE UserDirectory = C.G_USER_DIRECTORY_PUBLIC_SHARE + USER_DIRECTORY_TEMPLATES UserDirectory = C.G_USER_DIRECTORY_TEMPLATES + USER_DIRECTORY_VIDEOS UserDirectory = C.G_USER_DIRECTORY_VIDEOS +) + +const USER_N_DIRECTORIES int = C.G_USER_N_DIRECTORIES + +/* + * GApplicationFlags + */ + +type ApplicationFlags int + +const ( + APPLICATION_FLAGS_NONE ApplicationFlags = C.G_APPLICATION_FLAGS_NONE + APPLICATION_IS_SERVICE ApplicationFlags = C.G_APPLICATION_IS_SERVICE + APPLICATION_HANDLES_OPEN ApplicationFlags = C.G_APPLICATION_HANDLES_OPEN + APPLICATION_HANDLES_COMMAND_LINE ApplicationFlags = C.G_APPLICATION_HANDLES_COMMAND_LINE + APPLICATION_SEND_ENVIRONMENT ApplicationFlags = C.G_APPLICATION_SEND_ENVIRONMENT + APPLICATION_NON_UNIQUE ApplicationFlags = C.G_APPLICATION_NON_UNIQUE +) + +// goMarshal is called by the GLib runtime when a closure needs to be invoked. +// The closure will be invoked with as many arguments as it can take, from 0 to +// the full amount provided by the call. If the closure asks for more parameters +// than there are to give, then a runtime panic will occur. +// +//export goMarshal +func goMarshal( + gclosure *C.GClosure, + retValue *C.GValue, + nParams C.guint, + params *C.GValue, + invocationHint C.gpointer, + marshalData *C.GValue) { + + // Get the function value associated with this callback closure. + fs := closure.Get(unsafe.Pointer(gclosure)) + if !fs.IsValid() { + // Possible data race, bail. + return + } + + fsType := fs.Func.Type() + + // Get number of parameters passed in. + nGLibParams := int(nParams) + nTotalParams := nGLibParams + + // Reflect may panic, so we defer recover here to re-panic with our trace. + defer fs.TryRepanic() + + // Get number of parameters from the callback closure. If this exceeds + // the total number of marshaled parameters, trigger a runtime panic. + nCbParams := fsType.NumIn() + if nCbParams > nTotalParams { + fs.Panicf("too many closure args: have %d, max %d", nCbParams, nTotalParams) + } + + // Create a slice of reflect.Values as arguments to call the function. + gValues := gValueSlice(params, nCbParams) + args := make([]reflect.Value, 0, nCbParams) + + // Fill beginning of args, up to the minimum of the total number of callback + // parameters and parameters from the glib runtime. + for i := 0; i < nCbParams && i < nGLibParams; i++ { + v := Value{&gValues[i]} + + val, err := v.GoValue() + if err != nil { + fs.Panicf("no suitable Go value for arg %d: %v", i, err) + } + + // Parameters that are descendants of GObject come wrapped in another + // GObject. For C applications, the default marshaller + // (g_cclosure_marshal_VOID__VOID in gmarshal.c in the GTK glib library) + // 'peeks' into the enclosing object and passes the wrapped object to + // the handler. Use the *Object.goValue function to emulate that for Go + // signal handlers. + switch objVal := val.(type) { + case *Object: + if innerVal, err := objVal.goValue(); err == nil { + val = innerVal + } + + case *Variant: + switch ts := objVal.TypeString(); ts { + case "s": + val = objVal.GetString() + case "b": + val = gobool(C.g_variant_get_boolean(objVal.native())) + case "d": + val = float64(C.g_variant_get_double(objVal.native())) + case "n": + val = int16(C.g_variant_get_int16(objVal.native())) + case "i": + val = int32(C.g_variant_get_int32(objVal.native())) + case "x": + val = int64(C.g_variant_get_int64(objVal.native())) + case "y": + val = uint8(C.g_variant_get_byte(objVal.native())) + case "q": + val = uint16(C.g_variant_get_uint16(objVal.native())) + case "u": + val = uint32(C.g_variant_get_uint32(objVal.native())) + case "t": + val = uint64(C.g_variant_get_uint64(objVal.native())) + default: + fs.Panicf("variant conversion not yet implemented for type %s", ts) + } + } + + args = append(args, reflect.ValueOf(val).Convert(fsType.In(i))) + } + + // Call closure with args. If the callback returns one or more values, save + // the GValue equivalent of the first. + rv := fs.Func.Call(args) + if retValue != nil && len(rv) > 0 { + g, err := GValue(rv[0].Interface()) + if err != nil { + fs.Panicf("cannot save callback return value: %v", err) + } + + t, _, err := g.Type() + if err != nil { + fs.Panicf("cannot determine callback return value: %v", err) + } + + // Explicitly copy the return value as it may point to go-owned memory. + C.g_value_unset(retValue) + C.g_value_init(retValue, C.GType(t)) + C.g_value_copy(g.native(), retValue) + + *retValue = *g.native() + } +} + +// gValueSlice converts a C array of GValues to a Go slice. +func gValueSlice(values *C.GValue, nValues int) (slice []C.GValue) { + header := (*reflect.SliceHeader)((unsafe.Pointer(&slice))) + header.Cap = nValues + header.Len = nValues + header.Data = uintptr(unsafe.Pointer(values)) + return +} + +/* + * Main event loop + */ + +// Priority is the enumerated type for GLib priority event sources. +type Priority int + +const ( + PRIORITY_HIGH Priority = C.G_PRIORITY_HIGH + PRIORITY_DEFAULT Priority = C.G_PRIORITY_DEFAULT // TimeoutAdd + PRIORITY_HIGH_IDLE Priority = C.G_PRIORITY_HIGH_IDLE + PRIORITY_DEFAULT_IDLE Priority = C.G_PRIORITY_DEFAULT_IDLE // IdleAdd + PRIORITY_LOW Priority = C.G_PRIORITY_LOW +) + +type SourceHandle uint + +// IdleAdd adds an idle source to the default main event loop context with the +// DefaultIdle priority. If f is not a function with no parameter, then IdleAdd +// will panic. +// +// After running once, the source func will be removed from the main event loop, +// unless f returns a single bool true. +func IdleAdd(f interface{}) SourceHandle { + return sourceAttach( + C.g_idle_source_new(), + f, PRIORITY_DEFAULT_IDLE, false, + ) +} + +// IdleAddPriority adds an idle source to the default main event loop context +// with the given priority. Its behavior is the same as IdleAdd. +func IdleAddPriority(priority Priority, f interface{}) SourceHandle { + return sourceAttach( + C.g_idle_source_new(), + f, priority, true, + ) +} + +// TimeoutAdd adds an timeout source to the default main event loop context. +// Timeout is in milliseconds. If f is not a function with no parameter, then it +// will panic. +// +// After running once, the source func will be removed from the main event loop, +// unless f returns a single bool true. +func TimeoutAdd(milliseconds uint, f interface{}) SourceHandle { + return sourceAttach( + C.g_timeout_source_new(C.guint(milliseconds)), + f, PRIORITY_DEFAULT, false, + ) +} + +// TimeoutAddPriority is similar to TimeoutAdd with the given priority. Refer to +// TimeoutAdd for more information. +func TimeoutAddPriority(milliseconds uint, priority Priority, f interface{}) SourceHandle { + return sourceAttach( + C.g_timeout_source_new(C.guint(milliseconds)), + f, priority, true, + ) +} + +// TimeoutSecondsAdd is similar to TimeoutAdd, except with seconds granularity. +func TimeoutSecondsAdd(seconds uint, f interface{}) SourceHandle { + return sourceAttach( + C.g_timeout_source_new_seconds(C.guint(seconds)), + f, PRIORITY_DEFAULT, false, + ) +} + +// TimeoutSecondsAddPriority adds a timeout source with the given priority. +// Refer to TimeoutSecondsAdd for more information. +func TimeoutSecondsAddPriority(seconds uint, priority Priority, f interface{}) SourceHandle { + return sourceAttach( + C.g_timeout_source_new_seconds(C.guint(seconds)), + f, priority, true, + ) +} + +// sourceAttach attaches a source to the default main loop context. +func sourceAttach(src *C.struct__GSource, f interface{}, priority Priority, set bool) SourceHandle { + if src == nil { + panic("unexpected nil GSource") + } + + fs := closure.NewFuncStack(f, 2) + // Ensure no parameters prematurely. + if fs.Func.Type().NumIn() > 0 { + fs.Panicf("timeout source should have no parameters") + } + + if set { + C.g_source_set_priority(src, C.gint(priority)) + } + + // Create a new GClosure from f that invalidates itself when f returns + // false. The error is ignored here, as this will always be a function. + gclosure := ClosureNewFunc(fs) + + // Set closure to run as a callback when the idle source runs. + C.g_source_set_closure(src, gclosure) + + // Attach the idle source func to the default main event loop context. + return SourceHandle(C.g_source_attach(src, nil)) +} + +// Destroy is a wrapper around g_source_destroy() +func (v *Source) Destroy() { + C.g_source_destroy(v.native()) +} + +// IsDestroyed is a wrapper around g_source_is_destroyed() +func (v *Source) IsDestroyed() bool { + return gobool(C.g_source_is_destroyed(v.native())) +} + +// Unref is a wrapper around g_source_unref() +func (v *Source) Unref() { + C.g_source_unref(v.native()) +} + +// Ref is a wrapper around g_source_ref() +func (v *Source) Ref() *Source { + c := C.g_source_ref(v.native()) + if c == nil { + return nil + } + return (*Source)(c) +} + +// SourceRemove is a wrapper around g_source_remove() +func SourceRemove(src SourceHandle) bool { + return gobool(C.g_source_remove(C.guint(src))) +} + +/* + * Miscellaneous Utility Functions + */ + +// GetHomeDir is a wrapper around g_get_home_dir(). +func GetHomeDir() string { + c := C.g_get_home_dir() + return C.GoString((*C.char)(c)) +} + +// GetUserCacheDir is a wrapper around g_get_user_cache_dir(). +func GetUserCacheDir() string { + c := C.g_get_user_cache_dir() + return C.GoString((*C.char)(c)) +} + +// GetUserDataDir is a wrapper around g_get_user_data_dir(). +func GetUserDataDir() string { + c := C.g_get_user_data_dir() + return C.GoString((*C.char)(c)) +} + +// GetUserConfigDir is a wrapper around g_get_user_config_dir(). +func GetUserConfigDir() string { + c := C.g_get_user_config_dir() + return C.GoString((*C.char)(c)) +} + +// GetUserRuntimeDir is a wrapper around g_get_user_runtime_dir(). +func GetUserRuntimeDir() string { + c := C.g_get_user_runtime_dir() + return C.GoString((*C.char)(c)) +} + +// GetUserSpecialDir is a wrapper around g_get_user_special_dir(). A +// non-nil error is returned in the case that g_get_user_special_dir() +// returns NULL to differentiate between NULL and an empty string. +func GetUserSpecialDir(directory UserDirectory) (string, error) { + c := C.g_get_user_special_dir(C.GUserDirectory(directory)) + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +// FormatSize is a wrapper around g_format_size(). +func FormatSize(size uint64) string { + char := C.g_format_size(C.guint64(size)) + defer C.free(unsafe.Pointer(char)) + + return C.GoString(char) +} + +// FormatSizeFlags are flags to modify the format of the string returned by +// FormatSizeFull. +type FormatSizeFlags int + +const ( + FORMAT_SIZE_DEFAULT FormatSizeFlags = C.G_FORMAT_SIZE_DEFAULT + FORMAT_SIZE_LONG_FORMAT FormatSizeFlags = C.G_FORMAT_SIZE_LONG_FORMAT + FORMAT_SIZE_IEC_UNITS FormatSizeFlags = C.G_FORMAT_SIZE_IEC_UNITS + FORMAT_SIZE_BITS FormatSizeFlags = C.G_FORMAT_SIZE_BITS +) + +// FormatSizeFull is a wrapper around g_format_size_full(). +func FormatSizeFull(size uint64, flags FormatSizeFlags) string { + char := C.g_format_size_full(C.guint64(size), C.GFormatSizeFlags(flags)) + defer C.free(unsafe.Pointer(char)) + + return C.GoString(char) +} + +// SpacedPrimesClosest is a wrapper around g_spaced_primes_closest(). +func SpacedPrimesClosest(num uint) uint { + return uint(C.g_spaced_primes_closest(C.guint(num))) +} + +/* + * GObject + */ + +// IObject is an interface type implemented by Object and all types which embed +// an Object. It is meant to be used as a type for function arguments which +// require GObjects or any subclasses thereof. +type IObject interface { + toGObject() *C.GObject + toObject() *Object +} + +// Object is a representation of GLib's GObject. +type Object struct { + GObject *C.GObject +} + +func (v *Object) toGObject() *C.GObject { + if v == nil { + return nil + } + return v.native() +} + +func (v *Object) toObject() *Object { + return v +} + +// newObject creates a new Object from a GObject pointer. +func newObject(p *C.GObject) *Object { + if p == nil { + return nil + } + return &Object{GObject: p} +} + +// native returns a pointer to the underlying GObject. +func (v *Object) native() *C.GObject { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGObject(p) +} + +// goValue converts a *Object to a Go type (e.g. *Object => *gtk.Entry). +// It is used in goMarshal to convert generic GObject parameters to +// signal handlers to the actual types expected by the signal handler. +func (v *Object) goValue() (interface{}, error) { + objType := Type(C._g_type_from_instance(C.gpointer(v.native()))) + f, err := gValueMarshalers.lookupType(objType) + if err != nil { + return nil, err + } + + // The marshalers expect Values, not Objects + val, err := ValueInit(objType) + if err != nil { + return nil, err + } + val.SetInstance(uintptr(unsafe.Pointer(v.GObject))) + rv, err := f(uintptr(unsafe.Pointer(val.native()))) + return rv, err +} + +// Take wraps a unsafe.Pointer as a glib.Object, taking ownership of it. +// This function is exported for visibility in other gotk3 packages and +// is not meant to be used by applications. +// +// To be clear, this should mostly be used when Gtk says "transfer none". Refer +// to AssumeOwnership for more details. +func Take(ptr unsafe.Pointer) *Object { + obj := newObject(ToGObject(ptr)) + if obj == nil { + return nil + } + + obj.RefSink() + runtime.SetFinalizer(obj, (*Object).Unref) + return obj +} + +// AssumeOwnership is similar to Take, except the function does not take a +// reference. This is usually used for newly constructed objects that for some +// reason does not have an initial floating reference. +// +// To be clear, this should often be used when Gtk says "transfer full", as it +// means the ownership is transferred to the caller, so we can assume that much. +// This is in contrary to Take, which is used when Gtk says "transfer none", as +// we're now referencing an object that might possibly be kept, so we should +// mark as such. +func AssumeOwnership(ptr unsafe.Pointer) *Object { + obj := newObject(ToGObject(ptr)) + runtime.SetFinalizer(obj, (*Object).Unref) + return obj +} + +// Native returns a pointer to the underlying GObject. +func (v *Object) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +// IsA is a wrapper around g_type_is_a(). +func (v *Object) IsA(typ Type) bool { + return gobool(C.g_type_is_a(C.GType(v.TypeFromInstance()), C.GType(typ))) +} + +// TypeFromInstance is a wrapper around g_type_from_instance(). +func (v *Object) TypeFromInstance() Type { + c := C._g_type_from_instance(C.gpointer(unsafe.Pointer(v.native()))) + return Type(c) +} + +// ToGObject type converts an unsafe.Pointer as a native C GObject. +// This function is exported for visibility in other gotk3 packages and +// is not meant to be used by applications. +func ToGObject(p unsafe.Pointer) *C.GObject { + return (*C.GObject)(p) + // return C.toGObject(p) +} + +// Ref is a wrapper around g_object_ref(). +func (v *Object) Ref() { + C.g_object_ref(C.gpointer(v.GObject)) +} + +// Unref is a wrapper around g_object_unref(). +func (v *Object) Unref() { + C.g_object_unref(C.gpointer(v.GObject)) +} + +// RefSink is a wrapper around g_object_ref_sink(). +func (v *Object) RefSink() { + C.g_object_ref_sink(C.gpointer(v.GObject)) +} + +// IsFloating is a wrapper around g_object_is_floating(). +func (v *Object) IsFloating() bool { + c := C.g_object_is_floating(C.gpointer(v.GObject)) + return gobool(c) +} + +// ForceFloating is a wrapper around g_object_force_floating(). +func (v *Object) ForceFloating() { + C.g_object_force_floating(v.GObject) +} + +// StopEmission is a wrapper around g_signal_stop_emission_by_name(). +func (v *Object) StopEmission(s string) { + cstr := C.CString(s) + defer C.free(unsafe.Pointer(cstr)) + C.g_signal_stop_emission_by_name((C.gpointer)(v.GObject), + (*C.gchar)(cstr)) +} + +// Set calls SetProperty. +func (v *Object) Set(name string, value interface{}) error { + return v.SetProperty(name, value) +} + +// GetPropertyType returns the Type of a property of the underlying GObject. +// If the property is missing it will return TYPE_INVALID and an error. +func (v *Object) GetPropertyType(name string) (Type, error) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + + paramSpec := C.g_object_class_find_property(C._g_object_get_class(v.native()), (*C.gchar)(cstr)) + if paramSpec == nil { + return TYPE_INVALID, errors.New("couldn't find Property") + } + return Type(paramSpec.value_type), nil +} + +// GetProperty is a wrapper around g_object_get_property(). +func (v *Object) GetProperty(name string) (interface{}, error) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + + t, err := v.GetPropertyType(name) + if err != nil { + return nil, err + } + + p, err := ValueInit(t) + if err != nil { + return nil, errors.New("unable to allocate value") + } + C.g_object_get_property(v.GObject, (*C.gchar)(cstr), p.native()) + return p.GoValue() +} + +// SetProperty is a wrapper around g_object_set_property(). +func (v *Object) SetProperty(name string, value interface{}) error { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + + if _, ok := value.(Object); ok { + value = value.(Object).GObject + } + + p, err := GValue(value) + if err != nil { + return errors.New("Unable to perform type conversion") + } + C.g_object_set_property(v.GObject, (*C.gchar)(cstr), p.native()) + return nil +} + +/* + * GObject Signals + */ + +// Emit is a wrapper around g_signal_emitv() and emits the signal +// specified by the string s to an Object. Arguments to callback +// functions connected to this signal must be specified in args. Emit() +// returns an interface{} which must be type asserted as the Go +// equivalent type to the return value for native C callback. +// +// Note that this code is unsafe in that the types of values in args are +// not checked against whether they are suitable for the callback. +func (v *Object) Emit(s string, args ...interface{}) (interface{}, error) { + cstr := C.CString(s) + defer C.free(unsafe.Pointer(cstr)) + + // Create array of this instance and arguments + valv := C.alloc_gvalue_list(C.int(len(args)) + 1) + defer C.free(unsafe.Pointer(valv)) + + // Add args and valv + val, err := GValue(v) + if err != nil { + return nil, errors.New("Error converting Object to GValue: " + err.Error()) + } + C.val_list_insert(valv, C.int(0), val.native()) + for i := range args { + val, err := GValue(args[i]) + if err != nil { + return nil, fmt.Errorf("Error converting arg %d to GValue: %s", i, err.Error()) + } + C.val_list_insert(valv, C.int(i+1), val.native()) + } + + t := v.TypeFromInstance() + // TODO: use just the signal name + id := C.g_signal_lookup((*C.gchar)(cstr), C.GType(t)) + + ret, err := ValueAlloc() + if err != nil { + return nil, errors.New("Error creating Value for return value") + } + C.g_signal_emitv(valv, id, C.GQuark(0), ret.native()) + + return ret.GoValue() +} + +// HandlerBlock is a wrapper around g_signal_handler_block(). +func (v *Object) HandlerBlock(handle SignalHandle) { + C.g_signal_handler_block(C.gpointer(v.GObject), C.gulong(handle)) +} + +// HandlerUnblock is a wrapper around g_signal_handler_unblock(). +func (v *Object) HandlerUnblock(handle SignalHandle) { + C.g_signal_handler_unblock(C.gpointer(v.GObject), C.gulong(handle)) +} + +// HandlerDisconnect is a wrapper around g_signal_handler_disconnect(). +func (v *Object) HandlerDisconnect(handle SignalHandle) { + // Ensure that Gtk will not use the closure beforehand. + C.g_signal_handler_disconnect(C.gpointer(v.GObject), C.gulong(handle)) + closure.DisconnectSignal(uint(handle)) +} + +// Wrapper function for new objects with reference management. +func wrapObject(ptr unsafe.Pointer) *Object { + return Take(ptr) +} + +/* + * GInitiallyUnowned + */ + +// InitiallyUnowned is a representation of GLib's GInitiallyUnowned. +type InitiallyUnowned struct { + // This must be a pointer so copies of the ref-sinked object + // do not outlive the original object, causing an unref + // finalizer to prematurely run. + *Object +} + +// Native returns a pointer to the underlying GObject. This is implemented +// here rather than calling Native on the embedded Object to prevent a nil +// pointer dereference. +func (v *InitiallyUnowned) Native() uintptr { + if v == nil || v.Object == nil { + return uintptr(unsafe.Pointer(nil)) + } + return v.Object.Native() +} + +/* + * GValue + */ + +// Value is a representation of GLib's GValue. +// +// Don't allocate Values on the stack or heap manually as they may not +// be properly unset when going out of scope. Instead, use ValueAlloc(), +// which will set the runtime finalizer to unset the Value after it has +// left scope. +type Value struct { + GValue *C.GValue +} + +// native returns a pointer to the underlying GValue. +func (v *Value) native() *C.GValue { + return v.GValue +} + +// Native returns a pointer to the underlying GValue. +func (v *Value) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +// IsValue checks if value is a valid and initialized GValue structure. +func (v *Value) IsValue() bool { + return gobool(C._g_is_value(v.native())) +} + +// TypeName gets the type name of value. +func (v *Value) TypeName() string { + return C.GoString((*C.char)(C._g_value_type_name(v.native()))) +} + +// ValueAlloc allocates a Value and sets a runtime finalizer to call +// g_value_unset() on the underlying GValue after leaving scope. +// ValueAlloc() returns a non-nil error if the allocation failed. +func ValueAlloc() (*Value, error) { + c := C._g_value_alloc() + if c == nil { + return nil, nilPtrErr + } + + v := &Value{c} + + //An allocated GValue is not guaranteed to hold a value that can be unset + //We need to double check before unsetting, to prevent: + //`g_value_unset: assertion 'G_IS_VALUE (value)' failed` + runtime.SetFinalizer(v, func(f *Value) { + + if !f.IsValue() { + C.g_free(C.gpointer(f.native())) + return + } + + f.unset() + }) + + return v, nil +} + +// ValueInit is a wrapper around g_value_init() and allocates and +// initializes a new Value with the Type t. A runtime finalizer is set +// to call g_value_unset() on the underlying GValue after leaving scope. +// ValueInit() returns a non-nil error if the allocation failed. +func ValueInit(t Type) (*Value, error) { + c := C._g_value_init(C.GType(t)) + if c == nil { + return nil, nilPtrErr + } + + v := &Value{c} + + runtime.SetFinalizer(v, (*Value).unset) + return v, nil +} + +// ValueFromNative returns a type-asserted pointer to the Value. +func ValueFromNative(l unsafe.Pointer) *Value { + //TODO why it does not add finalizer to the value? + return &Value{(*C.GValue)(l)} +} + +func (v *Value) unset() { + C.g_value_unset(v.native()) +} + +// Type is a wrapper around the G_VALUE_HOLDS_GTYPE() macro and +// the g_value_get_gtype() function. GetType() returns TYPE_INVALID if v +// does not hold a Type, or otherwise returns the Type of v. +func (v *Value) Type() (actual Type, fundamental Type, err error) { + if !v.IsValue() { + return actual, fundamental, errors.New("invalid GValue") + } + cActual := C._g_value_type(v.native()) + cFundamental := C._g_value_fundamental(cActual) + return Type(cActual), Type(cFundamental), nil +} + +// GValue converts a Go type to a comparable GValue. GValue() +// returns a non-nil error if the conversion was unsuccessful. +func GValue(v interface{}) (gvalue *Value, err error) { + if v == nil { + val, err := ValueInit(TYPE_POINTER) + if err != nil { + return nil, err + } + val.SetPointer(uintptr(unsafe.Pointer(nil))) + return val, nil + } + + switch e := v.(type) { + case bool: + val, err := ValueInit(TYPE_BOOLEAN) + if err != nil { + return nil, err + } + val.SetBool(e) + return val, nil + + case int8: + val, err := ValueInit(TYPE_CHAR) + if err != nil { + return nil, err + } + val.SetSChar(e) + return val, nil + + case int64: + val, err := ValueInit(TYPE_INT64) + if err != nil { + return nil, err + } + val.SetInt64(e) + return val, nil + + case int: + val, err := ValueInit(TYPE_INT) + if err != nil { + return nil, err + } + val.SetInt(e) + return val, nil + + case uint8: + val, err := ValueInit(TYPE_UCHAR) + if err != nil { + return nil, err + } + val.SetUChar(e) + return val, nil + + case uint64: + val, err := ValueInit(TYPE_UINT64) + if err != nil { + return nil, err + } + val.SetUInt64(e) + return val, nil + + case uint: + val, err := ValueInit(TYPE_UINT) + if err != nil { + return nil, err + } + val.SetUInt(e) + return val, nil + + case float32: + val, err := ValueInit(TYPE_FLOAT) + if err != nil { + return nil, err + } + val.SetFloat(e) + return val, nil + + case float64: + val, err := ValueInit(TYPE_DOUBLE) + if err != nil { + return nil, err + } + val.SetDouble(e) + return val, nil + + case string: + val, err := ValueInit(TYPE_STRING) + if err != nil { + return nil, err + } + val.SetString(e) + return val, nil + + case *Object: + val, err := ValueInit(TYPE_OBJECT) + if err != nil { + return nil, err + } + val.SetInstance(uintptr(unsafe.Pointer(e.GObject))) + return val, nil + + default: + /* Try this since above doesn't catch constants under other types */ + rval := reflect.ValueOf(v) + switch rval.Kind() { + case reflect.Int8: + val, err := ValueInit(TYPE_CHAR) + if err != nil { + return nil, err + } + val.SetSChar(int8(rval.Int())) + return val, nil + + case reflect.Int16: + return nil, errors.New("Type not implemented") + + case reflect.Int32: + return nil, errors.New("Type not implemented") + + case reflect.Int64: + val, err := ValueInit(TYPE_INT64) + if err != nil { + return nil, err + } + val.SetInt64(rval.Int()) + return val, nil + + case reflect.Int: + val, err := ValueInit(TYPE_INT) + if err != nil { + return nil, err + } + val.SetInt(int(rval.Int())) + return val, nil + + case reflect.Uintptr, reflect.Ptr: + val, err := ValueInit(TYPE_POINTER) + if err != nil { + return nil, err + } + val.SetPointer(rval.Pointer()) + return val, nil + } + } + + return nil, errors.New("Type not implemented") +} + +// GValueMarshaler is a marshal function to convert a GValue into an +// appropriate Go type. The uintptr parameter is a *C.GValue. +type GValueMarshaler func(uintptr) (interface{}, error) + +// TypeMarshaler represents an actual type and it's associated marshaler. +type TypeMarshaler struct { + T Type + F GValueMarshaler +} + +// RegisterGValueMarshalers adds marshalers for several types to the +// internal marshalers map. Once registered, calling GoValue on any +// Value with a registered type will return the data returned by the +// marshaler. +func RegisterGValueMarshalers(tm []TypeMarshaler) { + gValueMarshalers.register(tm) +} + +type marshalMap map[Type]GValueMarshaler + +// gValueMarshalers is a map of Glib types to functions to marshal a +// GValue to a native Go type. +var gValueMarshalers = marshalMap{ + TYPE_INVALID: marshalInvalid, + TYPE_NONE: marshalNone, + TYPE_INTERFACE: marshalInterface, + TYPE_CHAR: marshalChar, + TYPE_UCHAR: marshalUchar, + TYPE_BOOLEAN: marshalBoolean, + TYPE_INT: marshalInt, + TYPE_LONG: marshalLong, + TYPE_ENUM: marshalEnum, + TYPE_INT64: marshalInt64, + TYPE_UINT: marshalUint, + TYPE_ULONG: marshalUlong, + TYPE_FLAGS: marshalFlags, + TYPE_UINT64: marshalUint64, + TYPE_FLOAT: marshalFloat, + TYPE_DOUBLE: marshalDouble, + TYPE_STRING: marshalString, + TYPE_POINTER: marshalPointer, + TYPE_BOXED: marshalBoxed, + TYPE_OBJECT: marshalObject, + TYPE_VARIANT: marshalVariant, +} + +func (m marshalMap) register(tm []TypeMarshaler) { + for i := range tm { + m[tm[i].T] = tm[i].F + } +} + +func (m marshalMap) lookup(v *Value) (GValueMarshaler, error) { + actual, fundamental, err := v.Type() + if err != nil { + return nil, err + } + + if f, ok := m[actual]; ok { + return f, nil + } + if f, ok := m[fundamental]; ok { + return f, nil + } + return nil, errors.New("missing marshaler for type") +} + +func (m marshalMap) lookupType(t Type) (GValueMarshaler, error) { + if f, ok := m[Type(t)]; ok { + return f, nil + } + return nil, errors.New("missing marshaler for type") +} + +func marshalInvalid(uintptr) (interface{}, error) { + return nil, errors.New("invalid type") +} + +func marshalNone(uintptr) (interface{}, error) { + return nil, nil +} + +func marshalInterface(uintptr) (interface{}, error) { + return nil, errors.New("interface conversion not yet implemented") +} + +func marshalChar(p uintptr) (interface{}, error) { + c := C.g_value_get_schar((*C.GValue)(unsafe.Pointer(p))) + return int8(c), nil +} + +func marshalUchar(p uintptr) (interface{}, error) { + c := C.g_value_get_uchar((*C.GValue)(unsafe.Pointer(p))) + return uint8(c), nil +} + +func marshalBoolean(p uintptr) (interface{}, error) { + c := C.g_value_get_boolean((*C.GValue)(unsafe.Pointer(p))) + return gobool(c), nil +} + +func marshalInt(p uintptr) (interface{}, error) { + c := C.g_value_get_int((*C.GValue)(unsafe.Pointer(p))) + return int(c), nil +} + +func marshalLong(p uintptr) (interface{}, error) { + c := C.g_value_get_long((*C.GValue)(unsafe.Pointer(p))) + return int(c), nil +} + +func marshalEnum(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return int(c), nil +} + +func marshalInt64(p uintptr) (interface{}, error) { + c := C.g_value_get_int64((*C.GValue)(unsafe.Pointer(p))) + return int64(c), nil +} + +func marshalUint(p uintptr) (interface{}, error) { + c := C.g_value_get_uint((*C.GValue)(unsafe.Pointer(p))) + return uint(c), nil +} + +func marshalUlong(p uintptr) (interface{}, error) { + c := C.g_value_get_ulong((*C.GValue)(unsafe.Pointer(p))) + return uint(c), nil +} + +func marshalFlags(p uintptr) (interface{}, error) { + c := C.g_value_get_flags((*C.GValue)(unsafe.Pointer(p))) + return uint(c), nil +} + +func marshalUint64(p uintptr) (interface{}, error) { + c := C.g_value_get_uint64((*C.GValue)(unsafe.Pointer(p))) + return uint64(c), nil +} + +func marshalFloat(p uintptr) (interface{}, error) { + c := C.g_value_get_float((*C.GValue)(unsafe.Pointer(p))) + return float32(c), nil +} + +func marshalDouble(p uintptr) (interface{}, error) { + c := C.g_value_get_double((*C.GValue)(unsafe.Pointer(p))) + return float64(c), nil +} + +func marshalString(p uintptr) (interface{}, error) { + c := C.g_value_get_string((*C.GValue)(unsafe.Pointer(p))) + return C.GoString((*C.char)(c)), nil +} + +func marshalBoxed(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + return uintptr(unsafe.Pointer(c)), nil +} + +func marshalPointer(p uintptr) (interface{}, error) { + c := C.g_value_get_pointer((*C.GValue)(unsafe.Pointer(p))) + return unsafe.Pointer(c), nil +} + +func marshalObject(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return newObject((*C.GObject)(c)), nil +} + +func marshalVariant(p uintptr) (interface{}, error) { + c := C.g_value_get_variant((*C.GValue)(unsafe.Pointer(p))) + return newVariant((*C.GVariant)(c)), nil +} + +// GoValue converts a Value to comparable Go type. GoValue() +// returns a non-nil error if the conversion was unsuccessful. The +// returned interface{} must be type asserted as the actual Go +// representation of the Value. +// +// This function is a wrapper around the many g_value_get_*() +// functions, depending on the type of the Value. +func (v *Value) GoValue() (interface{}, error) { + f, err := gValueMarshalers.lookup(v) + if err != nil { + return nil, err + } + + //No need to add finalizer because it is already done by ValueAlloc and ValueInit + rv, err := f(uintptr(unsafe.Pointer(v.native()))) + return rv, err +} + +// SetBool is a wrapper around g_value_set_boolean(). +func (v *Value) SetBool(val bool) { + C.g_value_set_boolean(v.native(), gbool(val)) +} + +// SetSChar is a wrapper around g_value_set_schar(). +func (v *Value) SetSChar(val int8) { + C.g_value_set_schar(v.native(), C.gint8(val)) +} + +// SetInt64 is a wrapper around g_value_set_int64(). +func (v *Value) SetInt64(val int64) { + C.g_value_set_int64(v.native(), C.gint64(val)) +} + +// SetInt is a wrapper around g_value_set_int(). +func (v *Value) SetInt(val int) { + C.g_value_set_int(v.native(), C.gint(val)) +} + +// SetUChar is a wrapper around g_value_set_uchar(). +func (v *Value) SetUChar(val uint8) { + C.g_value_set_uchar(v.native(), C.guchar(val)) +} + +// SetUInt64 is a wrapper around g_value_set_uint64(). +func (v *Value) SetUInt64(val uint64) { + C.g_value_set_uint64(v.native(), C.guint64(val)) +} + +// SetUInt is a wrapper around g_value_set_uint(). +func (v *Value) SetUInt(val uint) { + C.g_value_set_uint(v.native(), C.guint(val)) +} + +// SetFloat is a wrapper around g_value_set_float(). +func (v *Value) SetFloat(val float32) { + C.g_value_set_float(v.native(), C.gfloat(val)) +} + +// SetDouble is a wrapper around g_value_set_double(). +func (v *Value) SetDouble(val float64) { + C.g_value_set_double(v.native(), C.gdouble(val)) +} + +// SetString is a wrapper around g_value_set_string(). +func (v *Value) SetString(val string) { + cstr := C.CString(val) + defer C.free(unsafe.Pointer(cstr)) + C.g_value_set_string(v.native(), (*C.gchar)(cstr)) +} + +// SetInstance is a wrapper around g_value_set_instance(). +func (v *Value) SetInstance(instance uintptr) { + C.g_value_set_instance(v.native(), C.gpointer(instance)) +} + +// SetPointer is a wrapper around g_value_set_pointer(). +func (v *Value) SetPointer(p uintptr) { + C.g_value_set_pointer(v.native(), C.gpointer(p)) +} + +// GetPointer is a wrapper around g_value_get_pointer(). +func (v *Value) GetPointer() unsafe.Pointer { + return unsafe.Pointer(C.g_value_get_pointer(v.native())) +} + +// GetString is a wrapper around g_value_get_string(). GetString() +// returns a non-nil error if g_value_get_string() returned a NULL +// pointer to distinguish between returning a NULL pointer and returning +// an empty string. +func (v *Value) GetString() (string, error) { + c := C.g_value_get_string(v.native()) + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +type Signal struct { + name string + signalId C.guint +} + +func SignalNew(s string) (*Signal, error) { + cstr := C.CString(s) + defer C.free(unsafe.Pointer(cstr)) + + signalId := C._g_signal_new((*C.gchar)(cstr)) + + if signalId == 0 { + return nil, fmt.Errorf("invalid signal name: %s", s) + } + + return &Signal{ + name: s, + signalId: signalId, + }, nil +} + +func (s *Signal) String() string { + return s.name +} + +type Quark uint32 + +// GetPrgname is a wrapper around g_get_prgname(). +func GetPrgname() string { + c := C.g_get_prgname() + + return C.GoString((*C.char)(c)) +} + +// SetPrgname is a wrapper around g_set_prgname(). +func SetPrgname(name string) { + cstr := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr)) + + C.g_set_prgname(cstr) +} + +// GetApplicationName is a wrapper around g_get_application_name(). +func GetApplicationName() string { + c := C.g_get_application_name() + + return C.GoString((*C.char)(c)) +} + +// SetApplicationName is a wrapper around g_set_application_name(). +func SetApplicationName(name string) { + cstr := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr)) + + C.g_set_application_name(cstr) +} + +// InitI18n initializes the i18n subsystem. +func InitI18n(domain string, dir string) { + domainStr := C.CString(domain) + defer C.free(unsafe.Pointer(domainStr)) + + dirStr := C.CString(dir) + defer C.free(unsafe.Pointer(dirStr)) + + C.init_i18n(domainStr, dirStr) +} + +// Local localizes a string using gettext +func Local(input string) string { + cstr := C.CString(input) + defer C.free(unsafe.Pointer(cstr)) + + return C.GoString(C.localize(cstr)) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/glib.go.h b/vendor/github.com/gotk3/gotk3/glib/glib.go.h new file mode 100644 index 0000000..95440fb --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glib.go.h @@ -0,0 +1,190 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#ifndef __GLIB_GO_H__ +#define __GLIB_GO_H__ + +#include +#include +#include + +#include +#define G_SETTINGS_ENABLE_BACKEND +#include +#include +#include +#include +#include + +/* GObject Type Casting */ +static GObject *toGObject(void *p) { return (G_OBJECT(p)); } + +static GAction *toGAction(void *p) { return (G_ACTION(p)); } + +static GActionGroup *toGActionGroup(void *p) { return (G_ACTION_GROUP(p)); } + +static GActionMap *toGActionMap(void *p) { return (G_ACTION_MAP(p)); } + +static GAsyncResult *toGAsyncResult(void *p) { return (G_ASYNC_RESULT(p)); } + +static GSimpleAction *toGSimpleAction(void *p) { return (G_SIMPLE_ACTION(p)); } + +static GSimpleActionGroup *toGSimpleActionGroup(void *p) { + return (G_SIMPLE_ACTION_GROUP(p)); +} + +static GPropertyAction *toGPropertyAction(void *p) { + return (G_PROPERTY_ACTION(p)); +} + +static GMenuModel *toGMenuModel(void *p) { return (G_MENU_MODEL(p)); } + +static GMenu *toGMenu(void *p) { return (G_MENU(p)); } + +static GMenuItem *toGMenuItem(void *p) { return (G_MENU_ITEM(p)); } + +static GNotification *toGNotification(void *p) { return (G_NOTIFICATION(p)); } + +static GPermission *toGPermission(void *p) { return (G_PERMISSION(p)); } + +static GCancellable *toCancellable(void *p) { return (G_CANCELLABLE(p)); } + +static GIcon *toGIcon(void *p) { return (G_ICON(p)); } +static GFileIcon *toGFileIcon(void *p) { return (G_FILE_ICON(p)); } + +static GFile *toGFile(void *p) { return (G_FILE(p)); } + +static GApplication *toGApplication(void *p) { return (G_APPLICATION(p)); } + +static GSettings *toGSettings(void *p) { return (G_SETTINGS(p)); } + +static GSettingsBackend *toGSettingsBackend(void *p) { + return (G_SETTINGS_BACKEND(p)); +} + +static GBinding *toGBinding(void *p) { return (G_BINDING(p)); } + +static GType _g_type_from_instance(gpointer instance) { + return (G_TYPE_FROM_INSTANCE(instance)); +} + +/* Wrapper to avoid variable arg list */ +static void _g_object_set_one(gpointer object, const gchar *property_name, + void *val) { + g_object_set(object, property_name, *(gpointer **)val, NULL); +} + +static GValue *alloc_gvalue_list(int n) { + GValue *valv; + + valv = g_new0(GValue, n); + return (valv); +} + +static void val_list_insert(GValue *valv, int i, GValue *val) { + valv[i] = *val; +} + +/* + * GValue + */ + +static GValue *_g_value_alloc() { return (g_new0(GValue, 1)); } + +static GValue *_g_value_init(GType g_type) { + GValue *value; + + value = g_new0(GValue, 1); + return (g_value_init(value, g_type)); +} + +static gboolean _g_type_is_value(GType g_type) { + return (G_TYPE_IS_VALUE(g_type)); +} + +static gboolean _g_is_value(GValue *val) { return (G_IS_VALUE(val)); } + +static GType _g_value_type(GValue *val) { return (G_VALUE_TYPE(val)); } + +static const gchar *_g_value_type_name(GValue *val) { + return (G_VALUE_TYPE_NAME(val)); +} + +static GType _g_value_fundamental(GType type) { + return (G_TYPE_FUNDAMENTAL(type)); +} + +static GObjectClass *_g_object_get_class(GObject *object) { + return (G_OBJECT_GET_CLASS(object)); +} + +/* + * Closure support + */ + +extern void goMarshal(GClosure *, GValue *, guint, GValue *, gpointer, + GValue *); + +static inline GClosure *_g_closure_new() { + GClosure *closure; + + closure = g_closure_new_simple(sizeof(GClosure), NULL); + g_closure_set_marshal(closure, (GClosureMarshal)(goMarshal)); + return closure; +} + +extern void removeClosure(gpointer, GClosure *); + +static inline void _g_closure_add_finalize_notifier(GClosure *closure) { + g_closure_add_finalize_notifier(closure, NULL, + (GClosureNotify)(removeClosure)); +} + +static inline guint _g_signal_new(const gchar *name) { + return g_signal_new(name, G_TYPE_OBJECT, G_SIGNAL_RUN_FIRST | G_SIGNAL_ACTION, + 0, NULL, NULL, g_cclosure_marshal_VOID__POINTER, + G_TYPE_NONE, 0); +} + +static void init_i18n(const char *domain, const char *dir) { + setlocale(LC_ALL, ""); + bindtextdomain(domain, dir); + bind_textdomain_codeset(domain, "UTF-8"); + textdomain(domain); +} + +static const char *localize(const char *string) { return _(string); } + +static inline char **make_strings(int count) { + return (char **)malloc(sizeof(char *) * count); +} + +static inline void destroy_strings(char **strings) { free(strings); } + +static inline char *get_string(char **strings, int n) { return strings[n]; } + +static inline void set_string(char **strings, int n, char *str) { + strings[n] = str; +} + +static inline gchar **next_gcharptr(gchar **s) { return (s + 1); } + +extern gint goCompareDataFuncs(gconstpointer a, gconstpointer b, + gpointer user_data); + +#endif diff --git a/vendor/github.com/gotk3/gotk3/glib/glib_export.go b/vendor/github.com/gotk3/gotk3/glib/glib_export.go new file mode 100644 index 0000000..4ced8cf --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glib_export.go @@ -0,0 +1,27 @@ +package glib + +// #cgo pkg-config: gio-2.0 +// #include +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/internal/callback" +) + +//export goAsyncReadyCallbacks +func goAsyncReadyCallbacks(sourceObject *C.GObject, res *C.GAsyncResult, userData C.gpointer) { + var source *Object + if sourceObject != nil { + source = wrapObject(unsafe.Pointer(sourceObject)) + } + + fn := callback.Get(uintptr(userData)).(AsyncReadyCallback) + fn(source, wrapAsyncResult(wrapObject(unsafe.Pointer(res)))) +} + +//export goCompareDataFuncs +func goCompareDataFuncs(a, b C.gconstpointer, userData C.gpointer) C.gint { + fn := callback.Get(uintptr(userData)).(CompareDataFunc) + return C.gint(fn(uintptr(a), uintptr(b))) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/glib_extension.go b/vendor/github.com/gotk3/gotk3/glib/glib_extension.go new file mode 100644 index 0000000..f96286a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glib_extension.go @@ -0,0 +1,18 @@ +//glib_extension contains definitions and functions to interface between glib/gtk/gio and go universe + +package glib + +import ( + "reflect" +) + +// Should be implemented by any class which need special conversion like +// gtk.Application -> gio.Application +type IGlibConvert interface { + // If conversion can't be done, the function has to panic with a message that it can't convert to type + Convert(reflect.Type) reflect.Value +} + +var ( + IGlibConvertType reflect.Type +) diff --git a/vendor/github.com/gotk3/gotk3/glib/glib_since_2_42.go b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_42.go new file mode 100644 index 0000000..45b70e7 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_42.go @@ -0,0 +1,50 @@ +// Same copyright and license as the rest of the files in this project + +// +build !glib_2_40 + +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +/* + * Notification + */ + +// NotificationPriority is a representation of GLib's GNotificationPriority. +type NotificationPriority int + +const ( + NOTIFICATION_PRIORITY_NORMAL NotificationPriority = C.G_NOTIFICATION_PRIORITY_NORMAL + NOTIFICATION_PRIORITY_LOW NotificationPriority = C.G_NOTIFICATION_PRIORITY_LOW + NOTIFICATION_PRIORITY_HIGH NotificationPriority = C.G_NOTIFICATION_PRIORITY_HIGH + NOTIFICATION_PRIORITY_URGENT NotificationPriority = C.G_NOTIFICATION_PRIORITY_URGENT +) + +// SetPriority is a wrapper around g_notification_set_priority(). +func (v *Notification) SetPriority(prio NotificationPriority) { + C.g_notification_set_priority(v.native(), C.GNotificationPriority(prio)) +} + +/* + * Application + */ + +// GetResourceBasePath is a wrapper around g_application_get_resource_base_path(). +func (v *Application) GetResourceBasePath() string { + c := C.g_application_get_resource_base_path(v.native()) + + return C.GoString((*C.char)(c)) +} + +// SetResourceBasePath is a wrapper around g_application_set_resource_base_path(). +func (v *Application) SetResourceBasePath(bp string) { + cstr1 := (*C.gchar)(C.CString(bp)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_application_set_resource_base_path(v.native(), cstr1) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/glib_since_2_44.go b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_44.go new file mode 100644 index 0000000..09ac77f --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_44.go @@ -0,0 +1,30 @@ +// Same copyright and license as the rest of the files in this project + +// +build !glib_2_40,!glib_2_42 + +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +// #include "glib_since_2_44.go.h" +import "C" + +/* + * Application + */ + +// GetIsBusy is a wrapper around g_application_get_is_busy(). +func (v *Application) GetIsBusy() bool { + return gobool(C.g_application_get_is_busy(v.native())) +} + +/* + * SimpleAction + */ + +// SetStateHint is a wrapper around g_simple_action_set_state_hint +func (v *SimpleAction) SetStateHint(stateHint *Variant) { + C.g_simple_action_set_state_hint(v.native(), stateHint.native()) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/glib_since_2_44.go.h b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_44.go.h new file mode 100644 index 0000000..344f29b --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_44.go.h @@ -0,0 +1,16 @@ +// Same copyright and license as the rest of the files in this project + +#include + +#include +#include + +static GListModel *toGListModel(void *p) { return (G_LIST_MODEL(p)); } + +static GListStore *toGListStore(void *p) { return (G_LIST_STORE(p)); } + +static inline void _g_list_store_insert_sorted(GListStore *model, gpointer item, + gpointer user_data) { + g_list_store_insert_sorted(model, item, + (GCompareDataFunc)(goCompareDataFuncs), user_data); +} diff --git a/vendor/github.com/gotk3/gotk3/glib/glib_since_2_46.go b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_46.go new file mode 100644 index 0000000..18aaf97 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_46.go @@ -0,0 +1,23 @@ +// Same copyright and license as the rest of the files in this project + +// +build !glib_2_40,!glib_2_42,!glib_2_44 + +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +// #include "glib_since_2_44.go.h" +// #include "glib_since_2_46.go.h" +import "C" +import "github.com/gotk3/gotk3/internal/callback" + +/* + * GListStore + */ + +// Sort is a wrapper around g_list_store_sort(). +func (v *ListStore) Sort(compareFunc CompareDataFunc) { + C._g_list_store_sort(v.native(), C.gpointer(callback.Assign(compareFunc))) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/glib_since_2_46.go.h b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_46.go.h new file mode 100644 index 0000000..e4558b4 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_46.go.h @@ -0,0 +1,10 @@ +// Same copyright and license as the rest of the files in this project + +#include + +#include +#include + +static inline void _g_list_store_sort(GListStore *model, gpointer user_data) { + g_list_store_sort(model, (GCompareDataFunc)(goCompareDataFuncs), user_data); +} diff --git a/vendor/github.com/gotk3/gotk3/glib/glib_since_2_64.go b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_64.go new file mode 100644 index 0000000..4be21c1 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glib_since_2_64.go @@ -0,0 +1,20 @@ +// Same copyright and license as the rest of the files in this project + +// +build !glib_2_40,!glib_2_42,!glib_2_44,!glib_2_46,!glib_2_48,!glib_2_50,!glib_2_52,!glib_2_54,!glib_2_56,!glib_2_58,!glib_2_60,!glib_2_62 + +package glib + +// // #include +// // #include +// // #include +// // #include "glib.go.h" +// // #include "glib_since_2_44.go.h" +// import "C" + +/* + * GListStore + */ + +// TODO +// g_list_store_find +// g_list_store_find_with_equal_func diff --git a/vendor/github.com/gotk3/gotk3/glib/glib_test.go b/vendor/github.com/gotk3/gotk3/glib/glib_test.go new file mode 100644 index 0000000..a9c0cc3 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glib_test.go @@ -0,0 +1,133 @@ +package glib_test + +import ( + "runtime" + "testing" + + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/gtk" +) + +func init() { + gtk.Init(nil) +} + +// TestConnectNotifySignal ensures that property notification signals (those +// whose name begins with "notify::") are queried by the name "notify" (with the +// "::" and the property name omitted). This is because the signal is "notify" +// and the characters after the "::" are not recognized by the signal system. +// +// See +// https://developer.gnome.org/gobject/stable/gobject-The-Base-Object-Type.html#GObject-notify +// for background, and +// https://developer.gnome.org/gobject/stable/gobject-Signals.html#g-signal-new +// for the specification of valid signal names. +func TestConnectNotifySignal(t *testing.T) { + runtime.LockOSThread() + + // Create any GObject that has defined properties. + spacing := 0 + box, _ := gtk.BoxNew(gtk.ORIENTATION_HORIZONTAL, spacing) + + // Connect to a "notify::" signal to listen on property changes. + box.Connect("notify::spacing", func() { + gtk.MainQuit() + }) + + glib.IdleAdd(func(s string) bool { + t.Log(s) + spacing++ + box.SetSpacing(spacing) + return true + }, "IdleAdd executed") + + gtk.Main() +} + +/*At this moment Visionect specific*/ +func TestTimeoutAdd(t *testing.T) { + runtime.LockOSThread() + + glib.TimeoutAdd(2500, func(s string) bool { + t.Log(s) + gtk.MainQuit() + return false + }, "TimeoutAdd executed") + + gtk.Main() +} + +// TestTypeNames tests both glib.TypeFromName and glib.Type.Name +func TestTypeNames(t *testing.T) { + tp := glib.TypeFromName("GtkWindow") + name := tp.Name() + + if name != "GtkWindow" { + t.Error("Expected GtkWindow, got", name) + } +} + +func TestTypeIsA(t *testing.T) { + tp := glib.TypeFromName("GtkApplicationWindow") + tpParent := glib.TypeFromName("GtkWindow") + + isA := tp.IsA(tpParent) + + if !isA { + t.Error("Expected true, GtkApplicationWindow is a GtkWindow") + } +} + +func TestTypeNextBase(t *testing.T) { + tpLeaf := glib.TypeFromName("GtkWindow") + tpParent := glib.TypeFromName("GtkContainer") + + tpNextBase := glib.TypeNextBase(tpLeaf, tpParent) + name := tpNextBase.Name() + + if name != "GtkBin" { + t.Error("Expected GtkBin, got", name) + } +} + +func TestValueString_NonEmpty(t *testing.T) { + + expected := "test" + + value, err := glib.GValue(expected) + if err != nil { + t.Error("acquiring gvalue failed:", err.Error()) + return + } + + actual, err := value.GetString() + if err != nil { + t.Error(err.Error()) + return + } + + if actual != expected { + t.Errorf("Expected %q, got %q", expected, actual) + } +} + +func TestValueString_Empty(t *testing.T) { + + expected := "" + + value, err := glib.GValue(expected) + if err != nil { + t.Error("acquiring gvalue failed:", err.Error()) + return + } + + actual, err := value.GetString() + if err != nil { + t.Error(err.Error()) + return + } + + if actual != expected { + t.Errorf("Expected %q, got %q", expected, actual) + } +} diff --git a/vendor/github.com/gotk3/gotk3/glib/glistmodel.go b/vendor/github.com/gotk3/gotk3/glib/glistmodel.go new file mode 100644 index 0000000..219ea7c --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/glistmodel.go @@ -0,0 +1,164 @@ +// Same copyright and license as the rest of the files in this project + +// +build !glib_2_40,!glib_2_42 + +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +// #include "glib_since_2_44.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/internal/callback" +) + +/* + * GListModel + */ + +// IListModel is an interface representation of ListModel, +// used to avoid duplication when embedding the type in a wrapper of another GObject-based type. +type IListModel interface { + toGListModel() *C.GListModel +} + +// ListModel is a representation of GIO's GListModel. +type ListModel struct { + *Object +} + +func (v *ListModel) toGListModel() *C.GListModel { + if v == nil { + return nil + } + return v.native() +} + +// native returns a pointer to the underlying GListModel. +func (v *ListModel) native() *C.GListModel { + if v == nil || v.GObject == nil { + return nil + } + return C.toGListModel(unsafe.Pointer(v.GObject)) +} + +// Native returns a pointer to the underlying GListModel. +func (v *ListModel) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalListModel(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapListModel(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapListModel(obj *Object) *ListModel { + return &ListModel{obj} +} + +// GetItemType is a wrapper around g_list_model_get_item_type(). +func (v *ListModel) GetItemType() Type { + return Type(C.g_list_model_get_item_type(v.native())) +} + +// GetNItems is a wrapper around g_list_model_get_n_items(). +func (v *ListModel) GetNItems() uint { + return uint(C.g_list_model_get_n_items(v.native())) +} + +// GetItem is a wrapper around g_list_model_get_item(). +func (v *ListModel) GetItem(position uint) uintptr { + c := C.g_list_model_get_item(v.native(), C.guint(position)) + return uintptr(unsafe.Pointer(c)) +} + +// GetObject is a wrapper around g_list_model_get_object(). +func (v *ListModel) GetObject(position uint) *Object { + c := C.g_list_model_get_object(v.native(), C.guint(position)) + return wrapObject(unsafe.Pointer(c)) +} + +// ItemsChanged is a wrapper around g_list_model_items_changed(). +func (v *ListModel) ItemsChanged(position, removed, added uint) { + C.g_list_model_items_changed(v.native(), C.guint(position), C.guint(removed), C.guint(added)) +} + +/* + * GListStore + */ + +// ListStore is a representation of GListStore +type ListStore struct { + ListModel +} + +func (v *ListStore) native() *C.GListStore { + if v == nil || v.GObject == nil { + return nil + } + return C.toGListStore(unsafe.Pointer(v.GObject)) +} + +func (v *ListStore) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalListStore(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapListStore(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapListStore(obj *Object) *ListStore { + return &ListStore{ListModel{obj}} +} + +// ListStoreNew is a wrapper around g_list_store_new(). +func ListStoreNew(itemType Type) *ListStore { + c := C.g_list_store_new(C.GType(itemType)) + if c == nil { + return nil + } + return wrapListStore(wrapObject(unsafe.Pointer(c))) +} + +// Insert is a wrapper around g_list_store_insert(). +func (v *ListStore) Insert(position uint, item interface{}) { + gItem := ToGObject(unsafe.Pointer(&item)) + C.g_list_store_insert(v.native(), C.guint(position), C.gpointer(gItem)) +} + +// InsertSorted is a wrapper around g_list_store_insert_sorted(). +func (v *ListStore) InsertSorted(item interface{}, compareFunc CompareDataFunc) { + gItem := ToGObject(unsafe.Pointer(&item)) + C._g_list_store_insert_sorted(v.native(), C.gpointer(gItem), C.gpointer(callback.Assign(compareFunc))) +} + +// Append is a wrapper around g_list_store_append(). +func (v *ListStore) Append(item interface{}) { + gItem := ToGObject(unsafe.Pointer(&item)) + C.g_list_store_append(v.native(), C.gpointer(gItem)) +} + +// Remove is a wrapper around g_list_store_remove(). +func (v *ListStore) Remove(position uint) { + C.g_list_store_remove(v.native(), C.guint(position)) +} + +// Splice is a wrapper around g_list_store_splice(). +func (v *ListStore) Splice(position uint, removalLength uint, additions []interface{}) { + + additionsLength := len(additions) + gAdditions := make([]*C.GObject, additionsLength) + for i, add := range additions { + gAdditions[i] = ToGObject(unsafe.Pointer(&add)) + } + gAdditions = append(gAdditions, nil) + + additionsPtr := C.gpointer(gAdditions[0]) + + C.g_list_store_splice(v.native(), C.guint(position), C.guint(removalLength), &additionsPtr, C.guint(additionsLength)) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gmain_context.go b/vendor/github.com/gotk3/gotk3/glib/gmain_context.go new file mode 100644 index 0000000..2fed553 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gmain_context.go @@ -0,0 +1,65 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" + +type MainContext C.GMainContext + +// native returns a pointer to the underlying GMainContext. +func (v *MainContext) native() *C.GMainContext { + if v == nil { + return nil + } + return (*C.GMainContext)(v) +} + +// MainContextDefault is a wrapper around g_main_context_default(). +func MainContextDefault() *MainContext { + c := C.g_main_context_default() + if c == nil { + return nil + } + return (*MainContext)(c) +} + +// Iteration is a wrapper around g_main_context_iteration() +func (v *MainContext) Iteration(mayBlock bool) bool { + return gobool(C.g_main_context_iteration(v.native(), gbool(mayBlock))) +} + +// Pending is a wrapper around g_main_context_pending() +func (v *MainContext) Pending() bool { + return gobool(C.g_main_context_pending(v.native())) +} + +// MainDepth is a wrapper around g_main_depth(). +func MainDepth() int { + return int(C.g_main_depth()) +} + +// FindSourceById is a wrapper around g_main_context_find_source_by_id() +func (v *MainContext) FindSourceById(hdlSrc SourceHandle) *Source { + c := C.g_main_context_find_source_by_id(v.native(), C.guint(hdlSrc)) + if c == nil { + return nil + } + return (*Source)(c) +} + +// Acquire is a wrapper around g_main_context_acquire(). +func (v *MainContext) Acquire() { + C.g_main_context_acquire(v.native()) +} + +// Release is a wrapper around g_main_context_release(). +func (v *MainContext) Release() { + C.g_main_context_release(v.native()) +} + +// IsOwner is a wrapper around g_main_context_is_owner(). +func (v *MainContext) IsOwner() bool { + return gobool(C.g_main_context_is_owner(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gpermission.go b/vendor/github.com/gotk3/gotk3/glib/gpermission.go new file mode 100644 index 0000000..f6f3f92 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gpermission.go @@ -0,0 +1,126 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +// #include "gpermission.go.h" +import "C" +import ( + "errors" + "unsafe" + + "github.com/gotk3/gotk3/internal/callback" +) + +// Permission is a representation of GIO's GPermission. +type Permission struct { + *Object +} + +func (v *Permission) native() *C.GPermission { + if v == nil || v.GObject == nil { + return nil + } + return C.toGPermission(unsafe.Pointer(v.GObject)) +} + +// Native returns a uintptr to the underlying C.GPermission. +func (v *Permission) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalPermission(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapPermission(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapPermission(obj *Object) *Permission { + return &Permission{obj} +} + +// WrapPermission wraps given unsafe pointer into Permission. +func WrapPermission(ptr unsafe.Pointer) *Permission { + return wrapPermission(wrapObject(ptr)) +} + +// GetAllowed is a wrapper around g_permission_get_allowed(). +func (v *Permission) GetAllowed() bool { + c := C.g_permission_get_allowed(v.native()) + return gobool(c) +} + +// GetCanAcquire is a wrapper around g_permission_get_can_acquire(). +func (v *Permission) GetCanAcquire() bool { + c := C.g_permission_get_can_acquire(v.native()) + return gobool(c) +} + +// GetCanRelease is a wrapper around g_permission_get_can_release(). +func (v *Permission) GetCanRelease() bool { + c := C.g_permission_get_can_release(v.native()) + return gobool(c) +} + +// Acquire is a wrapper around g_permission_acquire(). +func (v *Permission) Acquire(cancellable *Cancellable) error { + var err *C.GError + c := C.g_permission_acquire(v.native(), cancellable.native(), &err) + acquired := gobool(c) + if !acquired { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// AcquireAsync is a wrapper around g_permission_acquire_async(). +func (v *Permission) AcquireAsync(cancellable *Cancellable, fn AsyncReadyCallback) { + C._g_permission_acquire_async(v.native(), cancellable.native(), C.gpointer(callback.Assign(fn))) +} + +// AcquireFinish is a wrapper around g_permission_acquire_finish(). +func (v *Permission) AcquireFinish(result *AsyncResult) error { + var err *C.GError + c := C.g_permission_acquire_finish(v.native(), result.native(), &err) + acquired := gobool(c) + if !acquired { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// Release is a wrapper around g_permission_release(). +func (v *Permission) Release(cancellable *Cancellable) error { + var err *C.GError + c := C.g_permission_release(v.native(), cancellable.native(), &err) + released := gobool(c) + if !released { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// ReleaseAsync is a wrapper around g_permission_release_async(). +func (v *Permission) ReleaseAsync(cancellable *Cancellable, fn AsyncReadyCallback) { + C._g_permission_release_async(v.native(), cancellable.native(), C.gpointer(callback.Assign(fn))) +} + +// ReleaseFinish is a wrapper around g_permission_release_finish(). +func (v *Permission) ReleaseFinish(result *AsyncResult) error { + var err *C.GError + c := C.g_permission_release_finish(v.native(), result.native(), &err) + released := gobool(c) + if !released { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// ImplUpdate is a wrapper around g_permission_impl_update(). +func (v *Permission) ImplUpdate(allowed, canAcquire, canRelease bool) { + C.g_permission_impl_update(v.native(), gbool(allowed), gbool(canAcquire), gbool(canRelease)) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gpermission.go.h b/vendor/github.com/gotk3/gotk3/glib/gpermission.go.h new file mode 100644 index 0000000..5c0f05e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gpermission.go.h @@ -0,0 +1,24 @@ +// Same copyright and license as the rest of the files in this project + +/* + * GAsyncReadyCallback + */ + +extern void goAsyncReadyCallbacks(GObject *source_object, GAsyncResult *res, + gpointer user_data); + +static inline void _g_permission_acquire_async(GPermission *permission, + GCancellable *cancellable, + gpointer user_data) { + g_permission_acquire_async(permission, cancellable, + (GAsyncReadyCallback)(goAsyncReadyCallbacks), + user_data); +} + +static inline void _g_permission_release_async(GPermission *permission, + GCancellable *cancellable, + gpointer user_data) { + g_permission_release_async(permission, cancellable, + (GAsyncReadyCallback)(goAsyncReadyCallbacks), + user_data); +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gsimpleactiongroup.go b/vendor/github.com/gotk3/gotk3/glib/gsimpleactiongroup.go new file mode 100644 index 0000000..f96936e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gsimpleactiongroup.go @@ -0,0 +1,58 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import ( + "unsafe" +) + +// SimpleActionGroup is a representation of glib's GSimpleActionGroup +type SimpleActionGroup struct { + *Object + + // Interfaces + IActionMap + IActionGroup +} + +// deprecated since 2.38: +// g_simple_action_group_lookup() +// g_simple_action_group_insert() +// g_simple_action_group_remove() +// g_simple_action_group_add_entries() +// -> See implementations in ActionMap + +// native() returns a pointer to the underlying GSimpleActionGroup. +func (v *SimpleActionGroup) native() *C.GSimpleActionGroup { + if v == nil || v.GObject == nil { + return nil + } + return C.toGSimpleActionGroup(unsafe.Pointer(v.GObject)) +} + +func (v *SimpleActionGroup) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalSimpleActionGroup(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapSimpleActionGroup(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapSimpleActionGroup(obj *Object) *SimpleActionGroup { + am := wrapActionMap(obj) + ag := wrapActionGroup(obj) + return &SimpleActionGroup{obj, am, ag} +} + +// SimpleActionGroupNew is a wrapper around g_simple_action_group_new +func SimpleActionGroupNew() *SimpleActionGroup { + c := C.g_simple_action_group_new() + if c == nil { + return nil + } + return wrapSimpleActionGroup(wrapObject(unsafe.Pointer(c))) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gsimpleactiongroup_test.go b/vendor/github.com/gotk3/gotk3/glib/gsimpleactiongroup_test.go new file mode 100644 index 0000000..0982bc6 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gsimpleactiongroup_test.go @@ -0,0 +1,70 @@ +package glib + +import ( + "testing" +) + +func TestSimpleActionGroupNew(t *testing.T) { + sag := SimpleActionGroupNew() + if sag == nil { + t.Error("SimpleActionGroupNew returned nil") + } + + if sag.IActionGroup == nil { + t.Error("Embedded IActionGroup is nil") + } + if sag.IActionMap == nil { + t.Error("Embedded IActionGroup is nil") + } +} + +func TestSimpleActionGroup_AddAction_RemoveAction_HasAction(t *testing.T) { + sag := SimpleActionGroupNew() + if sag == nil { + t.Error("SimpleActionGroup returned nil") + } + + // Check before: empty + hasAction := sag.HasAction("nope") + if hasAction { + t.Error("Action group contained unexpected action 'nope'") + } + hasAction = sag.HasAction("yepp") + if hasAction { + t.Error("Action group contained unexpected action 'yepp'") + } + + // Add a new action + act := SimpleActionNew("yepp", nil) + if act == nil { + t.Error("SimpleActionNew returned nil") + } + sag.AddAction(act) + + // Check that it exists + hasAction = sag.HasAction("nope") + if hasAction { + t.Error("Action group contained unexpected action 'nope'") + } + hasAction = sag.HasAction("yepp") + if !hasAction { + t.Error("Action group did not contain action 'yepp' after adding it") + } + + // Remove the action again + sag.RemoveAction("yepp") + + // Check that it was removed + hasAction = sag.HasAction("nope") + if hasAction { + t.Error("Action group contained unexpected action 'nope'") + } + hasAction = sag.HasAction("yepp") + if hasAction { + t.Error("Action group contained unexpected action 'yepp'") + } + + // NoFail check: removing a non-existing action + sag.RemoveAction("yepp") + sag.RemoveAction("nope") +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gsource.go b/vendor/github.com/gotk3/gotk3/glib/gsource.go new file mode 100644 index 0000000..d3518ec --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gsource.go @@ -0,0 +1,31 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" + +type Source C.GSource + +// native returns a pointer to the underlying GSource. +func (v *Source) native() *C.GSource { + if v == nil { + return nil + } + return (*C.GSource)(v) +} + +func wrapSource(sourcePtr *C.GSource) *Source { + source := Source(*sourcePtr) + return &source +} + +// MainCurrentSource is a wrapper around g_main_current_source(). +func MainCurrentSource() *Source { + c := C.g_main_current_source() + if c == nil { + return nil + } + return (*Source)(c) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gvariant.go b/vendor/github.com/gotk3/gotk3/glib/gvariant.go new file mode 100644 index 0000000..dacbcae --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gvariant.go @@ -0,0 +1,451 @@ +//GVariant : GVariant — strongly typed value datatype +// https://developer.gnome.org/glib/2.26/glib-GVariant.html + +package glib + +// #include "gvariant.go.h" +// #include "glib.go.h" +import "C" + +import ( + "errors" + "fmt" + "runtime" + "unsafe" +) + +/* + * GVariant + */ + +// IVariant is an interface type implemented by Variant and all types which embed +// an Variant. It is meant to be used as a type for function arguments which +// require GVariants or any subclasses thereof. +type IVariant interface { + ToGVariant() *C.GVariant + ToVariant() *Variant +} + +// A Variant is a representation of GLib's GVariant. +type Variant struct { + GVariant *C.GVariant +} + +// ToGVariant exposes the underlying *C.GVariant type for this Variant, +// necessary to implement IVariant. +func (v *Variant) ToGVariant() *C.GVariant { + if v == nil { + return nil + } + return v.native() +} + +// ToVariant returns this Variant, necessary to implement IVariant. +func (v *Variant) ToVariant() *Variant { + return v +} + +// native returns a pointer to the underlying GVariant. +func (v *Variant) native() *C.GVariant { + if v == nil || v.GVariant == nil { + return nil + } + return v.GVariant +} + +// Native returns a pointer to the underlying GVariant. +func (v *Variant) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +// newVariant wraps a native GVariant. +// Does NOT handle reference counting! Use takeVariant() to take ownership of values. +func newVariant(p *C.GVariant) *Variant { + if p == nil { + return nil + } + return &Variant{GVariant: p} +} + +// TakeVariant wraps a unsafe.Pointer as a glib.Variant, taking ownership of it. +// This function is exported for visibility in other gotk3 packages and +// is not meant to be used by applications. +func TakeVariant(ptr unsafe.Pointer) *Variant { + return takeVariant(C.toGVariant(ptr)) +} + +// takeVariant wraps a native GVariant, +// takes ownership and sets up a finalizer to free the instance during GC. +func takeVariant(p *C.GVariant) *Variant { + if p == nil { + return nil + } + obj := &Variant{GVariant: p} + + if obj.IsFloating() { + obj.RefSink() + } else { + obj.Ref() + } + + runtime.SetFinalizer(obj, (*Variant).Unref) + return obj +} + +// IsFloating returns true if the variant has a floating reference count. +// Reference counting is usually handled in the gotk layer, +// most applications should not call this. +func (v *Variant) IsFloating() bool { + return gobool(C.g_variant_is_floating(v.native())) +} + +// Ref is a wrapper around g_variant_ref. +// Reference counting is usually handled in the gotk layer, +// most applications should not need to call this. +func (v *Variant) Ref() { + C.g_variant_ref(v.native()) +} + +// RefSink is a wrapper around g_variant_ref_sink. +// Reference counting is usually handled in the gotk layer, +// most applications should not need to call this. +func (v *Variant) RefSink() { + C.g_variant_ref_sink(v.native()) +} + +// TakeRef is a wrapper around g_variant_take_ref. +// Reference counting is usually handled in the gotk layer, +// most applications should not need to call this. +func (v *Variant) TakeRef() { + C.g_variant_take_ref(v.native()) +} + +// Unref is a wrapper around g_variant_unref. +// Reference counting is usually handled in the gotk layer, +// most applications should not need to call this. +func (v *Variant) Unref() { + C.g_variant_unref(v.native()) +} + +// VariantFromInt16 is a wrapper around g_variant_new_int16 +func VariantFromInt16(value int16) *Variant { + return takeVariant(C.g_variant_new_int16(C.gint16(value))) +} + +// VariantFromInt32 is a wrapper around g_variant_new_int32 +func VariantFromInt32(value int32) *Variant { + return takeVariant(C.g_variant_new_int32(C.gint32(value))) +} + +// VariantFromInt64 is a wrapper around g_variant_new_int64 +func VariantFromInt64(value int64) *Variant { + return takeVariant(C.g_variant_new_int64(C.gint64(value))) +} + +// VariantFromByte is a wrapper around g_variant_new_byte +func VariantFromByte(value uint8) *Variant { + return takeVariant(C.g_variant_new_byte(C.guint8(value))) +} + +// VariantFromUint16 is a wrapper around g_variant_new_uint16 +func VariantFromUint16(value uint16) *Variant { + return takeVariant(C.g_variant_new_uint16(C.guint16(value))) +} + +// VariantFromUint32 is a wrapper around g_variant_new_uint32 +func VariantFromUint32(value uint32) *Variant { + return takeVariant(C.g_variant_new_uint32(C.guint32(value))) +} + +// VariantFromUint64 is a wrapper around g_variant_new_uint64 +func VariantFromUint64(value uint64) *Variant { + return takeVariant(C.g_variant_new_uint64(C.guint64(value))) +} + +// VariantFromBoolean is a wrapper around g_variant_new_boolean +func VariantFromBoolean(value bool) *Variant { + return takeVariant(C.g_variant_new_boolean(gbool(value))) +} + +// VariantFromFloat64 is a wrapper around g_variant_new_double(). +// I chose to respect the Golang float64 nomenclature instead +// of 'double' 'C'. Corresponding VariantType is: 'VARIANT_TYPE_DOUBLE' +func VariantFromFloat64(value float64) *Variant { + return takeVariant(C.g_variant_new_double(C.gdouble(value))) +} + +// VariantFromString is a wrapper around g_variant_new_string/g_variant_new_take_string. +// Uses g_variant_new_take_string to reduce memory allocations if possible. +func VariantFromString(value string) *Variant { + cstr := (*C.gchar)(C.CString(value)) + // g_variant_new_take_string takes owhership of the cstring and will call free() on it when done. + // Do NOT free this string in this function! + return takeVariant(C.g_variant_new_take_string(cstr)) +} + +// VariantFromVariant is a wrapper around g_variant_new_variant. +func VariantFromVariant(value *Variant) *Variant { + return takeVariant(C.g_variant_new_variant(value.native())) +} + +// TypeString returns the g variant type string for this variant. +func (v *Variant) TypeString() string { + // the string returned from this belongs to GVariant and must not be freed. + return C.GoString((*C.char)(C.g_variant_get_type_string(v.native()))) +} + +// IsContainer returns true if the variant is a container and false otherwise. +func (v *Variant) IsContainer() bool { + return gobool(C.g_variant_is_container(v.native())) +} + +// GetBoolean returns the bool value of this variant. +func (v *Variant) GetBoolean() bool { + return gobool(C.g_variant_get_boolean(v.native())) +} + +// GetDouble is a wrapper around g_variant_get_double() +func (v *Variant) GetDouble() float64 { + return float64(C.g_variant_get_double(v.native())) +} + +// GetString is a wrapper around g_variant_get_string. +// It returns the string value of the variant. +func (v *Variant) GetString() string { + + // The string value remains valid as long as the GVariant exists, do NOT free the cstring in this function. + var len C.gsize + gc := C.g_variant_get_string(v.native(), &len) + + // This is opposed to g_variant_dup_string, which copies the string. + // g_variant_dup_string is not implemented, + // as we copy the string value anyways when converting to a go string. + + return C.GoStringN((*C.char)(gc), (C.int)(len)) +} + +// GetVariant is a wrapper around g_variant_get_variant. +// It unboxes a nested GVariant. +func (v *Variant) GetVariant() *Variant { + c := C.g_variant_get_variant(v.native()) + if c == nil { + return nil + } + // The returned value is returned with full ownership transfer, + // only Unref(), don't Ref(). + obj := newVariant(c) + runtime.SetFinalizer(obj, (*Variant).Unref) + return obj +} + +// GetStrv returns a slice of strings from this variant. It wraps +// g_variant_get_strv, but returns copies of the strings instead. +func (v *Variant) GetStrv() []string { + gstrv := C.g_variant_get_strv(v.native(), nil) + // we do not own the memory for these strings, so we must not use strfreev + // but we must free the actual pointer we receive (transfer container). + // We don't implement g_variant_dup_strv which copies the strings, + // as we need to copy anyways when converting to go strings. + c := gstrv + defer C.g_free(C.gpointer(gstrv)) + var strs []string + + for *c != nil { + strs = append(strs, C.GoString((*C.char)(*c))) + c = C.next_gcharptr(c) + } + return strs +} + +// GetObjv returns a slice of object paths from this variant. It wraps +// g_variant_get_objv, but returns copies of the strings instead. +func (v *Variant) GetObjv() []string { + gstrv := C.g_variant_get_objv(v.native(), nil) + // we do not own the memory for these strings, so we must not use strfreev + // but we must free the actual pointer we receive (transfer container). + // We don't implement g_variant_dup_objv which copies the strings, + // as we need to copy anyways when converting to go strings. + c := gstrv + defer C.g_free(C.gpointer(gstrv)) + var strs []string + + for *c != nil { + strs = append(strs, C.GoString((*C.char)(*c))) + c = C.next_gcharptr(c) + } + return strs +} + +// GetInt returns the int64 value of the variant if it is an integer type, and +// an error otherwise. It wraps variouns `g_variant_get_*` functions dealing +// with integers of different sizes. +func (v *Variant) GetInt() (int64, error) { + t := v.TypeString() + var i int64 + switch t { + case "n": + i = int64(C.g_variant_get_int16(v.native())) + case "i": + i = int64(C.g_variant_get_int32(v.native())) + case "x": + i = int64(C.g_variant_get_int64(v.native())) + default: + return 0, fmt.Errorf("variant type %s not a signed integer type", t) + } + return i, nil +} + +// GetUint returns the uint64 value of the variant if it is an integer type, and +// an error otherwise. It wraps variouns `g_variant_get_*` functions dealing +// with integers of different sizes. +func (v *Variant) GetUint() (uint64, error) { + t := v.TypeString() + var i uint64 + switch t { + case "y": + i = uint64(C.g_variant_get_byte(v.native())) + case "q": + i = uint64(C.g_variant_get_uint16(v.native())) + case "u": + i = uint64(C.g_variant_get_uint32(v.native())) + case "t": + i = uint64(C.g_variant_get_uint64(v.native())) + default: + return 0, fmt.Errorf("variant type %s not an unsigned integer type", t) + } + return i, nil +} + +// Type returns the VariantType for this variant. +func (v *Variant) Type() *VariantType { + // The return value is valid for the lifetime of value and must not be freed. + return newVariantType(C.g_variant_get_type(v.native())) +} + +// IsType returns true if the variant's type matches t. +func (v *Variant) IsType(t *VariantType) bool { + return gobool(C.g_variant_is_of_type(v.native(), t.native())) +} + +// String wraps g_variant_print(). It returns a string understood +// by g_variant_parse(). +func (v *Variant) String() string { + gc := C.g_variant_print(v.native(), gbool(false)) + defer C.g_free(C.gpointer(gc)) + return C.GoString((*C.char)(gc)) +} + +// AnnotatedString wraps g_variant_print(), but returns a type-annotated +// string. +func (v *Variant) AnnotatedString() string { + gc := C.g_variant_print(v.native(), gbool(true)) + defer C.g_free(C.gpointer(gc)) + return C.GoString((*C.char)(gc)) +} + +// TODO: +//gint g_variant_compare () +//GVariantClass g_variant_classify () +//gboolean g_variant_check_format_string () +//void g_variant_get () +//void g_variant_get_va () +//GVariant * g_variant_new () +//GVariant * g_variant_new_va () +//GVariant * g_variant_new_handle () +//GVariant * g_variant_new_printf () +//GVariant * g_variant_new_object_path () +//gboolean g_variant_is_object_path () +//GVariant * g_variant_new_signature () +//gboolean g_variant_is_signature () +//GVariant * g_variant_new_strv () +//GVariant * g_variant_new_objv () +//GVariant * g_variant_new_bytestring () +//GVariant * g_variant_new_bytestring_array () +//guchar g_variant_get_byte () +//gint16 g_variant_get_int16 () +//guint16 g_variant_get_uint16 () +//gint32 g_variant_get_int32 () +//guint32 g_variant_get_uint32 () +//gint64 g_variant_get_int64 () +//guint64 g_variant_get_uint64 () +//gint32 g_variant_get_handle () +//gdouble g_variant_get_double () +//const gchar * g_variant_get_bytestring () +//gchar * g_variant_dup_bytestring () +//const gchar ** g_variant_get_bytestring_array () +//gchar ** g_variant_dup_bytestring_array () +//GVariant * g_variant_new_maybe () +//GVariant * g_variant_new_array () +//GVariant * g_variant_new_tuple () +//GVariant * g_variant_new_dict_entry () +//GVariant * g_variant_new_fixed_array () +//GVariant * g_variant_get_maybe () +//gsize g_variant_n_children () +//GVariant * g_variant_get_child_value () +//void g_variant_get_child () +//GVariant * g_variant_lookup_value () +//gboolean g_variant_lookup () +//gconstpointer g_variant_get_fixed_array () +//gsize g_variant_get_size () +//gconstpointer g_variant_get_data () +//GBytes * g_variant_get_data_as_bytes () +//void g_variant_store () +//GVariant * g_variant_new_from_data () +//GVariant * g_variant_new_from_bytes () +//GVariant * g_variant_byteswap () +//GVariant * g_variant_get_normal_form () +//gboolean g_variant_is_normal_form () +//guint g_variant_hash () +//gboolean g_variant_equal () +//gchar * g_variant_print () +//GString * g_variant_print_string () +//GVariantIter * g_variant_iter_copy () +//void g_variant_iter_free () +//gsize g_variant_iter_init () +//gsize g_variant_iter_n_children () +//GVariantIter * g_variant_iter_new () +//GVariant * g_variant_iter_next_value () +//gboolean g_variant_iter_next () +//gboolean g_variant_iter_loop () +//void g_variant_builder_unref () +//GVariantBuilder * g_variant_builder_ref () +//GVariantBuilder * g_variant_builder_new () +//void g_variant_builder_init () +//void g_variant_builder_clear () +//void g_variant_builder_add_value () +//void g_variant_builder_add () +//void g_variant_builder_add_parsed () +//GVariant * g_variant_builder_end () +//void g_variant_builder_open () +//void g_variant_builder_close () +//void g_variant_dict_unref () +//GVariantDict * g_variant_dict_ref () +//GVariantDict * g_variant_dict_new () +//void g_variant_dict_init () +//void g_variant_dict_clear () +//gboolean g_variant_dict_contains () +//gboolean g_variant_dict_lookup () +//GVariant * g_variant_dict_lookup_value () +//void g_variant_dict_insert () +//void g_variant_dict_insert_value () +//gboolean g_variant_dict_remove () +//GVariant * g_variant_dict_end () +//#define G_VARIANT_PARSE_ERROR + +// VariantParse is a wrapper around g_variant_parse() +func VariantParse(vType *VariantType, text string) (*Variant, error) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + var gerr *C.GError + c := C.g_variant_parse(vType.native(), (*C.gchar)(cstr), nil, nil, &gerr) + if c == nil { + defer C.g_error_free(gerr) + return nil, errors.New(goString(gerr.message)) + } + // will be freed during GC + return takeVariant(c), nil +} + +//GVariant * g_variant_new_parsed_va () +//GVariant * g_variant_new_parsed () +//gchar * g_variant_parse_error_print_context () diff --git a/vendor/github.com/gotk3/gotk3/glib/gvariant.go.h b/vendor/github.com/gotk3/gotk3/glib/gvariant.go.h new file mode 100644 index 0000000..e2b4d03 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gvariant.go.h @@ -0,0 +1,26 @@ +// Same copyright and license as the rest of the files in this project + +// GVariant : GVariant — strongly typed value datatype +// https://developer.gnome.org/glib/2.26/glib-GVariant.html + +#ifndef __GVARIANT_GO_H__ +#define __GVARIANT_GO_H__ + +#include +#include +#include +#include + +// Type Casting + +static GVariant *toGVariant(void *p) { return (GVariant *)p; } + +static GVariantBuilder *toGVariantBuilder(void *p) { + return (GVariantBuilder *)p; +} + +static GVariantDict *toGVariantDict(void *p) { return (GVariantDict *)p; } + +static GVariantIter *toGVariantIter(void *p) { return (GVariantIter *)p; } + +#endif diff --git a/vendor/github.com/gotk3/gotk3/glib/gvariant_test.go b/vendor/github.com/gotk3/gotk3/glib/gvariant_test.go new file mode 100644 index 0000000..3d26bff --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gvariant_test.go @@ -0,0 +1,188 @@ +// Same copyright and license as the rest of the files in this project + +package glib_test + +import ( + "math" + "testing" + + "github.com/gotk3/gotk3/glib" +) + +func TestVariantGetInt(t *testing.T) { + t.Run("int16", func(t *testing.T) { + expected := int16(math.MinInt16) + variant := glib.VariantFromInt16(expected) + actual, err := variant.GetInt() + if err != nil { + t.Error("Unexpected error:", err.Error()) + } + if int64(expected) != actual { + t.Error("Expected", expected, "got", actual) + } + }) + + t.Run("int32", func(t *testing.T) { + expected := int32(math.MinInt32) + variant := glib.VariantFromInt32(expected) + actual, err := variant.GetInt() + if err != nil { + t.Error("Unexpected error:", err.Error()) + } + if int64(expected) != actual { + t.Error("Expected", expected, "got", actual) + } + }) + + t.Run("int64", func(t *testing.T) { + expected := int64(math.MinInt64) + variant := glib.VariantFromInt64(expected) + actual, err := variant.GetInt() + if err != nil { + t.Error("Unexpected error:", err.Error()) + } + if expected != actual { + t.Error("Expected", expected, "got", actual) + } + }) + + t.Run("other type", func(t *testing.T) { + variant := glib.VariantFromUint64(987) + _, err := variant.GetInt() + if err == nil { + t.Error("expected error, did not get one") + } + }) +} + +func TestVariantGetUint(t *testing.T) { + t.Run("byte", func(t *testing.T) { + expected := uint8(math.MaxUint8) + variant := glib.VariantFromByte(expected) + actual, err := variant.GetUint() + if err != nil { + t.Error("Unexpected error:", err.Error()) + } + if uint64(expected) != actual { + t.Error("Expected", expected, "got", actual) + } + }) + + t.Run("int16", func(t *testing.T) { + expected := uint16(math.MaxUint16) + variant := glib.VariantFromUint16(expected) + actual, err := variant.GetUint() + if err != nil { + t.Error("Unexpected error:", err.Error()) + } + if uint64(expected) != actual { + t.Error("Expected", expected, "got", actual) + } + }) + + t.Run("int32", func(t *testing.T) { + expected := uint32(math.MaxUint32) + variant := glib.VariantFromUint32(expected) + actual, err := variant.GetUint() + if err != nil { + t.Error("Unexpected error:", err.Error()) + } + if uint64(expected) != actual { + t.Error("Expected", expected, "got", actual) + } + }) + + t.Run("int64", func(t *testing.T) { + expected := uint64(math.MaxUint64) + variant := glib.VariantFromUint64(expected) + actual, err := variant.GetUint() + if err != nil { + t.Error("Unexpected error:", err.Error()) + } + if expected != actual { + t.Error("Expected", expected, "got", actual) + } + }) + + t.Run("other type", func(t *testing.T) { + variant := glib.VariantFromInt64(987) + _, err := variant.GetUint() + if err == nil { + t.Error("expected error, did not get one") + } + }) +} + +func TestVariantType(t *testing.T) { + variant := glib.VariantFromBoolean(true) + variantType := variant.Type() + if !glib.VariantTypeEqual(glib.VARIANT_TYPE_BOOLEAN, variantType) { + t.Error("Expected", glib.VARIANT_TYPE_BOOLEAN, "got", variantType) + } +} + +func TestVariantBool(t *testing.T) { + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "false", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + variant := glib.VariantFromBoolean(tC.value) + actual := variant.GetBoolean() + if tC.value != actual { + t.Error("Expected", tC.value, "got", actual) + } + }) + } +} + +func TestVariantString(t *testing.T) { + testCases := []struct { + desc string + value string + }{ + { + desc: "Plain string", + value: "Simple Data", + }, + { + desc: "String with special characters", + value: "Üö@/Data", + }, + { + desc: "Empty String", + value: "", + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + variant := glib.VariantFromString(tC.value) + actual := variant.GetString() + if tC.value != actual { + t.Error("Expected", tC.value, "got", actual) + } + }) + } +} + +func TestVariantVariant(t *testing.T) { + + boxed := glib.VariantFromString("I'm in a box") + + variant := glib.VariantFromVariant(boxed) + + actual := variant.GetVariant() + if boxed.Native() != actual.Native() { + t.Error("Expected", boxed.Native(), "got", actual.Native()) + } +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gvariantbuilder.go b/vendor/github.com/gotk3/gotk3/glib/gvariantbuilder.go new file mode 100644 index 0000000..c18e787 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gvariantbuilder.go @@ -0,0 +1,52 @@ +// Same copyright and license as the rest of the files in this project + +// GVariant : GVariant — strongly typed value datatype +// https://developer.gnome.org/glib/2.26/glib-GVariant.html + +package glib + +// #include +// #include +// #include "glib.go.h" +// #include "gvariant.go.h" +import "C" +import "unsafe" + +/* + * GVariantBuilder + */ + +// VariantBuilder is a representation of GLib's VariantBuilder. +type VariantBuilder struct { + GVariantBuilder *C.GVariantBuilder +} + +func (v *VariantBuilder) toGVariantBuilder() *C.GVariantBuilder { + if v == nil { + return nil + } + return v.native() +} + +func (v *VariantBuilder) toVariantBuilder() *VariantBuilder { + return v +} + +// newVariantBuilder creates a new VariantBuilder from a GVariantBuilder pointer. +func newVariantBuilder(p *C.GVariantBuilder) *VariantBuilder { + return &VariantBuilder{GVariantBuilder: p} +} + +// native returns a pointer to the underlying GVariantBuilder. +func (v *VariantBuilder) native() *C.GVariantBuilder { + if v == nil || v.GVariantBuilder == nil { + return nil + } + p := unsafe.Pointer(v.GVariantBuilder) + return C.toGVariantBuilder(p) +} + +// Native returns a pointer to the underlying GVariantBuilder. +func (v *VariantBuilder) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gvariantclass.go b/vendor/github.com/gotk3/gotk3/glib/gvariantclass.go new file mode 100644 index 0000000..aea0618 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gvariantclass.go @@ -0,0 +1,39 @@ +// Same copyright and license as the rest of the files in this project + +//GVariant : GVariant — strongly typed value datatype +// https://developer.gnome.org/glib/2.26/glib-GVariant.html + +package glib + +// #include +// #include +// #include "glib.go.h" +// #include "gvariant.go.h" +import "C" + +/* + * GVariantClass + */ + +type VariantClass int + +const ( + VARIANT_CLASS_BOOLEAN VariantClass = C.G_VARIANT_CLASS_BOOLEAN //The GVariant is a boolean. + VARIANT_CLASS_BYTE VariantClass = C.G_VARIANT_CLASS_BYTE //The GVariant is a byte. + VARIANT_CLASS_INT16 VariantClass = C.G_VARIANT_CLASS_INT16 //The GVariant is a signed 16 bit integer. + VARIANT_CLASS_UINT16 VariantClass = C.G_VARIANT_CLASS_UINT16 //The GVariant is an unsigned 16 bit integer. + VARIANT_CLASS_INT32 VariantClass = C.G_VARIANT_CLASS_INT32 //The GVariant is a signed 32 bit integer. + VARIANT_CLASS_UINT32 VariantClass = C.G_VARIANT_CLASS_UINT32 //The GVariant is an unsigned 32 bit integer. + VARIANT_CLASS_INT64 VariantClass = C.G_VARIANT_CLASS_INT64 //The GVariant is a signed 64 bit integer. + VARIANT_CLASS_UINT64 VariantClass = C.G_VARIANT_CLASS_UINT64 //The GVariant is an unsigned 64 bit integer. + VARIANT_CLASS_HANDLE VariantClass = C.G_VARIANT_CLASS_HANDLE //The GVariant is a file handle index. + VARIANT_CLASS_DOUBLE VariantClass = C.G_VARIANT_CLASS_DOUBLE //The GVariant is a double precision floating point value. + VARIANT_CLASS_STRING VariantClass = C.G_VARIANT_CLASS_STRING //The GVariant is a normal string. + VARIANT_CLASS_OBJECT_PATH VariantClass = C.G_VARIANT_CLASS_OBJECT_PATH //The GVariant is a D-Bus object path string. + VARIANT_CLASS_SIGNATURE VariantClass = C.G_VARIANT_CLASS_SIGNATURE //The GVariant is a D-Bus signature string. + VARIANT_CLASS_VARIANT VariantClass = C.G_VARIANT_CLASS_VARIANT //The GVariant is a variant. + VARIANT_CLASS_MAYBE VariantClass = C.G_VARIANT_CLASS_MAYBE //The GVariant is a maybe-typed value. + VARIANT_CLASS_ARRAY VariantClass = C.G_VARIANT_CLASS_ARRAY //The GVariant is an array. + VARIANT_CLASS_TUPLE VariantClass = C.G_VARIANT_CLASS_TUPLE //The GVariant is a tuple. + VARIANT_CLASS_DICT_ENTRY VariantClass = C.G_VARIANT_CLASS_DICT_ENTRY //The GVariant is a dictionary entry. +) diff --git a/vendor/github.com/gotk3/gotk3/glib/gvariantdict.go b/vendor/github.com/gotk3/gotk3/glib/gvariantdict.go new file mode 100644 index 0000000..e682008 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gvariantdict.go @@ -0,0 +1,52 @@ +// Same copyright and license as the rest of the files in this project + +//GVariant : GVariant — strongly typed value datatype +// https://developer.gnome.org/glib/2.26/glib-GVariant.html + +package glib + +// #include +// #include +// #include "glib.go.h" +// #include "gvariant.go.h" +import "C" +import "unsafe" + +/* + * GVariantDict + */ + +// VariantDict is a representation of GLib's VariantDict. +type VariantDict struct { + GVariantDict *C.GVariantDict +} + +func (v *VariantDict) toGVariantDict() *C.GVariantDict { + if v == nil { + return nil + } + return v.native() +} + +func (v *VariantDict) toVariantDict() *VariantDict { + return v +} + +// newVariantDict creates a new VariantDict from a GVariantDict pointer. +func newVariantDict(p *C.GVariantDict) *VariantDict { + return &VariantDict{GVariantDict: p} +} + +// native returns a pointer to the underlying GVariantDict. +func (v *VariantDict) native() *C.GVariantDict { + if v == nil || v.GVariantDict == nil { + return nil + } + p := unsafe.Pointer(v.GVariantDict) + return C.toGVariantDict(p) +} + +// Native returns a pointer to the underlying GVariantDict. +func (v *VariantDict) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gvariantiter.go b/vendor/github.com/gotk3/gotk3/glib/gvariantiter.go new file mode 100644 index 0000000..17b55ae --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gvariantiter.go @@ -0,0 +1,52 @@ +// Same copyright and license as the rest of the files in this project + +//GVariant : GVariant — strongly typed value datatype +// https://developer.gnome.org/glib/2.26/glib-GVariant.html + +package glib + +// #include +// #include +// #include "glib.go.h" +// #include "gvariant.go.h" +import "C" +import "unsafe" + +/* + * GVariantIter + */ + +// VariantIter is a representation of GLib's GVariantIter. +type VariantIter struct { + GVariantIter *C.GVariantIter +} + +func (v *VariantIter) toGVariantIter() *C.GVariantIter { + if v == nil { + return nil + } + return v.native() +} + +func (v *VariantIter) toVariantIter() *VariantIter { + return v +} + +// newVariantIter creates a new VariantIter from a GVariantIter pointer. +func newVariantIter(p *C.GVariantIter) *VariantIter { + return &VariantIter{GVariantIter: p} +} + +// native returns a pointer to the underlying GVariantIter. +func (v *VariantIter) native() *C.GVariantIter { + if v == nil || v.GVariantIter == nil { + return nil + } + p := unsafe.Pointer(v.GVariantIter) + return C.toGVariantIter(p) +} + +// Native returns a pointer to the underlying GVariantIter. +func (v *VariantIter) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/gvarianttype.go b/vendor/github.com/gotk3/gotk3/glib/gvarianttype.go new file mode 100644 index 0000000..3723f43 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gvarianttype.go @@ -0,0 +1,147 @@ +// Same copyright and license as the rest of the files in this project + +//GVariant : GVariant — strongly typed value datatype +// https://developer.gnome.org/glib/2.26/glib-GVariant.html + +package glib + +// #include +// #include +// #include "gvarianttype.go.h" +import "C" + +import ( + "runtime" + "unsafe" +) + +// A VariantType is a wrapper for the GVariantType, which encodes type +// information for GVariants. +type VariantType struct { + GVariantType *C.GVariantType +} + +func (v *VariantType) native() *C.GVariantType { + if v == nil { + return nil + } + return v.GVariantType +} + +// String returns a copy of this VariantType's type string. +func (v *VariantType) String() string { + ch := C.g_variant_type_dup_string(v.native()) + defer C.g_free(C.gpointer(ch)) + return C.GoString((*C.char)(ch)) +} + +// newVariantType wraps a native GVariantType. +// Does not create a finalizer. +// Use takeVariantType for instances which need to be freed after use. +func newVariantType(v *C.GVariantType) *VariantType { + if v == nil { + return nil + } + return &VariantType{v} +} + +// takeVariantType wraps a native GVariantType +// and sets up a finalizer to free the instance during GC. +func takeVariantType(v *C.GVariantType) *VariantType { + if v == nil { + return nil + } + obj := &VariantType{v} + runtime.SetFinalizer(obj, (*VariantType).Free) + return obj +} + +// Variant types for comparing between them. Cannot be const because +// they are pointers. +// Note that variant types cannot be compared by value, use VariantTypeEqual() instead. +var ( + VARIANT_TYPE_BOOLEAN = newVariantType(C._G_VARIANT_TYPE_BOOLEAN) + VARIANT_TYPE_BYTE = newVariantType(C._G_VARIANT_TYPE_BYTE) + VARIANT_TYPE_INT16 = newVariantType(C._G_VARIANT_TYPE_INT16) + VARIANT_TYPE_UINT16 = newVariantType(C._G_VARIANT_TYPE_UINT16) + VARIANT_TYPE_INT32 = newVariantType(C._G_VARIANT_TYPE_INT32) + VARIANT_TYPE_UINT32 = newVariantType(C._G_VARIANT_TYPE_UINT32) + VARIANT_TYPE_INT64 = newVariantType(C._G_VARIANT_TYPE_INT64) + VARIANT_TYPE_UINT64 = newVariantType(C._G_VARIANT_TYPE_UINT64) + VARIANT_TYPE_HANDLE = newVariantType(C._G_VARIANT_TYPE_HANDLE) + VARIANT_TYPE_DOUBLE = newVariantType(C._G_VARIANT_TYPE_DOUBLE) + VARIANT_TYPE_STRING = newVariantType(C._G_VARIANT_TYPE_STRING) + VARIANT_TYPE_OBJECT_PATH = newVariantType(C._G_VARIANT_TYPE_OBJECT_PATH) + VARIANT_TYPE_SIGNATURE = newVariantType(C._G_VARIANT_TYPE_SIGNATURE) + VARIANT_TYPE_VARIANT = newVariantType(C._G_VARIANT_TYPE_VARIANT) + VARIANT_TYPE_ANY = newVariantType(C._G_VARIANT_TYPE_ANY) + VARIANT_TYPE_BASIC = newVariantType(C._G_VARIANT_TYPE_BASIC) + VARIANT_TYPE_MAYBE = newVariantType(C._G_VARIANT_TYPE_MAYBE) + VARIANT_TYPE_ARRAY = newVariantType(C._G_VARIANT_TYPE_ARRAY) + VARIANT_TYPE_TUPLE = newVariantType(C._G_VARIANT_TYPE_TUPLE) + VARIANT_TYPE_UNIT = newVariantType(C._G_VARIANT_TYPE_UNIT) + VARIANT_TYPE_DICT_ENTRY = newVariantType(C._G_VARIANT_TYPE_DICT_ENTRY) + VARIANT_TYPE_DICTIONARY = newVariantType(C._G_VARIANT_TYPE_DICTIONARY) + VARIANT_TYPE_STRING_ARRAY = newVariantType(C._G_VARIANT_TYPE_STRING_ARRAY) + VARIANT_TYPE_OBJECT_PATH_ARRAY = newVariantType(C._G_VARIANT_TYPE_OBJECT_PATH_ARRAY) + VARIANT_TYPE_BYTESTRING = newVariantType(C._G_VARIANT_TYPE_BYTESTRING) + VARIANT_TYPE_BYTESTRING_ARRAY = newVariantType(C._G_VARIANT_TYPE_BYTESTRING_ARRAY) + VARIANT_TYPE_VARDICT = newVariantType(C._G_VARIANT_TYPE_VARDICT) +) + +// Free is a wrapper around g_variant_type_free. +// Reference counting is usually handled in the gotk layer, +// most applications should not call this. +func (v *VariantType) Free() { + C.g_variant_type_free(v.native()) +} + +// VariantTypeNew is a wrapper around g_variant_type_new. +func VariantTypeNew(typeString string) *VariantType { + cstr := (*C.gchar)(C.CString(typeString)) + defer C.free(unsafe.Pointer(cstr)) + + c := C.g_variant_type_new(cstr) + return takeVariantType(c) +} + +// VariantTypeStringIsValid is a wrapper around g_variant_type_string_is_valid. +func VariantTypeStringIsValid(typeString string) bool { + cstr := (*C.gchar)(C.CString(typeString)) + defer C.free(unsafe.Pointer(cstr)) + + return gobool(C.g_variant_type_string_is_valid(cstr)) +} + +// VariantTypeEqual is a wrapper around g_variant_type_equal +func VariantTypeEqual(type1, type2 *VariantType) bool { + return gobool(C.g_variant_type_equal(C.gconstpointer(type1.native()), C.gconstpointer(type2.native()))) +} + +// IsSubtypeOf is a wrapper around g_variant_type_is_subtype_of +func (v *VariantType) IsSubtypeOf(supertype *VariantType) bool { + return gobool(C.g_variant_type_is_subtype_of(v.native(), supertype.native())) +} + +// TODO: +// g_variant_type_copy +// g_variant_type_string_scan +// g_variant_type_is_definite +// g_variant_type_is_container +// g_variant_type_is_basic +// g_variant_type_is_maybe +// g_variant_type_is_array +// g_variant_type_is_tuple +// g_variant_type_is_dict_entry +// g_variant_type_is_variant +// g_variant_type_hash +// g_variant_type_new_maybe +// g_variant_type_new_array +// g_variant_type_new_tuple +// g_variant_type_new_dict_entry +// g_variant_type_element +// g_variant_type_n_items +// g_variant_type_first +// g_variant_type_next +// g_variant_type_key +// g_variant_type_value diff --git a/vendor/github.com/gotk3/gotk3/glib/gvarianttype.go.h b/vendor/github.com/gotk3/gotk3/glib/gvarianttype.go.h new file mode 100644 index 0000000..283a9dc --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gvarianttype.go.h @@ -0,0 +1,39 @@ +// Same copyright and license as the rest of the files in this project + +// GVariant : GVariant — strongly typed value datatype +// https://developer.gnome.org/glib/2.26/glib-GVariant.html + +#ifndef __GVARIANTTYPE_GO_H__ +#define __GVARIANTTYPE_GO_H__ + +const GVariantType *_G_VARIANT_TYPE_BOOLEAN = G_VARIANT_TYPE_BOOLEAN; +const GVariantType *_G_VARIANT_TYPE_BYTE = G_VARIANT_TYPE_BYTE; +const GVariantType *_G_VARIANT_TYPE_INT16 = G_VARIANT_TYPE_INT16; +const GVariantType *_G_VARIANT_TYPE_UINT16 = G_VARIANT_TYPE_UINT16; +const GVariantType *_G_VARIANT_TYPE_INT32 = G_VARIANT_TYPE_INT32; +const GVariantType *_G_VARIANT_TYPE_UINT32 = G_VARIANT_TYPE_UINT32; +const GVariantType *_G_VARIANT_TYPE_INT64 = G_VARIANT_TYPE_INT64; +const GVariantType *_G_VARIANT_TYPE_UINT64 = G_VARIANT_TYPE_UINT64; +const GVariantType *_G_VARIANT_TYPE_HANDLE = G_VARIANT_TYPE_HANDLE; +const GVariantType *_G_VARIANT_TYPE_DOUBLE = G_VARIANT_TYPE_DOUBLE; +const GVariantType *_G_VARIANT_TYPE_STRING = G_VARIANT_TYPE_STRING; +const GVariantType *_G_VARIANT_TYPE_OBJECT_PATH = G_VARIANT_TYPE_OBJECT_PATH; +const GVariantType *_G_VARIANT_TYPE_SIGNATURE = G_VARIANT_TYPE_SIGNATURE; +const GVariantType *_G_VARIANT_TYPE_VARIANT = G_VARIANT_TYPE_VARIANT; +const GVariantType *_G_VARIANT_TYPE_ANY = G_VARIANT_TYPE_ANY; +const GVariantType *_G_VARIANT_TYPE_BASIC = G_VARIANT_TYPE_BASIC; +const GVariantType *_G_VARIANT_TYPE_MAYBE = G_VARIANT_TYPE_MAYBE; +const GVariantType *_G_VARIANT_TYPE_ARRAY = G_VARIANT_TYPE_ARRAY; +const GVariantType *_G_VARIANT_TYPE_TUPLE = G_VARIANT_TYPE_TUPLE; +const GVariantType *_G_VARIANT_TYPE_UNIT = G_VARIANT_TYPE_UNIT; +const GVariantType *_G_VARIANT_TYPE_DICT_ENTRY = G_VARIANT_TYPE_DICT_ENTRY; +const GVariantType *_G_VARIANT_TYPE_DICTIONARY = G_VARIANT_TYPE_DICTIONARY; +const GVariantType *_G_VARIANT_TYPE_STRING_ARRAY = G_VARIANT_TYPE_STRING_ARRAY; +const GVariantType *_G_VARIANT_TYPE_OBJECT_PATH_ARRAY = + G_VARIANT_TYPE_OBJECT_PATH_ARRAY; +const GVariantType *_G_VARIANT_TYPE_BYTESTRING = G_VARIANT_TYPE_BYTESTRING; +const GVariantType *_G_VARIANT_TYPE_BYTESTRING_ARRAY = + G_VARIANT_TYPE_BYTESTRING_ARRAY; +const GVariantType *_G_VARIANT_TYPE_VARDICT = G_VARIANT_TYPE_VARDICT; + +#endif diff --git a/vendor/github.com/gotk3/gotk3/glib/gvarianttype_test.go b/vendor/github.com/gotk3/gotk3/glib/gvarianttype_test.go new file mode 100644 index 0000000..0481f3a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/gvarianttype_test.go @@ -0,0 +1,118 @@ +// Same copyright and license as the rest of the files in this project + +package glib_test + +import ( + "testing" + + "github.com/gotk3/gotk3/glib" +) + +func TestVariantTypeEqual(t *testing.T) { + testCases := []struct { + desc string + type1 *glib.VariantType + type2 *glib.VariantType + expected bool + }{ + { + desc: "bool == bool constants", + type1: glib.VARIANT_TYPE_BOOLEAN, + type2: glib.VARIANT_TYPE_BOOLEAN, + expected: true, + }, + { + desc: "bool != string constants", + type1: glib.VARIANT_TYPE_BOOLEAN, + type2: glib.VARIANT_TYPE_STRING, + expected: false, + }, + { + desc: "bool == bool dynamic", + type1: glib.VARIANT_TYPE_BOOLEAN, + type2: glib.VariantTypeNew("b"), + expected: true, + }, + { + desc: "bool != string dynamic", + type1: glib.VariantTypeNew("b"), + type2: glib.VariantTypeNew("s"), + expected: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + actual := glib.VariantTypeEqual(tC.type1, tC.type2) + if tC.expected != actual { + t.Error("Expected", tC.expected, "got", actual) + } + }) + } +} + +func TestVariantTypeStringIsValid(t *testing.T) { + testCases := []struct { + desc string + input string + expected bool + }{ + { + desc: "String", + input: "s", + expected: true, + }, + { + desc: "Boolean", + input: "b", + expected: true, + }, + { + desc: "Tuple of String and Boolean", + input: "(sb)", + expected: true, + }, + { + desc: "Junk", + input: "r{{sb}", + expected: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + actual := glib.VariantTypeStringIsValid(tC.input) + if tC.expected != actual { + t.Error("Expected", tC.expected, "got", actual) + } + }) + } +} + +func TestVariantIsSubtypeOf(t *testing.T) { + testCases := []struct { + desc string + type1 *glib.VariantType + superType *glib.VariantType + expected bool + }{ + { + desc: "bool is not a supertype", + type1: glib.VARIANT_TYPE_STRING, + superType: glib.VARIANT_TYPE_BOOLEAN, + expected: false, + }, + { + desc: "a* is supertype of as", + type1: glib.VariantTypeNew("as"), + superType: glib.VariantTypeNew("a*"), + expected: true, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + actual := tC.type1.IsSubtypeOf(tC.superType) + if tC.expected != actual { + t.Error("Expected", tC.expected, "got", actual) + } + }) + } +} diff --git a/vendor/github.com/gotk3/gotk3/glib/list.go b/vendor/github.com/gotk3/gotk3/glib/list.go new file mode 100644 index 0000000..a49a625 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/list.go @@ -0,0 +1,175 @@ +package glib + +// #include +// #include +// #include "glib.go.h" +import "C" +import ( + "unsafe" +) + +/* + * Linked Lists + */ + +// List is a representation of Glib's GList. +type List struct { + list *C.struct__GList + // If set, dataWrap is called every time NthData() + // or Data() is called to wrap raw underlying + // value into appropriate type. + dataWrap func(unsafe.Pointer) interface{} +} + +func WrapList(obj uintptr) *List { + return wrapList((*C.struct__GList)(unsafe.Pointer(obj))) +} + +func wrapList(obj *C.struct__GList) *List { + if obj == nil { + return nil + } + return &List{list: obj} +} + +func (v *List) wrapNewHead(obj *C.struct__GList) *List { + if obj == nil { + return nil + } + return &List{ + list: obj, + dataWrap: v.dataWrap, + } +} + +func (v *List) Native() uintptr { + return uintptr(unsafe.Pointer(v.list)) +} + +func (v *List) native() *C.struct__GList { + if v == nil || v.list == nil { + return nil + } + return v.list +} + +// DataWapper sets wrap functions, which is called during NthData() +// and Data(). It's used to cast raw C data into appropriate +// Go structures and types every time that data is retreived. +func (v *List) DataWrapper(fn func(unsafe.Pointer) interface{}) { + if v == nil { + return + } + v.dataWrap = fn +} + +// Append is a wrapper around g_list_append(). +func (v *List) Append(data uintptr) *List { + glist := C.g_list_append(v.native(), C.gpointer(data)) + return v.wrapNewHead(glist) +} + +// Prepend is a wrapper around g_list_prepend(). +func (v *List) Prepend(data uintptr) *List { + glist := C.g_list_prepend(v.native(), C.gpointer(data)) + return v.wrapNewHead(glist) +} + +// Insert is a wrapper around g_list_insert(). +func (v *List) Insert(data uintptr, position int) *List { + glist := C.g_list_insert(v.native(), C.gpointer(data), C.gint(position)) + return v.wrapNewHead(glist) +} + +// Length is a wrapper around g_list_length(). +func (v *List) Length() uint { + return uint(C.g_list_length(v.native())) +} + +// nthDataRaw is a wrapper around g_list_nth_data(). +func (v *List) nthDataRaw(n uint) unsafe.Pointer { + return unsafe.Pointer(C.g_list_nth_data(v.native(), C.guint(n))) +} + +// Nth() is a wrapper around g_list_nth(). +func (v *List) Nth(n uint) *List { + list := wrapList(C.g_list_nth(v.native(), C.guint(n))) + list.DataWrapper(v.dataWrap) + return list +} + +// NthData acts the same as g_list_nth_data(), but passes +// retrieved value before returning through wrap function, set by DataWrapper(). +// If no wrap function is set, it returns raw unsafe.Pointer. +func (v *List) NthData(n uint) interface{} { + ptr := v.nthDataRaw(n) + if v.dataWrap != nil { + return v.dataWrap(ptr) + } + return ptr +} + +// Free is a wrapper around g_list_free(). +func (v *List) Free() { + C.g_list_free(v.native()) +} + +// Next is a wrapper around the next struct field +func (v *List) Next() *List { + return v.wrapNewHead(v.native().next) +} + +// Previous is a wrapper around the prev struct field +func (v *List) Previous() *List { + return v.wrapNewHead(v.native().prev) +} + +// First is a wrapper around g_list_first(). +func (v *List) First() *List { + return v.wrapNewHead(C.g_list_first(v.native())) +} + +// Last is a wrapper around g_list_last(). +func (v *List) Last() *List { + return v.wrapNewHead(C.g_list_last(v.native())) +} + +// Reverse is a wrapper around g_list_reverse(). +func (v *List) Reverse() *List { + return v.wrapNewHead(C.g_list_reverse(v.native())) +} + +// dataRaw is a wrapper around the data struct field +func (v *List) dataRaw() unsafe.Pointer { + return unsafe.Pointer(v.native().data) +} + +// Data acts the same as data struct field, but passes +// retrieved value before returning through wrap function, set by DataWrapper(). +// If no wrap function is set, it returns raw unsafe.Pointer. +func (v *List) Data() interface{} { + ptr := v.dataRaw() + if v.dataWrap != nil { + return v.dataWrap(ptr) + } + return ptr +} + +// Foreach acts the same as g_list_foreach(). +// No user_data argument is implemented because of Go clojure capabilities. +func (v *List) Foreach(fn func(item interface{})) { + for l := v; l != nil; l = l.Next() { + fn(l.Data()) + } +} + +// FreeFull acts the same as g_list_free_full(). +// Calling list.FreeFull(fn) is equivalent to calling list.Foreach(fn) and +// list.Free() sequentially. +func (v *List) FreeFull(fn func(item interface{})) { + v.Foreach(fn) + v.Free() +} + +// CompareDataFunc is a representation of GCompareDataFunc +type CompareDataFunc func(a, b uintptr) int diff --git a/vendor/github.com/gotk3/gotk3/glib/list_test.go b/vendor/github.com/gotk3/gotk3/glib/list_test.go new file mode 100644 index 0000000..66e3693 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/list_test.go @@ -0,0 +1,76 @@ +package glib + +import ( + "fmt" + "testing" + "unsafe" +) + +func TestList_Basics(t *testing.T) { + list := (&List{}).Append(0).Append(1).Append(2) + if list.Length() != 3 { + t.Errorf("Length of list with 3 appended elements must be 3. (Got %v).", list.Length()) + } + + list = (&List{}).Prepend(0).Prepend(1).Prepend(2) + if list.Length() != 3 { + t.Errorf("Length of list with 3 prepended elements must be 3. (Got %v).", list.Length()) + } + + list = (&List{}).Insert(0, 0).Insert(1, 0).Insert(2, 0) + if list.Length() != 3 { + t.Errorf("Length of list with 3 inserted elements must be 3. (Got %v).", list.Length()) + } +} + +func TestList_DataWrapper(t *testing.T) { + list := (&List{}).Append(0).Append(1).Append(2) + list.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return fmt.Sprintf("Value %v", uintptr(ptr)) + }) + + i := 0 + for l := list; l != nil; l = l.Next() { + expect := fmt.Sprintf("Value %v", i) + i++ + actual, ok := l.Data().(string) + if !ok { + t.Error("DataWrapper must have returned a string!") + } + if actual != expect { + t.Errorf("DataWrapper returned unexpected result. Expected '%v', got '%v'.", expect, actual) + } + } +} + +func TestList_Foreach(t *testing.T) { + list := (&List{}).Append(0).Append(1).Append(2) + list.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return int(uintptr(ptr) + 1) + }) + + sum := 0 + list.Foreach(func(item interface{}) { + sum += item.(int) + }) + + if sum != 6 { + t.Errorf("Foreach resulted into wrong sum. Got %v, expected %v.", sum, 6) + } +} + +func TestList_Nth(t *testing.T) { + list := (&List{}).Append(0).Append(1).Append(2) + list.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return int(uintptr(ptr) + 1) + }) + + for i := uint(0); i < 3; i++ { + nth := list.Nth(i).Data().(int) + nthData := list.NthData(i).(int) + + if nth != nthData { + t.Errorf("%v's element didn't match. Nth->Data returned %v; NthData returned %v.", i, nth, nthData) + } + } +} diff --git a/vendor/github.com/gotk3/gotk3/glib/menu.go b/vendor/github.com/gotk3/gotk3/glib/menu.go new file mode 100644 index 0000000..0e3a68c --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/menu.go @@ -0,0 +1,447 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +// Predefined attribute names for GMenu +var ( + MENU_ATTRIBUTE_ACTION string = C.G_MENU_ATTRIBUTE_ACTION + MENU_ATTRIBUTE_ACTION_NAMESPACE string = C.G_MENU_ATTRIBUTE_ACTION_NAMESPACE + MENU_ATTRIBUTE_TARGET string = C.G_MENU_ATTRIBUTE_TARGET + MENU_ATTRIBUTE_LABEL string = C.G_MENU_ATTRIBUTE_LABEL + MENU_ATTRIBUTE_ICON string = C.G_MENU_ATTRIBUTE_ICON +) + +// Predefined link names for GMenu +var ( + MENU_LINK_SECTION string = C.G_MENU_LINK_SECTION + MENU_LINK_SUBMENU string = C.G_MENU_LINK_SUBMENU +) + +// MenuModel is a representation of GMenuModel. +type MenuModel struct { + *Object +} + +// native returns a pointer to the underlying GMenuModel. +func (v *MenuModel) native() *C.GMenuModel { + if v == nil || v.GObject == nil { + return nil + } + return C.toGMenuModel(unsafe.Pointer(v.GObject)) +} + +// Native returns a pointer to the underlying GMenuModel. +func (v *MenuModel) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalMenuModel(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapMenuModel(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapMenuModel(obj *Object) *MenuModel { + return &MenuModel{obj} +} + +// IsMutable is a wrapper around g_menu_model_is_mutable(). +func (v *MenuModel) IsMutable() bool { + return gobool(C.g_menu_model_is_mutable(v.native())) +} + +// GetNItems is a wrapper around g_menu_model_get_n_items(). +func (v *MenuModel) GetNItems() int { + return int(C.g_menu_model_get_n_items(v.native())) +} + +// GetItemLink is a wrapper around g_menu_model_get_item_link(). +func (v *MenuModel) GetItemLink(index int, link string) *MenuModel { + cstr := (*C.gchar)(C.CString(link)) + defer C.free(unsafe.Pointer(cstr)) + c := C.g_menu_model_get_item_link(v.native(), C.gint(index), cstr) + if c == nil { + return nil + } + return wrapMenuModel(wrapObject(unsafe.Pointer(c))) +} + +// ItemsChanged is a wrapper around g_menu_model_items_changed(). +func (v *MenuModel) ItemsChanged(position, removed, added int) { + C.g_menu_model_items_changed(v.native(), C.gint(position), C.gint(removed), C.gint(added)) +} + +// GVariant * g_menu_model_get_item_attribute_value () +// gboolean g_menu_model_get_item_attribute () +// GMenuAttributeIter * g_menu_model_iterate_item_attributes () +// GMenuLinkIter * g_menu_model_iterate_item_links () + +// Menu is a representation of GMenu. +type Menu struct { + MenuModel +} + +// native() returns a pointer to the underlying GMenu. +func (v *Menu) native() *C.GMenu { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGMenu(p) +} + +func marshalMenu(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapMenu(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapMenu(obj *Object) *Menu { + return &Menu{MenuModel{obj}} +} + +// MenuNew is a wrapper around g_menu_new(). +func MenuNew() *Menu { + c := C.g_menu_new() + if c == nil { + return nil + } + return wrapMenu(wrapObject(unsafe.Pointer(c))) +} + +// Freeze is a wrapper around g_menu_freeze(). +func (v *Menu) Freeze() { + C.g_menu_freeze(v.native()) +} + +// Insert is a wrapper around g_menu_insert(). +func (v *Menu) Insert(position int, label, detailedAction string) { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + cstr2 := (*C.gchar)(C.CString(detailedAction)) + defer C.free(unsafe.Pointer(cstr2)) + + C.g_menu_insert(v.native(), C.gint(position), cstr1, cstr2) +} + +// Prepend is a wrapper around g_menu_prepend(). +func (v *Menu) Prepend(label, detailedAction string) { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + cstr2 := (*C.gchar)(C.CString(detailedAction)) + defer C.free(unsafe.Pointer(cstr2)) + + C.g_menu_prepend(v.native(), cstr1, cstr2) +} + +// Append is a wrapper around g_menu_append(). +func (v *Menu) Append(label, detailedAction string) { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + cstr2 := (*C.gchar)(C.CString(detailedAction)) + defer C.free(unsafe.Pointer(cstr2)) + + C.g_menu_append(v.native(), cstr1, cstr2) +} + +// InsertItem is a wrapper around g_menu_insert_item(). +func (v *Menu) InsertItem(position int, item *MenuItem) { + C.g_menu_insert_item(v.native(), C.gint(position), item.native()) +} + +// AppendItem is a wrapper around g_menu_append_item(). +func (v *Menu) AppendItem(item *MenuItem) { + C.g_menu_append_item(v.native(), item.native()) +} + +// PrependItem is a wrapper around g_menu_prepend_item(). +func (v *Menu) PrependItem(item *MenuItem) { + C.g_menu_prepend_item(v.native(), item.native()) +} + +// InsertSection is a wrapper around g_menu_insert_section(). +func (v *Menu) InsertSection(position int, label string, section *MenuModel) { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_menu_insert_section(v.native(), C.gint(position), cstr1, section.native()) +} + +// PrependSection is a wrapper around g_menu_prepend_section(). +func (v *Menu) PrependSection(label string, section *MenuModel) { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_menu_prepend_section(v.native(), cstr1, section.native()) +} + +// AppendSection is a wrapper around g_menu_append_section(). +func (v *Menu) AppendSection(label string, section *MenuModel) { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_menu_append_section(v.native(), cstr1, section.native()) +} + +// InsertSectionWithoutLabel is a wrapper around g_menu_insert_section() +// with label set to null. +func (v *Menu) InsertSectionWithoutLabel(position int, section *MenuModel) { + C.g_menu_insert_section(v.native(), C.gint(position), nil, section.native()) +} + +// PrependSectionWithoutLabel is a wrapper around +// g_menu_prepend_section() with label set to null. +func (v *Menu) PrependSectionWithoutLabel(section *MenuModel) { + C.g_menu_prepend_section(v.native(), nil, section.native()) +} + +// AppendSectionWithoutLabel is a wrapper around g_menu_append_section() +// with label set to null. +func (v *Menu) AppendSectionWithoutLabel(section *MenuModel) { + C.g_menu_append_section(v.native(), nil, section.native()) +} + +// InsertSubmenu is a wrapper around g_menu_insert_submenu(). +func (v *Menu) InsertSubmenu(position int, label string, submenu *MenuModel) { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_menu_insert_submenu(v.native(), C.gint(position), cstr1, submenu.native()) +} + +// PrependSubmenu is a wrapper around g_menu_prepend_submenu(). +func (v *Menu) PrependSubmenu(label string, submenu *MenuModel) { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_menu_prepend_submenu(v.native(), cstr1, submenu.native()) +} + +// AppendSubmenu is a wrapper around g_menu_append_submenu(). +func (v *Menu) AppendSubmenu(label string, submenu *MenuModel) { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_menu_append_submenu(v.native(), cstr1, submenu.native()) +} + +// Remove is a wrapper around g_menu_remove(). +func (v *Menu) Remove(position int) { + C.g_menu_remove(v.native(), C.gint(position)) +} + +// RemoveAll is a wrapper around g_menu_remove_all(). +func (v *Menu) RemoveAll() { + C.g_menu_remove_all(v.native()) +} + +// MenuItem is a representation of GMenuItem. +type MenuItem struct { + *Object +} + +// native() returns a pointer to the underlying GMenuItem. +func (v *MenuItem) native() *C.GMenuItem { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGMenuItem(p) +} + +func marshalMenuItem(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapMenuItem(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapMenuItem(obj *Object) *MenuItem { + return &MenuItem{obj} +} + +// MenuItemNew is a wrapper around g_menu_item_new(NULL, NULL). +func MenuItemNew() *MenuItem { + c := C.g_menu_item_new(nil, nil) + if c == nil { + return nil + } + return wrapMenuItem(wrapObject(unsafe.Pointer(c))) +} + +// MenuItemNewWithLabel is a wrapper around g_menu_item_new(label, NULL). +func MenuItemNewWithLabel(label string) *MenuItem { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + c := C.g_menu_item_new(cstr1, nil) + if c == nil { + return nil + } + return wrapMenuItem(wrapObject(unsafe.Pointer(c))) +} + +// MenuItemNewWithAction is a wrapper around g_menu_item_new(NULL, detailedAction). +func MenuItemNewWithAction(detailedAction string) *MenuItem { + cstr1 := (*C.gchar)(C.CString(detailedAction)) + defer C.free(unsafe.Pointer(cstr1)) + + c := C.g_menu_item_new(nil, cstr1) + if c == nil { + return nil + } + return wrapMenuItem(wrapObject(unsafe.Pointer(c))) +} + +// MenuItemNewWithLabelAndAction is a wrapper around g_menu_item_new(label, detailedAction). +func MenuItemNewWithLabelAndAction(label, detailedAction string) *MenuItem { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + cstr2 := (*C.gchar)(C.CString(detailedAction)) + defer C.free(unsafe.Pointer(cstr2)) + + c := C.g_menu_item_new(cstr1, cstr2) + if c == nil { + return nil + } + return wrapMenuItem(wrapObject(unsafe.Pointer(c))) +} + +// MenuItemNewSection is a wrapper around g_menu_item_new_section(). +func MenuItemNewSection(label string, section *MenuModel) *MenuItem { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + c := C.g_menu_item_new_section(cstr1, section.native()) + if c == nil { + return nil + } + return wrapMenuItem(wrapObject(unsafe.Pointer(c))) +} + +// MenuItemNewSubmenu is a wrapper around g_menu_item_new_submenu(). +func MenuItemNewSubmenu(label string, submenu *MenuModel) *MenuItem { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + c := C.g_menu_item_new_submenu(cstr1, submenu.native()) + if c == nil { + return nil + } + return wrapMenuItem(wrapObject(unsafe.Pointer(c))) +} + +// MenuItemNewFromModel is a wrapper around g_menu_item_new_from_model(). +func MenuItemNewFromModel(model *MenuModel, index int) *MenuItem { + c := C.g_menu_item_new_from_model(model.native(), C.gint(index)) + if c == nil { + return nil + } + return wrapMenuItem(wrapObject(unsafe.Pointer(c))) +} + +// SetLabel is a wrapper around g_menu_item_set_label(). +func (v *MenuItem) SetLabel(label string) { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_menu_item_set_label(v.native(), cstr1) +} + +// UnsetLabel is a wrapper around g_menu_item_set_label(NULL). +func (v *MenuItem) UnsetLabel() { + C.g_menu_item_set_label(v.native(), nil) +} + +// SetDetailedAction is a wrapper around g_menu_item_set_detailed_action(). +func (v *MenuItem) SetDetailedAction(act string) { + cstr1 := (*C.gchar)(C.CString(act)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_menu_item_set_detailed_action(v.native(), cstr1) +} + +// SetSection is a wrapper around g_menu_item_set_section(). +func (v *MenuItem) SetSection(section *MenuModel) { + C.g_menu_item_set_section(v.native(), section.native()) +} + +// SetSubmenu is a wrapper around g_menu_item_set_submenu(). +func (v *MenuItem) SetSubmenu(submenu *MenuModel) { + C.g_menu_item_set_submenu(v.native(), submenu.native()) +} + +// GetLink is a wrapper around g_menu_item_get_link(). +func (v *MenuItem) GetLink(link string) *MenuModel { + cstr1 := (*C.gchar)(C.CString(link)) + defer C.free(unsafe.Pointer(cstr1)) + + c := C.g_menu_item_get_link(v.native(), cstr1) + if c == nil { + return nil + } + return wrapMenuModel(wrapObject(unsafe.Pointer(c))) +} + +// SetLink is a wrapper around g_menu_item_Set_link(). +func (v *MenuItem) SetLink(link string, model *MenuModel) { + cstr1 := (*C.gchar)(C.CString(link)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_menu_item_set_link(v.native(), cstr1, model.native()) +} + +// SetActionAndTargetValue is a wrapper around g_menu_item_set_action_and_target_value() +func (v *MenuItem) SetActionAndTargetValue(action string, targetValue IVariant) { + cstr1 := (*C.gchar)(C.CString(action)) + defer C.free(unsafe.Pointer(cstr1)) + + var c *C.GVariant + if targetValue != nil { + c = targetValue.ToGVariant() + } + + C.g_menu_item_set_action_and_target_value(v.native(), cstr1, c) +} + +// UnsetAction is a wrapper around g_menu_item_set_action_and_target_value(NULL, NULL) +// Unsets both action and target value. Unsetting the action also clears the target value. +func (v *MenuItem) UnsetAction() { + C.g_menu_item_set_action_and_target_value(v.native(), nil, nil) +} + +// SetAttributeValue is a wrapper around g_menu_item_set_attribute_value() +func (v *MenuItem) SetAttributeValue(attribute string, value IVariant) { + var c *C.GVariant + if value != nil { + c = value.ToGVariant() + } + + cstr1 := (*C.gchar)(C.CString(attribute)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_menu_item_set_attribute_value(v.native(), cstr1, c) +} + +// GetAttributeValue is a wrapper around g_menu_item_get_attribute_value() +func (v *MenuItem) GetAttributeValue(attribute string, expectedType *VariantType) *Variant { + cstr1 := (*C.gchar)(C.CString(attribute)) + defer C.free(unsafe.Pointer(cstr1)) + + c := C.g_menu_item_get_attribute_value(v.native(), cstr1, expectedType.native()) + if c == nil { + return nil + } + return newVariant(c) +} + +// TODO: These require positional parameters with *any* type, according to the format string passed. +// This is likely not possible to represent 1:1 in go. +// gboolean g_menu_item_get_attribute () +// void g_menu_item_set_attribute () +// void g_menu_item_set_action_and_target () diff --git a/vendor/github.com/gotk3/gotk3/glib/menu_test.go b/vendor/github.com/gotk3/gotk3/glib/menu_test.go new file mode 100644 index 0000000..cdcdb80 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/menu_test.go @@ -0,0 +1,143 @@ +package glib_test + +import ( + "testing" + + "github.com/gotk3/gotk3/glib" +) + +func TestGetSetAttributeValueCustomBool(t *testing.T) { + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "false", + value: false, + }, + } + + menuItem := glib.MenuItemNew() + + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + variant := glib.VariantFromBoolean(tC.value) + + menuItem.SetAttributeValue("custom-bool-attribute", variant) + actual := menuItem.GetAttributeValue("custom-bool-attribute", glib.VARIANT_TYPE_BOOLEAN) + + if !actual.IsType(glib.VARIANT_TYPE_BOOLEAN) { + t.Error("Expected value of type", glib.VARIANT_TYPE_BOOLEAN, "got", actual.Type()) + } + + if tC.value != actual.GetBoolean() { + t.Error("Expected", tC.value, "got", actual) + } + }) + } +} + +func TestUnsetLabel(t *testing.T) { + menuItem := glib.MenuItemNewWithLabel("unit_label") + + menuItem.UnsetLabel() + + value := menuItem.GetAttributeValue(glib.MENU_ATTRIBUTE_LABEL, glib.VARIANT_TYPE_STRING) + actual := value.GetString() + + if "" != actual { + t.Error("Expected empty string, got", actual) + } +} + +func TestSetLabel(t *testing.T) { + menuItem := glib.MenuItemNewWithLabel("unit_label") + + expected := "New Label" + menuItem.SetLabel(expected) + + value := menuItem.GetAttributeValue(glib.MENU_ATTRIBUTE_LABEL, glib.VARIANT_TYPE_STRING) + actual := value.GetString() + + if expected != actual { + t.Error("Expected", expected, "got", actual) + } +} + +func TestSetDetailedAction(t *testing.T) { + menuItem := glib.MenuItemNewWithAction("unit_action") + + expected := "new-action" + menuItem.SetDetailedAction(expected) + + value := menuItem.GetAttributeValue(glib.MENU_ATTRIBUTE_ACTION, glib.VARIANT_TYPE_STRING) + actual := value.GetString() + + if expected != actual { + t.Error("Expected", expected, "got", actual) + } +} + +func TestSetActionAndTargetValue(t *testing.T) { + menuItem := glib.MenuItemNew() + + t.Run("Action, Value", func(t *testing.T) { + expectedValue := glib.VariantFromString("Hello!") + expected := "act1" + menuItem.SetActionAndTargetValue(expected, expectedValue) + + // Check target value + actualValue := menuItem.GetAttributeValue(glib.MENU_ATTRIBUTE_TARGET, glib.VARIANT_TYPE_STRING) + if expectedValue.Native() != actualValue.Native() { + t.Error("Expected", expectedValue.Native(), "got", actualValue.Native()) + } + + // Check action value + actualAction := menuItem.GetAttributeValue(glib.MENU_ATTRIBUTE_ACTION, glib.VARIANT_TYPE_STRING).GetString() + if expected != actualAction { + t.Error("Expected", expected, "got", actualAction) + } + }) + t.Run("Action, Null Value", func(t *testing.T) { + expected := "act2" + menuItem.SetActionAndTargetValue(expected, nil) + + // Check target value + actualValue := menuItem.GetAttributeValue(glib.MENU_ATTRIBUTE_TARGET, glib.VARIANT_TYPE_STRING) + if actualValue != nil { + t.Error("Expected nil value got", actualValue.Native()) + } + + // Check action value + actualAction := menuItem.GetAttributeValue(glib.MENU_ATTRIBUTE_ACTION, glib.VARIANT_TYPE_STRING).GetString() + if expected != actualAction { + t.Error("Expected", expected, "got", actualAction) + } + }) +} + +func TestUnsetAction(t *testing.T) { + menuItem := glib.MenuItemNew() + + initialValue := glib.VariantFromString("Hello!") + initial := "act1" + menuItem.SetActionAndTargetValue(initial, initialValue) + + menuItem.UnsetAction() + + // Check target value + actualValue := menuItem.GetAttributeValue(glib.MENU_ATTRIBUTE_TARGET, glib.VARIANT_TYPE_STRING) + if actualValue != nil { + t.Error("Expected nil value got", actualValue.Native()) + } + + // Check action value + actualAction := menuItem.GetAttributeValue(glib.MENU_ATTRIBUTE_ACTION, glib.VARIANT_TYPE_STRING) + if actualAction != nil { + t.Error("Expected nil action got", actualAction.Native()) + } +} diff --git a/vendor/github.com/gotk3/gotk3/glib/notifications.go b/vendor/github.com/gotk3/gotk3/glib/notifications.go new file mode 100644 index 0000000..f1a8c74 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/notifications.go @@ -0,0 +1,94 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +// Notification is a representation of GNotification. +type Notification struct { + *Object +} + +// native() returns a pointer to the underlying GNotification. +func (v *Notification) native() *C.GNotification { + if v == nil || v.GObject == nil { + return nil + } + return C.toGNotification(unsafe.Pointer(v.GObject)) +} + +func (v *Notification) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalNotification(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapNotification(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapNotification(obj *Object) *Notification { + return &Notification{obj} +} + +// NotificationNew is a wrapper around g_notification_new(). +func NotificationNew(title string) *Notification { + cstr1 := (*C.gchar)(C.CString(title)) + defer C.free(unsafe.Pointer(cstr1)) + + c := C.g_notification_new(cstr1) + if c == nil { + return nil + } + return wrapNotification(wrapObject(unsafe.Pointer(c))) +} + +// SetTitle is a wrapper around g_notification_set_title(). +func (v *Notification) SetTitle(title string) { + cstr1 := (*C.gchar)(C.CString(title)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_notification_set_title(v.native(), cstr1) +} + +// SetBody is a wrapper around g_notification_set_body(). +func (v *Notification) SetBody(body string) { + cstr1 := (*C.gchar)(C.CString(body)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_notification_set_body(v.native(), cstr1) +} + +// SetDefaultAction is a wrapper around g_notification_set_default_action(). +func (v *Notification) SetDefaultAction(detailedAction string) { + cstr1 := (*C.gchar)(C.CString(detailedAction)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_notification_set_default_action(v.native(), cstr1) +} + +// AddButton is a wrapper around g_notification_add_button(). +func (v *Notification) AddButton(label, detailedAction string) { + cstr1 := (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr1)) + + cstr2 := (*C.gchar)(C.CString(detailedAction)) + defer C.free(unsafe.Pointer(cstr2)) + + C.g_notification_add_button(v.native(), cstr1, cstr2) +} + +// SetIcon is a wrapper around g_notification_set_icon(). +func (v *Notification) SetIcon(iconPath string) { + fileIcon := FileIconNew(iconPath) + + C.g_notification_set_icon(v.native(), (*C.GIcon)(fileIcon.native())) +} + +// void g_notification_set_default_action_and_target () // requires varargs +// void g_notification_set_default_action_and_target_value () // requires variant +// void g_notification_add_button_with_target () // requires varargs +// void g_notification_add_button_with_target_value () //requires variant +// void g_notification_set_urgent () // Deprecated, so not implemented diff --git a/vendor/github.com/gotk3/gotk3/glib/settings.go b/vendor/github.com/gotk3/gotk3/glib/settings.go new file mode 100644 index 0000000..1bca146 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/settings.go @@ -0,0 +1,304 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +// Settings is a representation of GSettings. +type Settings struct { + *Object +} + +// native() returns a pointer to the underlying GSettings. +func (v *Settings) native() *C.GSettings { + if v == nil || v.GObject == nil { + return nil + } + return C.toGSettings(unsafe.Pointer(v.GObject)) +} + +func (v *Settings) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalSettings(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapSettings(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapSettings(obj *Object) *Settings { + return &Settings{obj} +} + +func wrapFullSettings(obj *C.GSettings) *Settings { + if obj == nil { + return nil + } + return wrapSettings(wrapObject(unsafe.Pointer(obj))) +} + +// SettingsNew is a wrapper around g_settings_new(). +func SettingsNew(schemaID string) *Settings { + cstr := (*C.gchar)(C.CString(schemaID)) + defer C.free(unsafe.Pointer(cstr)) + + return wrapFullSettings(C.g_settings_new(cstr)) +} + +// SettingsNewWithPath is a wrapper around g_settings_new_with_path(). +func SettingsNewWithPath(schemaID, path string) *Settings { + cstr1 := (*C.gchar)(C.CString(schemaID)) + defer C.free(unsafe.Pointer(cstr1)) + + cstr2 := (*C.gchar)(C.CString(path)) + defer C.free(unsafe.Pointer(cstr2)) + + return wrapFullSettings(C.g_settings_new_with_path(cstr1, cstr2)) +} + +// SettingsNewWithBackend is a wrapper around g_settings_new_with_backend(). +func SettingsNewWithBackend(schemaID string, backend *SettingsBackend) *Settings { + cstr1 := (*C.gchar)(C.CString(schemaID)) + defer C.free(unsafe.Pointer(cstr1)) + + return wrapFullSettings(C.g_settings_new_with_backend(cstr1, backend.native())) +} + +// SettingsNewWithBackendAndPath is a wrapper around g_settings_new_with_backend_and_path(). +func SettingsNewWithBackendAndPath(schemaID string, backend *SettingsBackend, path string) *Settings { + cstr1 := (*C.gchar)(C.CString(schemaID)) + defer C.free(unsafe.Pointer(cstr1)) + + cstr2 := (*C.gchar)(C.CString(path)) + defer C.free(unsafe.Pointer(cstr2)) + + return wrapFullSettings(C.g_settings_new_with_backend_and_path(cstr1, backend.native(), cstr2)) +} + +// SettingsNewFull is a wrapper around g_settings_new_full(). +func SettingsNewFull(schema *SettingsSchema, backend *SettingsBackend, path string) *Settings { + cstr1 := (*C.gchar)(C.CString(path)) + defer C.free(unsafe.Pointer(cstr1)) + + return wrapFullSettings(C.g_settings_new_full(schema.native(), backend.native(), cstr1)) +} + +// SettingsSync is a wrapper around g_settings_sync(). +func SettingsSync() { + C.g_settings_sync() +} + +// IsWritable is a wrapper around g_settings_is_writable(). +func (v *Settings) IsWritable(name string) bool { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return gobool(C.g_settings_is_writable(v.native(), cstr1)) +} + +// Delay is a wrapper around g_settings_delay(). +func (v *Settings) Delay() { + C.g_settings_delay(v.native()) +} + +// Apply is a wrapper around g_settings_apply(). +func (v *Settings) Apply() { + C.g_settings_apply(v.native()) +} + +// Revert is a wrapper around g_settings_revert(). +func (v *Settings) Revert() { + C.g_settings_revert(v.native()) +} + +// GetHasUnapplied is a wrapper around g_settings_get_has_unapplied(). +func (v *Settings) GetHasUnapplied() bool { + return gobool(C.g_settings_get_has_unapplied(v.native())) +} + +// GetChild is a wrapper around g_settings_get_child(). +func (v *Settings) GetChild(name string) *Settings { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return wrapFullSettings(C.g_settings_get_child(v.native(), cstr1)) +} + +// Reset is a wrapper around g_settings_reset(). +func (v *Settings) Reset(name string) { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + C.g_settings_reset(v.native(), cstr1) +} + +// ListChildren is a wrapper around g_settings_list_children(). +func (v *Settings) ListChildren() []string { + return toGoStringArray(C.g_settings_list_children(v.native())) +} + +// GetBoolean is a wrapper around g_settings_get_boolean(). +func (v *Settings) GetBoolean(name string) bool { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return gobool(C.g_settings_get_boolean(v.native(), cstr1)) +} + +// SetBoolean is a wrapper around g_settings_set_boolean(). +func (v *Settings) SetBoolean(name string, value bool) bool { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return gobool(C.g_settings_set_boolean(v.native(), cstr1, gbool(value))) +} + +// GetInt is a wrapper around g_settings_get_int(). +func (v *Settings) GetInt(name string) int { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return int(C.g_settings_get_int(v.native(), cstr1)) +} + +// SetInt is a wrapper around g_settings_set_int(). +func (v *Settings) SetInt(name string, value int) bool { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return gobool(C.g_settings_set_int(v.native(), cstr1, C.gint(value))) +} + +// GetUInt is a wrapper around g_settings_get_uint(). +func (v *Settings) GetUInt(name string) uint { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return uint(C.g_settings_get_uint(v.native(), cstr1)) +} + +// SetUInt is a wrapper around g_settings_set_uint(). +func (v *Settings) SetUInt(name string, value uint) bool { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return gobool(C.g_settings_set_uint(v.native(), cstr1, C.guint(value))) +} + +// GetDouble is a wrapper around g_settings_get_double(). +func (v *Settings) GetDouble(name string) float64 { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return float64(C.g_settings_get_double(v.native(), cstr1)) +} + +// SetDouble is a wrapper around g_settings_set_double(). +func (v *Settings) SetDouble(name string, value float64) bool { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return gobool(C.g_settings_set_double(v.native(), cstr1, C.gdouble(value))) +} + +// GetString is a wrapper around g_settings_get_string(). +func (v *Settings) GetString(name string) string { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return C.GoString((*C.char)(C.g_settings_get_string(v.native(), cstr1))) +} + +// SetString is a wrapper around g_settings_set_string(). +func (v *Settings) SetString(name string, value string) bool { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + cstr2 := (*C.gchar)(C.CString(value)) + defer C.free(unsafe.Pointer(cstr2)) + + return gobool(C.g_settings_set_string(v.native(), cstr1, cstr2)) +} + +// GetEnum is a wrapper around g_settings_get_enum(). +func (v *Settings) GetEnum(name string) int { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return int(C.g_settings_get_enum(v.native(), cstr1)) +} + +// GetStrv is a wrapper around g_settings_get_strv(). +func (v *Settings) GetStrv(name string) []string { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + return toGoStringArray(C.g_settings_get_strv(v.native(), cstr1)) +} + +// SetStrv is a wrapper around g_settings_set_strv(). +func (v *Settings) SetStrv(name string, values []string) bool { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + cvalues := make([]*C.gchar, len(values)) + for i, accel := range values { + cvalues[i] = (*C.gchar)(C.CString(accel)) + defer C.free(unsafe.Pointer(cvalues[i])) + } + cvalues = append(cvalues, nil) + + return gobool(C.g_settings_set_strv(v.native(), cstr1, &cvalues[0])) +} + +// SetEnum is a wrapper around g_settings_set_enum(). +func (v *Settings) SetEnum(name string, value int) bool { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return gobool(C.g_settings_set_enum(v.native(), cstr1, C.gint(value))) +} + +// GetFlags is a wrapper around g_settings_get_flags(). +func (v *Settings) GetFlags(name string) uint { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return uint(C.g_settings_get_flags(v.native(), cstr1)) +} + +// SetFlags is a wrapper around g_settings_set_flags(). +func (v *Settings) SetFlags(name string, value uint) bool { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + return gobool(C.g_settings_set_flags(v.native(), cstr1, C.guint(value))) +} + +func (v *Settings) GetValue(name string) *Variant { + cstr := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr)) + return newVariant(C.g_settings_get_value(v.native(), cstr)) +} + +// GVariant * g_settings_get_value () +// gboolean g_settings_set_value () +// GVariant * g_settings_get_user_value () +// GVariant * g_settings_get_default_value () +// const gchar * const * g_settings_list_schemas () +// const gchar * const * g_settings_list_relocatable_schemas () +// gchar ** g_settings_list_keys () +// GVariant * g_settings_get_range () +// gboolean g_settings_range_check () +// void g_settings_get () +// gboolean g_settings_set () +// gpointer g_settings_get_mapped () +// void g_settings_bind () +// void g_settings_bind_with_mapping () +// void g_settings_bind_writable () +// void g_settings_unbind () +// gaction * g_settings_create_action () +// gchar ** g_settings_get_strv () +// gboolean g_settings_set_strv () diff --git a/vendor/github.com/gotk3/gotk3/glib/settings_backend.go b/vendor/github.com/gotk3/gotk3/glib/settings_backend.go new file mode 100644 index 0000000..3579ee4 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/settings_backend.go @@ -0,0 +1,70 @@ +package glib + +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +// SettingsBackend is a representation of GSettingsBackend. +type SettingsBackend struct { + *Object +} + +// native() returns a pointer to the underlying GSettingsBackend. +func (v *SettingsBackend) native() *C.GSettingsBackend { + if v == nil || v.GObject == nil { + return nil + } + return C.toGSettingsBackend(unsafe.Pointer(v.GObject)) +} + +func (v *SettingsBackend) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalSettingsBackend(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapSettingsBackend(wrapObject(unsafe.Pointer(c))), nil +} + +func wrapSettingsBackend(obj *Object) *SettingsBackend { + return &SettingsBackend{obj} +} + +// SettingsBackendGetDefault is a wrapper around g_settings_backend_get_default(). +func SettingsBackendGetDefault() *SettingsBackend { + return wrapSettingsBackend(wrapObject(unsafe.Pointer(C.g_settings_backend_get_default()))) +} + +// KeyfileSettingsBackendNew is a wrapper around g_keyfile_settings_backend_new(). +func KeyfileSettingsBackendNew(filename, rootPath, rootGroup string) *SettingsBackend { + cstr1 := (*C.gchar)(C.CString(filename)) + defer C.free(unsafe.Pointer(cstr1)) + + cstr2 := (*C.gchar)(C.CString(rootPath)) + defer C.free(unsafe.Pointer(cstr2)) + + cstr3 := (*C.gchar)(C.CString(rootGroup)) + defer C.free(unsafe.Pointer(cstr3)) + + return wrapSettingsBackend(wrapObject(unsafe.Pointer(C.g_keyfile_settings_backend_new(cstr1, cstr2, cstr3)))) +} + +// MemorySettingsBackendNew is a wrapper around g_memory_settings_backend_new(). +func MemorySettingsBackendNew() *SettingsBackend { + return wrapSettingsBackend(wrapObject(unsafe.Pointer(C.g_memory_settings_backend_new()))) +} + +// NullSettingsBackendNew is a wrapper around g_null_settings_backend_new(). +func NullSettingsBackendNew() *SettingsBackend { + return wrapSettingsBackend(wrapObject(unsafe.Pointer(C.g_null_settings_backend_new()))) +} + +// void g_settings_backend_changed () +// void g_settings_backend_path_changed () +// void g_settings_backend_keys_changed () +// void g_settings_backend_path_writable_changed () +// void g_settings_backend_writable_changed () +// void g_settings_backend_changed_tree () +// void g_settings_backend_flatten_tree () diff --git a/vendor/github.com/gotk3/gotk3/glib/settings_schema.go b/vendor/github.com/gotk3/gotk3/glib/settings_schema.go new file mode 100644 index 0000000..41839b1 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/settings_schema.go @@ -0,0 +1,95 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +// SettingsSchema is a representation of GSettingsSchema. +type SettingsSchema struct { + schema *C.GSettingsSchema +} + +func wrapSettingsSchema(obj *C.GSettingsSchema) *SettingsSchema { + if obj == nil { + return nil + } + return &SettingsSchema{obj} +} + +func (v *SettingsSchema) Native() uintptr { + return uintptr(unsafe.Pointer(v.schema)) +} + +func (v *SettingsSchema) native() *C.GSettingsSchema { + if v == nil || v.schema == nil { + return nil + } + return v.schema +} + +// Ref() is a wrapper around g_settings_schema_ref(). +func (v *SettingsSchema) Ref() *SettingsSchema { + return wrapSettingsSchema(C.g_settings_schema_ref(v.native())) +} + +// Unref() is a wrapper around g_settings_schema_unref(). +func (v *SettingsSchema) Unref() { + C.g_settings_schema_unref(v.native()) +} + +// GetID() is a wrapper around g_settings_schema_get_id(). +func (v *SettingsSchema) GetID() string { + return C.GoString((*C.char)(C.g_settings_schema_get_id(v.native()))) +} + +// GetPath() is a wrapper around g_settings_schema_get_path(). +func (v *SettingsSchema) GetPath() string { + return C.GoString((*C.char)(C.g_settings_schema_get_path(v.native()))) +} + +// HasKey() is a wrapper around g_settings_schema_has_key(). +func (v *SettingsSchema) HasKey(v1 string) bool { + cstr := (*C.gchar)(C.CString(v1)) + defer C.free(unsafe.Pointer(cstr)) + + return gobool(C.g_settings_schema_has_key(v.native(), cstr)) +} + +func toGoStringArray(c **C.gchar) []string { + var strs []string + originalc := c + defer C.g_strfreev(originalc) + + for *c != nil { + strs = append(strs, C.GoString((*C.char)(*c))) + c = C.next_gcharptr(c) + } + + return strs + +} + +// // ListChildren() is a wrapper around g_settings_schema_list_children(). +// func (v *SettingsSchema) ListChildren() []string { +// return toGoStringArray(C.g_settings_schema_list_children(v.native())) +// } + +// // ListKeys() is a wrapper around g_settings_schema_list_keys(). +// func (v *SettingsSchema) ListKeys() []string { +// return toGoStringArray(C.g_settings_schema_list_keys(v.native())) +// } + +// const GVariantType * g_settings_schema_key_get_value_type () +// GVariant * g_settings_schema_key_get_default_value () +// GVariant * g_settings_schema_key_get_range () +// gboolean g_settings_schema_key_range_check () +// const gchar * g_settings_schema_key_get_name () +// const gchar * g_settings_schema_key_get_summary () +// const gchar * g_settings_schema_key_get_description () + +// GSettingsSchemaKey * g_settings_schema_get_key () +// GSettingsSchemaKey * g_settings_schema_key_ref () +// void g_settings_schema_key_unref () diff --git a/vendor/github.com/gotk3/gotk3/glib/settings_schema_source.go b/vendor/github.com/gotk3/gotk3/glib/settings_schema_source.go new file mode 100644 index 0000000..a66a4c1 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/settings_schema_source.go @@ -0,0 +1,69 @@ +package glib + +// #include +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +// SettingsSchemaSource is a representation of GSettingsSchemaSource. +type SettingsSchemaSource struct { + source *C.GSettingsSchemaSource +} + +func wrapSettingsSchemaSource(obj *C.GSettingsSchemaSource) *SettingsSchemaSource { + if obj == nil { + return nil + } + return &SettingsSchemaSource{obj} +} + +func (v *SettingsSchemaSource) Native() uintptr { + return uintptr(unsafe.Pointer(v.source)) +} + +func (v *SettingsSchemaSource) native() *C.GSettingsSchemaSource { + if v == nil || v.source == nil { + return nil + } + return v.source +} + +// SettingsSchemaSourceGetDefault is a wrapper around g_settings_schema_source_get_default(). +func SettingsSchemaSourceGetDefault() *SettingsSchemaSource { + return wrapSettingsSchemaSource(C.g_settings_schema_source_get_default()) +} + +// Ref() is a wrapper around g_settings_schema_source_ref(). +func (v *SettingsSchemaSource) Ref() *SettingsSchemaSource { + return wrapSettingsSchemaSource(C.g_settings_schema_source_ref(v.native())) +} + +// Unref() is a wrapper around g_settings_schema_source_unref(). +func (v *SettingsSchemaSource) Unref() { + C.g_settings_schema_source_unref(v.native()) +} + +// SettingsSchemaSourceNewFromDirectory() is a wrapper around g_settings_schema_source_new_from_directory(). +func SettingsSchemaSourceNewFromDirectory(dir string, parent *SettingsSchemaSource, trusted bool) *SettingsSchemaSource { + cstr := (*C.gchar)(C.CString(dir)) + defer C.free(unsafe.Pointer(cstr)) + + return wrapSettingsSchemaSource(C.g_settings_schema_source_new_from_directory(cstr, parent.native(), gbool(trusted), nil)) +} + +// Lookup() is a wrapper around g_settings_schema_source_lookup(). +func (v *SettingsSchemaSource) Lookup(schema string, recursive bool) *SettingsSchema { + cstr := (*C.gchar)(C.CString(schema)) + defer C.free(unsafe.Pointer(cstr)) + + return wrapSettingsSchema(C.g_settings_schema_source_lookup(v.native(), cstr, gbool(recursive))) +} + +// ListSchemas is a wrapper around g_settings_schema_source_list_schemas(). +func (v *SettingsSchemaSource) ListSchemas(recursive bool) (nonReolcatable, relocatable []string) { + var nonRel, rel **C.gchar + C.g_settings_schema_source_list_schemas(v.native(), gbool(recursive), &nonRel, &rel) + return toGoStringArray(nonRel), toGoStringArray(rel) +} diff --git a/vendor/github.com/gotk3/gotk3/glib/slist.go b/vendor/github.com/gotk3/gotk3/glib/slist.go new file mode 100644 index 0000000..2b3a6d8 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/glib/slist.go @@ -0,0 +1,159 @@ +package glib + +// #include +// #include +// #include "glib.go.h" +import "C" +import "unsafe" + +// SList is a representation of Glib's GSList. A SList must be manually freed +// by either calling Free() or FreeFull() +type SList struct { + list *C.struct__GSList + // If set, dataWrap is called every time Data() + // is called to wrap raw underlying + // value into appropriate type. + dataWrap func(unsafe.Pointer) interface{} +} + +func WrapSList(obj uintptr) *SList { + return wrapSList((*C.struct__GSList)(unsafe.Pointer(obj))) +} + +func wrapSList(obj *C.struct__GSList) *SList { + if obj == nil { + return nil + } + + //NOTE a list should be freed by calling either + //g_slist_free() or g_slist_free_full(). However, it's not possible to use a + //finalizer for this. + return &SList{list: obj} +} + +func (v *SList) wrapNewHead(obj *C.struct__GSList) *SList { + if obj == nil { + return nil + } + return &SList{ + list: obj, + dataWrap: v.dataWrap, + } +} + +func (v *SList) Native() uintptr { + return uintptr(unsafe.Pointer(v.list)) +} + +func (v *SList) native() *C.struct__GSList { + if v == nil || v.list == nil { + return nil + } + return v.list +} + +// DataWapper sets wrap functions, which is called during NthData() +// and Data(). It's used to cast raw C data into appropriate +// Go structures and types every time that data is retreived. +func (v *SList) DataWrapper(fn func(unsafe.Pointer) interface{}) { + if v == nil { + return + } + v.dataWrap = fn +} + +func (v *SList) Append(data uintptr) *SList { + ret := C.g_slist_append(v.native(), C.gpointer(data)) + if ret == v.native() { + return v + } + + return wrapSList(ret) +} + +// Length is a wrapper around g_slist_length(). +func (v *SList) Length() uint { + return uint(C.g_slist_length(v.native())) +} + +// Next is a wrapper around the next struct field +func (v *SList) Next() *SList { + n := v.native() + if n == nil { + return nil + } + + return wrapSList(n.next) +} + +// dataRaw is a wrapper around the data struct field +func (v *SList) dataRaw() unsafe.Pointer { + n := v.native() + if n == nil { + return nil + } + return unsafe.Pointer(n.data) +} + +// DataRaw is a wrapper around the data struct field +func (v *SList) DataRaw() unsafe.Pointer { + n := v.native() + if n == nil { + return nil + } + return unsafe.Pointer(n.data) +} + +// Data acts the same as data struct field, but it returns raw unsafe.Pointer as interface. +// TODO: Align with List struct and add member + logic for `dataWrap func(unsafe.Pointer) interface{}`? +func (v *SList) Data() interface{} { + ptr := v.dataRaw() + if v.dataWrap != nil { + return v.dataWrap(ptr) + } + return ptr +} + +// Foreach acts the same as g_slist_foreach(). +// No user_data argument is implemented because of Go clojure capabilities. +func (v *SList) Foreach(fn func(item interface{})) { + for l := v; l != nil; l = l.Next() { + fn(l.Data()) + } +} + +// Free is a wrapper around g_slist_free(). +func (v *SList) Free() { + C.g_slist_free(v.native()) +} + +// FreeFull is a wrapper around g_slist_free_full(). +func (v *SList) FreeFull() { + //TODO implement GDestroyNotify callback + C.g_slist_free_full(v.native(), nil) +} + +// GSList * g_slist_alloc () +// GSList * g_slist_prepend () +// GSList * g_slist_insert () +// GSList * g_slist_insert_before () +// GSList * g_slist_insert_sorted () +// GSList * g_slist_remove () +// GSList * g_slist_remove_link () +// GSList * g_slist_delete_link () +// GSList * g_slist_remove_all () +// void g_slist_free_1 () +// GSList * g_slist_copy () +// GSList * g_slist_copy_deep () +// GSList * g_slist_reverse () +// GSList * g_slist_insert_sorted_with_data () +// GSList * g_slist_sort () +// GSList * g_slist_sort_with_data () +// GSList * g_slist_concat () +// GSList * g_slist_last () +// GSList * g_slist_nth () +// gpointer g_slist_nth_data () +// GSList * g_slist_find () +// GSList * g_slist_find_custom () +// gint g_slist_position () +// gint g_slist_index () diff --git a/vendor/github.com/gotk3/gotk3/gtk/aboutdialog.go b/vendor/github.com/gotk3/gotk3/gtk/aboutdialog.go new file mode 100644 index 0000000..a805e59 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/aboutdialog.go @@ -0,0 +1,328 @@ +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_about_dialog_get_type()), marshalAboutDialog}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkAboutDialog"] = wrapAboutDialog +} + +/* + * GtkAboutDialog + */ + +// AboutDialog is a representation of GTK's GtkAboutDialog. +type AboutDialog struct { + Dialog +} + +// native returns a pointer to the underlying GtkAboutDialog. +func (v *AboutDialog) native() *C.GtkAboutDialog { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkAboutDialog(p) +} + +func marshalAboutDialog(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapAboutDialog(obj), nil +} + +func wrapAboutDialog(obj *glib.Object) *AboutDialog { + if obj == nil { + return nil + } + + return &AboutDialog{Dialog{Window{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}}}} +} + +// AboutDialogNew is a wrapper around gtk_about_dialog_new(). +func AboutDialogNew() (*AboutDialog, error) { + c := C.gtk_about_dialog_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapAboutDialog(obj), nil +} + +// GetComments is a wrapper around gtk_about_dialog_get_comments(). +func (v *AboutDialog) GetComments() string { + c := C.gtk_about_dialog_get_comments(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetComments is a wrapper around gtk_about_dialog_set_comments(). +func (v *AboutDialog) SetComments(comments string) { + cstr := C.CString(comments) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_about_dialog_set_comments(v.native(), (*C.gchar)(cstr)) +} + +// GetCopyright is a wrapper around gtk_about_dialog_get_copyright(). +func (v *AboutDialog) GetCopyright() string { + c := C.gtk_about_dialog_get_copyright(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetCopyright is a wrapper around gtk_about_dialog_set_copyright(). +func (v *AboutDialog) SetCopyright(copyright string) { + cstr := C.CString(copyright) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_about_dialog_set_copyright(v.native(), (*C.gchar)(cstr)) +} + +// GetLicense is a wrapper around gtk_about_dialog_get_license(). +func (v *AboutDialog) GetLicense() string { + c := C.gtk_about_dialog_get_license(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetLicense is a wrapper around gtk_about_dialog_set_license(). +func (v *AboutDialog) SetLicense(license string) { + cstr := C.CString(license) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_about_dialog_set_license(v.native(), (*C.gchar)(cstr)) +} + +// GetLicenseType is a wrapper around gtk_about_dialog_get_license_type(). +func (v *AboutDialog) GetLicenseType() License { + c := C.gtk_about_dialog_get_license_type(v.native()) + return License(c) +} + +// SetLicenseType is a wrapper around gtk_about_dialog_set_license_type(). +func (v *AboutDialog) SetLicenseType(license License) { + C.gtk_about_dialog_set_license_type(v.native(), C.GtkLicense(license)) +} + +// GetLogo is a wrapper around gtk_about_dialog_get_logo(). +func (v *AboutDialog) GetLogo() (*gdk.Pixbuf, error) { + c := C.gtk_about_dialog_get_logo(v.native()) + if c == nil { + return nil, nilPtrErr + } + + p := &gdk.Pixbuf{glib.Take(unsafe.Pointer(c))} + return p, nil +} + +// SetLogo is a wrapper around gtk_about_dialog_set_logo(). +func (v *AboutDialog) SetLogo(logo *gdk.Pixbuf) { + logoPtr := (*C.GdkPixbuf)(unsafe.Pointer(logo.Native())) + C.gtk_about_dialog_set_logo(v.native(), logoPtr) +} + +// GetLogoIconName is a wrapper around gtk_about_dialog_get_logo_icon_name(). +func (v *AboutDialog) GetLogoIconName() string { + c := C.gtk_about_dialog_get_logo_icon_name(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetLogoIconName is a wrapper around gtk_about_dialog_set_logo_icon_name(). +func (v *AboutDialog) SetLogoIconName(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_about_dialog_set_logo_icon_name(v.native(), (*C.gchar)(cstr)) +} + +// GetProgramName is a wrapper around gtk_about_dialog_get_program_name(). +func (v *AboutDialog) GetProgramName() string { + c := C.gtk_about_dialog_get_program_name(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetProgramName is a wrapper around gtk_about_dialog_set_program_name(). +func (v *AboutDialog) SetProgramName(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_about_dialog_set_program_name(v.native(), (*C.gchar)(cstr)) +} + +// GetAuthors is a wrapper around gtk_about_dialog_get_authors(). +func (v *AboutDialog) GetAuthors() []string { + var authors []string + cauthors := C.gtk_about_dialog_get_authors(v.native()) + if cauthors == nil { + return nil + } + for { + if *cauthors == nil { + break + } + authors = append(authors, C.GoString((*C.char)(*cauthors))) + cauthors = nextgcharptr(cauthors) + } + return authors +} + +// SetAuthors is a wrapper around gtk_about_dialog_set_authors(). +func (v *AboutDialog) SetAuthors(authors []string) { + cauthors := C.make_strings(C.int(len(authors) + 1)) + for i, author := range authors { + cstr := C.CString(author) + defer C.free(unsafe.Pointer(cstr)) + C.set_string(cauthors, C.int(i), (*C.gchar)(cstr)) + } + + C.set_string(cauthors, C.int(len(authors)), nil) + C.gtk_about_dialog_set_authors(v.native(), cauthors) + C.destroy_strings(cauthors) +} + +// GetArtists is a wrapper around gtk_about_dialog_get_artists(). +func (v *AboutDialog) GetArtists() []string { + var artists []string + cartists := C.gtk_about_dialog_get_artists(v.native()) + if cartists == nil { + return nil + } + for { + if *cartists == nil { + break + } + artists = append(artists, C.GoString((*C.char)(*cartists))) + cartists = nextgcharptr(cartists) + } + return artists +} + +// SetArtists is a wrapper around gtk_about_dialog_set_artists(). +func (v *AboutDialog) SetArtists(artists []string) { + cartists := C.make_strings(C.int(len(artists) + 1)) + for i, artist := range artists { + cstr := C.CString(artist) + defer C.free(unsafe.Pointer(cstr)) + C.set_string(cartists, C.int(i), (*C.gchar)(cstr)) + } + + C.set_string(cartists, C.int(len(artists)), nil) + C.gtk_about_dialog_set_artists(v.native(), cartists) + C.destroy_strings(cartists) +} + +// GetDocumenters is a wrapper around gtk_about_dialog_get_documenters(). +func (v *AboutDialog) GetDocumenters() []string { + var documenters []string + cdocumenters := C.gtk_about_dialog_get_documenters(v.native()) + if cdocumenters == nil { + return nil + } + for { + if *cdocumenters == nil { + break + } + documenters = append(documenters, C.GoString((*C.char)(*cdocumenters))) + cdocumenters = nextgcharptr(cdocumenters) + } + return documenters +} + +// SetDocumenters is a wrapper around gtk_about_dialog_set_documenters(). +func (v *AboutDialog) SetDocumenters(documenters []string) { + cdocumenters := C.make_strings(C.int(len(documenters) + 1)) + for i, doc := range documenters { + cstr := C.CString(doc) + defer C.free(unsafe.Pointer(cstr)) + C.set_string(cdocumenters, C.int(i), (*C.gchar)(cstr)) + } + + C.set_string(cdocumenters, C.int(len(documenters)), nil) + C.gtk_about_dialog_set_documenters(v.native(), cdocumenters) + C.destroy_strings(cdocumenters) +} + +// GetTranslatorCredits is a wrapper around gtk_about_dialog_get_translator_credits(). +func (v *AboutDialog) GetTranslatorCredits() string { + c := C.gtk_about_dialog_get_translator_credits(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetTranslatorCredits is a wrapper around gtk_about_dialog_set_translator_credits(). +func (v *AboutDialog) SetTranslatorCredits(translatorCredits string) { + cstr := C.CString(translatorCredits) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_about_dialog_set_translator_credits(v.native(), (*C.gchar)(cstr)) +} + +// GetVersion is a wrapper around gtk_about_dialog_get_version(). +func (v *AboutDialog) GetVersion() string { + c := C.gtk_about_dialog_get_version(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetVersion is a wrapper around gtk_about_dialog_set_version(). +func (v *AboutDialog) SetVersion(version string) { + cstr := C.CString(version) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_about_dialog_set_version(v.native(), (*C.gchar)(cstr)) +} + +// GetWebsite is a wrapper around gtk_about_dialog_get_website(). +func (v *AboutDialog) GetWebsite() string { + c := C.gtk_about_dialog_get_website(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetWebsite is a wrapper around gtk_about_dialog_set_website(). +func (v *AboutDialog) SetWebsite(website string) { + cstr := C.CString(website) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_about_dialog_set_website(v.native(), (*C.gchar)(cstr)) +} + +// GetWebsiteLabel is a wrapper around gtk_about_dialog_get_website_label(). +func (v *AboutDialog) GetWebsiteLabel() string { + c := C.gtk_about_dialog_get_website_label(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetWebsiteLabel is a wrapper around gtk_about_dialog_set_website_label(). +func (v *AboutDialog) SetWebsiteLabel(websiteLabel string) { + cstr := C.CString(websiteLabel) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_about_dialog_set_website_label(v.native(), (*C.gchar)(cstr)) +} + +// GetWrapLicense is a wrapper around gtk_about_dialog_get_wrap_license(). +func (v *AboutDialog) GetWrapLicense() bool { + return gobool(C.gtk_about_dialog_get_wrap_license(v.native())) +} + +// SetWrapLicense is a wrapper around gtk_about_dialog_set_wrap_license(). +func (v *AboutDialog) SetWrapLicense(wrapLicense bool) { + C.gtk_about_dialog_set_wrap_license(v.native(), gbool(wrapLicense)) +} + +// AddCreditSection is a wrapper around gtk_about_dialog_add_credit_section(). +func (v *AboutDialog) AddCreditSection(sectionName string, people []string) { + cname := (*C.gchar)(C.CString(sectionName)) + defer C.free(unsafe.Pointer(cname)) + + cpeople := C.make_strings(C.int(len(people)) + 1) + defer C.destroy_strings(cpeople) + for i, p := range people { + cp := (*C.gchar)(C.CString(p)) + defer C.free(unsafe.Pointer(cp)) + C.set_string(cpeople, C.int(i), cp) + } + C.set_string(cpeople, C.int(len(people)), nil) + + C.gtk_about_dialog_add_credit_section(v.native(), cname, cpeople) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/accel.go b/vendor/github.com/gotk3/gotk3/gtk/accel.go new file mode 100644 index 0000000..1780602 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/accel.go @@ -0,0 +1,447 @@ +// Same copyright and license as the rest of the files in this project +// This file contains accelerator related functions and structures + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +// AccelFlags is a representation of GTK's GtkAccelFlags +type AccelFlags int + +const ( + ACCEL_VISIBLE AccelFlags = C.GTK_ACCEL_VISIBLE + ACCEL_LOCKED AccelFlags = C.GTK_ACCEL_LOCKED + ACCEL_MASK AccelFlags = C.GTK_ACCEL_MASK +) + +func marshalAccelFlags(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return AccelFlags(c), nil +} + +// AcceleratorName is a wrapper around gtk_accelerator_name(). +func AcceleratorName(key uint, mods gdk.ModifierType) string { + c := C.gtk_accelerator_name(C.guint(key), C.GdkModifierType(mods)) + defer C.free(unsafe.Pointer(c)) + return C.GoString((*C.char)(c)) +} + +// AcceleratorValid is a wrapper around gtk_accelerator_valid(). +func AcceleratorValid(key uint, mods gdk.ModifierType) bool { + return gobool(C.gtk_accelerator_valid(C.guint(key), C.GdkModifierType(mods))) +} + +// AcceleratorGetDefaultModMask is a wrapper around gtk_accelerator_get_default_mod_mask(). +func AcceleratorGetDefaultModMask() gdk.ModifierType { + return gdk.ModifierType(C.gtk_accelerator_get_default_mod_mask()) +} + +// AcceleratorParse is a wrapper around gtk_accelerator_parse(). +func AcceleratorParse(acc string) (key uint, mods gdk.ModifierType) { + cstr := C.CString(acc) + defer C.free(unsafe.Pointer(cstr)) + + k := C.guint(0) + m := C.GdkModifierType(0) + + C.gtk_accelerator_parse((*C.gchar)(cstr), &k, &m) + return uint(k), gdk.ModifierType(m) +} + +// AcceleratorGetLabel is a wrapper around gtk_accelerator_get_label(). +func AcceleratorGetLabel(key uint, mods gdk.ModifierType) string { + c := C.gtk_accelerator_get_label(C.guint(key), C.GdkModifierType(mods)) + defer C.free(unsafe.Pointer(c)) + return C.GoString((*C.char)(c)) +} + +// AcceleratorSetDefaultModMask is a wrapper around gtk_accelerator_set_default_mod_mask(). +func AcceleratorSetDefaultModMask(mods gdk.ModifierType) { + C.gtk_accelerator_set_default_mod_mask(C.GdkModifierType(mods)) +} + +/* + * GtkAccelLabel + */ + +// TODO: +// gtk_accel_label_new(). +// gtk_accel_label_set_accel_closure(). +// gtk_accel_label_get_accel_widget(). +// gtk_accel_label_set_accel_widget(). +// gtk_accel_label_get_accel_width(). +// gtk_accel_label_set_accel(). since GTK 3.6 +// gtk_accel_label_get_accel(). since GTK 3.12 +// gtk_accel_label_refetch(). + +/* + * GtkAccelGroup + */ + +// AccelGroup is a representation of GTK's GtkAccelGroup. +type AccelGroup struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkAccelGroup. +func (v *AccelGroup) native() *C.GtkAccelGroup { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkAccelGroup(p) +} + +func marshalAccelGroup(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapAccelGroup(obj), nil +} + +func wrapAccelGroup(obj *glib.Object) *AccelGroup { + if obj == nil { + return nil + } + + return &AccelGroup{obj} +} + +// AccelGroup is a wrapper around gtk_accel_group_new(). +func AccelGroupNew() (*AccelGroup, error) { + c := C.gtk_accel_group_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapAccelGroup(obj), nil +} + +// Connect is a wrapper around gtk_accel_group_connect(). +func (v *AccelGroup) Connect(key uint, mods gdk.ModifierType, flags AccelFlags, f interface{}) { + closure := glib.ClosureNew(f) + cl := (*C.struct__GClosure)(unsafe.Pointer(closure)) + C.gtk_accel_group_connect( + v.native(), + C.guint(key), + C.GdkModifierType(mods), + C.GtkAccelFlags(flags), + cl) +} + +// ConnectByPath is a wrapper around gtk_accel_group_connect_by_path(). +func (v *AccelGroup) ConnectByPath(path string, f interface{}) { + closure := glib.ClosureNew(f) + cl := (*C.struct__GClosure)(unsafe.Pointer(closure)) + + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_accel_group_connect_by_path( + v.native(), + (*C.gchar)(cstr), + cl) +} + +// Disconnect is a wrapper around gtk_accel_group_disconnect(). +func (v *AccelGroup) Disconnect(f interface{}) { + closure := glib.ClosureNew(f) + cl := (*C.struct__GClosure)(unsafe.Pointer(closure)) + C.gtk_accel_group_disconnect(v.native(), cl) +} + +// DisconnectKey is a wrapper around gtk_accel_group_disconnect_key(). +func (v *AccelGroup) DisconnectKey(key uint, mods gdk.ModifierType) { + C.gtk_accel_group_disconnect_key(v.native(), C.guint(key), C.GdkModifierType(mods)) +} + +// Lock is a wrapper around gtk_accel_group_lock(). +func (v *AccelGroup) Lock() { + C.gtk_accel_group_lock(v.native()) +} + +// Unlock is a wrapper around gtk_accel_group_unlock(). +func (v *AccelGroup) Unlock() { + C.gtk_accel_group_unlock(v.native()) +} + +// IsLocked is a wrapper around gtk_accel_group_get_is_locked(). +func (v *AccelGroup) IsLocked() bool { + return gobool(C.gtk_accel_group_get_is_locked(v.native())) +} + +// AccelGroupFromClosure is a wrapper around gtk_accel_group_from_accel_closure(). +func AccelGroupFromClosure(f interface{}) *AccelGroup { + closure := glib.ClosureNew(f) + cl := (*C.struct__GClosure)(unsafe.Pointer(closure)) + c := C.gtk_accel_group_from_accel_closure(cl) + if c == nil { + return nil + } + return wrapAccelGroup(glib.Take(unsafe.Pointer(c))) +} + +// GetModifierMask is a wrapper around gtk_accel_group_get_modifier_mask(). +func (v *AccelGroup) GetModifierMask() gdk.ModifierType { + return gdk.ModifierType(C.gtk_accel_group_get_modifier_mask(v.native())) +} + +// AccelGroupsActivate is a wrapper around gtk_accel_groups_activate(). +func AccelGroupsActivate(obj *glib.Object, key uint, mods gdk.ModifierType) bool { + return gobool(C.gtk_accel_groups_activate((*C.GObject)(unsafe.Pointer(obj.Native())), C.guint(key), C.GdkModifierType(mods))) +} + +// Activate is a wrapper around gtk_accel_group_activate(). +func (v *AccelGroup) Activate(quark glib.Quark, acceleratable *glib.Object, key uint, mods gdk.ModifierType) bool { + return gobool(C.gtk_accel_group_activate(v.native(), C.GQuark(quark), (*C.GObject)(unsafe.Pointer(acceleratable.Native())), C.guint(key), C.GdkModifierType(mods))) +} + +// AccelGroupsFromObject is a wrapper around gtk_accel_groups_from_object(). +func AccelGroupsFromObject(obj *glib.Object) *glib.SList { + res := C.gtk_accel_groups_from_object((*C.GObject)(unsafe.Pointer(obj.Native()))) + if res == nil { + return nil + } + + // TODO: call DataWrapper on SList and wrap them to gtk.AccelGroup + + return (*glib.SList)(unsafe.Pointer(res)) +} + +/* + * GtkAccelMap + */ + +// AccelMap is a representation of GTK's GtkAccelMap. +type AccelMap struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkAccelMap. +func (v *AccelMap) native() *C.GtkAccelMap { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkAccelMap(p) +} + +func marshalAccelMap(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapAccelMap(obj), nil +} + +func wrapAccelMap(obj *glib.Object) *AccelMap { + if obj == nil { + return nil + } + + return &AccelMap{obj} +} + +// AccelMapAddEntry is a wrapper around gtk_accel_map_add_entry(). +func AccelMapAddEntry(path string, key uint, mods gdk.ModifierType) { + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_accel_map_add_entry((*C.gchar)(cstr), C.guint(key), C.GdkModifierType(mods)) +} + +type AccelKey C.GtkAccelKey + +func (v *AccelKey) native() *C.GtkAccelKey { + if v == nil { + return nil + } + return (*C.GtkAccelKey)(v) +} + +// AccelMapLookupEntry is a wrapper around gtk_accel_map_lookup_entry(). +func AccelMapLookupEntry(path string) *AccelKey { + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + + var v = new(AccelKey) + + C.gtk_accel_map_lookup_entry((*C.gchar)(cstr), v.native()) + return v +} + +// AccelMapChangeEntry is a wrapper around gtk_accel_map_change_entry(). +func AccelMapChangeEntry(path string, key uint, mods gdk.ModifierType, replace bool) bool { + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + + return gobool(C.gtk_accel_map_change_entry((*C.gchar)(cstr), C.guint(key), C.GdkModifierType(mods), gbool(replace))) +} + +// AccelMapLoad is a wrapper around gtk_accel_map_load(). +func AccelMapLoad(fileName string) { + cstr := C.CString(fileName) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_accel_map_load((*C.gchar)(cstr)) +} + +// AccelMapSave is a wrapper around gtk_accel_map_save(). +func AccelMapSave(fileName string) { + cstr := C.CString(fileName) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_accel_map_save((*C.gchar)(cstr)) +} + +// AccelMapLoadFD is a wrapper around gtk_accel_map_load_fd(). +func AccelMapLoadFD(fd int) { + C.gtk_accel_map_load_fd(C.gint(fd)) +} + +// AccelMapSaveFD is a wrapper around gtk_accel_map_save_fd(). +func AccelMapSaveFD(fd int) { + C.gtk_accel_map_save_fd(C.gint(fd)) +} + +// AccelMapAddFilter is a wrapper around gtk_accel_map_add_filter(). +func AccelMapAddFilter(filter string) { + cstr := C.CString(filter) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_accel_map_add_filter((*C.gchar)(cstr)) +} + +// AccelMapGet is a wrapper around gtk_accel_map_get(). +func AccelMapGet() *AccelMap { + c := C.gtk_accel_map_get() + if c == nil { + return nil + } + return wrapAccelMap(glib.Take(unsafe.Pointer(c))) +} + +// AccelMapLockPath is a wrapper around gtk_accel_map_lock_path(). +func AccelMapLockPath(path string) { + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_accel_map_lock_path((*C.gchar)(cstr)) +} + +// AccelMapUnlockPath is a wrapper around gtk_accel_map_unlock_path(). +func AccelMapUnlockPath(path string) { + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_accel_map_unlock_path((*C.gchar)(cstr)) +} + +// SetAccelGroup is a wrapper around gtk_menu_set_accel_group(). +func (v *Menu) SetAccelGroup(accelGroup *AccelGroup) { + C.gtk_menu_set_accel_group(v.native(), accelGroup.native()) +} + +// GetAccelGroup is a wrapper around gtk_menu_get_accel_group(). +func (v *Menu) GetAccelGroup() *AccelGroup { + c := C.gtk_menu_get_accel_group(v.native()) + if c == nil { + return nil + } + return wrapAccelGroup(glib.Take(unsafe.Pointer(c))) +} + +// SetAccelPath is a wrapper around gtk_menu_set_accel_path(). +func (v *Menu) SetAccelPath(path string) { + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_menu_set_accel_path(v.native(), (*C.gchar)(cstr)) +} + +// GetAccelPath is a wrapper around gtk_menu_get_accel_path(). +func (v *Menu) GetAccelPath() string { + c := C.gtk_menu_get_accel_path(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetAccelPath is a wrapper around gtk_menu_item_set_accel_path(). +func (v *MenuItem) SetAccelPath(path string) { + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_menu_item_set_accel_path(v.native(), (*C.gchar)(cstr)) +} + +// GetAccelPath is a wrapper around gtk_menu_item_get_accel_path(). +func (v *MenuItem) GetAccelPath() string { + c := C.gtk_menu_item_get_accel_path(v.native()) + return C.GoString((*C.char)(c)) +} + +// AddAccelerator is a wrapper around gtk_widget_add_accelerator(). +func (v *Widget) AddAccelerator(signal string, group *AccelGroup, key uint, mods gdk.ModifierType, flags AccelFlags) { + csignal := (*C.gchar)(C.CString(signal)) + defer C.free(unsafe.Pointer(csignal)) + + C.gtk_widget_add_accelerator(v.native(), + csignal, + group.native(), + C.guint(key), + C.GdkModifierType(mods), + C.GtkAccelFlags(flags)) +} + +// RemoveAccelerator is a wrapper around gtk_widget_remove_accelerator(). +func (v *Widget) RemoveAccelerator(group *AccelGroup, key uint, mods gdk.ModifierType) bool { + return gobool(C.gtk_widget_remove_accelerator(v.native(), + group.native(), + C.guint(key), + C.GdkModifierType(mods))) +} + +// SetAccelPath is a wrapper around gtk_widget_set_accel_path(). +func (v *Widget) SetAccelPath(path string, group *AccelGroup) { + cstr := (*C.gchar)(C.CString(path)) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_widget_set_accel_path(v.native(), cstr, group.native()) +} + +// CanActivateAccel is a wrapper around gtk_widget_can_activate_accel(). +func (v *Widget) CanActivateAccel(signalId uint) bool { + return gobool(C.gtk_widget_can_activate_accel(v.native(), C.guint(signalId))) +} + +// AddAccelGroup() is a wrapper around gtk_window_add_accel_group(). +func (v *Window) AddAccelGroup(accelGroup *AccelGroup) { + C.gtk_window_add_accel_group(v.native(), accelGroup.native()) +} + +// RemoveAccelGroup() is a wrapper around gtk_window_remove_accel_group(). +func (v *Window) RemoveAccelGroup(accelGroup *AccelGroup) { + C.gtk_window_remove_accel_group(v.native(), accelGroup.native()) +} + +// These three functions are for system level access - thus not as high priority to implement +// TODO: void gtk_accelerator_parse_with_keycode () +// TODO: gchar * gtk_accelerator_name_with_keycode () +// TODO: gchar * gtk_accelerator_get_label_with_keycode () + +// TODO: GtkAccelKey * gtk_accel_group_find () - this function uses a function type - I don't know how to represent it in cgo +// TODO: gtk_accel_map_foreach_unfiltered - can't be done without a function type +// TODO: gtk_accel_map_foreach - can't be done without a function type + +// TODO: gtk_accel_map_load_scanner + +/* + * GtkWidget + */ + +// TODO: +// gtk_widget_list_accel_closures diff --git a/vendor/github.com/gotk3/gotk3/gtk/accel_test.go b/vendor/github.com/gotk3/gotk3/gtk/accel_test.go new file mode 100644 index 0000000..938fd22 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/accel_test.go @@ -0,0 +1,34 @@ +// Same copyright and license as the rest of the files in this project + +package gtk + +import "testing" + +func Test_AccelGroup_Locking(t *testing.T) { + ag, _ := AccelGroupNew() + if ag.IsLocked() { + t.Error("A newly created AccelGroup should not be locked") + } + + ag.Lock() + + if !ag.IsLocked() { + t.Error("A locked AccelGroup should report being locked") + } + + ag.Unlock() + + if ag.IsLocked() { + t.Error("An unlocked AccelGroup should report being unlocked") + } +} + +func Test_AcceleratorParse(t *testing.T) { + l, r := AcceleratorParse("F1") + if l != 65470 { + t.Errorf("Expected parsed key to equal %d but was %d", 65470, l) + } + if r != 9 { + t.Errorf("Expected parsed mods to equal %d but was %d", 9, r) + } +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/actionable.go b/vendor/github.com/gotk3/gotk3/gtk/actionable.go new file mode 100644 index 0000000..2dff2f2 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/actionable.go @@ -0,0 +1,121 @@ +package gtk + +// #include +// #include "gtk.go.h" +// #include "actionable.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_actionable_get_type()), marshalActionable}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkActionable"] = marshalActionable +} + +// IActionable is a representation of the GtkActionable GInterface, +// used to avoid duplication when embedding the type in a wrapper of another GObject-based type. +// The non-Interface version should only be used Actionable is used if the concrete type is not known. +type IActionable interface { + Native() uintptr + toActionable() *C.GtkActionable + + SetActionName(name string) + GetActionName() (string, error) + // SetActionTargetValue(value *glib.Variant) + // GetActionTargetValue() (*glib.Variant, error) + // SetActionTarget(string, params...) + SetDetailedActionName(name string) +} + +// Actionable is a representation of the GtkActionable GInterface. +// Do not embed this concrete type in implementing structs but rather use IActionable +// (see Button wrapper for an example) +type Actionable struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkActionable. +func (v *Actionable) native() *C.GtkActionable { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkActionable(p) +} + +func marshalActionable(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapActionable(obj), nil +} + +func wrapActionable(obj *glib.Object) *Actionable { + if obj == nil { + return nil + } + + return &Actionable{obj} +} + +func (v *Actionable) toActionable() *C.GtkActionable { + if v == nil { + return nil + } + return v.native() +} + +// SetActionName is a wrapper around gtk_actionable_set_action_name(). +// Since 3.4 +func (v *Actionable) SetActionName(action_name string) { + cstr := C.CString(action_name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_actionable_set_action_name(v.native(), (*C.gchar)(cstr)) +} + +// GetActionName is a wrapper around gtk_actionable_set_action_name(). +// Since 3.4 +func (v *Actionable) GetActionName() (string, error) { + c := C.gtk_actionable_get_action_name(v.native()) + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +// SetDetailedActionName is a wrapper around gtk_actionable_set_detailed_action_name(). +// Since 3.4 +func (v *Actionable) SetDetailedActionName(detailed_action_name string) { + cstr := C.CString(detailed_action_name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_actionable_set_detailed_action_name(v.native(), (*C.gchar)(cstr)) +} + +// SetActionTargetValue is a wrapper around gtk_actionable_set_action_target_value(). +// Since 3.4 +/*func (v *Actionable) SetActionTargetValue(value *glib.Variant) { + // FIXME ToGVariant does not work here + C.gtk_actionable_set_action_target_value(v.native(), value.ToGVariant()) +}*/ + +// GetActionTargetValue is a wrapper around gtk_actionable_get_action_target_value(). +// Since 3.4 +/*func (v *Actionable) GetActionTargetValue() (*glib.Variant, error) { + // FIXME: newVariant is not exported from glib + return newVariant(C.gtk_actionable_get_action_target_value(v.native(), cstr)) +}*/ + +/* +// Since 3.4 +void +gtk_actionable_set_action_target (GtkActionable *actionable, + const gchar *format_string, + ...); +*/ diff --git a/vendor/github.com/gotk3/gotk3/gtk/actionable.go.h b/vendor/github.com/gotk3/gotk3/gtk/actionable.go.h new file mode 100644 index 0000000..24846f7 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/actionable.go.h @@ -0,0 +1 @@ +static GtkActionable *toGtkActionable(void *p) { return (GTK_ACTIONABLE(p)); } diff --git a/vendor/github.com/gotk3/gotk3/gtk/actionable_test.go b/vendor/github.com/gotk3/gotk3/gtk/actionable_test.go new file mode 100644 index 0000000..5a572a9 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/actionable_test.go @@ -0,0 +1,35 @@ +package gtk + +import "testing" + +func TestActionableImplementsIActionable(t *testing.T) { + var cut interface{} + cut = &Actionable{} + _, ok := cut.(IActionable) + + if !ok { + t.Error("Actionable does not implement IActionable") + return + } +} + +// TestGetSetActionName tests the getter and setter for action name +// using a button, as we need an actual instance implementing Actionable. +func TestGetSetActionName(t *testing.T) { + cut, err := ButtonNew() + if err != nil { + t.Fatal("Error creating button", err.Error()) + } + + expected := "app.stuff" + cut.SetActionName(expected) + + actual, err := cut.GetActionName() + if err != nil { + t.Fatal("Error getting action name", err.Error()) + } + + if expected != actual { + t.Fatalf("Expected %s got %s", expected, actual) + } +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/actionbar_since_3_12.go b/vendor/github.com/gotk3/gotk3/gtk/actionbar_since_3_12.go new file mode 100644 index 0000000..7f21262 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/actionbar_since_3_12.go @@ -0,0 +1,109 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10 + +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// This file includes wrapers for symbols included since GTK 3.12, and +// and should not be included in a build intended to target any older GTK +// versions. To target an older build, such as 3.10, use +// 'go build -tags gtk_3_10'. Otherwise, if no build tags are used, GTK 3.12 +// is assumed and this file is built. +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10 + +package gtk + +// #include +// #include "actionbar_since_3_12.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_action_bar_get_type()), marshalActionBar}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkActionBar"] = wrapActionBar +} + +// ActionBar is a representation of GtkActionBar +type ActionBar struct { + Bin +} + +func (v *ActionBar) native() *C.GtkActionBar { + if v == nil || v.GObject == nil { + return nil + } + + p := unsafe.Pointer(v.GObject) + return C.toGtkActionBar(p) +} + +func marshalActionBar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapActionBar(glib.Take(unsafe.Pointer(c))), nil +} + +func wrapActionBar(obj *glib.Object) *ActionBar { + if obj == nil { + return nil + } + + return &ActionBar{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// ActionBarNew is a wrapper around gtk_action_bar_new() +func ActionBarNew() (*ActionBar, error) { + c := C.gtk_action_bar_new() + if c == nil { + return nil, nilPtrErr + } + return wrapActionBar(glib.Take(unsafe.Pointer(c))), nil +} + +// PackStart is a wrapper around gtk_action_bar_pack_start(). +func (a *ActionBar) PackStart(child IWidget) { + C.gtk_action_bar_pack_start(a.native(), child.toWidget()) +} + +// PackEnd is a wrapper around gtk_action_bar_pack_end(). +func (a *ActionBar) PackEnd(child IWidget) { + C.gtk_action_bar_pack_end(a.native(), child.toWidget()) +} + +// SetCenterWidget is a wrapper around gtk_action_bar_set_center_widget(). +func (a *ActionBar) SetCenterWidget(child IWidget) { + if child == nil { + C.gtk_action_bar_set_center_widget(a.native(), nil) + } else { + C.gtk_action_bar_set_center_widget(a.native(), child.toWidget()) + } +} + +// GetCenterWidget is a wrapper around gtk_action_bar_get_center_widget(). +func (a *ActionBar) GetCenterWidget() (IWidget, error) { + w := C.gtk_action_bar_get_center_widget(a.native()) + if w == nil { + return nil, nil + } + return castWidget(w) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/actionbar_since_3_12.go.h b/vendor/github.com/gotk3/gotk3/gtk/actionbar_since_3_12.go.h new file mode 100644 index 0000000..4b5cd89 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/actionbar_since_3_12.go.h @@ -0,0 +1,21 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12 + +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +static GtkActionBar *toGtkActionBar(void *p) { return (GTK_ACTION_BAR(p)); } diff --git a/vendor/github.com/gotk3/gotk3/gtk/app_chooser.go b/vendor/github.com/gotk3/gotk3/gtk/app_chooser.go new file mode 100644 index 0000000..b7ab8dd --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/app_chooser.go @@ -0,0 +1,408 @@ +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_app_chooser_get_type()), marshalAppChooser}, + {glib.Type(C.gtk_app_chooser_button_get_type()), marshalAppChooserButton}, + {glib.Type(C.gtk_app_chooser_widget_get_type()), marshalAppChooserWidget}, + {glib.Type(C.gtk_app_chooser_dialog_get_type()), marshalAppChooserDialog}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkAppChooser"] = wrapAppChooser + WrapMap["GtkAppChooserButton"] = wrapAppChooserButton + WrapMap["GtkAppChooserWidget"] = wrapAppChooserWidget + WrapMap["GtkAppChooserDialog"] = wrapAppChooserDialog +} + +/* + * GtkAppChooser + */ + +// AppChooser is a representation of GTK's GtkAppChooser GInterface. +type AppChooser struct { + *glib.Object +} + +// IAppChooser is an interface type implemented by all structs +// embedding an AppChooser. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkAppChooser. +type IAppChooser interface { + toAppChooser() *C.GtkAppChooser +} + +// native returns a pointer to the underlying GtkAppChooser. +func (v *AppChooser) native() *C.GtkAppChooser { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkAppChooser(p) +} + +func marshalAppChooser(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapAppChooser(obj), nil +} + +func wrapAppChooser(obj *glib.Object) *AppChooser { + if obj == nil { + return nil + } + + return &AppChooser{obj} +} + +func (v *AppChooser) toAppChooser() *C.GtkAppChooser { + if v == nil { + return nil + } + return v.native() +} + +// TODO: Needs gio/GAppInfo implementation first +// gtk_app_chooser_get_app_info () + +// GetContentType is a wrapper around gtk_app_chooser_get_content_type(). +func (v *AppChooser) GetContentType() string { + cstr := C.gtk_app_chooser_get_content_type(v.native()) + defer C.free(unsafe.Pointer(cstr)) + return C.GoString((*C.char)(cstr)) +} + +// Refresh is a wrapper around gtk_app_chooser_refresh(). +func (v *AppChooser) Refresh() { + C.gtk_app_chooser_refresh(v.native()) +} + +/* + * GtkAppChooserButton + */ + +// AppChooserButton is a representation of GTK's GtkAppChooserButton. +type AppChooserButton struct { + ComboBox + + // Interfaces + AppChooser +} + +// native returns a pointer to the underlying GtkAppChooserButton. +func (v *AppChooserButton) native() *C.GtkAppChooserButton { + if v == nil || v.GObject == nil { + return nil + } + + p := unsafe.Pointer(v.GObject) + return C.toGtkAppChooserButton(p) +} + +func marshalAppChooserButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapAppChooserButton(glib.Take(unsafe.Pointer(c))), nil +} + +func wrapAppChooserButton(obj *glib.Object) *AppChooserButton { + if obj == nil { + return nil + } + + cl := wrapCellLayout(obj) + ce := wrapCellEditable(obj) + ac := wrapAppChooser(obj) + return &AppChooserButton{ComboBox{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}, *cl, *ce}, *ac} +} + +// AppChooserButtonNew() is a wrapper around gtk_app_chooser_button_new(). +func AppChooserButtonNew(content_type string) (*AppChooserButton, error) { + cstr := C.CString(content_type) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_app_chooser_button_new((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapAppChooserButton(glib.Take(unsafe.Pointer(c))), nil +} + +// TODO: Needs gio/GIcon implemented first +// gtk_app_chooser_button_append_custom_item () + +// AppendSeparator() is a wrapper around gtk_app_chooser_button_append_separator(). +func (v *AppChooserButton) AppendSeparator() { + C.gtk_app_chooser_button_append_separator(v.native()) +} + +// SetActiveCustomItem() is a wrapper around gtk_app_chooser_button_set_active_custom_item(). +func (v *AppChooserButton) SetActiveCustomItem(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_app_chooser_button_set_active_custom_item(v.native(), (*C.gchar)(cstr)) +} + +// GetShowDefaultItem() is a wrapper around gtk_app_chooser_button_get_show_default_item(). +func (v *AppChooserButton) GetShowDefaultItem() bool { + return gobool(C.gtk_app_chooser_button_get_show_default_item(v.native())) +} + +// SetShowDefaultItem() is a wrapper around gtk_app_chooser_button_set_show_default_item(). +func (v *AppChooserButton) SetShowDefaultItem(setting bool) { + C.gtk_app_chooser_button_set_show_default_item(v.native(), gbool(setting)) +} + +// GetShowDialogItem() is a wrapper around gtk_app_chooser_button_get_show_dialog_item(). +func (v *AppChooserButton) GetShowDialogItem() bool { + return gobool(C.gtk_app_chooser_button_get_show_dialog_item(v.native())) +} + +// SetShowDialogItem() is a wrapper around gtk_app_chooser_button_set_show_dialog_item(). +func (v *AppChooserButton) SetShowDialogItem(setting bool) { + C.gtk_app_chooser_button_set_show_dialog_item(v.native(), gbool(setting)) +} + +// GetHeading() is a wrapper around gtk_app_chooser_button_get_heading(). +// In case when gtk_app_chooser_button_get_heading() returns a nil string, +// GetHeading() returns a non-nil error. +func (v *AppChooserButton) GetHeading() (string, error) { + cstr := C.gtk_app_chooser_button_get_heading(v.native()) + if cstr == nil { + return "", nilPtrErr + } + defer C.free(unsafe.Pointer(cstr)) + return C.GoString((*C.char)(cstr)), nil +} + +// SetHeading() is a wrapper around gtk_app_chooser_button_set_heading(). +func (v *AppChooserButton) SetHeading(heading string) { + cstr := C.CString(heading) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_app_chooser_button_set_heading(v.native(), (*C.gchar)(cstr)) +} + +/* + * GtkAppChooserWidget + */ + +// AppChooserWidget is a representation of GTK's GtkAppChooserWidget. +type AppChooserWidget struct { + Box + + // Interfaces + AppChooser +} + +// native returns a pointer to the underlying GtkAppChooserWidget. +func (v *AppChooserWidget) native() *C.GtkAppChooserWidget { + if v == nil || v.GObject == nil { + return nil + } + + p := unsafe.Pointer(v.GObject) + return C.toGtkAppChooserWidget(p) +} + +func marshalAppChooserWidget(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapAppChooserWidget(glib.Take(unsafe.Pointer(c))), nil +} + +func wrapAppChooserWidget(obj *glib.Object) *AppChooserWidget { + if obj == nil { + return nil + } + + box := wrapBox(obj) + ac := wrapAppChooser(obj) + return &AppChooserWidget{*box, *ac} +} + +// AppChooserWidgetNew() is a wrapper around gtk_app_chooser_widget_new(). +func AppChooserWidgetNew(content_type string) (*AppChooserWidget, error) { + cstr := C.CString(content_type) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_app_chooser_widget_new((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapAppChooserWidget(glib.Take(unsafe.Pointer(c))), nil +} + +// GetShowDefault() is a wrapper around gtk_app_chooser_widget_get_show_default(). +func (v *AppChooserWidget) GetShowDefault() bool { + return gobool(C.gtk_app_chooser_widget_get_show_default(v.native())) +} + +// SetShowDefault() is a wrapper around gtk_app_chooser_widget_set_show_default(). +func (v *AppChooserWidget) SetShowDefault(setting bool) { + C.gtk_app_chooser_widget_set_show_default(v.native(), gbool(setting)) +} + +// GetShowRecommended() is a wrapper around gtk_app_chooser_widget_get_show_recommended(). +func (v *AppChooserWidget) GetShowRecommended() bool { + return gobool(C.gtk_app_chooser_widget_get_show_recommended(v.native())) +} + +// SetShowRecommended() is a wrapper around gtk_app_chooser_widget_set_show_recommended(). +func (v *AppChooserWidget) SetShowRecommended(setting bool) { + C.gtk_app_chooser_widget_set_show_recommended(v.native(), gbool(setting)) +} + +// GetShowFallback() is a wrapper around gtk_app_chooser_widget_get_show_fallback(). +func (v *AppChooserWidget) GetShowFallback() bool { + return gobool(C.gtk_app_chooser_widget_get_show_fallback(v.native())) +} + +// SetShowFallback() is a wrapper around gtk_app_chooser_widget_set_show_fallback(). +func (v *AppChooserWidget) SetShowFallback(setting bool) { + C.gtk_app_chooser_widget_set_show_fallback(v.native(), gbool(setting)) +} + +// GetShowOther() is a wrapper around gtk_app_chooser_widget_get_show_other(). +func (v *AppChooserWidget) GetShowOther() bool { + return gobool(C.gtk_app_chooser_widget_get_show_other(v.native())) +} + +// SetShowOther() is a wrapper around gtk_app_chooser_widget_set_show_other(). +func (v *AppChooserWidget) SetShowOther(setting bool) { + C.gtk_app_chooser_widget_set_show_other(v.native(), gbool(setting)) +} + +// GetShowAll() is a wrapper around gtk_app_chooser_widget_get_show_all(). +func (v *AppChooserWidget) GetShowAll() bool { + return gobool(C.gtk_app_chooser_widget_get_show_all(v.native())) +} + +// SetShowAll() is a wrapper around gtk_app_chooser_widget_set_show_all(). +func (v *AppChooserWidget) SetShowAll(setting bool) { + C.gtk_app_chooser_widget_set_show_all(v.native(), gbool(setting)) +} + +// GetDefaultText() is a wrapper around gtk_app_chooser_widget_get_default_text(). +// In case when gtk_app_chooser_widget_get_default_text() returns a nil string, +// GetDefaultText() returns a non-nil error. +func (v *AppChooserWidget) GetDefaultText() (string, error) { + cstr := C.gtk_app_chooser_widget_get_default_text(v.native()) + if cstr == nil { + return "", nilPtrErr + } + defer C.free(unsafe.Pointer(cstr)) + return C.GoString((*C.char)(cstr)), nil +} + +// SetDefaultText() is a wrapper around gtk_app_chooser_widget_set_default_text(). +func (v *AppChooserWidget) SetDefaultText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_app_chooser_widget_set_default_text(v.native(), (*C.gchar)(cstr)) +} + +/* + * GtkAppChooserDialog + */ + +// AppChooserDialog is a representation of GTK's GtkAppChooserDialog. +type AppChooserDialog struct { + Dialog + + // Interfaces + AppChooser +} + +// native returns a pointer to the underlying GtkAppChooserButton. +func (v *AppChooserDialog) native() *C.GtkAppChooserDialog { + if v == nil || v.GObject == nil { + return nil + } + + p := unsafe.Pointer(v.GObject) + return C.toGtkAppChooserDialog(p) +} + +func marshalAppChooserDialog(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapAppChooserDialog(glib.Take(unsafe.Pointer(c))), nil +} + +func wrapAppChooserDialog(obj *glib.Object) *AppChooserDialog { + if obj == nil { + return nil + } + + dialog := wrapDialog(obj) + ac := wrapAppChooser(obj) + return &AppChooserDialog{*dialog, *ac} +} + +// AppChooserDialogNew is a wrapper around gtk_app_chooser_dialog_new(). +func AppChooserDialogNew(parent IWindow, flags DialogFlags, file *glib.File) (*AppChooserDialog, error) { + + var gfile *C.GFile + if file != nil { + gfile = (*C.GFile)(unsafe.Pointer(file.Native())) + } + + var pw *C.GtkWindow = nil + if parent != nil { + pw = parent.toWindow() + } + + c := C.gtk_app_chooser_dialog_new(pw, C.GtkDialogFlags(flags), gfile) + if c == nil { + return nil, nilPtrErr + } + return wrapAppChooserDialog(glib.Take(unsafe.Pointer(c))), nil +} + +// AppChooserDialogNewForContentType() is a wrapper around gtk_app_chooser_dialog_new_for_content_type(). +func AppChooserDialogNewForContentType(parent IWindow, flags DialogFlags, content_type string) (*AppChooserDialog, error) { + + cstr := C.CString(content_type) + defer C.free(unsafe.Pointer(cstr)) + + var pw *C.GtkWindow = nil + if parent != nil { + pw = parent.toWindow() + } + + c := C.gtk_app_chooser_dialog_new_for_content_type(pw, C.GtkDialogFlags(flags), (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapAppChooserDialog(glib.Take(unsafe.Pointer(c))), nil +} + +// GetWidget() is a wrapper around gtk_app_chooser_dialog_get_widget(). +func (v *AppChooserDialog) GetWidget() *AppChooserWidget { + c := C.gtk_app_chooser_dialog_get_widget(v.native()) + return wrapAppChooserWidget(glib.Take(unsafe.Pointer(c))) +} + +// GetHeading() is a wrapper around gtk_app_chooser_dialog_get_heading(). +// In case when gtk_app_chooser_dialog_get_heading() returns a nil string, +// GetHeading() returns a non-nil error. +func (v *AppChooserDialog) GetHeading() (string, error) { + cstr := C.gtk_app_chooser_dialog_get_heading(v.native()) + if cstr == nil { + return "", nilPtrErr + } + defer C.free(unsafe.Pointer(cstr)) + return C.GoString((*C.char)(cstr)), nil +} + +// SetHeading() is a wrapper around gtk_app_chooser_dialog_set_heading(). +func (v *AppChooserDialog) SetHeading(heading string) { + cstr := C.CString(heading) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_app_chooser_dialog_set_heading(v.native(), (*C.gchar)(cstr)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/application.go b/vendor/github.com/gotk3/gotk3/gtk/application.go new file mode 100644 index 0000000..7e39156 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/application.go @@ -0,0 +1,172 @@ +// Same copyright and license as the rest of the files in this project +// This file contains style related functions and structures + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// ApplicationInhibitFlags is a representation of GTK's GtkApplicationInhibitFlags. +type ApplicationInhibitFlags int + +const ( + APPLICATION_INHIBIT_LOGOUT ApplicationInhibitFlags = C.GTK_APPLICATION_INHIBIT_LOGOUT + APPLICATION_INHIBIT_SWITCH ApplicationInhibitFlags = C.GTK_APPLICATION_INHIBIT_SWITCH + APPLICATION_INHIBIT_SUSPEND ApplicationInhibitFlags = C.GTK_APPLICATION_INHIBIT_SUSPEND + APPLICATION_INHIBIT_IDLE ApplicationInhibitFlags = C.GTK_APPLICATION_INHIBIT_IDLE +) + +/* + * GtkApplication + */ + +// Application is a representation of GTK's GtkApplication. +type Application struct { + glib.Application +} + +// native returns a pointer to the underlying GtkApplication. +func (v *Application) native() *C.GtkApplication { + if v == nil || v.GObject == nil { + return nil + } + return C.toGtkApplication(unsafe.Pointer(v.GObject)) +} + +func marshalApplication(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapApplication(obj), nil +} + +func wrapApplication(obj *glib.Object) *Application { + if obj == nil { + return nil + } + + am := &glib.ActionMap{obj} + ag := &glib.ActionGroup{obj} + return &Application{glib.Application{obj, am, ag}} +} + +// ApplicationNew is a wrapper around gtk_application_new(). +func ApplicationNew(appId string, flags glib.ApplicationFlags) (*Application, error) { + cstr := (*C.gchar)(C.CString(appId)) + defer C.free(unsafe.Pointer(cstr)) + + c := C.gtk_application_new(cstr, C.GApplicationFlags(flags)) + if c == nil { + return nil, nilPtrErr + } + return wrapApplication(glib.Take(unsafe.Pointer(c))), nil +} + +// AddWindow is a wrapper around gtk_application_add_window(). +func (v *Application) AddWindow(w IWindow) { + C.gtk_application_add_window(v.native(), w.toWindow()) +} + +// RemoveWindow is a wrapper around gtk_application_remove_window(). +func (v *Application) RemoveWindow(w IWindow) { + C.gtk_application_remove_window(v.native(), w.toWindow()) +} + +// GetWindowByID is a wrapper around gtk_application_get_window_by_id(). +func (v *Application) GetWindowByID(id uint) *Window { + c := C.gtk_application_get_window_by_id(v.native(), C.guint(id)) + if c == nil { + return nil + } + return wrapWindow(glib.Take(unsafe.Pointer(c))) +} + +// GetActiveWindow is a wrapper around gtk_application_get_active_window(). +func (v *Application) GetActiveWindow() *Window { + c := C.gtk_application_get_active_window(v.native()) + if c == nil { + return nil + } + return wrapWindow(glib.Take(unsafe.Pointer(c))) +} + +// Uninhibit is a wrapper around gtk_application_uninhibit(). +func (v *Application) Uninhibit(cookie uint) { + C.gtk_application_uninhibit(v.native(), C.guint(cookie)) +} + +// GetAppMenu is a wrapper around gtk_application_get_app_menu(). +func (v *Application) GetAppMenu() *glib.MenuModel { + c := C.gtk_application_get_app_menu(v.native()) + if c == nil { + return nil + } + return &glib.MenuModel{glib.Take(unsafe.Pointer(c))} +} + +// SetAppMenu is a wrapper around gtk_application_set_app_menu(). +func (v *Application) SetAppMenu(m *glib.MenuModel) { + mptr := (*C.GMenuModel)(unsafe.Pointer(m.Native())) + C.gtk_application_set_app_menu(v.native(), mptr) +} + +// GetMenubar is a wrapper around gtk_application_get_menubar(). +func (v *Application) GetMenubar() *glib.MenuModel { + c := C.gtk_application_get_menubar(v.native()) + if c == nil { + return nil + } + return &glib.MenuModel{glib.Take(unsafe.Pointer(c))} +} + +// SetMenubar is a wrapper around gtk_application_set_menubar(). +func (v *Application) SetMenubar(m *glib.MenuModel) { + mptr := (*C.GMenuModel)(unsafe.Pointer(m.Native())) + C.gtk_application_set_menubar(v.native(), mptr) +} + +// IsInhibited is a wrapper around gtk_application_is_inhibited(). +func (v *Application) IsInhibited(flags ApplicationInhibitFlags) bool { + return gobool(C.gtk_application_is_inhibited(v.native(), C.GtkApplicationInhibitFlags(flags))) +} + +// Inhibited is a wrapper around gtk_application_inhibit(). +func (v *Application) Inhibited(window IWindow, flags ApplicationInhibitFlags, reason string) uint { + + cstr1 := (*C.gchar)(C.CString(reason)) + defer C.free(unsafe.Pointer(cstr1)) + + var w *C.GtkWindow = nil + if window != nil { + w = window.toWindow() + } + + return uint(C.gtk_application_inhibit(v.native(), w, C.GtkApplicationInhibitFlags(flags), cstr1)) +} + +// void gtk_application_add_accelerator () // deprecated and uses a gvariant paramater +// void gtk_application_remove_accelerator () // deprecated and uses a gvariant paramater + +// GetWindows is a wrapper around gtk_application_get_windows(). +// Returned list is wrapped to return *gtk.Window elements. +func (v *Application) GetWindows() *glib.List { + clist := C.gtk_application_get_windows(v.native()) + if clist == nil { + return nil + } + + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return wrapWindow(glib.Take(ptr)) + }) + runtime.SetFinalizer(glist, func(l *glib.List) { + l.Free() + }) + return glist +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/application_since_3_12.go b/vendor/github.com/gotk3/gotk3/gtk/application_since_3_12.go new file mode 100644 index 0000000..478505e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/application_since_3_12.go @@ -0,0 +1,62 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10 + +// See: https://developer.gnome.org/gtk3/3.12/api-index-3-12.html + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import "unsafe" + +// GetAccelsForAction is a wrapper around gtk_application_get_accels_for_action(). +func (v *Application) GetAccelsForAction(act string) []string { + cstr1 := (*C.gchar)(C.CString(act)) + defer C.free(unsafe.Pointer(cstr1)) + + var descs []string + c := C.gtk_application_get_accels_for_action(v.native(), cstr1) + originalc := c + defer C.g_strfreev(originalc) + + for *c != nil { + descs = append(descs, C.GoString((*C.char)(*c))) + c = nextgcharptr(c) + } + + return descs +} + +// SetAccelsForAction is a wrapper around gtk_application_set_accels_for_action(). +func (v *Application) SetAccelsForAction(act string, accels []string) { + cstr1 := (*C.gchar)(C.CString(act)) + defer C.free(unsafe.Pointer(cstr1)) + + caccels := C.make_strings(C.int(len(accels) + 1)) + defer C.destroy_strings(caccels) + + for i, accel := range accels { + cstr := C.CString(accel) + defer C.free(unsafe.Pointer(cstr)) + C.set_string(caccels, C.int(i), (*C.gchar)(cstr)) + } + + C.set_string(caccels, C.int(len(accels)), nil) + + C.gtk_application_set_accels_for_action(v.native(), cstr1, caccels) +} + +// ListActionDescriptions is a wrapper around gtk_application_list_action_descriptions(). +func (v *Application) ListActionDescriptions() []string { + var descs []string + c := C.gtk_application_list_action_descriptions(v.native()) + originalc := c + defer C.g_strfreev(originalc) + + for *c != nil { + descs = append(descs, C.GoString((*C.char)(*c))) + c = nextgcharptr(c) + } + + return descs +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/application_since_3_14.go b/vendor/github.com/gotk3/gotk3/gtk/application_since_3_14.go new file mode 100644 index 0000000..9c749c5 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/application_since_3_14.go @@ -0,0 +1,49 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12 + +// See: https://developer.gnome.org/gtk3/3.14/api-index-3-14.html + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// PrefersAppMenu is a wrapper around gtk_application_prefers_app_menu(). +func (v *Application) PrefersAppMenu() bool { + return gobool(C.gtk_application_prefers_app_menu(v.native())) +} + +// GetActionsForAccel is a wrapper around gtk_application_get_actions_for_accel(). +func (v *Application) GetActionsForAccel(acc string) []string { + cstr1 := (*C.gchar)(C.CString(acc)) + defer C.free(unsafe.Pointer(cstr1)) + + var acts []string + c := C.gtk_application_get_actions_for_accel(v.native(), cstr1) + originalc := c + defer C.g_strfreev(originalc) + + for *c != nil { + acts = append(acts, C.GoString((*C.char)(*c))) + c = nextgcharptr(c) + } + + return acts +} + +// GetMenuByID is a wrapper around gtk_application_get_menu_by_id(). +func (v *Application) GetMenuByID(id string) *glib.Menu { + cstr1 := (*C.gchar)(C.CString(id)) + defer C.free(unsafe.Pointer(cstr1)) + + c := C.gtk_application_get_menu_by_id(v.native(), cstr1) + if c == nil { + return nil + } + return &glib.Menu{glib.MenuModel{glib.Take(unsafe.Pointer(c))}} +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/application_window.go b/vendor/github.com/gotk3/gotk3/gtk/application_window.go new file mode 100644 index 0000000..f5bc2c0 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/application_window.go @@ -0,0 +1,75 @@ +// Same copyright and license as the rest of the files in this project +// This file contains style related functions and structures + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +/* + * GtkApplicationWindow + */ + +// ApplicationWindow is a representation of GTK's GtkApplicationWindow. +type ApplicationWindow struct { + Window + + // Interfaces + glib.IActionMap + glib.IActionGroup +} + +// native returns a pointer to the underlying GtkApplicationWindow. +func (v *ApplicationWindow) native() *C.GtkApplicationWindow { + if v == nil || v.Window.GObject == nil { // v.Window is necessary because v.GObject would be ambiguous + return nil + } + p := unsafe.Pointer(v.Window.GObject) + return C.toGtkApplicationWindow(p) +} + +func marshalApplicationWindow(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapApplicationWindow(obj), nil +} + +func wrapApplicationWindow(obj *glib.Object) *ApplicationWindow { + if obj == nil { + return nil + } + + am := &glib.ActionMap{obj} + ag := &glib.ActionGroup{obj} + return &ApplicationWindow{Window{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}}, am, ag} +} + +// ApplicationWindowNew is a wrapper around gtk_application_window_new(). +func ApplicationWindowNew(app *Application) (*ApplicationWindow, error) { + c := C.gtk_application_window_new(app.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapApplicationWindow(glib.Take(unsafe.Pointer(c))), nil +} + +// SetShowMenubar is a wrapper around gtk_application_window_set_show_menubar(). +func (v *ApplicationWindow) SetShowMenubar(b bool) { + C.gtk_application_window_set_show_menubar(v.native(), gbool(b)) +} + +// GetShowMenubar is a wrapper around gtk_application_window_get_show_menubar(). +func (v *ApplicationWindow) GetShowMenubar() bool { + return gobool(C.gtk_application_window_get_show_menubar(v.native())) +} + +// GetID is a wrapper around gtk_application_window_get_id(). +func (v *ApplicationWindow) GetID() uint { + return uint(C.gtk_application_window_get_id(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/application_window_since_3_20.go b/vendor/github.com/gotk3/gotk3/gtk/application_window_since_3_20.go new file mode 100644 index 0000000..e8553b2 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/application_window_since_3_20.go @@ -0,0 +1,28 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16,!gtk_3_18 + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// SetHelpOverlay is a wrapper around gtk_application_window_set_help_overlay(). +func (v *ApplicationWindow) SetHelpOverlay(helpOverlay *ShortcutsWindow) { + C.gtk_application_window_set_help_overlay(v.native(), helpOverlay.native()) +} + +// GetHelpOverlay is a wrapper around gtk_application_window_get_help_overlay(). +func (v *ApplicationWindow) GetHelpOverlay() *ShortcutsWindow { + c := C.gtk_application_window_get_help_overlay(v.native()) + if c == nil { + return nil + } + return wrapShortcutsWindow(glib.Take(unsafe.Pointer(c))) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/box_since_3_12.go b/vendor/github.com/gotk3/gotk3/gtk/box_since_3_12.go new file mode 100644 index 0000000..cc140ca --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/box_since_3_12.go @@ -0,0 +1,48 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10 + +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// This file includes wrapers for symbols included since GTK 3.12, and +// and should not be included in a build intended to target any older GTK +// versions. To target an older build, such as 3.10, use +// 'go build -tags gtk_3_10'. Otherwise, if no build tags are used, GTK 3.12 +// is assumed and this file is built. +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10 + +package gtk + +// #include +// #include "gtk.go.h" +import "C" + +// SetCenterWidget is a wrapper around gtk_box_set_center_widget(). +func (a *Box) SetCenterWidget(child IWidget) { + if child == nil { + C.gtk_box_set_center_widget(a.native(), nil) + } else { + C.gtk_box_set_center_widget(a.native(), child.toWidget()) + } +} + +// GetCenterWidget is a wrapper around gtk_box_get_center_widget(). +func (a *Box) GetCenterWidget() (IWidget, error) { + w := C.gtk_box_get_center_widget(a.native()) + if w == nil { + return nil, nil + } + return castWidget(w) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/button_box.go b/vendor/github.com/gotk3/gotk3/gtk/button_box.go new file mode 100644 index 0000000..2d082f4 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/button_box.go @@ -0,0 +1,98 @@ +// Same copyright and license as the rest of the files in this project +// This file contains accelerator related functions and structures + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +type ButtonBoxStyle int + +const ( + BUTTONBOX_SPREAD ButtonBoxStyle = C.GTK_BUTTONBOX_SPREAD + BUTTONBOX_EDGE ButtonBoxStyle = C.GTK_BUTTONBOX_EDGE + BUTTONBOX_START ButtonBoxStyle = C.GTK_BUTTONBOX_START + BUTTONBOX_END ButtonBoxStyle = C.GTK_BUTTONBOX_END + BUTTONBOX_CENTER ButtonBoxStyle = C.GTK_BUTTONBOX_CENTER +) + +/* + * GtkButtonBox + */ + +// ButtonBox is a representation of GTK's GtkButtonBox. +type ButtonBox struct { + Box +} + +// native returns a pointer to the underlying GtkButtonBox. +func (v *ButtonBox) native() *C.GtkButtonBox { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkButtonBox(p) +} + +func marshalButtonBox(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapButtonBox(obj), nil +} + +func wrapButtonBox(obj *glib.Object) *ButtonBox { + if obj == nil { + return nil + } + + return &ButtonBox{Box{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// ButtonBoxNew is a wrapper around gtk_button_box_new(). +func ButtonBoxNew(o Orientation) (*ButtonBox, error) { + c := C.gtk_button_box_new(C.GtkOrientation(o)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapButtonBox(obj), nil +} + +// GetLayout() is a wrapper around gtk_button_box_get_layout(). +func (v *ButtonBox) GetLayout() ButtonBoxStyle { + c := C.gtk_button_box_get_layout(v.native()) + return ButtonBoxStyle(c) +} + +// GetChildSecondary() is a wrapper around gtk_button_box_get_child_secondary(). +func (v *ButtonBox) GetChildSecondary(child IWidget) bool { + c := C.gtk_button_box_get_child_secondary(v.native(), child.toWidget()) + return gobool(c) +} + +// GetChildNonHomogeneous() is a wrapper around gtk_button_box_get_child_non_homogeneous(). +func (v *ButtonBox) GetChildNonHomogeneous(child IWidget) bool { + c := C.gtk_button_box_get_child_non_homogeneous(v.native(), child.toWidget()) + return gobool(c) +} + +// SetLayout() is a wrapper around gtk_button_box_set_layout(). +func (v *ButtonBox) SetLayout(style ButtonBoxStyle) { + C.gtk_button_box_set_layout(v.native(), C.GtkButtonBoxStyle(style)) +} + +// SetChildSecondary() is a wrapper around gtk_button_box_set_child_secondary(). +func (v *ButtonBox) SetChildSecondary(child IWidget, isSecondary bool) { + C.gtk_button_box_set_child_secondary(v.native(), child.toWidget(), gbool(isSecondary)) +} + +// SetChildNonHomogeneous() is a wrapper around gtk_button_box_set_child_non_homogeneous(). +func (v *ButtonBox) SetChildNonHomogeneous(child IWidget, nonHomogeneous bool) { + C.gtk_button_box_set_child_non_homogeneous(v.native(), child.toWidget(), gbool(nonHomogeneous)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/cell_area.go b/vendor/github.com/gotk3/gotk3/gtk/cell_area.go new file mode 100644 index 0000000..c7a6418 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/cell_area.go @@ -0,0 +1,580 @@ +// Same copyright and license as the rest of the files in this project + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "fmt" + "unsafe" + + "github.com/gotk3/gotk3/cairo" + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +/* + * GtkCellArea + */ + +// TODO: macro +// GTK_CELL_AREA_WARN_INVALID_CELL_PROPERTY_ID(object, property_id, pspec) +// object - the GObject on which set_cell_property() or get_cell_property() was called +// property_id - the numeric id of the property +// pspec - the GParamSpec of the property +// C.GTK_CELL_AREA_WARN_INVALID_CELL_PROPERTY_ID + +// CellArea is a representation of GTK's GtkCellArea. +type CellArea struct { + glib.InitiallyUnowned +} + +type ICellArea interface { + toCellArea() *C.GtkCellArea + ToCellArea() *CellArea +} + +// native returns a pointer to the underlying GtkCellArea. +func (v *CellArea) native() *C.GtkCellArea { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellArea(p) +} + +func (v *CellArea) toCellArea() *C.GtkCellArea { + if v == nil { + return nil + } + return v.native() +} + +// ToCellArea is a helper getter, in case you use the interface gtk.ICellArea in your program. +// It returns e.g. *gtk.CellAreaBox as a *gtk.CellArea. +func (v *CellArea) ToCellArea() *CellArea { + return v +} + +func marshalCellArea(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellArea(obj), nil +} + +func wrapCellArea(obj *glib.Object) *CellArea { + if obj == nil { + return nil + } + + return &CellArea{glib.InitiallyUnowned{obj}} +} + +// Add is a wrapper around gtk_cell_area_add(). +func (v *CellArea) Add(renderer ICellRenderer) { + C.gtk_cell_area_add(v.native(), renderer.toCellRenderer()) +} + +// Remove is a wrapper around gtk_cell_area_remove(). +func (v *CellArea) Remove(renderer ICellRenderer) { + C.gtk_cell_area_remove(v.native(), renderer.toCellRenderer()) +} + +// HasRenderer is a wrapper around gtk_cell_area_has_renderer(). +func (v *CellArea) HasRenderer(renderer ICellRenderer) bool { + return gobool(C.gtk_cell_area_has_renderer(v.native(), renderer.toCellRenderer())) +} + +// TODO: +// depends on GtkCellCallback +// Foreach is a wrapper around gtk_cell_area_foreach(). +// func (v *CellArea) Foreach(cb CellCallback, callbackData interface{}) { +// } + +// TODO: +// depends on GtkCellAllocCallback +// ForeachAlloc is a wrapper around gtk_cell_area_foreach_alloc(). +// func (v *CellArea) ForeachAlloc(context *CellAreaContext, widget IWidget, cellArea, backgroundArea *gdk.Rectangle, cb CellAllocCallback, callbackData interface{}) { +// } + +// AreaEvent is a wrapper around gtk_cell_area_event(). +func (v *CellArea) AreaEvent(context *CellAreaContext, widget IWidget, + event *gdk.Event, cellArea *gdk.Rectangle, flags CellRendererState) int { + + e := (*C.GdkEvent)(unsafe.Pointer(event.Native())) + c := C.gtk_cell_area_event(v.native(), context.native(), widget.toWidget(), + e, nativeGdkRectangle(*cellArea), C.GtkCellRendererState(flags)) + + return int(c) +} + +// Render is a wrapper around gtk_cell_area_render(). +func (v *CellArea) Render(context *CellAreaContext, widget IWidget, cr *cairo.Context, + backgroundArea, cellArea *gdk.Rectangle, flags CellRendererState, paintFocus bool) { + + cairoContext := (*C.cairo_t)(unsafe.Pointer(cr.Native())) + + C.gtk_cell_area_render(v.native(), context.native(), widget.toWidget(), cairoContext, + nativeGdkRectangle(*backgroundArea), nativeGdkRectangle(*cellArea), + C.GtkCellRendererState(flags), gbool(paintFocus)) +} + +// GetCellAllocation is a wrapper around gtk_cell_area_get_cell_allocation(). +func (v *CellArea) GetCellAllocation(context *CellAreaContext, widget IWidget, + renderer ICellRenderer, cellArea *gdk.Rectangle) *gdk.Rectangle { + + var cRect *C.GdkRectangle + C.gtk_cell_area_get_cell_allocation(v.native(), context.native(), widget.toWidget(), + renderer.toCellRenderer(), nativeGdkRectangle(*cellArea), cRect) + allocation := gdk.WrapRectangle(uintptr(unsafe.Pointer(cRect))) + return allocation + +} + +// GetCellAtPosition is a wrapper around gtk_cell_area_get_cell_at_position(). +func (v *CellArea) GetCellAtPosition(context *CellAreaContext, widget IWidget, + cellArea *gdk.Rectangle, x, y int) (ICellRenderer, *gdk.Rectangle, error) { + + var cRect *C.GdkRectangle + + renderer := C.gtk_cell_area_get_cell_at_position(v.native(), context.native(), widget.toWidget(), + nativeGdkRectangle(*cellArea), C.gint(x), C.gint(y), cRect) + + var allocation *gdk.Rectangle + + if cRect != nil { + allocation = gdk.WrapRectangle(uintptr(unsafe.Pointer(cRect))) + } + + r, err := castCellRenderer(renderer) + + return r, allocation, err +} + +// CreateContext is a wrapper around gtk_cell_area_create_context(). +func (v *CellArea) CreateContext() (*CellAreaContext, error) { + c := C.gtk_cell_area_create_context(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapCellAreaContext(glib.Take(unsafe.Pointer(c))), nil +} + +// CopyContext is a wrapper around gtk_cell_area_copy_context(). +func (v *CellArea) CopyContext(context *CellAreaContext) (*CellAreaContext, error) { + c := C.gtk_cell_area_copy_context(v.native(), context.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapCellAreaContext(glib.Take(unsafe.Pointer(c))), nil +} + +// TODO: +// depends on GtkSizeRequestMode +// gtk_cell_area_get_request_mode + +// GetPreferredWidth is a wrapper around gtk_cell_area_get_preferred_width(). +func (v *CellArea) GetPreferredWidth(context *CellAreaContext, widget IWidget) (int, int) { + var minWidth C.gint + var naturalWidth C.gint + C.gtk_cell_area_get_preferred_width(v.native(), context.native(), widget.toWidget(), + &minWidth, &naturalWidth) + + return int(minWidth), int(naturalWidth) +} + +// GetPreferredHeightForWidth is a wrapper around gtk_cell_area_get_preferred_height_for_width(). +func (v *CellArea) GetPreferredHeightForWidth(context *CellAreaContext, widget IWidget, width int) (int, int) { + var minHeight C.gint + var naturalHeight C.gint + C.gtk_cell_area_get_preferred_height_for_width(v.native(), context.native(), widget.toWidget(), + C.gint(width), &minHeight, &naturalHeight) + + return int(minHeight), int(naturalHeight) +} + +// GetPreferredHeight is a wrapper around gtk_cell_area_get_preferred_height(). +func (v *CellArea) GetPreferredHeight(context *CellAreaContext, widget IWidget) (int, int) { + var minHeight C.gint + var naturalHeight C.gint + C.gtk_cell_area_get_preferred_height(v.native(), context.native(), widget.toWidget(), + &minHeight, &naturalHeight) + + return int(minHeight), int(naturalHeight) +} + +// GetPreferredWidthForHeight is a wrapper around gtk_cell_area_get_preferred_width_for_height(). +func (v *CellArea) GetPreferredWidthForHeight(context *CellAreaContext, widget IWidget, height int) (int, int) { + var minWidth C.gint + var naturalWidth C.gint + C.gtk_cell_area_get_preferred_width_for_height(v.native(), context.native(), widget.toWidget(), + C.gint(height), &minWidth, &naturalWidth) + + return int(minWidth), int(naturalWidth) +} + +// GetCurrentPathString is a wrapper around gtk_cell_area_get_current_path_string(). +func (v *CellArea) GetCurrentPathString() string { + c := C.gtk_cell_area_get_current_path_string(v.native()) + // This string belongs to the area and should not be freed. + return goString(c) +} + +// ApplyAttributes is a wrapper around gtk_cell_area_apply_attributes(). +func (v *CellArea) ApplyAttributes(model ITreeModel, iter *TreeIter, isExpander, isExpanded bool) { + C.gtk_cell_area_apply_attributes(v.native(), model.toTreeModel(), iter.native(), + gbool(isExpander), gbool(isExpanded)) +} + +// AttributeConnect is a wrapper around gtk_cell_area_attribute_connect(). +func (v *CellArea) AttributeConnect(renderer ICellRenderer, attribute string, column int) { + cstr := C.CString(attribute) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_cell_area_attribute_connect(v.native(), renderer.toCellRenderer(), (*C.gchar)(cstr), C.gint(column)) +} + +// AttributeDisconnect is a wrapper around gtk_cell_area_attribute_disconnect(). +func (v *CellArea) AttributeDisconnect(renderer ICellRenderer, attribute string) { + cstr := C.CString(attribute) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_cell_area_attribute_disconnect(v.native(), renderer.toCellRenderer(), (*C.gchar)(cstr)) +} + +// TODO: +// gtk_cell_area_class_install_cell_property // depends on GParamSpec +// gtk_cell_area_class_find_cell_property // depends on GParamSpec +// gtk_cell_area_class_list_cell_properties // depends on GParamSpec +// gtk_cell_area_add_with_properties +// gtk_cell_area_cell_set +// gtk_cell_area_cell_get +// gtk_cell_area_cell_set_valist +// gtk_cell_area_cell_get_valist + +// CellSetProperty is a wrapper around gtk_cell_area_cell_set_property(). +func (v *CellArea) CellSetProperty(renderer ICellRenderer, propertyName string, value interface{}) error { + gval, err := glib.GValue(value) + if err != nil { + return err + } + cstr := C.CString(propertyName) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_cell_area_cell_set_property(v.native(), renderer.toCellRenderer(), (*C.gchar)(cstr), + (*C.GValue)(unsafe.Pointer(gval.Native()))) + return nil +} + +// CellGetProperty is a wrapper around gtk_cell_area_cell_get_property(). +func (v *CellArea) CellGetProperty(renderer ICellRenderer, propertyName string) (interface{}, error) { + cstr := C.CString(propertyName) + defer C.free(unsafe.Pointer(cstr)) + + var gval C.GValue + C.gtk_cell_area_cell_get_property(v.native(), renderer.toCellRenderer(), (*C.gchar)(cstr), &gval) + value := glib.ValueFromNative(unsafe.Pointer(&gval)) + return value.GoValue() +} + +// IsActivatable is a wrapper around gtk_cell_area_is_activatable(). +func (v *CellArea) IsActivatable() bool { + return gobool(C.gtk_cell_area_is_activatable(v.native())) +} + +// Activate is a wrapper around gtk_cell_area_activate(). +func (v *CellArea) Activate(context *CellAreaContext, widget IWidget, + cellArea *gdk.Rectangle, flags CellRendererState, editOnly bool) { + + C.gtk_cell_area_activate(v.native(), context.native(), widget.toWidget(), + nativeGdkRectangle(*cellArea), C.GtkCellRendererState(flags), gbool(editOnly)) +} + +// Focus is a wrapper around gtk_cell_area_focus(). +func (v *CellArea) Focus(direction DirectionType) bool { + return gobool(C.gtk_cell_area_focus(v.native(), C.GtkDirectionType(direction))) +} + +// SetFocusCell is a wrapper around gtk_cell_area_set_focus_cell(). +func (v *CellArea) SetFocusCell(renderer ICellRenderer) { + C.gtk_cell_area_set_focus_cell(v.native(), renderer.toCellRenderer()) +} + +// GetFocusCell is a wrapper around gtk_cell_area_get_focus_cell(). +func (v *CellArea) GetFocusCell() (ICellRenderer, error) { + c := C.gtk_cell_area_get_focus_cell(v.native()) + return castCellRenderer(c) +} + +// AddFocusSibling is a wrapper around gtk_cell_area_add_focus_sibling(). +func (v *CellArea) AddFocusSibling(renderer, sibling ICellRenderer) { + C.gtk_cell_area_add_focus_sibling(v.native(), renderer.toCellRenderer(), sibling.toCellRenderer()) +} + +// RemoveFocusSibling is a wrapper around gtk_cell_area_remove_focus_sibling(). +func (v *CellArea) RemoveFocusSibling(renderer, sibling ICellRenderer) { + C.gtk_cell_area_remove_focus_sibling(v.native(), renderer.toCellRenderer(), sibling.toCellRenderer()) +} + +// IsFocusSibling is a wrapper around gtk_cell_area_is_focus_sibling(). +func (v *CellArea) IsFocusSibling(renderer, sibling ICellRenderer) bool { + return gobool(C.gtk_cell_area_is_focus_sibling(v.native(), renderer.toCellRenderer(), sibling.toCellRenderer())) +} + +// GetFocusSiblings is a wrapper around gtk_cell_area_get_focus_siblings(). +func (v *CellArea) GetFocusSiblings(renderer ICellRenderer) ([]ICellRenderer, error) { + clist := C.gtk_cell_area_get_focus_siblings(v.native(), renderer.toCellRenderer()) + if clist == nil { + return nil, nilPtrErr + } + + // The returned list is internal and should not be freed. + var cellRendererList []ICellRenderer + wlist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + for ; wlist.Data() != nil; wlist = wlist.Next() { + w, ok := wlist.Data().(*CellRenderer) + if !ok { + return nil, fmt.Errorf("element is not of type *CellRenderer, got %T", w) + } + cRenderer, err := castCellRenderer(w.toCellRenderer()) + if err != nil { + return nil, err + } + cellRendererList = append(cellRendererList, cRenderer) + } + + return cellRendererList, nil +} + +// GetFocusFromSibling is a wrapper around gtk_cell_area_get_focus_from_sibling(). +func (v *CellArea) GetFocusFromSibling(renderer ICellRenderer) (ICellRenderer, error) { + c := C.gtk_cell_area_get_focus_from_sibling(v.native(), renderer.toCellRenderer()) + return castCellRenderer(c) +} + +// GetEditedCell is a wrapper around gtk_cell_area_get_edited_cell(). +func (v *CellArea) GetEditedCell() (ICellRenderer, error) { + c := C.gtk_cell_area_get_edited_cell(v.native()) + return castCellRenderer(c) +} + +// GetEditWidget is a wrapper around gtk_cell_area_get_edit_widget(). +func (v *CellArea) GetEditWidget() (ICellEditable, error) { + c := C.gtk_cell_area_get_edit_widget(v.native()) + return castCellEditable(c) +} + +// ActivateCell is a wrapper around gtk_cell_area_activate_cell(). +func (v *CellArea) ActivateCell(widget IWidget, renderer ICellRenderer, + event *gdk.Event, cellArea *gdk.Rectangle, flags CellRendererState) bool { + + e := (*C.GdkEvent)(unsafe.Pointer(event.Native())) + c := C.gtk_cell_area_activate_cell(v.native(), widget.toWidget(), renderer.toCellRenderer(), + e, nativeGdkRectangle(*cellArea), C.GtkCellRendererState(flags)) + + return gobool(c) +} + +// StopEditing is a wrapper around gtk_cell_area_stop_editing(). +func (v *CellArea) StopEditing(cancelled bool) { + C.gtk_cell_area_stop_editing(v.native(), gbool(cancelled)) +} + +// InnerCellArea is a wrapper around gtk_cell_area_inner_cell_area(). +func (v *CellArea) InnerCellArea(widget IWidget, cellArea *gdk.Rectangle) *gdk.Rectangle { + var cRect *C.GdkRectangle + C.gtk_cell_area_inner_cell_area(v.native(), widget.toWidget(), nativeGdkRectangle(*cellArea), cRect) + innerArea := gdk.WrapRectangle(uintptr(unsafe.Pointer(cRect))) + return innerArea +} + +// RequestRenderer is a wrapper around gtk_cell_area_request_renderer(). +func (v *CellArea) RequestRenderer(renderer ICellRenderer, orientation Orientation, + widget IWidget, forSize int) (int, int) { + + var minSize C.gint + var naturalSize C.gint + + C.gtk_cell_area_request_renderer(v.native(), renderer.toCellRenderer(), C.GtkOrientation(orientation), + widget.toWidget(), C.gint(forSize), &minSize, &naturalSize) + + return int(minSize), int(naturalSize) +} + +/* + * GtkCellAreaContext + */ + +type CellAreaContext struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkCellAreaContext. +func (v *CellAreaContext) native() *C.GtkCellAreaContext { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellAreaContext(p) +} + +func (v *CellAreaContext) toCellAreaContext() *C.GtkCellAreaContext { + if v == nil { + return nil + } + return v.native() +} + +func marshalCellAreaContext(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellAreaContext(obj), nil +} + +func wrapCellAreaContext(obj *glib.Object) *CellAreaContext { + if obj == nil { + return nil + } + + return &CellAreaContext{obj} +} + +// GetArea is a wrapper around gtk_cell_area_context_get_area(). +func (v *CellAreaContext) GetArea() (*CellArea, error) { + c := C.gtk_cell_area_context_get_area(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapCellArea(glib.Take(unsafe.Pointer(c))), nil +} + +// Allocate is a wrapper around gtk_cell_area_context_allocate(). +func (v *CellAreaContext) Allocate(width, height int) { + C.gtk_cell_area_context_allocate(v.native(), C.gint(width), C.gint(height)) +} + +// Reset is a wrapper around gtk_cell_area_context_reset(). +func (v *CellAreaContext) Reset(width, height int) { + C.gtk_cell_area_context_reset(v.native()) +} + +// GetPreferredWidth is a wrapper around gtk_cell_area_context_get_preferred_width(). +func (v *CellAreaContext) GetPreferredWidth() (int, int) { + var minWidth C.gint + var naturalWidth C.gint + C.gtk_cell_area_context_get_preferred_width(v.native(), &minWidth, &naturalWidth) + return int(minWidth), int(naturalWidth) +} + +// GetPreferredHeight is a wrapper around gtk_cell_area_context_get_preferred_height(). +func (v *CellAreaContext) GetPreferredHeight() (int, int) { + var minHeight C.gint + var naturalHeight C.gint + C.gtk_cell_area_context_get_preferred_height(v.native(), &minHeight, &naturalHeight) + return int(minHeight), int(naturalHeight) +} + +// GetPreferredHeightForWidth is a wrapper around gtk_cell_area_context_get_preferred_height_for_width(). +func (v *CellAreaContext) GetPreferredHeightForWidth(width int) (int, int) { + var minHeight C.gint + var naturalHeight C.gint + C.gtk_cell_area_context_get_preferred_height_for_width(v.native(), C.gint(width), &minHeight, &naturalHeight) + return int(minHeight), int(naturalHeight) +} + +// GetPreferredWidthForHeight is a wrapper around gtk_cell_area_context_get_preferred_width_for_height(). +func (v *CellAreaContext) GetPreferredWidthForHeight(height int) (int, int) { + var minWidth C.gint + var naturalWidth C.gint + C.gtk_cell_area_context_get_preferred_width_for_height(v.native(), C.gint(height), &minWidth, &naturalWidth) + return int(minWidth), int(naturalWidth) +} + +// GetAllocation is a wrapper around gtk_cell_area_context_get_allocation(). +func (v *CellAreaContext) GetAllocation() (int, int) { + var height C.gint + var width C.gint + C.gtk_cell_area_context_get_allocation(v.native(), &height, &width) + return int(height), int(width) +} + +// PushPreferredWidth is a wrapper around gtk_cell_area_context_push_preferred_width(). +func (v *CellAreaContext) PushPreferredWidth(minWidth, naturalWidth int) { + C.gtk_cell_area_context_push_preferred_width(v.native(), C.gint(minWidth), C.gint(naturalWidth)) +} + +// PushPreferredHeight is a wrapper around gtk_cell_area_context_push_preferred_height(). +func (v *CellAreaContext) PushPreferredHeight(minHeight, naturalHeight int) { + C.gtk_cell_area_context_push_preferred_height(v.native(), C.gint(minHeight), C.gint(naturalHeight)) +} + +/* + * GtkCellAreaBox + */ + +// CellAreaBox is a representation of GTK's GtkCellAreaBox. +type CellAreaBox struct { + CellArea + + // Interfaces + Orientable +} + +// native returns a pointer to the underlying GtkCellAreaBox. +func (v *CellAreaBox) native() *C.GtkCellAreaBox { + if v == nil || v.CellArea.GObject == nil { + return nil + } + p := unsafe.Pointer(v.CellArea.GObject) + return C.toGtkCellAreaBox(p) +} + +func (v *CellArea) toOrientable() *C.GtkOrientable { + if v == nil { + return nil + } + return C.toGtkOrientable(unsafe.Pointer(v.GObject)) +} + +func marshalCellAreaBox(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellAreaBox(obj), nil +} + +func wrapCellAreaBox(obj *glib.Object) *CellAreaBox { + if obj == nil { + return nil + } + + cellArea := wrapCellArea(obj) + o := wrapOrientable(obj) + return &CellAreaBox{*cellArea, *o} +} + +// CellAreaBoxNew is a wrapper around gtk_cell_area_box_new(). +func CellAreaBoxNew() (*CellAreaBox, error) { + c := C.gtk_cell_area_box_new() + if c == nil { + return nil, nilPtrErr + } + return wrapCellAreaBox(glib.Take(unsafe.Pointer(c))), nil +} + +// PackStart is a wrapper around gtk_cell_area_box_pack_start(). +func (v *CellAreaBox) PackStart(renderer ICellRenderer, expand, align, fixed bool) { + C.gtk_cell_area_box_pack_start(v.native(), renderer.toCellRenderer(), gbool(expand), gbool(align), gbool(fixed)) +} + +// PackEnd is a wrapper around gtk_cell_area_box_pack_end(). +func (v *CellAreaBox) PackEnd(renderer ICellRenderer, expand, align, fixed bool) { + C.gtk_cell_area_box_pack_end(v.native(), renderer.toCellRenderer(), gbool(expand), gbool(align), gbool(fixed)) +} + +// GetSpacing is a wrapper around gtk_cell_area_box_get_spacing(). +func (v *CellAreaBox) GetSpacing() int { + return int(C.gtk_cell_area_box_get_spacing(v.native())) +} + +// SetSpacing is a wrapper around gtk_cell_area_box_set_spacing(). +func (v *CellAreaBox) SetSpacing(spacing int) { + C.gtk_cell_area_box_set_spacing(v.native(), C.gint(spacing)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/cell_area_since_3_14.go b/vendor/github.com/gotk3/gotk3/gtk/cell_area_since_3_14.go new file mode 100644 index 0000000..b987631 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/cell_area_since_3_14.go @@ -0,0 +1,23 @@ +// Same copyright and license as the rest of the files in this project +// See: https://developer.gnome.org/gtk3/3.14/api-index-3-14.html + +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12 + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import "unsafe" + +/* + * GtkCellArea + */ + +// AttributeGetColumn is a wrapper around gtk_cell_area_attribute_get_column(). +func (v *CellArea) AttributeGetColumn(renderer ICellRenderer, attribute string) int { + cstr := C.CString(attribute) + defer C.free(unsafe.Pointer(cstr)) + column := C.gtk_cell_area_attribute_get_column(v.native(), renderer.toCellRenderer(), (*C.gchar)(cstr)) + return int(column) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/color_chooser.go b/vendor/github.com/gotk3/gotk3/gtk/color_chooser.go new file mode 100644 index 0000000..28e824e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/color_chooser.go @@ -0,0 +1,170 @@ +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_color_chooser_get_type()), marshalColorChooser}, + {glib.Type(C.gtk_color_chooser_dialog_get_type()), marshalColorChooserDialog}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkColorChooser"] = wrapColorChooser + WrapMap["GtkColorChooserDialog"] = wrapColorChooserDialog +} + +/* + * GtkColorChooser + */ + +// ColorChooser is a representation of GTK's GtkColorChooser GInterface. +type ColorChooser struct { + *glib.Object +} + +// IColorChooser is an interface type implemented by all structs +// embedding an ColorChooser. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkColorChooser. +type IColorChooser interface { + toColorChooser() *C.GtkColorChooser +} + +// native returns a pointer to the underlying GtkColorChooser. +func (v *ColorChooser) native() *C.GtkColorChooser { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkColorChooser(p) +} + +func marshalColorChooser(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapColorChooser(obj), nil +} + +func wrapColorChooser(obj *glib.Object) *ColorChooser { + if obj == nil { + return nil + } + + return &ColorChooser{obj} +} + +func (v *ColorChooser) toColorChooser() *C.GtkColorChooser { + if v == nil { + return nil + } + return v.native() +} + +// GetRGBA() is a wrapper around gtk_color_chooser_get_rgba(). +func (v *ColorChooser) GetRGBA() *gdk.RGBA { + gdkColor := gdk.NewRGBA() + C.gtk_color_chooser_get_rgba(v.native(), (*C.GdkRGBA)(unsafe.Pointer(gdkColor.Native()))) + return gdkColor +} + +// SetRGBA() is a wrapper around gtk_color_chooser_set_rgba(). +func (v *ColorChooser) SetRGBA(gdkColor *gdk.RGBA) { + C.gtk_color_chooser_set_rgba(v.native(), (*C.GdkRGBA)(unsafe.Pointer(gdkColor.Native()))) +} + +// GetUseAlpha() is a wrapper around gtk_color_chooser_get_use_alpha(). +func (v *ColorChooser) GetUseAlpha() bool { + return gobool(C.gtk_color_chooser_get_use_alpha(v.native())) +} + +// SetUseAlpha() is a wrapper around gtk_color_chooser_set_use_alpha(). +func (v *ColorChooser) SetUseAlpha(use_alpha bool) { + C.gtk_color_chooser_set_use_alpha(v.native(), gbool(use_alpha)) +} + +// AddPalette() is a wrapper around gtk_color_chooser_add_palette(). +func (v *ColorChooser) AddPalette(orientation Orientation, colors_per_line int, colors []*gdk.RGBA) { + n_colors := len(colors) + var c_colors []C.GdkRGBA + for _, c := range colors { + c_colors = append(c_colors, *(*C.GdkRGBA)(unsafe.Pointer(c.Native()))) + } + C.gtk_color_chooser_add_palette( + v.native(), + C.GtkOrientation(orientation), + C.gint(colors_per_line), + C.gint(n_colors), + &c_colors[0], + ) +} + +/* + * GtkColorChooserDialog + */ + +// ColorChooserDialog is a representation of GTK's GtkColorChooserDialog. +type ColorChooserDialog struct { + Dialog + + // Interfaces + ColorChooser +} + +// native returns a pointer to the underlying GtkColorChooserButton. +func (v *ColorChooserDialog) native() *C.GtkColorChooserDialog { + if v == nil || v.GObject == nil { + return nil + } + + p := unsafe.Pointer(v.GObject) + return C.toGtkColorChooserDialog(p) +} + +func marshalColorChooserDialog(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapColorChooserDialog(glib.Take(unsafe.Pointer(c))), nil +} + +func wrapColorChooserDialog(obj *glib.Object) *ColorChooserDialog { + if obj == nil { + return nil + } + + dialog := wrapDialog(obj) + cc := wrapColorChooser(obj) + return &ColorChooserDialog{*dialog, *cc} +} + +// ColorChooserDialogNew() is a wrapper around gtk_color_chooser_dialog_new(). +func ColorChooserDialogNew(title string, parent IWindow) (*ColorChooserDialog, error) { + + cstr := C.CString(title) + defer C.free(unsafe.Pointer(cstr)) + + var w *C.GtkWindow = nil + if parent != nil { + w = parent.toWindow() + } + + c := C.gtk_color_chooser_dialog_new((*C.gchar)(cstr), w) + if c == nil { + return nil, nilPtrErr + } + return wrapColorChooserDialog(glib.Take(unsafe.Pointer(c))), nil +} + +/* + * GtkColorChooserWidget + */ + +// TODO: +// gtk_color_chooser_widget_new(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/combo_box.go b/vendor/github.com/gotk3/gotk3/gtk/combo_box.go new file mode 100644 index 0000000..a5200a0 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/combo_box.go @@ -0,0 +1,413 @@ +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "errors" + "fmt" + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_combo_box_get_type()), marshalComboBox}, + {glib.Type(C.gtk_combo_box_text_get_type()), marshalComboBoxText}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkComboBox"] = wrapComboBox + WrapMap["GtkComboBoxText"] = wrapComboBoxText +} + +/* + * GtkComboBox + */ + +// ComboBox is a representation of GTK's GtkComboBox. +type ComboBox struct { + Bin + + // Interfaces + CellLayout + CellEditable +} + +// native returns a pointer to the underlying GtkComboBox. +func (v *ComboBox) native() *C.GtkComboBox { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkComboBox(p) +} + +func (v *ComboBox) toCellLayout() *C.GtkCellLayout { + if v == nil { + return nil + } + return C.toGtkCellLayout(unsafe.Pointer(v.GObject)) +} + +func marshalComboBox(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapComboBox(obj), nil +} + +func wrapComboBox(obj *glib.Object) *ComboBox { + if obj == nil { + return nil + } + + cl := wrapCellLayout(obj) + ce := wrapCellEditable(obj) + return &ComboBox{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}, *cl, *ce} +} + +// ComboBoxNew is a wrapper around gtk_combo_box_new(). +func ComboBoxNew() (*ComboBox, error) { + c := C.gtk_combo_box_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapComboBox(obj), nil +} + +// ComboBoxNewWithEntry is a wrapper around gtk_combo_box_new_with_entry(). +func ComboBoxNewWithEntry() (*ComboBox, error) { + c := C.gtk_combo_box_new_with_entry() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapComboBox(obj), nil +} + +// ComboBoxNewWithModel is a wrapper around gtk_combo_box_new_with_model(). +func ComboBoxNewWithModel(model ITreeModel) (*ComboBox, error) { + c := C.gtk_combo_box_new_with_model(model.toTreeModel()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapComboBox(obj), nil +} + +// is a wrapper around gtk_combo_box_new_with_model_and_entry(). +func ComboBoxNewWithModelAndEntry(model ITreeModel) (*ComboBox, error) { + c := C.gtk_combo_box_new_with_model_and_entry(model.toTreeModel()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapComboBox(obj), nil +} + +// GetWrapWidth is a wrapper around gtk_combo_box_get_wrap_width(). +func (v *ComboBox) GetWrapWidth() int { + c := C.gtk_combo_box_get_wrap_width(v.native()) + return int(c) +} + +// SetWrapWidth is a wrapper around gtk_combo_box_set_wrap_width(). +func (v *ComboBox) SetWrapWidth(wrapWidth int) { + C.gtk_combo_box_set_wrap_width(v.native(), C.gint(wrapWidth)) +} + +// GetRowSpanColumn is a wrapper around gtk_combo_box_get_row_span_column(). +func (v *ComboBox) GetRowSpanColumn() int { + c := C.gtk_combo_box_get_row_span_column(v.native()) + return int(c) +} + +// SetRowSpanColumn is a wrapper around gtk_combo_box_set_row_span_column(). +func (v *ComboBox) SetRowSpanColumn(rowSpan int) { + C.gtk_combo_box_set_row_span_column(v.native(), C.gint(rowSpan)) +} + +// GetColumnSpanColumn is a wrapper around gtk_combo_box_get_column_span_column(). +func (v *ComboBox) GetColumnSpanColumn() int { + c := C.gtk_combo_box_get_column_span_column(v.native()) + return int(c) +} + +// SetColumnSpanColumn is a wrapper around gtk_combo_box_set_column_span_column(). +func (v *ComboBox) SetColumnSpanColumn(wrapWidth int) { + C.gtk_combo_box_set_column_span_column(v.native(), C.gint(wrapWidth)) +} + +// GetActive is a wrapper around gtk_combo_box_get_active(). +func (v *ComboBox) GetActive() int { + c := C.gtk_combo_box_get_active(v.native()) + return int(c) +} + +// SetActive is a wrapper around gtk_combo_box_set_active(). +func (v *ComboBox) SetActive(index int) { + C.gtk_combo_box_set_active(v.native(), C.gint(index)) +} + +// GetActiveIter is a wrapper around gtk_combo_box_get_active_iter(). +func (v *ComboBox) GetActiveIter() (*TreeIter, error) { + var cIter C.GtkTreeIter + c := C.gtk_combo_box_get_active_iter(v.native(), &cIter) + if !gobool(c) { + return nil, errors.New("unable to get active iter") + } + return &TreeIter{cIter}, nil +} + +// SetActiveIter is a wrapper around gtk_combo_box_set_active_iter(). +func (v *ComboBox) SetActiveIter(iter *TreeIter) { + var cIter *C.GtkTreeIter + if iter != nil { + cIter = &iter.GtkTreeIter + } + C.gtk_combo_box_set_active_iter(v.native(), cIter) +} + +// GetIDColumn is a wrapper around gtk_combo_box_get_id_column() +func (v *ComboBox) GetIDColumn() int { + c := C.gtk_combo_box_get_id_column(v.native()) + return int(c) +} + +// SetIDColumn is a wrapper around gtk_combo_box_set_id_column() +func (v *ComboBox) SetIDColumn(idColumn int) { + C.gtk_combo_box_set_id_column(v.native(), C.gint(idColumn)) +} + +// GetActiveID is a wrapper around gtk_combo_box_get_active_id(). +func (v *ComboBox) GetActiveID() string { + c := C.gtk_combo_box_get_active_id(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetActiveID is a wrapper around gtk_combo_box_set_active_id(). +func (v *ComboBox) SetActiveID(id string) bool { + cid := C.CString(id) + defer C.free(unsafe.Pointer(cid)) + c := C.gtk_combo_box_set_active_id(v.native(), (*C.gchar)(cid)) + return gobool(c) +} + +// GetModel is a wrapper around gtk_combo_box_get_model(). +func (v *ComboBox) GetModel() (ITreeModel, error) { + c := C.gtk_combo_box_get_model(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castTreeModel(c) +} + +// SetModel is a wrapper around gtk_combo_box_set_model(). +func (v *ComboBox) SetModel(model ITreeModel) { + var mptr *C.GtkTreeModel + if model != nil { + mptr = model.toTreeModel() + } + C.gtk_combo_box_set_model(v.native(), mptr) +} + +// PopupForDevice is a wrapper around gtk_combo_box_popup_for_device() +func (v *ComboBox) PopupForDevice(device *gdk.Device) { + var devicePtr *C.GdkDevice + if device != nil { + devicePtr = (*C.GdkDevice)(unsafe.Pointer(device.Native())) + } + C.gtk_combo_box_popup_for_device(v.native(), devicePtr) +} + +// Popup is a wrapper around gtk_combo_box_popup(). +func (v *ComboBox) Popup() { + C.gtk_combo_box_popup(v.native()) +} + +// Popdown is a wrapper around gtk_combo_box_popdown(). +func (v *ComboBox) Popdown() { + C.gtk_combo_box_popdown(v.native()) +} + +// GetHasEntry is a wrapper around gtk_combo_box_get_has_entry(). +func (v *ComboBox) GetHasEntry() bool { + c := C.gtk_combo_box_get_has_entry(v.native()) + return gobool(c) +} + +// SetEntryTextColumn is a wrapper around gtk_combo_box_set_entry_text_column(). +func (v *ComboBox) SetEntryTextColumn(textColumn int) { + C.gtk_combo_box_set_entry_text_column(v.native(), C.gint(textColumn)) +} + +// GetEntryTextColumn is a wrapper around gtk_combo_box_get_entry_text_column(). +func (v *ComboBox) GetEntryTextColumn() int { + c := C.gtk_combo_box_get_entry_text_column(v.native()) + return int(c) +} + +// SetPopupFixedWidth is a wrapper around gtk_combo_box_set_popup_fixed_width +func (v *ComboBox) SetPopupFixedWidth(fixedWidth bool) { + C.gtk_combo_box_set_popup_fixed_width(v.native(), gbool(fixedWidth)) +} + +// GetPopupFixedWidth is a wrapper around gtk_combo_box_get_popup_fixed_width +func (v *ComboBox) GetPopupFixedWidth() bool { + c := C.gtk_combo_box_get_popup_fixed_width(v.native()) + return gobool(c) +} + +// GetEntry is a convenience func to get the Entry within the ComboBox. +// If the Combobox does not contain an Entry, an error is returned. +func (v *ComboBox) GetEntry() (*Entry, error) { + hasEntry := C.gtk_combo_box_get_has_entry(v.native()) + if hasEntry == C.FALSE { + return nil, errors.New("combobox has no entry") + } + bin := &v.Bin + widget, err := bin.GetChild() + if err != nil { + return nil, err + } + entry, ok := widget.(*Entry) + if !ok { + return nil, fmt.Errorf("expected child to be of type *gtk.Entry, got %T", widget) + } + return entry, nil +} + +/* + * GtkComboBoxText + */ + +// ComboBoxText is a representation of GTK's GtkComboBoxText. +type ComboBoxText struct { + ComboBox +} + +// native returns a pointer to the underlying GtkComboBoxText. +func (v *ComboBoxText) native() *C.GtkComboBoxText { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkComboBoxText(p) +} + +func marshalComboBoxText(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapComboBoxText(obj), nil +} + +func wrapComboBoxText(obj *glib.Object) *ComboBoxText { + if obj == nil { + return nil + } + + return &ComboBoxText{*wrapComboBox(obj)} +} + +// ComboBoxTextNew is a wrapper around gtk_combo_box_text_new(). +func ComboBoxTextNew() (*ComboBoxText, error) { + c := C.gtk_combo_box_text_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapComboBoxText(obj), nil +} + +// ComboBoxTextNewWithEntry is a wrapper around gtk_combo_box_text_new_with_entry(). +func ComboBoxTextNewWithEntry() (*ComboBoxText, error) { + c := C.gtk_combo_box_text_new_with_entry() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapComboBoxText(obj), nil +} + +// Append is a wrapper around gtk_combo_box_text_append(). +func (v *ComboBoxText) Append(id, text string) { + cid := C.CString(id) + ctext := C.CString(text) + defer C.free(unsafe.Pointer(cid)) + defer C.free(unsafe.Pointer(ctext)) + C.gtk_combo_box_text_append(v.native(), (*C.gchar)(cid), (*C.gchar)(ctext)) +} + +// Prepend is a wrapper around gtk_combo_box_text_prepend(). +func (v *ComboBoxText) Prepend(id, text string) { + cid := C.CString(id) + ctext := C.CString(text) + defer C.free(unsafe.Pointer(cid)) + defer C.free(unsafe.Pointer(ctext)) + C.gtk_combo_box_text_prepend(v.native(), (*C.gchar)(cid), (*C.gchar)(ctext)) +} + +// Insert is a wrapper around gtk_combo_box_text_insert(). +func (v *ComboBoxText) Insert(position int, id, text string) { + cid := C.CString(id) + ctext := C.CString(text) + defer C.free(unsafe.Pointer(cid)) + defer C.free(unsafe.Pointer(ctext)) + C.gtk_combo_box_text_insert(v.native(), C.gint(position), (*C.gchar)(cid), (*C.gchar)(ctext)) +} + +// AppendText is a wrapper around gtk_combo_box_text_append_text(). +func (v *ComboBoxText) AppendText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_combo_box_text_append_text(v.native(), (*C.gchar)(cstr)) +} + +// PrependText is a wrapper around gtk_combo_box_text_prepend_text(). +func (v *ComboBoxText) PrependText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_combo_box_text_prepend_text(v.native(), (*C.gchar)(cstr)) +} + +// InsertText is a wrapper around gtk_combo_box_text_insert_text(). +func (v *ComboBoxText) InsertText(position int, text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_combo_box_text_insert_text(v.native(), C.gint(position), (*C.gchar)(cstr)) +} + +// Remove is a wrapper around gtk_combo_box_text_remove(). +func (v *ComboBoxText) Remove(position int) { + C.gtk_combo_box_text_remove(v.native(), C.gint(position)) +} + +// RemoveAll is a wrapper around gtk_combo_box_text_remove_all(). +func (v *ComboBoxText) RemoveAll() { + C.gtk_combo_box_text_remove_all(v.native()) +} + +// GetActiveText is a wrapper around gtk_combo_box_text_get_active_text(). +func (v *ComboBoxText) GetActiveText() string { + c := (*C.char)(C.gtk_combo_box_text_get_active_text(v.native())) + defer C.free(unsafe.Pointer(c)) + return C.GoString(c) +} + +// gtk_combo_box_new_with_area, requires GtkCellArea +// gtk_combo_box_new_with_area_and_entry, requires GtkCellArea +// gtk_combo_box_get_row_separator_func, requires GtkTreeViewRowSeparatorFunc +// gtk_combo_box_set_row_separator_func, requires GtkTreeViewRowSeparatorFunc +// gtk_combo_box_get_popup_accessible, requires AtkObject +// gtk_combo_box_set_add_tearoffs, deprecated since 3.10 +// gtk_combo_box_get_add_tearoffs, deprecated since 3.10 +// gtk_combo_box_set_title, deprecated since 3.10 +// gtk_combo_box_get_title, deprecated since 3.10 +// gtk_combo_box_set_focus_on_click, deprecated since 3.20 +// gtk_combo_box_get_focus_on_click, deprecated since 3.20 +// gtk_combo_box_set_button_sensitivity, requires GtkSensitivityType +// gtk_combo_box_get_button_sensitivity, requires GtkSensitivityType diff --git a/vendor/github.com/gotk3/gotk3/gtk/fixed.go b/vendor/github.com/gotk3/gotk3/gtk/fixed.go new file mode 100644 index 0000000..ace0670 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/fixed.go @@ -0,0 +1,72 @@ +package gtk + +// #include +// #include "gtk.go.h" +// #include "fixed.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_fixed_get_type()), marshalFixed}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkFixed"] = wrapFixed +} + +/* + * GtkFixed + */ + +// Fixed is a representation of GTK's GtkFixed. +type Fixed struct { + Container +} + +func (v *Fixed) native() *C.GtkFixed { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkFixed(p) +} + +func marshalFixed(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapFixed(obj), nil +} + +func wrapFixed(obj *glib.Object) *Fixed { + if obj == nil { + return nil + } + + return &Fixed{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// FixedNew is a wrapper around gtk_fixed_new(). +func FixedNew() (*Fixed, error) { + c := C.gtk_fixed_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapFixed(obj), nil +} + +// Put is a wrapper around gtk_fixed_put(). +func (v *Fixed) Put(w IWidget, x, y int) { + C.gtk_fixed_put(v.native(), w.toWidget(), C.gint(x), C.gint(y)) +} + +// Move is a wrapper around gtk_fixed_move(). +func (v *Fixed) Move(w IWidget, x, y int) { + C.gtk_fixed_move(v.native(), w.toWidget(), C.gint(x), C.gint(y)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/fixed.go.h b/vendor/github.com/gotk3/gotk3/gtk/fixed.go.h new file mode 100644 index 0000000..76cee7e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/fixed.go.h @@ -0,0 +1 @@ +static GtkFixed *toGtkFixed(void *p) { return (GTK_FIXED(p)); } \ No newline at end of file diff --git a/vendor/github.com/gotk3/gotk3/gtk/font_chooser.go b/vendor/github.com/gotk3/gotk3/gtk/font_chooser.go new file mode 100644 index 0000000..622e986 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/font_chooser.go @@ -0,0 +1,221 @@ +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_font_chooser_get_type()), marshalFontChooser}, + {glib.Type(C.gtk_font_button_get_type()), marshalFontButton}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkFontChooser"] = wrapFontChooser + WrapMap["GtkFontButton"] = wrapFontButton + +} + +/* + * GtkFontChooser + */ + +// FontChooser is a representation of GTK's GtkFontChooser GInterface. +type FontChooser struct { + *glib.Object +} + +// IFontChooser is an interface type implemented by all structs +// embedding an FontChooser. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkFontChooser. +type IFontChooser interface { + toFontChooser() *C.GtkFontChooser +} + +// native returns a pointer to the underlying GtkFontChooser. +func (v *FontChooser) native() *C.GtkFontChooser { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkFontChooser(p) +} + +func marshalFontChooser(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapFontChooser(obj), nil +} + +func wrapFontChooser(obj *glib.Object) *FontChooser { + if obj == nil { + return nil + } + + return &FontChooser{obj} +} + +func (v *FontChooser) toFontChooser() *C.GtkFontChooser { + if v == nil { + return nil + } + return v.native() +} + +// GetFont is a wrapper around gtk_font_chooser_get_font(). +func (v *FontChooser) GetFont() string { + c := C.gtk_font_chooser_get_font(v.native()) + return goString(c) +} + +// SetFont is a wrapper around gtk_font_chooser_set_font(). +func (v *FontChooser) SetFont(font string) { + cstr := C.CString(font) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_font_chooser_set_font(v.native(), (*C.gchar)(cstr)) +} + +//PangoFontFamily * gtk_font_chooser_get_font_family () +//PangoFontFace * gtk_font_chooser_get_font_face () +//gint gtk_font_chooser_get_font_size () +//PangoFontDescription * gtk_font_chooser_get_font_desc () +//void gtk_font_chooser_set_font_desc () +//gchar * gtk_font_chooser_get_preview_text () +//void gtk_font_chooser_set_preview_text () +//gboolean gtk_font_chooser_get_show_preview_entry () +//void gtk_font_chooser_set_show_preview_entry () +//gboolean (*GtkFontFilterFunc) () +//void gtk_font_chooser_set_filter_func () +//void gtk_font_chooser_set_font_map () +//PangoFontMap * gtk_font_chooser_get_font_map () + +/* + * GtkFontButton + */ + +// FontButton is a representation of GTK's GtkFontButton. +type FontButton struct { + Button + + // Interfaces + FontChooser +} + +// native returns a pointer to the underlying GtkFontButton. +func (v *FontButton) native() *C.GtkFontButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkFontButton(p) +} + +func marshalFontButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapFontButton(obj), nil +} + +func wrapFontButton(obj *glib.Object) *FontButton { + if obj == nil { + return nil + } + + button := wrapButton(obj) + fc := wrapFontChooser(obj) + return &FontButton{*button, *fc} +} + +// FontButtonNew is a wrapper around gtk_font_button_new(). +func FontButtonNew() (*FontButton, error) { + c := C.gtk_font_button_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapFontButton(obj), nil +} + +// FontButtonNewWithFont is a wrapper around gtk_font_button_new_with_font(). +func FontButtonNewWithFont(fontname string) (*FontButton, error) { + cstr := C.CString(fontname) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_font_button_new_with_font((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapFontButton(obj), nil +} + +// SetShowStyle is a wrapper around gtk_font_button_set_show_style(). +func (v *FontButton) SetShowStyle(showStyle bool) { + C.gtk_font_button_set_show_style(v.native(), gbool(showStyle)) +} + +// GetShowStyle is a wrapper around gtk_font_button_get_show_style(). +func (v *FontButton) GetShowStyle() bool { + c := C.gtk_font_button_get_show_style(v.native()) + return gobool(c) +} + +// SetShowSize is a wrapper around gtk_font_button_set_show_size(). +func (v *FontButton) SetShowSize(showSize bool) { + C.gtk_font_button_set_show_size(v.native(), gbool(showSize)) +} + +// GetShowSize is a wrapper around gtk_font_button_get_show_size(). +func (v *FontButton) GetShowSize() bool { + c := C.gtk_font_button_get_show_size(v.native()) + return gobool(c) +} + +// SetUseFont is a wrapper around gtk_font_button_set_use_font(). +func (v *FontButton) SetUseFont(useFont bool) { + C.gtk_font_button_set_use_font(v.native(), gbool(useFont)) +} + +// GetUseFont is a wrapper around gtk_font_button_get_use_font(). +func (v *FontButton) GetUseFont() bool { + c := C.gtk_font_button_get_use_font(v.native()) + return gobool(c) +} + +// SetUseSize is a wrapper around gtk_font_button_set_use_size(). +func (v *FontButton) SetUseSize(useSize bool) { + C.gtk_font_button_set_use_size(v.native(), gbool(useSize)) +} + +// GetUseSize is a wrapper around gtk_font_button_get_use_size(). +func (v *FontButton) GetUseSize() bool { + c := C.gtk_font_button_get_use_size(v.native()) + return gobool(c) +} + +// SetTitle is a wrapper around gtk_font_button_set_title(). +func (v *FontButton) SetTitle(title string) { + cstr := C.CString(title) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_font_button_set_title(v.native(), (*C.gchar)(cstr)) +} + +// GetTitle is a wrapper around gtk_font_button_get_title(). +func (v *FontButton) GetTitle() string { + c := C.gtk_font_button_get_title(v.native()) + defer C.free(unsafe.Pointer(c)) + return goString(c) +} + +/* + * GtkFontChooserWidget + */ + +// TODO: +// gtk_font_chooser_widget_new(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/gdk.go b/vendor/github.com/gotk3/gotk3/gtk/gdk.go new file mode 100644 index 0000000..8bf6579 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gdk.go @@ -0,0 +1,41 @@ +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import "github.com/gotk3/gotk3/gdk" + +func nativeGdkRectangle(rect gdk.Rectangle) *C.GdkRectangle { + // Note: Here we can't use rect.GdkRectangle because it would return + // C type prefixed with gdk package. A ways how to resolve this Go + // issue with same C structs in different Go packages is documented + // here https://github.com/golang/go/issues/13467 . + // This is the easiest way how to resolve the problem. + return &C.GdkRectangle{ + x: C.int(rect.GetX()), + y: C.int(rect.GetY()), + width: C.int(rect.GetWidth()), + height: C.int(rect.GetHeight()), + } +} + +func nativeGdkGeometry(geom gdk.Geometry) *C.GdkGeometry { + // Note: Here we can't use geom.GdkGeometry because it would return + // C type prefixed with gdk package. A ways how to resolve this Go + // issue with same C structs in different Go packages is documented + // here https://github.com/golang/go/issues/13467 . + // This is the easiest way how to resolve the problem. + return &C.GdkGeometry{ + min_width: C.gint(geom.GetMinWidth()), + min_height: C.gint(geom.GetMinHeight()), + max_width: C.gint(geom.GetMaxWidth()), + max_height: C.gint(geom.GetMaxHeight()), + base_width: C.gint(geom.GetBaseWidth()), + base_height: C.gint(geom.GetBaseHeight()), + width_inc: C.gint(geom.GetWidthInc()), + height_inc: C.gint(geom.GetHeightInc()), + min_aspect: C.gdouble(geom.GetMinAspect()), + max_aspect: C.gdouble(geom.GetMaxAspect()), + win_gravity: C.GdkGravity(geom.GetWinGravity()), + } +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/glarea.go b/vendor/github.com/gotk3/gotk3/gtk/glarea.go new file mode 100644 index 0000000..845a8dc --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/glarea.go @@ -0,0 +1,183 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14 +// Supports building with gtk 3.16+ + +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package gtk + +// #include +// #include "gtk_since_3_16.go.h" +import "C" +import ( + "errors" + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +func init() { + + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_gl_area_get_type()), marshalGLArea}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkGLArea"] = wrapGLArea +} + +/* + * GtkGLArea + */ + +// GLArea is a representation of GTK's GtkGLArea. +type GLArea struct { + Widget +} + +// native returns a pointer to the underlying GtkGLArea. +func (v *GLArea) native() *C.GtkGLArea { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkGLArea(p) +} + +func marshalGLArea(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapGLArea(obj), nil +} + +func wrapGLArea(obj *glib.Object) *GLArea { + if obj == nil { + return nil + } + + return &GLArea{Widget{glib.InitiallyUnowned{obj}}} +} + +func WidgetToGLArea(widget *Widget) (*GLArea, error) { + obj := glib.Take(unsafe.Pointer(widget.GObject)) + return wrapGLArea(obj), nil +} + +// GLAreaNew is a wrapper around gtk_gl_area_new(). +func GLAreaNew() (*GLArea, error) { + c := C.gtk_gl_area_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + + return wrapGLArea(obj), nil +} + +// MajorVersion is a representation of OpenGL major version. +type MajorVersion int + +// MinorVersion is a representation of OpenGL minor version. +type MinorVersion int + +// GetRequiredVersion is a wrapper around gtk_gl_area_get_required_version(). +func (v *GLArea) GetRequiredVersion() (MajorVersion, MinorVersion) { + var major, minor int + C.gtk_gl_area_get_required_version(v.native(), + (*C.gint)(unsafe.Pointer(&major)), (*C.gint)(unsafe.Pointer(&minor))) + + return MajorVersion(major), MinorVersion(minor) +} + +// SetRequiredVersion is a wrapper around gtk_gl_area_set_required_version(). +func (v *GLArea) SetRequiredVersion(major, minor int) { + C.gtk_gl_area_set_required_version(v.native(), (C.gint)(major), (C.gint)(minor)) +} + +// TODO: +// void gtk_gl_area_set_error (GtkGLArea *area, const GError *error); +// gtk_gl_area_set_has_alpha(). +// gtk_gl_area_get_has_alpha(). + +// HasDepthBuffer is a wrapper around gtk_gl_area_get_has_depth_buffer(). +func (v *GLArea) HasDepthBuffer() bool { + return gobool(C.gtk_gl_area_get_has_depth_buffer(v.native())) +} + +// SetHasDepthBuffer is a wrapper around gtk_gl_area_set_has_depth_buffer(). +func (v *GLArea) SetHasDepthBuffer(hasDepthBuffer bool) { + C.gtk_gl_area_set_has_depth_buffer(v.native(), gbool(hasDepthBuffer)) +} + +// HasStencilBuffer is a wrapper around gtk_gl_area_get_has_stencil_buffer(). +func (v *GLArea) HasStencilBuffer() bool { + return gobool(C.gtk_gl_area_get_has_stencil_buffer(v.native())) +} + +// SetHasStencilBuffer is a wrapper around gtk_gl_area_set_has_stencil_buffer(). +func (v *GLArea) SetHasStencilBuffer(hasStencilBuffer bool) { + C.gtk_gl_area_set_has_stencil_buffer(v.native(), gbool(hasStencilBuffer)) +} + +// GetAutoRender is a wrapper around gtk_gl_area_get_auto_render(). +func (v *GLArea) GetAutoRender() bool { + return gobool(C.gtk_gl_area_get_auto_render(v.native())) +} + +// SetAutoRender is a wrapper around gtk_gl_area_set_auto_render(). +func (v *GLArea) SetAutoRender(autoRender bool) { + C.gtk_gl_area_set_auto_render(v.native(), gbool(autoRender)) +} + +// QueueRender is a wrapper around gtk_gl_area_queue_render(). +func (v *GLArea) QueueRender() { + C.gtk_gl_area_queue_render(v.native()) +} + +// GetContext is a wrapper around gtk_gl_area_get_context(). +func (v *GLArea) GetContext() (*gdk.GLContext, error) { + c := C.gtk_gl_area_get_context(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + return &(gdk.GLContext{obj}), nil +} + +// MakeCurrent is a wrapper around gtk_gl_area_make_current(). +func (v *GLArea) MakeCurrent() { + C.gtk_gl_area_make_current(v.native()) +} + +// AttachBuffers is a wrapper around gtk_gl_area_attach_buffers(). +func (v *GLArea) AttachBuffers() { + C.gtk_gl_area_attach_buffers(v.native()) +} + +// GError* gtk_gl_area_get_error (GtkGLArea *area); +func (v *GLArea) GetError() error { + var err *C.GError = nil + err = C.gtk_gl_area_get_error(v.native()) + if err != nil { + defer C.g_error_free(err) + return errors.New(goString(err.message)) + } + return nil +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/glarea_since_3_22.go b/vendor/github.com/gotk3/gotk3/gtk/glarea_since_3_22.go new file mode 100644 index 0000000..4d19667 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/glarea_since_3_22.go @@ -0,0 +1,17 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16,!gtk_3_18,!gtk_3_20 +// Supports building with gtk 3.22+ + +package gtk + +// #include +import "C" + +// GetUseES is a wrapper around gtk_gl_area_get_use_es(). +func (v *GLArea) GetUseES() bool { + return gobool(C.gtk_gl_area_get_use_es(v.native())) +} + +// SetUseES is a wrapper around gtk_gl_area_set_use_es(). +func (v *GLArea) SetUseES(es bool) { + C.gtk_gl_area_set_use_es(v.native(), gbool(es)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/glib.go b/vendor/github.com/gotk3/gotk3/gtk/glib.go new file mode 100644 index 0000000..6a7e0f5 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/glib.go @@ -0,0 +1,20 @@ +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func nativeGPermission(permission *glib.Permission) *C.GPermission { + // Note: would return C type prefixed with glib package. + // Go issue: here https://github.com/golang/go/issues/13467. + var perm *C.GPermission + if permission != nil { + perm = (*C.GPermission)(unsafe.Pointer(permission.Native())) + } + return perm +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk.go b/vendor/github.com/gotk3/gotk3/gtk/gtk.go new file mode 100644 index 0000000..9f3e140 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk.go @@ -0,0 +1,11983 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// Go bindings for GTK+ 3. Supports version 3.6 and later. +// +// Functions use the same names as the native C function calls, but use +// CamelCase. In cases where native GTK uses pointers to values to +// simulate multiple return values, Go's native multiple return values +// are used instead. Whenever a native GTK call could return an +// unexpected NULL pointer, an additional error is returned in the Go +// binding. +// +// GTK's C API documentation can be very useful for understanding how the +// functions in this package work and what each type is for. This +// documentation can be found at https://developer.gnome.org/gtk3/. +// +// In addition to Go versions of the C GTK functions, every struct type +// includes a method named Native (either by direct implementation, or +// by means of struct embedding). These methods return a uintptr of the +// native C object the binding type represents. These pointers may be +// type switched to a native C pointer using unsafe and used with cgo +// function calls outside this package. +// +// Memory management is handled in proper Go fashion, using runtime +// finalizers to properly free memory when it is no longer needed. Each +// time a Go type is created with a pointer to a GObject, a reference is +// added for Go, sinking the floating reference when necessary. After +// going out of scope and the next time Go's garbage collector is run, a +// finalizer is run to remove Go's reference to the GObject. When this +// reference count hits zero (when neither Go nor GTK holds ownership) +// the object will be freed internally by GTK. +package gtk + +// #cgo pkg-config: gdk-3.0 gio-2.0 glib-2.0 gobject-2.0 gtk+-3.0 +// #include +// #include +// #include "gtk.go.h" +import "C" +import ( + "errors" + "fmt" + "reflect" + "runtime" + "sync" + "unsafe" + + "github.com/gotk3/gotk3/cairo" + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/internal/callback" + "github.com/gotk3/gotk3/pango" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.gtk_align_get_type()), marshalAlign}, + {glib.Type(C.gtk_accel_flags_get_type()), marshalAccelFlags}, + {glib.Type(C.gtk_accel_group_get_type()), marshalAccelGroup}, + {glib.Type(C.gtk_accel_map_get_type()), marshalAccelMap}, + {glib.Type(C.gtk_arrow_placement_get_type()), marshalArrowPlacement}, + {glib.Type(C.gtk_arrow_type_get_type()), marshalArrowType}, + {glib.Type(C.gtk_assistant_page_type_get_type()), marshalAssistantPageType}, + {glib.Type(C.gtk_buttons_type_get_type()), marshalButtonsType}, + {glib.Type(C.gtk_calendar_display_options_get_type()), marshalCalendarDisplayOptions}, + {glib.Type(C.gtk_cell_renderer_accel_mode_get_type()), marshalCellRendererAccelMode}, + {glib.Type(C.gtk_cell_renderer_mode_get_type()), marshalCellRendererMode}, + {glib.Type(C.gtk_cell_renderer_state_get_type()), marshalCellRendererState}, + {glib.Type(C.gtk_corner_type_get_type()), marshalCornerType}, + {glib.Type(C.gtk_dest_defaults_get_type()), marshalDestDefaults}, + {glib.Type(C.gtk_dialog_flags_get_type()), marshalDialogFlags}, + {glib.Type(C.gtk_entry_icon_position_get_type()), marshalEntryIconPosition}, + {glib.Type(C.gtk_file_chooser_action_get_type()), marshalFileChooserAction}, + {glib.Type(C.gtk_icon_lookup_flags_get_type()), marshalSortType}, + {glib.Type(C.gtk_icon_size_get_type()), marshalIconSize}, + {glib.Type(C.gtk_image_type_get_type()), marshalImageType}, + {glib.Type(C.gtk_input_hints_get_type()), marshalInputHints}, + {glib.Type(C.gtk_input_purpose_get_type()), marshalInputPurpose}, + {glib.Type(C.gtk_direction_type_get_type()), marshalDirectionType}, + {glib.Type(C.gtk_justification_get_type()), marshalJustification}, + {glib.Type(C.gtk_license_get_type()), marshalLicense}, + {glib.Type(C.gtk_message_type_get_type()), marshalMessageType}, + {glib.Type(C.gtk_orientation_get_type()), marshalOrientation}, + {glib.Type(C.gtk_pack_type_get_type()), marshalPackType}, + {glib.Type(C.gtk_path_type_get_type()), marshalPathType}, + {glib.Type(C.gtk_policy_type_get_type()), marshalPolicyType}, + {glib.Type(C.gtk_position_type_get_type()), marshalPositionType}, + {glib.Type(C.gtk_relief_style_get_type()), marshalReliefStyle}, + {glib.Type(C.gtk_response_type_get_type()), marshalResponseType}, + {glib.Type(C.gtk_selection_mode_get_type()), marshalSelectionMode}, + {glib.Type(C.gtk_scroll_type_get_type()), marshalScrollType}, + {glib.Type(C.gtk_scroll_step_get_type()), marshalScrollStep}, + {glib.Type(C.gtk_sensitivity_type_get_type()), marshalSensitivityType}, + {glib.Type(C.gtk_shadow_type_get_type()), marshalShadowType}, + {glib.Type(C.gtk_sort_type_get_type()), marshalSortType}, + {glib.Type(C.gtk_spin_button_update_policy_get_type()), marshalSpinButtonUpdatePolicy}, + {glib.Type(C.gtk_spin_type_get_type()), marshalSpinType}, + {glib.Type(C.gtk_state_flags_get_type()), marshalStateFlags}, + {glib.Type(C.gtk_target_flags_get_type()), marshalTargetFlags}, + {glib.Type(C.gtk_text_direction_get_type()), marshalTextDirection}, + {glib.Type(C.gtk_text_search_flags_get_type()), marshalTextSearchFlags}, + {glib.Type(C.gtk_toolbar_style_get_type()), marshalToolbarStyle}, + {glib.Type(C.gtk_tree_model_flags_get_type()), marshalTreeModelFlags}, + {glib.Type(C.gtk_window_position_get_type()), marshalWindowPosition}, + {glib.Type(C.gtk_window_type_get_type()), marshalWindowType}, + {glib.Type(C.gtk_wrap_mode_get_type()), marshalWrapMode}, + + // Objects/Interfaces + {glib.Type(C.gtk_accel_group_get_type()), marshalAccelGroup}, + {glib.Type(C.gtk_accel_map_get_type()), marshalAccelMap}, + {glib.Type(C.gtk_adjustment_get_type()), marshalAdjustment}, + {glib.Type(C.gtk_application_get_type()), marshalApplication}, + {glib.Type(C.gtk_application_window_get_type()), marshalApplicationWindow}, + {glib.Type(C.gtk_assistant_get_type()), marshalAssistant}, + {glib.Type(C.gtk_bin_get_type()), marshalBin}, + {glib.Type(C.gtk_builder_get_type()), marshalBuilder}, + {glib.Type(C.gtk_button_get_type()), marshalButton}, + {glib.Type(C.gtk_button_box_get_type()), marshalButtonBox}, + {glib.Type(C.gtk_box_get_type()), marshalBox}, + {glib.Type(C.gtk_calendar_get_type()), marshalCalendar}, + {glib.Type(C.gtk_cell_layout_get_type()), marshalCellLayout}, + {glib.Type(C.gtk_cell_editable_get_type()), marshalCellEditable}, + {glib.Type(C.gtk_cell_renderer_get_type()), marshalCellRenderer}, + {glib.Type(C.gtk_cell_renderer_spinner_get_type()), marshalCellRendererSpinner}, + {glib.Type(C.gtk_cell_renderer_pixbuf_get_type()), marshalCellRendererPixbuf}, + {glib.Type(C.gtk_cell_renderer_text_get_type()), marshalCellRendererText}, + {glib.Type(C.gtk_cell_renderer_progress_get_type()), marshalCellRendererProgress}, + {glib.Type(C.gtk_cell_renderer_toggle_get_type()), marshalCellRendererToggle}, + {glib.Type(C.gtk_cell_renderer_combo_get_type()), marshalCellRendererCombo}, + {glib.Type(C.gtk_cell_renderer_accel_get_type()), marshalCellRendererAccel}, + {glib.Type(C.gtk_cell_renderer_spin_get_type()), marshalCellRendererSpin}, + {glib.Type(C.gtk_check_button_get_type()), marshalCheckButton}, + {glib.Type(C.gtk_check_menu_item_get_type()), marshalCheckMenuItem}, + {glib.Type(C.gtk_clipboard_get_type()), marshalClipboard}, + {glib.Type(C.gtk_container_get_type()), marshalContainer}, + {glib.Type(C.gtk_dialog_get_type()), marshalDialog}, + {glib.Type(C.gtk_drawing_area_get_type()), marshalDrawingArea}, + {glib.Type(C.gtk_editable_get_type()), marshalEditable}, + {glib.Type(C.gtk_entry_get_type()), marshalEntry}, + {glib.Type(C.gtk_entry_buffer_get_type()), marshalEntryBuffer}, + {glib.Type(C.gtk_entry_completion_get_type()), marshalEntryCompletion}, + {glib.Type(C.gtk_event_box_get_type()), marshalEventBox}, + {glib.Type(C.gtk_expander_get_type()), marshalExpander}, + {glib.Type(C.gtk_file_chooser_get_type()), marshalFileChooser}, + {glib.Type(C.gtk_file_chooser_button_get_type()), marshalFileChooserButton}, + {glib.Type(C.gtk_file_chooser_dialog_get_type()), marshalFileChooserDialog}, + {glib.Type(C.gtk_file_chooser_widget_get_type()), marshalFileChooserWidget}, + {glib.Type(C.gtk_frame_get_type()), marshalFrame}, + {glib.Type(C.gtk_aspect_frame_get_type()), marshalAspectFrame}, + {glib.Type(C.gtk_grid_get_type()), marshalGrid}, + {glib.Type(C.gtk_icon_view_get_type()), marshalIconView}, + {glib.Type(C.gtk_image_get_type()), marshalImage}, + {glib.Type(C.gtk_label_get_type()), marshalLabel}, + {glib.Type(C.gtk_link_button_get_type()), marshalLinkButton}, + {glib.Type(C.gtk_lock_button_get_type()), marshalLockButton}, + {glib.Type(C.gtk_layout_get_type()), marshalLayout}, + {glib.Type(C.gtk_tree_model_sort_get_type()), marshalTreeModelSort}, + {glib.Type(C.gtk_list_store_get_type()), marshalListStore}, + {glib.Type(C.gtk_menu_get_type()), marshalMenu}, + {glib.Type(C.gtk_menu_bar_get_type()), marshalMenuBar}, + {glib.Type(C.gtk_menu_button_get_type()), marshalMenuButton}, + {glib.Type(C.gtk_menu_item_get_type()), marshalMenuItem}, + {glib.Type(C.gtk_menu_shell_get_type()), marshalMenuShell}, + {glib.Type(C.gtk_message_dialog_get_type()), marshalMessageDialog}, + {glib.Type(C.gtk_notebook_get_type()), marshalNotebook}, + {glib.Type(C.gtk_offscreen_window_get_type()), marshalOffscreenWindow}, + {glib.Type(C.gtk_orientable_get_type()), marshalOrientable}, + {glib.Type(C.gtk_overlay_get_type()), marshalOverlay}, + {glib.Type(C.gtk_paned_get_type()), marshalPaned}, + {glib.Type(C.gtk_progress_bar_get_type()), marshalProgressBar}, + {glib.Type(C.gtk_radio_button_get_type()), marshalRadioButton}, + {glib.Type(C.gtk_radio_menu_item_get_type()), marshalRadioMenuItem}, + {glib.Type(C.gtk_range_get_type()), marshalRange}, + {glib.Type(C.gtk_scale_button_get_type()), marshalScaleButton}, + {glib.Type(C.gtk_scale_get_type()), marshalScale}, + {glib.Type(C.gtk_scrollbar_get_type()), marshalScrollbar}, + {glib.Type(C.gtk_scrolled_window_get_type()), marshalScrolledWindow}, + {glib.Type(C.gtk_search_entry_get_type()), marshalSearchEntry}, + {glib.Type(C.gtk_selection_data_get_type()), marshalSelectionData}, + {glib.Type(C.gtk_separator_get_type()), marshalSeparator}, + {glib.Type(C.gtk_separator_menu_item_get_type()), marshalSeparatorMenuItem}, + {glib.Type(C.gtk_separator_tool_item_get_type()), marshalSeparatorToolItem}, + {glib.Type(C.gtk_spin_button_get_type()), marshalSpinButton}, + {glib.Type(C.gtk_spinner_get_type()), marshalSpinner}, + {glib.Type(C.gtk_statusbar_get_type()), marshalStatusbar}, + {glib.Type(C.gtk_switch_get_type()), marshalSwitch}, + {glib.Type(C.gtk_text_view_get_type()), marshalTextView}, + {glib.Type(C.gtk_text_tag_get_type()), marshalTextTag}, + {glib.Type(C.gtk_text_tag_table_get_type()), marshalTextTagTable}, + {glib.Type(C.gtk_text_buffer_get_type()), marshalTextBuffer}, + {glib.Type(C.gtk_toggle_button_get_type()), marshalToggleButton}, + {glib.Type(C.gtk_toolbar_get_type()), marshalToolbar}, + {glib.Type(C.gtk_tool_button_get_type()), marshalToolButton}, + {glib.Type(C.gtk_toggle_tool_button_get_type()), marshalToggleToolButton}, + {glib.Type(C.gtk_tool_item_get_type()), marshalToolItem}, + {glib.Type(C.gtk_tooltip_get_type()), marshalTooltip}, + {glib.Type(C.gtk_tree_model_get_type()), marshalTreeModel}, + {glib.Type(C.gtk_tree_sortable_get_type()), marshalTreeSortable}, + {glib.Type(C.gtk_tree_selection_get_type()), marshalTreeSelection}, + {glib.Type(C.gtk_tree_store_get_type()), marshalTreeStore}, + {glib.Type(C.gtk_tree_view_get_type()), marshalTreeView}, + {glib.Type(C.gtk_tree_view_column_get_type()), marshalTreeViewColumn}, + {glib.Type(C.gtk_cell_area_get_type()), marshalCellArea}, + {glib.Type(C.gtk_cell_area_context_get_type()), marshalCellAreaContext}, + {glib.Type(C.gtk_cell_area_box_get_type()), marshalCellAreaBox}, + {glib.Type(C.gtk_volume_button_get_type()), marshalVolumeButton}, + {glib.Type(C.gtk_widget_get_type()), marshalWidget}, + {glib.Type(C.gtk_window_get_type()), marshalWindow}, + {glib.Type(C.gtk_window_group_get_type()), marshalWindowGroup}, + + // Boxed + {glib.Type(C.gtk_target_entry_get_type()), marshalTargetEntry}, + {glib.Type(C.gtk_text_iter_get_type()), marshalTextIter}, + {glib.Type(C.gtk_text_mark_get_type()), marshalTextMark}, + {glib.Type(C.gtk_tree_iter_get_type()), marshalTreeIter}, + {glib.Type(C.gtk_tree_path_get_type()), marshalTreePath}, + } + glib.RegisterGValueMarshalers(tm) +} + +/* + * Callback helpers + */ + +//export gotk3_callbackDelete +func gotk3_callbackDelete(callbackID C.gpointer) { + callback.Delete(uintptr(callbackID)) +} + +/* + * Type conversions + */ + +func gbool(b bool) C.gboolean { + if b { + return C.gboolean(1) + } + return C.gboolean(0) +} + +func gobool(b C.gboolean) bool { + return b != C.FALSE +} + +func cGSList(clist *glib.SList) *C.GSList { + if clist == nil { + return nil + } + return (*C.GSList)(unsafe.Pointer(clist.Native())) +} + +func free(str ...interface{}) { + for _, s := range str { + switch x := s.(type) { + case *C.char: + C.free(unsafe.Pointer(x)) + case []*C.char: + for _, cp := range x { + C.free(unsafe.Pointer(cp)) + } + /* + case C.gpointer: + C.g_free(C.gpointer(c)) + */ + default: + fmt.Printf("utils.go free(): Unknown type: %T\n", x) + } + + } +} + +// nextguchar increments guchar by 1. Hopefully, this could be inlined by the Go +// compiler. +func nextguchar(guchar *C.guchar) *C.guchar { + return (*C.guchar)(unsafe.Pointer(uintptr(unsafe.Pointer(guchar)) + 1)) +} + +// ucharString returns a copy of the given guchar pointer. The pointer guchar +// array is assumed to have valid UTF-8. +func ucharString(guchar *C.guchar) string { + // Seek and find the string length. + var strlen int + for ptr := guchar; *ptr != 0; ptr = nextguchar(ptr) { + strlen++ + } + + // Array of unsigned char means GoString is unavailable, so maybe this is + // fine. + var data []byte + sliceHeader := (*reflect.SliceHeader)(unsafe.Pointer(&data)) + sliceHeader.Len = strlen + sliceHeader.Cap = strlen + sliceHeader.Data = uintptr(unsafe.Pointer(guchar)) + + // Return a copy of the string. + return string(data) +} + +// nextgcharptr increments gcharptr by 1. Hopefully, this could be inlined by +// the Go compiler. +func nextgcharptr(gcharptr **C.gchar) **C.gchar { + return (**C.gchar)(unsafe.Pointer(uintptr(unsafe.Pointer(gcharptr)) + 1)) +} + +func goString(cstr *C.gchar) string { + return C.GoString((*C.char)(cstr)) +} + +// same implementation as package glib +func toGoStringArray(c **C.gchar) []string { + if c == nil { + return nil + } + + // free when done + defer C.g_strfreev(c) + + strsLen := 0 + for scan := c; *scan != nil; scan = nextgcharptr(scan) { + strsLen++ + } + + strs := make([]string, strsLen) + for i := range strs { + strs[i] = C.GoString((*C.char)(*c)) + c = nextgcharptr(c) + } + + return strs +} + +// Wrapper function for TestBoolConvs since cgo can't be used with +// testing package +func testBoolConvs() error { + b := gobool(gbool(true)) + if b != true { + return errors.New("Unexpected bool conversion result") + } + + cb := gbool(gobool(C.gboolean(0))) + if cb != C.gboolean(0) { + return errors.New("Unexpected bool conversion result") + } + + return nil +} + +/* + * Unexported vars + */ + +var nilPtrErr = errors.New("cgo returned unexpected nil pointer") + +/* + * Constants + */ + +// Align is a representation of GTK's GtkAlign. +type Align int + +const ( + ALIGN_FILL Align = C.GTK_ALIGN_FILL + ALIGN_START Align = C.GTK_ALIGN_START + ALIGN_END Align = C.GTK_ALIGN_END + ALIGN_CENTER Align = C.GTK_ALIGN_CENTER +) + +func marshalAlign(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Align(c), nil +} + +// ArrowPlacement is a representation of GTK's GtkArrowPlacement. +type ArrowPlacement int + +const ( + ARROWS_BOTH ArrowPlacement = C.GTK_ARROWS_BOTH + ARROWS_START ArrowPlacement = C.GTK_ARROWS_START + ARROWS_END ArrowPlacement = C.GTK_ARROWS_END +) + +func marshalArrowPlacement(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ArrowPlacement(c), nil +} + +// ArrowType is a representation of GTK's GtkArrowType. +type ArrowType int + +const ( + ARROW_UP ArrowType = C.GTK_ARROW_UP + ARROW_DOWN ArrowType = C.GTK_ARROW_DOWN + ARROW_LEFT ArrowType = C.GTK_ARROW_LEFT + ARROW_RIGHT ArrowType = C.GTK_ARROW_RIGHT + ARROW_NONE ArrowType = C.GTK_ARROW_NONE +) + +func marshalArrowType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ArrowType(c), nil +} + +// AssistantPageType is a representation of GTK's GtkAssistantPageType. +type AssistantPageType int + +const ( + ASSISTANT_PAGE_CONTENT AssistantPageType = C.GTK_ASSISTANT_PAGE_CONTENT + ASSISTANT_PAGE_INTRO AssistantPageType = C.GTK_ASSISTANT_PAGE_INTRO + ASSISTANT_PAGE_CONFIRM AssistantPageType = C.GTK_ASSISTANT_PAGE_CONFIRM + ASSISTANT_PAGE_SUMMARY AssistantPageType = C.GTK_ASSISTANT_PAGE_SUMMARY + ASSISTANT_PAGE_PROGRESS AssistantPageType = C.GTK_ASSISTANT_PAGE_PROGRESS + ASSISTANT_PAGE_CUSTOM AssistantPageType = C.GTK_ASSISTANT_PAGE_CUSTOM +) + +func marshalAssistantPageType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return AssistantPageType(c), nil +} + +// ButtonsType is a representation of GTK's GtkButtonsType. +type ButtonsType int + +const ( + BUTTONS_NONE ButtonsType = C.GTK_BUTTONS_NONE + BUTTONS_OK ButtonsType = C.GTK_BUTTONS_OK + BUTTONS_CLOSE ButtonsType = C.GTK_BUTTONS_CLOSE + BUTTONS_CANCEL ButtonsType = C.GTK_BUTTONS_CANCEL + BUTTONS_YES_NO ButtonsType = C.GTK_BUTTONS_YES_NO + BUTTONS_OK_CANCEL ButtonsType = C.GTK_BUTTONS_OK_CANCEL +) + +func marshalButtonsType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ButtonsType(c), nil +} + +// SensitivityType is a representation of GTK's GtkSensitivityType +type SensitivityType int + +const ( + SENSITIVITY_AUTO SensitivityType = C.GTK_SENSITIVITY_AUTO + SENSITIVITY_ON SensitivityType = C.GTK_SENSITIVITY_ON + SENSITIVITY_OFF SensitivityType = C.GTK_SENSITIVITY_OFF +) + +func marshalSensitivityType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return SensitivityType(c), nil +} + +// CalendarDisplayOptions is a representation of GTK's GtkCalendarDisplayOptions +type CalendarDisplayOptions int + +const ( + CALENDAR_SHOW_HEADING CalendarDisplayOptions = C.GTK_CALENDAR_SHOW_HEADING + CALENDAR_SHOW_DAY_NAMES CalendarDisplayOptions = C.GTK_CALENDAR_SHOW_DAY_NAMES + CALENDAR_NO_MONTH_CHANGE CalendarDisplayOptions = C.GTK_CALENDAR_NO_MONTH_CHANGE + CALENDAR_SHOW_WEEK_NUMBERS CalendarDisplayOptions = C.GTK_CALENDAR_SHOW_WEEK_NUMBERS + CALENDAR_SHOW_DETAILS CalendarDisplayOptions = C.GTK_CALENDAR_SHOW_DETAILS +) + +func marshalCalendarDisplayOptions(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return CalendarDisplayOptions(c), nil +} + +// DestDefaults is a representation of GTK's GtkDestDefaults. +type DestDefaults int + +const ( + DEST_DEFAULT_MOTION DestDefaults = C.GTK_DEST_DEFAULT_MOTION + DEST_DEFAULT_HIGHLIGHT DestDefaults = C.GTK_DEST_DEFAULT_HIGHLIGHT + DEST_DEFAULT_DROP DestDefaults = C.GTK_DEST_DEFAULT_DROP + DEST_DEFAULT_ALL DestDefaults = C.GTK_DEST_DEFAULT_ALL +) + +func marshalDestDefaults(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return DestDefaults(c), nil +} + +// DialogFlags is a representation of GTK's GtkDialogFlags. +type DialogFlags int + +const ( + DIALOG_MODAL DialogFlags = C.GTK_DIALOG_MODAL + DIALOG_DESTROY_WITH_PARENT DialogFlags = C.GTK_DIALOG_DESTROY_WITH_PARENT +) + +func marshalDialogFlags(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return DialogFlags(c), nil +} + +// EntryIconPosition is a representation of GTK's GtkEntryIconPosition. +type EntryIconPosition int + +const ( + ENTRY_ICON_PRIMARY EntryIconPosition = C.GTK_ENTRY_ICON_PRIMARY + ENTRY_ICON_SECONDARY EntryIconPosition = C.GTK_ENTRY_ICON_SECONDARY +) + +func marshalEntryIconPosition(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return EntryIconPosition(c), nil +} + +// FileChooserAction is a representation of GTK's GtkFileChooserAction. +type FileChooserAction int + +const ( + FILE_CHOOSER_ACTION_OPEN FileChooserAction = C.GTK_FILE_CHOOSER_ACTION_OPEN + FILE_CHOOSER_ACTION_SAVE FileChooserAction = C.GTK_FILE_CHOOSER_ACTION_SAVE + FILE_CHOOSER_ACTION_SELECT_FOLDER FileChooserAction = C.GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER + FILE_CHOOSER_ACTION_CREATE_FOLDER FileChooserAction = C.GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER +) + +func marshalFileChooserAction(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return FileChooserAction(c), nil +} + +// IconLookupFlags is a representation of GTK's GtkIconLookupFlags. +type IconLookupFlags int + +const ( + ICON_LOOKUP_NO_SVG IconLookupFlags = C.GTK_ICON_LOOKUP_NO_SVG + ICON_LOOKUP_FORCE_SVG IconLookupFlags = C.GTK_ICON_LOOKUP_FORCE_SVG + ICON_LOOKUP_USE_BUILTIN IconLookupFlags = C.GTK_ICON_LOOKUP_USE_BUILTIN + ICON_LOOKUP_GENERIC_FALLBACK IconLookupFlags = C.GTK_ICON_LOOKUP_GENERIC_FALLBACK + ICON_LOOKUP_FORCE_SIZE IconLookupFlags = C.GTK_ICON_LOOKUP_FORCE_SIZE +) + +func marshalIconLookupFlags(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return IconLookupFlags(c), nil +} + +// IconSize is a representation of GTK's GtkIconSize. +type IconSize int + +const ( + ICON_SIZE_INVALID IconSize = C.GTK_ICON_SIZE_INVALID + ICON_SIZE_MENU IconSize = C.GTK_ICON_SIZE_MENU + ICON_SIZE_SMALL_TOOLBAR IconSize = C.GTK_ICON_SIZE_SMALL_TOOLBAR + ICON_SIZE_LARGE_TOOLBAR IconSize = C.GTK_ICON_SIZE_LARGE_TOOLBAR + ICON_SIZE_BUTTON IconSize = C.GTK_ICON_SIZE_BUTTON + ICON_SIZE_DND IconSize = C.GTK_ICON_SIZE_DND + ICON_SIZE_DIALOG IconSize = C.GTK_ICON_SIZE_DIALOG +) + +func marshalIconSize(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return IconSize(c), nil +} + +// ImageType is a representation of GTK's GtkImageType. +type ImageType int + +const ( + IMAGE_EMPTY ImageType = C.GTK_IMAGE_EMPTY + IMAGE_PIXBUF ImageType = C.GTK_IMAGE_PIXBUF + IMAGE_STOCK ImageType = C.GTK_IMAGE_STOCK + IMAGE_ICON_SET ImageType = C.GTK_IMAGE_ICON_SET + IMAGE_ANIMATION ImageType = C.GTK_IMAGE_ANIMATION + IMAGE_ICON_NAME ImageType = C.GTK_IMAGE_ICON_NAME + IMAGE_GICON ImageType = C.GTK_IMAGE_GICON +) + +// TODO: add GTK_IMAGE_SURFACE for GTK 3.10 + +func marshalImageType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ImageType(c), nil +} + +// InputHints is a representation of GTK's GtkInputHints. +type InputHints int + +const ( + INPUT_HINT_NONE InputHints = C.GTK_INPUT_HINT_NONE + INPUT_HINT_SPELLCHECK InputHints = C.GTK_INPUT_HINT_SPELLCHECK + INPUT_HINT_NO_SPELLCHECK InputHints = C.GTK_INPUT_HINT_NO_SPELLCHECK + INPUT_HINT_WORD_COMPLETION InputHints = C.GTK_INPUT_HINT_WORD_COMPLETION + INPUT_HINT_LOWERCASE InputHints = C.GTK_INPUT_HINT_LOWERCASE + INPUT_HINT_UPPERCASE_CHARS InputHints = C.GTK_INPUT_HINT_UPPERCASE_CHARS + INPUT_HINT_UPPERCASE_WORDS InputHints = C.GTK_INPUT_HINT_UPPERCASE_WORDS + INPUT_HINT_UPPERCASE_SENTENCES InputHints = C.GTK_INPUT_HINT_UPPERCASE_SENTENCES + INPUT_HINT_INHIBIT_OSK InputHints = C.GTK_INPUT_HINT_INHIBIT_OSK +) + +// TODO: +// GTK_INPUT_HINT_VERTICAL_WRITING Since 3.18 +// GTK_INPUT_HINT_EMOJI Since 3.22.20 +// GTK_INPUT_HINT_NO_EMOJI Since 3.22.20 + +func marshalInputHints(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return InputHints(c), nil +} + +// InputPurpose is a representation of GTK's GtkInputPurpose. +type InputPurpose int + +const ( + INPUT_PURPOSE_FREE_FORM InputPurpose = C.GTK_INPUT_PURPOSE_FREE_FORM + INPUT_PURPOSE_ALPHA InputPurpose = C.GTK_INPUT_PURPOSE_ALPHA + INPUT_PURPOSE_DIGITS InputPurpose = C.GTK_INPUT_PURPOSE_DIGITS + INPUT_PURPOSE_NUMBER InputPurpose = C.GTK_INPUT_PURPOSE_NUMBER + INPUT_PURPOSE_PHONE InputPurpose = C.GTK_INPUT_PURPOSE_PHONE + INPUT_PURPOSE_URL InputPurpose = C.GTK_INPUT_PURPOSE_URL + INPUT_PURPOSE_EMAIL InputPurpose = C.GTK_INPUT_PURPOSE_EMAIL + INPUT_PURPOSE_NAME InputPurpose = C.GTK_INPUT_PURPOSE_NAME + INPUT_PURPOSE_PASSWORD InputPurpose = C.GTK_INPUT_PURPOSE_PASSWORD + INPUT_PURPOSE_PIN InputPurpose = C.GTK_INPUT_PURPOSE_PIN +) + +func marshalInputPurpose(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return InputPurpose(c), nil +} + +// TODO: +// GtkBaselinePosition +// GtkDeleteType + +// DirectionType is a representation of GTK's GtkDirectionType. +type DirectionType int + +const ( + DIR_TAB_FORWARD DirectionType = C.GTK_DIR_TAB_FORWARD + DIR_TAB_BACKWARD DirectionType = C.GTK_DIR_TAB_BACKWARD + DIR_UP DirectionType = C.GTK_DIR_UP + DIR_DOWN DirectionType = C.GTK_DIR_DOWN + DIR_LEFT DirectionType = C.GTK_DIR_LEFT + DIR_RIGHT DirectionType = C.GTK_DIR_RIGHT +) + +func marshalDirectionType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return DirectionType(c), nil +} + +// Justification is a representation of GTK's GtkJustification. +type Justification int + +const ( + JUSTIFY_LEFT Justification = C.GTK_JUSTIFY_LEFT + JUSTIFY_RIGHT Justification = C.GTK_JUSTIFY_RIGHT + JUSTIFY_CENTER Justification = C.GTK_JUSTIFY_CENTER + JUSTIFY_FILL Justification = C.GTK_JUSTIFY_FILL +) + +func marshalJustification(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Justification(c), nil +} + +// License is a representation of GTK's GtkLicense. +type License int + +const ( + LICENSE_UNKNOWN License = C.GTK_LICENSE_UNKNOWN + LICENSE_CUSTOM License = C.GTK_LICENSE_CUSTOM + LICENSE_GPL_2_0 License = C.GTK_LICENSE_GPL_2_0 + LICENSE_GPL_3_0 License = C.GTK_LICENSE_GPL_3_0 + LICENSE_LGPL_2_1 License = C.GTK_LICENSE_LGPL_2_1 + LICENSE_LGPL_3_0 License = C.GTK_LICENSE_LGPL_3_0 + LICENSE_BSD License = C.GTK_LICENSE_BSD + LICENSE_MIT_X11 License = C.GTK_LICENSE_MIT_X11 + LICENSE_GTK_ARTISTIC License = C.GTK_LICENSE_ARTISTIC +) + +func marshalLicense(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return License(c), nil +} + +// MessageType is a representation of GTK's GtkMessageType. +type MessageType int + +const ( + MESSAGE_INFO MessageType = C.GTK_MESSAGE_INFO + MESSAGE_WARNING MessageType = C.GTK_MESSAGE_WARNING + MESSAGE_QUESTION MessageType = C.GTK_MESSAGE_QUESTION + MESSAGE_ERROR MessageType = C.GTK_MESSAGE_ERROR + MESSAGE_OTHER MessageType = C.GTK_MESSAGE_OTHER +) + +func marshalMessageType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return MessageType(c), nil +} + +// TODO: +// GtkMovementStep + +// Orientation is a representation of GTK's GtkOrientation. +type Orientation int + +const ( + ORIENTATION_HORIZONTAL Orientation = C.GTK_ORIENTATION_HORIZONTAL + ORIENTATION_VERTICAL Orientation = C.GTK_ORIENTATION_VERTICAL +) + +func marshalOrientation(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Orientation(c), nil +} + +// PackType is a representation of GTK's GtkPackType. +type PackType int + +const ( + PACK_START PackType = C.GTK_PACK_START + PACK_END PackType = C.GTK_PACK_END +) + +func marshalPackType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PackType(c), nil +} + +// PathType is a representation of GTK's GtkPathType. +type PathType int + +const ( + PATH_WIDGET PathType = C.GTK_PATH_WIDGET + PATH_WIDGET_CLASS PathType = C.GTK_PATH_WIDGET_CLASS + PATH_CLASS PathType = C.GTK_PATH_CLASS +) + +func marshalPathType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PathType(c), nil +} + +// PolicyType is a representation of GTK's GtkPolicyType. +type PolicyType int + +const ( + POLICY_ALWAYS PolicyType = C.GTK_POLICY_ALWAYS + POLICY_AUTOMATIC PolicyType = C.GTK_POLICY_AUTOMATIC + POLICY_NEVER PolicyType = C.GTK_POLICY_NEVER +) + +func marshalPolicyType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PolicyType(c), nil +} + +// SpinButtonUpdatePolicy is a representation of GTK's GtkSpinButtonUpdatePolicy. +type SpinButtonUpdatePolicy int + +const ( + UPDATE_ALWAYS SpinButtonUpdatePolicy = C.GTK_UPDATE_ALWAYS + UPDATE_IF_VALID SpinButtonUpdatePolicy = C.GTK_UPDATE_IF_VALID +) + +func marshalSpinButtonUpdatePolicy(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return SpinButtonUpdatePolicy(c), nil +} + +// SpinType is a representation of GTK's GtkSpinType. +type SpinType int + +const ( + SPIN_STEP_FORWARD SpinType = C.GTK_SPIN_STEP_FORWARD + SPIN_STEP_BACKWARD SpinType = C.GTK_SPIN_STEP_BACKWARD + SPIN_PAGE_BACKWARD SpinType = C.GTK_SPIN_PAGE_BACKWARD + SPIN_HOME SpinType = C.GTK_SPIN_HOME + SPIN_END SpinType = C.GTK_SPIN_END + SPIN_USER_DEFINED SpinType = C.GTK_SPIN_USER_DEFINED +) + +func marshalSpinType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return SpinType(c), nil +} + +// TreeViewGridLine is a representation of GTK's GtkTreeViewGridLines. +type TreeViewGridLines int + +const ( + TREE_VIEW_GRID_LINES_NONE TreeViewGridLines = C.GTK_TREE_VIEW_GRID_LINES_NONE + TREE_VIEW_GRID_LINES_HORIZONTAL TreeViewGridLines = C.GTK_TREE_VIEW_GRID_LINES_HORIZONTAL + TREE_VIEW_GRID_LINES_VERTICAL TreeViewGridLines = C.GTK_TREE_VIEW_GRID_LINES_VERTICAL + TREE_VIEW_GRID_LINES_BOTH TreeViewGridLines = C.GTK_TREE_VIEW_GRID_LINES_BOTH +) + +// CellRendererAccelMode is a representation of GtkCellRendererAccelMode +type CellRendererAccelMode int + +const ( + // CELL_RENDERER_ACCEL_MODE_GTK is documented as GTK+ accelerators mode + CELL_RENDERER_ACCEL_MODE_GTK CellRendererAccelMode = C.GTK_CELL_RENDERER_ACCEL_MODE_GTK + // CELL_RENDERER_ACCEL_MODE_OTHER is documented as Other accelerator mode + CELL_RENDERER_ACCEL_MODE_OTHER CellRendererAccelMode = C.GTK_CELL_RENDERER_ACCEL_MODE_OTHER +) + +func marshalCellRendererAccelMode(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return CellRendererAccelMode(c), nil +} + +// CellRendererState is a representation of GTK's GtkCellRendererState +type CellRendererState int + +const ( + CELL_RENDERER_SELECTED CellRendererState = C.GTK_CELL_RENDERER_SELECTED + CELL_RENDERER_PRELIT CellRendererState = C.GTK_CELL_RENDERER_PRELIT + CELL_RENDERER_INSENSITIVE CellRendererState = C.GTK_CELL_RENDERER_INSENSITIVE + CELL_RENDERER_SORTED CellRendererState = C.GTK_CELL_RENDERER_SORTED + CELL_RENDERER_FOCUSED CellRendererState = C.GTK_CELL_RENDERER_FOCUSED + CELL_RENDERER_EXPANDABLE CellRendererState = C.GTK_CELL_RENDERER_EXPANDABLE // since 3.4 + CELL_RENDERER_EXPANDED CellRendererState = C.GTK_CELL_RENDERER_EXPANDED // since 3.4 +) + +func marshalCellRendererState(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return CellRendererState(c), nil +} + +// CellRendererMode is a representation of GTK's GtkCellRendererMode +type CellRendererMode int + +const ( + CELL_RENDERER_MODE_INERT CellRendererMode = C.GTK_CELL_RENDERER_MODE_INERT + CELL_RENDERER_MODE_ACTIVATABLE CellRendererMode = C.GTK_CELL_RENDERER_MODE_ACTIVATABLE + CELL_RENDERER_MODE_EDITABLE CellRendererMode = C.GTK_CELL_RENDERER_MODE_EDITABLE +) + +func marshalCellRendererMode(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return CellRendererMode(c), nil +} + +// PositionType is a representation of GTK's GtkPositionType. +type PositionType int + +const ( + POS_LEFT PositionType = C.GTK_POS_LEFT + POS_RIGHT PositionType = C.GTK_POS_RIGHT + POS_TOP PositionType = C.GTK_POS_TOP + POS_BOTTOM PositionType = C.GTK_POS_BOTTOM +) + +func marshalPositionType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PositionType(c), nil +} + +// ReliefStyle is a representation of GTK's GtkReliefStyle. +type ReliefStyle int + +const ( + RELIEF_NORMAL ReliefStyle = C.GTK_RELIEF_NORMAL + RELIEF_HALF ReliefStyle = C.GTK_RELIEF_HALF + RELIEF_NONE ReliefStyle = C.GTK_RELIEF_NONE +) + +func marshalReliefStyle(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ReliefStyle(c), nil +} + +// ResponseType is a representation of GTK's GtkResponseType. +type ResponseType int + +const ( + RESPONSE_NONE ResponseType = C.GTK_RESPONSE_NONE + RESPONSE_REJECT ResponseType = C.GTK_RESPONSE_REJECT + RESPONSE_ACCEPT ResponseType = C.GTK_RESPONSE_ACCEPT + RESPONSE_DELETE_EVENT ResponseType = C.GTK_RESPONSE_DELETE_EVENT + RESPONSE_OK ResponseType = C.GTK_RESPONSE_OK + RESPONSE_CANCEL ResponseType = C.GTK_RESPONSE_CANCEL + RESPONSE_CLOSE ResponseType = C.GTK_RESPONSE_CLOSE + RESPONSE_YES ResponseType = C.GTK_RESPONSE_YES + RESPONSE_NO ResponseType = C.GTK_RESPONSE_NO + RESPONSE_APPLY ResponseType = C.GTK_RESPONSE_APPLY + RESPONSE_HELP ResponseType = C.GTK_RESPONSE_HELP +) + +func marshalResponseType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ResponseType(c), nil +} + +// ScrollType is a representation of GTK's GtkScrollType. +type ScrollType int + +const ( + SCROLL_NONE ScrollType = C.GTK_SCROLL_NONE + SCROLL_JUMP ScrollType = C.GTK_SCROLL_JUMP + SCROLL_STEP_BACKWARD ScrollType = C.GTK_SCROLL_STEP_BACKWARD + SCROLL_STEP_FORWARD ScrollType = C.GTK_SCROLL_STEP_FORWARD + SCROLL_PAGE_BACKWARD ScrollType = C.GTK_SCROLL_PAGE_BACKWARD + SCROLL_PAGE_FORWARD ScrollType = C.GTK_SCROLL_PAGE_FORWARD + SCROLL_STEP_UP ScrollType = C.GTK_SCROLL_STEP_UP + SCROLL_STEP_DOWN ScrollType = C.GTK_SCROLL_STEP_DOWN + SCROLL_PAGE_UP ScrollType = C.GTK_SCROLL_PAGE_UP + SCROLL_PAGE_DOWN ScrollType = C.GTK_SCROLL_PAGE_DOWN + SCROLL_STEP_LEFT ScrollType = C.GTK_SCROLL_STEP_LEFT + SCROLL_STEP_RIGHT ScrollType = C.GTK_SCROLL_STEP_RIGHT + SCROLL_PAGE_LEFT ScrollType = C.GTK_SCROLL_PAGE_LEFT + SCROLL_PAGE_RIGHT ScrollType = C.GTK_SCROLL_PAGE_RIGHT + SCROLL_START ScrollType = C.GTK_SCROLL_START + SCROLL_END ScrollType = C.GTK_SCROLL_END +) + +func marshalScrollType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ScrollType(c), nil +} + +// ScrollStep is a representation of GTK's GtkScrollStep. +type ScrollStep int + +const ( + SCROLL_STEPS ScrollStep = C.GTK_SCROLL_STEPS + SCROLL_PAGES ScrollStep = C.GTK_SCROLL_PAGES + SCROLL_ENDS ScrollStep = C.GTK_SCROLL_ENDS + SCROLL_HORIZONTAL_STEPS ScrollStep = C.GTK_SCROLL_HORIZONTAL_STEPS + SCROLL_HORIZONTAL_PAGES ScrollStep = C.GTK_SCROLL_HORIZONTAL_PAGES + SCROLL_HORIZONTAL_ENDS ScrollStep = C.GTK_SCROLL_HORIZONTAL_ENDS +) + +func marshalScrollStep(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ScrollStep(c), nil +} + +// SelectionMode is a representation of GTK's GtkSelectionMode. +type SelectionMode int + +const ( + SELECTION_NONE SelectionMode = C.GTK_SELECTION_NONE + SELECTION_SINGLE SelectionMode = C.GTK_SELECTION_SINGLE + SELECTION_BROWSE SelectionMode = C.GTK_SELECTION_BROWSE + SELECTION_MULTIPLE SelectionMode = C.GTK_SELECTION_MULTIPLE +) + +func marshalSelectionMode(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return SelectionMode(c), nil +} + +// ShadowType is a representation of GTK's GtkShadowType. +type ShadowType int + +const ( + SHADOW_NONE ShadowType = C.GTK_SHADOW_NONE + SHADOW_IN ShadowType = C.GTK_SHADOW_IN + SHADOW_OUT ShadowType = C.GTK_SHADOW_OUT + SHADOW_ETCHED_IN ShadowType = C.GTK_SHADOW_ETCHED_IN + SHADOW_ETCHED_OUT ShadowType = C.GTK_SHADOW_ETCHED_OUT +) + +func marshalShadowType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ShadowType(c), nil +} + +// SizeGroupMode is a representation of GTK's GtkSizeGroupMode +type SizeGroupMode int + +const ( + SIZE_GROUP_NONE SizeGroupMode = C.GTK_SIZE_GROUP_NONE + SIZE_GROUP_HORIZONTAL SizeGroupMode = C.GTK_SIZE_GROUP_HORIZONTAL + SIZE_GROUP_VERTICAL SizeGroupMode = C.GTK_SIZE_GROUP_VERTICAL + SIZE_GROUP_BOTH SizeGroupMode = C.GTK_SIZE_GROUP_BOTH +) + +func marshalSizeGroupMode(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return SizeGroupMode(c), nil +} + +// SortType is a representation of GTK's GtkSortType. +type SortType int + +const ( + SORT_ASCENDING SortType = C.GTK_SORT_ASCENDING + SORT_DESCENDING = C.GTK_SORT_DESCENDING +) + +// Use as column id in SetSortColumnId to specify ListStore sorted +// by default column or unsorted +const ( + SORT_COLUMN_DEFAULT int = -1 + SORT_COLUMN_UNSORTED int = -2 +) + +func marshalSortType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return SortType(c), nil +} + +// StateFlags is a representation of GTK's GtkStateFlags. +type StateFlags int + +const ( + STATE_FLAG_NORMAL StateFlags = C.GTK_STATE_FLAG_NORMAL + STATE_FLAG_ACTIVE StateFlags = C.GTK_STATE_FLAG_ACTIVE + STATE_FLAG_PRELIGHT StateFlags = C.GTK_STATE_FLAG_PRELIGHT + STATE_FLAG_SELECTED StateFlags = C.GTK_STATE_FLAG_SELECTED + STATE_FLAG_INSENSITIVE StateFlags = C.GTK_STATE_FLAG_INSENSITIVE + STATE_FLAG_INCONSISTENT StateFlags = C.GTK_STATE_FLAG_INCONSISTENT + STATE_FLAG_FOCUSED StateFlags = C.GTK_STATE_FLAG_FOCUSED + STATE_FLAG_BACKDROP StateFlags = C.GTK_STATE_FLAG_BACKDROP +) + +func marshalStateFlags(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return StateFlags(c), nil +} + +// TextDirection is a representation of GTK's GtkTextDirection. +type TextDirection int + +const ( + TEXT_DIR_NONE TextDirection = C.GTK_TEXT_DIR_NONE + TEXT_DIR_LTR TextDirection = C.GTK_TEXT_DIR_LTR + TEXT_DIR_RTL TextDirection = C.GTK_TEXT_DIR_RTL +) + +func marshalTextDirection(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return TextDirection(c), nil +} + +// TargetFlags is a representation of GTK's GtkTargetFlags. +type TargetFlags int + +const ( + TARGET_SAME_APP TargetFlags = C.GTK_TARGET_SAME_APP + TARGET_SAME_WIDGET TargetFlags = C.GTK_TARGET_SAME_WIDGET + TARGET_OTHER_APP TargetFlags = C.GTK_TARGET_OTHER_APP + TARGET_OTHER_WIDGET TargetFlags = C.GTK_TARGET_OTHER_WIDGET +) + +func marshalTargetFlags(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return TargetFlags(c), nil +} + +// ToolbarStyle is a representation of GTK's GtkToolbarStyle. +type ToolbarStyle int + +const ( + TOOLBAR_ICONS ToolbarStyle = C.GTK_TOOLBAR_ICONS + TOOLBAR_TEXT ToolbarStyle = C.GTK_TOOLBAR_TEXT + TOOLBAR_BOTH ToolbarStyle = C.GTK_TOOLBAR_BOTH + TOOLBAR_BOTH_HORIZ ToolbarStyle = C.GTK_TOOLBAR_BOTH_HORIZ +) + +func marshalToolbarStyle(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ToolbarStyle(c), nil +} + +// TreeModelFlags is a representation of GTK's GtkTreeModelFlags. +type TreeModelFlags int + +const ( + TREE_MODEL_ITERS_PERSIST TreeModelFlags = C.GTK_TREE_MODEL_ITERS_PERSIST + TREE_MODEL_LIST_ONLY TreeModelFlags = C.GTK_TREE_MODEL_LIST_ONLY +) + +func marshalTreeModelFlags(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return TreeModelFlags(c), nil +} + +// WindowPosition is a representation of GTK's GtkWindowPosition. +type WindowPosition int + +const ( + WIN_POS_NONE WindowPosition = C.GTK_WIN_POS_NONE + WIN_POS_CENTER WindowPosition = C.GTK_WIN_POS_CENTER + WIN_POS_MOUSE WindowPosition = C.GTK_WIN_POS_MOUSE + WIN_POS_CENTER_ALWAYS WindowPosition = C.GTK_WIN_POS_CENTER_ALWAYS + WIN_POS_CENTER_ON_PARENT WindowPosition = C.GTK_WIN_POS_CENTER_ON_PARENT +) + +func marshalWindowPosition(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return WindowPosition(c), nil +} + +// WindowType is a representation of GTK's GtkWindowType. +type WindowType int + +const ( + WINDOW_TOPLEVEL WindowType = C.GTK_WINDOW_TOPLEVEL + WINDOW_POPUP WindowType = C.GTK_WINDOW_POPUP +) + +func marshalWindowType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return WindowType(c), nil +} + +// WrapMode is a representation of GTK's GtkWrapMode. +type WrapMode int + +const ( + WRAP_NONE WrapMode = C.GTK_WRAP_NONE + WRAP_CHAR WrapMode = C.GTK_WRAP_CHAR + WRAP_WORD WrapMode = C.GTK_WRAP_WORD + WRAP_WORD_CHAR WrapMode = C.GTK_WRAP_WORD_CHAR +) + +func marshalWrapMode(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return WrapMode(c), nil +} + +// TextSearchFlags is a representation of GTK's GtkTextSearchFlags. +type TextSearchFlags int + +const ( + TEXT_SEARCH_VISIBLE_ONLY TextSearchFlags = C.GTK_TEXT_SEARCH_VISIBLE_ONLY + TEXT_SEARCH_TEXT_ONLY TextSearchFlags = C.GTK_TEXT_SEARCH_TEXT_ONLY + TEXT_SEARCH_CASE_INSENSITIVE TextSearchFlags = C.GTK_TEXT_SEARCH_CASE_INSENSITIVE +) + +func marshalTextSearchFlags(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return TextSearchFlags(c), nil +} + +// CornerType is a representation of GTK's GtkCornerType. +type CornerType int + +const ( + CORNER_TOP_LEFT CornerType = C.GTK_CORNER_TOP_LEFT + CORNER_BOTTOM_LEFT CornerType = C.GTK_CORNER_BOTTOM_LEFT + CORNER_TOP_RIGHT CornerType = C.GTK_CORNER_TOP_RIGHT + CORNER_BOTTOM_RIGHT CornerType = C.GTK_CORNER_BOTTOM_RIGHT +) + +func marshalCornerType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return CornerType(c), nil +} + +/* + * Init and main event loop + */ + +/* +Init() is a wrapper around gtk_init() and must be called before any +other GTK calls and is used to initialize everything necessary. + +In addition to setting up GTK for usage, a pointer to a slice of +strings may be passed in to parse standard GTK command line arguments. +args will be modified to remove any flags that were handled. +Alternatively, nil may be passed in to not perform any command line +parsing. +*/ +func Init(args *[]string) { + if args != nil { + argc := C.int(len(*args)) + argv := C.make_strings(argc) + defer C.destroy_strings(argv) + + for i, arg := range *args { + cstr := C.CString(arg) + C.set_string(argv, C.int(i), (*C.gchar)(cstr)) + } + + C.gtk_init((*C.int)(unsafe.Pointer(&argc)), + (***C.char)(unsafe.Pointer(&argv))) + + unhandled := make([]string, argc) + for i := 0; i < int(argc); i++ { + cstr := C.get_string(argv, C.int(i)) + unhandled[i] = goString(cstr) + C.free(unsafe.Pointer(cstr)) + } + *args = unhandled + } else { + C.gtk_init(nil, nil) + } +} + +/* +InitCheck() is a wrapper around gtk_init_check() and works exactly like Init() +only that it doesn't terminate the program if initialization fails. +*/ +func InitCheck(args *[]string) error { + success := false + if args != nil { + argc := C.int(len(*args)) + argv := C.make_strings(argc) + defer C.destroy_strings(argv) + + for i, arg := range *args { + cstr := C.CString(arg) + C.set_string(argv, C.int(i), (*C.gchar)(cstr)) + } + + success = gobool(C.gtk_init_check((*C.int)(unsafe.Pointer(&argc)), + (***C.char)(unsafe.Pointer(&argv)))) + + unhandled := make([]string, argc) + for i := 0; i < int(argc); i++ { + cstr := C.get_string(argv, C.int(i)) + unhandled[i] = goString(cstr) + C.free(unsafe.Pointer(cstr)) + } + *args = unhandled + } else { + success = gobool(C.gtk_init_check(nil, nil)) + } + if success { + return nil + } else { + return errors.New("Unable to initialize GTK") + } +} + +// Main() is a wrapper around gtk_main() and runs the GTK main loop, +// blocking until MainQuit() is called. +func Main() { + C.gtk_main() +} + +// MainIteration is a wrapper around gtk_main_iteration. +func MainIteration() bool { + return gobool(C.gtk_main_iteration()) +} + +// MainIterationDo is a wrapper around gtk_main_iteration_do. +func MainIterationDo(blocking bool) bool { + return gobool(C.gtk_main_iteration_do(gbool(blocking))) +} + +// EventsPending is a wrapper around gtk_events_pending. +func EventsPending() bool { + return gobool(C.gtk_events_pending()) +} + +// MainQuit() is a wrapper around gtk_main_quit() is used to terminate +// the GTK main loop (started by Main()). +func MainQuit() { + C.gtk_main_quit() +} + +/* + * GtkAdjustment + */ + +// Adjustment is a representation of GTK's GtkAdjustment. +type Adjustment struct { + glib.InitiallyUnowned +} + +// native returns a pointer to the underlying GtkAdjustment. +func (v *Adjustment) native() *C.GtkAdjustment { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkAdjustment(p) +} + +func marshalAdjustment(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapAdjustment(obj), nil +} + +func wrapAdjustment(obj *glib.Object) *Adjustment { + if obj == nil { + return nil + } + + return &Adjustment{glib.InitiallyUnowned{obj}} +} + +// AdjustmentNew is a wrapper around gtk_adjustment_new(). +func AdjustmentNew(value, lower, upper, stepIncrement, pageIncrement, pageSize float64) (*Adjustment, error) { + c := C.gtk_adjustment_new(C.gdouble(value), + C.gdouble(lower), + C.gdouble(upper), + C.gdouble(stepIncrement), + C.gdouble(pageIncrement), + C.gdouble(pageSize)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapAdjustment(obj), nil +} + +// GetValue is a wrapper around gtk_adjustment_get_value(). +func (v *Adjustment) GetValue() float64 { + c := C.gtk_adjustment_get_value(v.native()) + return float64(c) +} + +// SetValue is a wrapper around gtk_adjustment_set_value(). +func (v *Adjustment) SetValue(value float64) { + C.gtk_adjustment_set_value(v.native(), C.gdouble(value)) +} + +// GetLower is a wrapper around gtk_adjustment_get_lower(). +func (v *Adjustment) GetLower() float64 { + c := C.gtk_adjustment_get_lower(v.native()) + return float64(c) +} + +// GetPageSize is a wrapper around gtk_adjustment_get_page_size(). +func (v *Adjustment) GetPageSize() float64 { + return float64(C.gtk_adjustment_get_page_size(v.native())) +} + +// SetPageSize is a wrapper around gtk_adjustment_set_page_size(). +func (v *Adjustment) SetPageSize(value float64) { + C.gtk_adjustment_set_page_size(v.native(), C.gdouble(value)) +} + +// Configure is a wrapper around gtk_adjustment_configure(). +func (v *Adjustment) Configure(value, lower, upper, stepIncrement, pageIncrement, pageSize float64) { + C.gtk_adjustment_configure(v.native(), C.gdouble(value), + C.gdouble(lower), C.gdouble(upper), C.gdouble(stepIncrement), + C.gdouble(pageIncrement), C.gdouble(pageSize)) +} + +// SetLower is a wrapper around gtk_adjustment_set_lower(). +func (v *Adjustment) SetLower(value float64) { + C.gtk_adjustment_set_lower(v.native(), C.gdouble(value)) +} + +// GetUpper is a wrapper around gtk_adjustment_get_upper(). +func (v *Adjustment) GetUpper() float64 { + c := C.gtk_adjustment_get_upper(v.native()) + return float64(c) +} + +// SetUpper is a wrapper around gtk_adjustment_set_upper(). +func (v *Adjustment) SetUpper(value float64) { + C.gtk_adjustment_set_upper(v.native(), C.gdouble(value)) +} + +// GetPageIncrement is a wrapper around gtk_adjustment_get_page_increment(). +func (v *Adjustment) GetPageIncrement() float64 { + c := C.gtk_adjustment_get_page_increment(v.native()) + return float64(c) +} + +// SetPageIncrement is a wrapper around gtk_adjustment_set_page_increment(). +func (v *Adjustment) SetPageIncrement(value float64) { + C.gtk_adjustment_set_page_increment(v.native(), C.gdouble(value)) +} + +// GetStepIncrement is a wrapper around gtk_adjustment_get_step_increment(). +func (v *Adjustment) GetStepIncrement() float64 { + c := C.gtk_adjustment_get_step_increment(v.native()) + return float64(c) +} + +// SetStepIncrement is a wrapper around gtk_adjustment_set_step_increment(). +func (v *Adjustment) SetStepIncrement(value float64) { + C.gtk_adjustment_set_step_increment(v.native(), C.gdouble(value)) +} + +// GetMinimumIncrement is a wrapper around gtk_adjustment_get_minimum_increment(). +func (v *Adjustment) GetMinimumIncrement() float64 { + c := C.gtk_adjustment_get_minimum_increment(v.native()) + return float64(c) +} + +/* +void gtk_adjustment_clamp_page () +void gtk_adjustment_changed () +void gtk_adjustment_value_changed () +void gtk_adjustment_configure () +*/ + +/* + * GtkAssistant + */ + +// Assistant is a representation of GTK's GtkAssistant. +type Assistant struct { + Window +} + +// native returns a pointer to the underlying GtkAssistant. +func (v *Assistant) native() *C.GtkAssistant { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkAssistant(p) +} + +func marshalAssistant(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapAssistant(obj), nil +} + +func wrapAssistant(obj *glib.Object) *Assistant { + if obj == nil { + return nil + } + + return &Assistant{Window{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}}} +} + +// AssistantNew is a wrapper around gtk_assistant_new(). +func AssistantNew() (*Assistant, error) { + c := C.gtk_assistant_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapAssistant(obj), nil +} + +// GetCurrentPage is a wrapper around gtk_assistant_get_current_page(). +func (v *Assistant) GetCurrentPage() int { + c := C.gtk_assistant_get_current_page(v.native()) + return int(c) +} + +// SetCurrentPage is a wrapper around gtk_assistant_set_current_page(). +func (v *Assistant) SetCurrentPage(pageNum int) { + C.gtk_assistant_set_current_page(v.native(), C.gint(pageNum)) +} + +// GetNPages is a wrapper around gtk_assistant_get_n_pages(). +func (v *Assistant) GetNPages() int { + c := C.gtk_assistant_get_n_pages(v.native()) + return int(c) +} + +// GetNthPage is a wrapper around gtk_assistant_get_nth_page(). +func (v *Assistant) GetNthPage(pageNum int) (IWidget, error) { + c := C.gtk_assistant_get_nth_page(v.native(), C.gint(pageNum)) + if c == nil { + return nil, fmt.Errorf("page %d is out of bounds", pageNum) + } + return castWidget(c) +} + +// PrependPage is a wrapper around gtk_assistant_prepend_page(). +func (v *Assistant) PrependPage(page IWidget) int { + c := C.gtk_assistant_prepend_page(v.native(), page.toWidget()) + return int(c) +} + +// AppendPage is a wrapper around gtk_assistant_append_page(). +func (v *Assistant) AppendPage(page IWidget) int { + c := C.gtk_assistant_append_page(v.native(), page.toWidget()) + return int(c) +} + +// InsertPage is a wrapper around gtk_assistant_insert_page(). +func (v *Assistant) InsertPage(page IWidget, position int) int { + c := C.gtk_assistant_insert_page(v.native(), page.toWidget(), + C.gint(position)) + return int(c) +} + +// RemovePage is a wrapper around gtk_assistant_remove_page(). +func (v *Assistant) RemovePage(pageNum int) { + C.gtk_assistant_remove_page(v.native(), C.gint(pageNum)) +} + +// TODO: gtk_assistant_set_forward_page_func + +// SetPageType is a wrapper around gtk_assistant_set_page_type(). +func (v *Assistant) SetPageType(page IWidget, ptype AssistantPageType) { + C.gtk_assistant_set_page_type(v.native(), page.toWidget(), + C.GtkAssistantPageType(ptype)) +} + +// GetPageType is a wrapper around gtk_assistant_get_page_type(). +func (v *Assistant) GetPageType(page IWidget) AssistantPageType { + c := C.gtk_assistant_get_page_type(v.native(), page.toWidget()) + return AssistantPageType(c) +} + +// SetPageTitle is a wrapper around gtk_assistant_set_page_title(). +func (v *Assistant) SetPageTitle(page IWidget, title string) { + cstr := C.CString(title) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_assistant_set_page_title(v.native(), page.toWidget(), + (*C.gchar)(cstr)) +} + +// GetPageTitle is a wrapper around gtk_assistant_get_page_title(). +func (v *Assistant) GetPageTitle(page IWidget) string { + return goString(C.gtk_assistant_get_page_title(v.native(), page.toWidget())) +} + +// SetPageComplete is a wrapper around gtk_assistant_set_page_complete(). +func (v *Assistant) SetPageComplete(page IWidget, complete bool) { + C.gtk_assistant_set_page_complete(v.native(), page.toWidget(), + gbool(complete)) +} + +// GetPageComplete is a wrapper around gtk_assistant_get_page_complete(). +func (v *Assistant) GetPageComplete(page IWidget) bool { + c := C.gtk_assistant_get_page_complete(v.native(), page.toWidget()) + return gobool(c) +} + +// AddActionWidget is a wrapper around gtk_assistant_add_action_widget(). +func (v *Assistant) AddActionWidget(child IWidget) { + C.gtk_assistant_add_action_widget(v.native(), child.toWidget()) +} + +// RemoveActionWidget is a wrapper around gtk_assistant_remove_action_widget(). +func (v *Assistant) RemoveActionWidget(child IWidget) { + C.gtk_assistant_remove_action_widget(v.native(), child.toWidget()) +} + +// UpdateButtonsState is a wrapper around gtk_assistant_update_buttons_state(). +func (v *Assistant) UpdateButtonsState() { + C.gtk_assistant_update_buttons_state(v.native()) +} + +// Commit is a wrapper around gtk_assistant_commit(). +func (v *Assistant) Commit() { + C.gtk_assistant_commit(v.native()) +} + +// NextPage is a wrapper around gtk_assistant_next_page(). +func (v *Assistant) NextPage() { + C.gtk_assistant_next_page(v.native()) +} + +// PreviousPage is a wrapper around gtk_assistant_previous_page(). +func (v *Assistant) PreviousPage() { + C.gtk_assistant_previous_page(v.native()) +} + +/* + * GtkBin + */ + +// Bin is a representation of GTK's GtkBin. +type Bin struct { + Container +} + +// native returns a pointer to the underlying GtkBin. +func (v *Bin) native() *C.GtkBin { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkBin(p) +} + +func marshalBin(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapBin(obj), nil +} + +func wrapBin(obj *glib.Object) *Bin { + if obj == nil { + return nil + } + + return &Bin{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// GetChild is a wrapper around gtk_bin_get_child(). +func (v *Bin) GetChild() (IWidget, error) { + c := C.gtk_bin_get_child(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +/* + * GtkBuilder + */ + +// Builder is a representation of GTK's GtkBuilder. +type Builder struct { + *glib.Object +} + +// native() returns a pointer to the underlying GtkBuilder. +func (b *Builder) native() *C.GtkBuilder { + if b == nil || b.GObject == nil { + return nil + } + p := unsafe.Pointer(b.GObject) + return C.toGtkBuilder(p) +} + +func marshalBuilder(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return &Builder{obj}, nil +} + +// BuilderNew is a wrapper around gtk_builder_new(). +func BuilderNew() (*Builder, error) { + c := C.gtk_builder_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return &Builder{obj}, nil +} + +// AddFromFile is a wrapper around gtk_builder_add_from_file(). +func (b *Builder) AddFromFile(filename string) error { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + var err *C.GError = nil + res := C.gtk_builder_add_from_file(b.native(), (*C.gchar)(cstr), &err) + if res == 0 { + defer C.g_error_free(err) + return errors.New(goString(err.message)) + } + return nil +} + +// AddFromResource is a wrapper around gtk_builder_add_from_resource(). +func (b *Builder) AddFromResource(path string) error { + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + var err *C.GError = nil + res := C.gtk_builder_add_from_resource(b.native(), (*C.gchar)(cstr), &err) + if res == 0 { + defer C.g_error_free(err) + return errors.New(goString(err.message)) + } + return nil +} + +// AddFromString is a wrapper around gtk_builder_add_from_string(). +func (b *Builder) AddFromString(str string) error { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + length := (C.gsize)(len(str)) + var err *C.GError = nil + res := C.gtk_builder_add_from_string(b.native(), (*C.gchar)(cstr), length, &err) + if res == 0 { + defer C.g_error_free(err) + return errors.New(goString(err.message)) + } + return nil +} + +// GetObject is a wrapper around gtk_builder_get_object(). The returned result +// is an IObject, so it will need to be type-asserted to the appropriate type before +// being used. For example, to get an object and type assert it as a window: +// +// obj, err := builder.GetObject("window") +// if err != nil { +// // object not found +// return +// } +// if w, ok := obj.(*gtk.Window); ok { +// // do stuff with w here +// } else { +// // not a *gtk.Window +// } +// +func (b *Builder) GetObject(name string) (glib.IObject, error) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_builder_get_object(b.native(), (*C.gchar)(cstr)) + if c == nil { + return nil, errors.New("object '" + name + "' not found") + } + obj, err := cast(c) + if err != nil { + return nil, err + } + return obj, nil +} + +var ( + builderSignals = struct { + sync.RWMutex + m map[*C.GtkBuilder]map[string]interface{} + }{ + m: make(map[*C.GtkBuilder]map[string]interface{}), + } +) + +// ConnectSignals is a wrapper around gtk_builder_connect_signals_full(). +func (b *Builder) ConnectSignals(signals map[string]interface{}) { + builderSignals.Lock() + builderSignals.m[b.native()] = signals + builderSignals.Unlock() + + C._gtk_builder_connect_signals_full(b.native()) +} + +/* + * GtkBuildable + */ + +// TODO: +// GtkBuildableIface +// gtk_buildable_set_name(). +// gtk_buildable_get_name(). +// gtk_buildable_add_child(). +// gtk_buildable_set_buildable_property(). +// gtk_buildable_construct_child(). +// gtk_buildable_custom_tag_start(). +// gtk_buildable_custom_tag_end(). +// gtk_buildable_custom_finished(). +// gtk_buildable_parser_finished(). +// gtk_buildable_get_internal_child(). + +/* + * GtkButton + */ + +// Button is a representation of GTK's GtkButton. +type Button struct { + Bin + + // Interfaces + IActionable +} + +// native() returns a pointer to the underlying GtkButton. +func (v *Button) native() *C.GtkButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkButton(p) +} + +func marshalButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapButton(obj), nil +} + +func wrapButton(obj *glib.Object) *Button { + if obj == nil { + return nil + } + + actionable := &Actionable{obj} + return &Button{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}, actionable} +} + +// ButtonNew() is a wrapper around gtk_button_new(). +func ButtonNew() (*Button, error) { + c := C.gtk_button_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapButton(obj), nil +} + +// ButtonNewWithLabel() is a wrapper around gtk_button_new_with_label(). +func ButtonNewWithLabel(label string) (*Button, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_button_new_with_label((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapButton(obj), nil +} + +// ButtonNewWithMnemonic() is a wrapper around gtk_button_new_with_mnemonic(). +func ButtonNewWithMnemonic(label string) (*Button, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_button_new_with_mnemonic((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapButton(obj), nil +} + +// Clicked() is a wrapper around gtk_button_clicked(). +func (v *Button) Clicked() { + C.gtk_button_clicked(v.native()) +} + +// SetRelief() is a wrapper around gtk_button_set_relief(). +func (v *Button) SetRelief(newStyle ReliefStyle) { + C.gtk_button_set_relief(v.native(), C.GtkReliefStyle(newStyle)) +} + +// GetRelief() is a wrapper around gtk_button_get_relief(). +func (v *Button) GetRelief() ReliefStyle { + c := C.gtk_button_get_relief(v.native()) + return ReliefStyle(c) +} + +// SetLabel() is a wrapper around gtk_button_set_label(). +func (v *Button) SetLabel(label string) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_button_set_label(v.native(), (*C.gchar)(cstr)) +} + +// GetLabel() is a wrapper around gtk_button_get_label(). +func (v *Button) GetLabel() (string, error) { + c := C.gtk_button_get_label(v.native()) + if c == nil { + return "", nilPtrErr + } + return goString(c), nil +} + +// SetUseUnderline() is a wrapper around gtk_button_set_use_underline(). +func (v *Button) SetUseUnderline(useUnderline bool) { + C.gtk_button_set_use_underline(v.native(), gbool(useUnderline)) +} + +// GetUseUnderline() is a wrapper around gtk_button_get_use_underline(). +func (v *Button) GetUseUnderline() bool { + c := C.gtk_button_get_use_underline(v.native()) + return gobool(c) +} + +// SetImage() is a wrapper around gtk_button_set_image(). +func (v *Button) SetImage(image IWidget) { + C.gtk_button_set_image(v.native(), image.toWidget()) +} + +// GetImage() is a wrapper around gtk_button_get_image(). +func (v *Button) GetImage() (IWidget, error) { + c := C.gtk_button_get_image(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// SetImagePosition() is a wrapper around gtk_button_set_image_position(). +func (v *Button) SetImagePosition(position PositionType) { + C.gtk_button_set_image_position(v.native(), C.GtkPositionType(position)) +} + +// GetImagePosition() is a wrapper around gtk_button_get_image_position(). +func (v *Button) GetImagePosition() PositionType { + c := C.gtk_button_get_image_position(v.native()) + return PositionType(c) +} + +// SetAlwaysShowImage() is a wrapper around gtk_button_set_always_show_image(). +func (v *Button) SetAlwaysShowImage(alwaysShow bool) { + C.gtk_button_set_always_show_image(v.native(), gbool(alwaysShow)) +} + +// GetAlwaysShowImage() is a wrapper around gtk_button_get_always_show_image(). +func (v *Button) GetAlwaysShowImage() bool { + c := C.gtk_button_get_always_show_image(v.native()) + return gobool(c) +} + +// GetEventWindow() is a wrapper around gtk_button_get_event_window(). +func (v *Button) GetEventWindow() (*gdk.Window, error) { + c := C.gtk_button_get_event_window(v.native()) + if c == nil { + return nil, nilPtrErr + } + + w := &gdk.Window{glib.Take(unsafe.Pointer(c))} + return w, nil +} + +/* + * GtkColorButton + */ + +// ColorButton is a representation of GTK's GtkColorButton. +type ColorButton struct { + Button + + // Interfaces + ColorChooser +} + +// Native returns a pointer to the underlying GtkColorButton. +func (v *ColorButton) native() *C.GtkColorButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkColorButton(p) +} + +func wrapColorButton(obj *glib.Object) *ColorButton { + if obj == nil { + return nil + } + + cc := wrapColorChooser(obj) + actionable := wrapActionable(obj) + return &ColorButton{Button{Bin{Container{Widget{ + glib.InitiallyUnowned{obj}}}}, actionable}, *cc} +} + +// ColorButtonNew is a wrapper around gtk_color_button_new(). +func ColorButtonNew() (*ColorButton, error) { + c := C.gtk_color_button_new() + if c == nil { + return nil, nilPtrErr + } + return wrapColorButton(glib.Take(unsafe.Pointer(c))), nil +} + +// ColorButtonNewWithRGBA is a wrapper around gtk_color_button_new_with_rgba(). +func ColorButtonNewWithRGBA(gdkColor *gdk.RGBA) (*ColorButton, error) { + c := C.gtk_color_button_new_with_rgba((*C.GdkRGBA)(unsafe.Pointer(gdkColor.Native()))) + if c == nil { + return nil, nilPtrErr + } + return wrapColorButton(glib.Take(unsafe.Pointer(c))), nil +} + +// SetTitle is a wrapper around gtk_color_button_set_title(). +func (v *ColorButton) SetTitle(title string) { + cstr := C.CString(title) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_color_button_set_title(v.native(), (*C.gchar)(cstr)) +} + +// GetTitle is a wrapper around gtk_color_button_get_title(). +func (v *ColorButton) GetTitle() string { + c := C.gtk_color_button_get_title(v.native()) + defer C.free(unsafe.Pointer(c)) + return goString(c) +} + +/* + * GtkBox + */ + +// Box is a representation of GTK's GtkBox. +type Box struct { + Container +} + +// native() returns a pointer to the underlying GtkBox. +func (v *Box) native() *C.GtkBox { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkBox(p) +} + +func marshalBox(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapBox(obj), nil +} + +func wrapBox(obj *glib.Object) *Box { + if obj == nil { + return nil + } + + return &Box{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +func (v *Box) toOrientable() *C.GtkOrientable { + if v == nil { + return nil + } + return C.toGtkOrientable(unsafe.Pointer(v.GObject)) +} + +// GetOrientation() is a wrapper around C.gtk_orientable_get_orientation() for a GtkBox +func (v *Box) GetOrientation() Orientation { + return Orientation(C.gtk_orientable_get_orientation(v.toOrientable())) +} + +// SetOrientation() is a wrapper around C.gtk_orientable_set_orientation() for a GtkBox +func (v *Box) SetOrientation(o Orientation) { + C.gtk_orientable_set_orientation(v.toOrientable(), C.GtkOrientation(o)) +} + +// BoxNew() is a wrapper around gtk_box_new(). +func BoxNew(orientation Orientation, spacing int) (*Box, error) { + c := C.gtk_box_new(C.GtkOrientation(orientation), C.gint(spacing)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapBox(obj), nil +} + +// PackStart() is a wrapper around gtk_box_pack_start(). +func (v *Box) PackStart(child IWidget, expand, fill bool, padding uint) { + C.gtk_box_pack_start(v.native(), child.toWidget(), gbool(expand), + gbool(fill), C.guint(padding)) +} + +// PackEnd() is a wrapper around gtk_box_pack_end(). +func (v *Box) PackEnd(child IWidget, expand, fill bool, padding uint) { + C.gtk_box_pack_end(v.native(), child.toWidget(), gbool(expand), + gbool(fill), C.guint(padding)) +} + +// GetHomogeneous() is a wrapper around gtk_box_get_homogeneous(). +func (v *Box) GetHomogeneous() bool { + c := C.gtk_box_get_homogeneous(v.native()) + return gobool(c) +} + +// SetHomogeneous() is a wrapper around gtk_box_set_homogeneous(). +func (v *Box) SetHomogeneous(homogeneous bool) { + C.gtk_box_set_homogeneous(v.native(), gbool(homogeneous)) +} + +// GetSpacing() is a wrapper around gtk_box_get_spacing(). +func (v *Box) GetSpacing() int { + c := C.gtk_box_get_spacing(v.native()) + return int(c) +} + +// SetSpacing() is a wrapper around gtk_box_set_spacing() +func (v *Box) SetSpacing(spacing int) { + C.gtk_box_set_spacing(v.native(), C.gint(spacing)) +} + +// ReorderChild() is a wrapper around gtk_box_reorder_child(). +func (v *Box) ReorderChild(child IWidget, position int) { + C.gtk_box_reorder_child(v.native(), child.toWidget(), C.gint(position)) +} + +// QueryChildPacking() is a wrapper around gtk_box_query_child_packing(). +func (v *Box) QueryChildPacking(child IWidget) (expand, fill bool, padding uint, packType PackType) { + var cexpand, cfill C.gboolean + var cpadding C.guint + var cpackType C.GtkPackType + + C.gtk_box_query_child_packing(v.native(), child.toWidget(), &cexpand, + &cfill, &cpadding, &cpackType) + return gobool(cexpand), gobool(cfill), uint(cpadding), PackType(cpackType) +} + +// SetChildPacking() is a wrapper around gtk_box_set_child_packing(). +func (v *Box) SetChildPacking(child IWidget, expand, fill bool, padding uint, packType PackType) { + C.gtk_box_set_child_packing(v.native(), child.toWidget(), gbool(expand), + gbool(fill), C.guint(padding), C.GtkPackType(packType)) +} + +/* + * GtkCalendar + */ + +// Calendar is a representation of GTK's GtkCalendar. +type Calendar struct { + Widget +} + +// native() returns a pointer to the underlying GtkCalendar. +func (v *Calendar) native() *C.GtkCalendar { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCalendar(p) +} + +func marshalCalendar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCalendar(obj), nil +} + +func wrapCalendar(obj *glib.Object) *Calendar { + if obj == nil { + return nil + } + + return &Calendar{Widget{glib.InitiallyUnowned{obj}}} +} + +// TODO: +// GtkCalendarDetailFunc + +// CalendarNew is a wrapper around gtk_calendar_new(). +func CalendarNew() (*Calendar, error) { + c := C.gtk_calendar_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCalendar(obj), nil +} + +// SelectMonth is a wrapper around gtk_calendar_select_month(). +func (v *Calendar) SelectMonth(month, year uint) { + C.gtk_calendar_select_month(v.native(), C.guint(month), C.guint(year)) +} + +// SelectDay is a wrapper around gtk_calendar_select_day(). +func (v *Calendar) SelectDay(day uint) { + C.gtk_calendar_select_day(v.native(), C.guint(day)) +} + +// MarkDay is a wrapper around gtk_calendar_mark_day(). +func (v *Calendar) MarkDay(day uint) { + C.gtk_calendar_mark_day(v.native(), C.guint(day)) +} + +// UnmarkDay is a wrapper around gtk_calendar_unmark_day(). +func (v *Calendar) UnmarkDay(day uint) { + C.gtk_calendar_unmark_day(v.native(), C.guint(day)) +} + +// GetDayIsMarked is a wrapper around gtk_calendar_get_day_is_marked(). +func (v *Calendar) GetDayIsMarked(day uint) bool { + c := C.gtk_calendar_get_day_is_marked(v.native(), C.guint(day)) + return gobool(c) +} + +// ClearMarks is a wrapper around gtk_calendar_clear_marks(). +func (v *Calendar) ClearMarks() { + C.gtk_calendar_clear_marks(v.native()) +} + +// GetDisplayOptions is a wrapper around gtk_calendar_get_display_options(). +func (v *Calendar) GetDisplayOptions() CalendarDisplayOptions { + c := C.gtk_calendar_get_display_options(v.native()) + return CalendarDisplayOptions(c) +} + +// SetDisplayOptions is a wrapper around gtk_calendar_set_display_options(). +func (v *Calendar) SetDisplayOptions(flags CalendarDisplayOptions) { + C.gtk_calendar_set_display_options(v.native(), + C.GtkCalendarDisplayOptions(flags)) +} + +// GetDate is a wrapper around gtk_calendar_get_date(). +func (v *Calendar) GetDate() (year, month, day uint) { + var cyear, cmonth, cday C.guint + C.gtk_calendar_get_date(v.native(), &cyear, &cmonth, &cday) + return uint(cyear), uint(cmonth), uint(cday) +} + +// TODO: +// gtk_calendar_set_detail_func(). + +// GetDetailWidthChars is a wrapper around gtk_calendar_get_detail_width_chars(). +func (v *Calendar) GetDetailWidthChars() int { + c := C.gtk_calendar_get_detail_width_chars(v.native()) + return int(c) +} + +// SetDetailWidthChars is a wrapper around gtk_calendar_set_detail_width_chars(). +func (v *Calendar) SetDetailWidthChars(chars int) { + C.gtk_calendar_set_detail_width_chars(v.native(), C.gint(chars)) +} + +// GetDetailHeightRows is a wrapper around gtk_calendar_get_detail_height_rows(). +func (v *Calendar) GetDetailHeightRows() int { + c := C.gtk_calendar_get_detail_height_rows(v.native()) + return int(c) +} + +// SetDetailHeightRows is a wrapper around gtk_calendar_set_detail_height_rows(). +func (v *Calendar) SetDetailHeightRows(rows int) { + C.gtk_calendar_set_detail_height_rows(v.native(), C.gint(rows)) +} + +/* + * GtkCellLayout + */ + +// CellLayout is a representation of GTK's GtkCellLayout GInterface. +type CellLayout struct { + *glib.Object +} + +// ICellLayout is an interface type implemented by all structs +// embedding a CellLayout. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkCellLayout. +type ICellLayout interface { + toCellLayout() *C.GtkCellLayout +} + +// native() returns a pointer to the underlying GObject as a GtkCellLayout. +func (v *CellLayout) native() *C.GtkCellLayout { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellLayout(p) +} + +func marshalCellLayout(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellLayout(obj), nil +} + +func wrapCellLayout(obj *glib.Object) *CellLayout { + if obj == nil { + return nil + } + + return &CellLayout{obj} +} + +func (v *CellLayout) toCellLayout() *C.GtkCellLayout { + if v == nil { + return nil + } + return v.native() +} + +// PackStart is a wrapper around gtk_cell_layout_pack_start(). +func (v *CellLayout) PackStart(cell ICellRenderer, expand bool) { + C.gtk_cell_layout_pack_start(v.native(), cell.toCellRenderer(), + gbool(expand)) +} + +// AddAttribute is a wrapper around gtk_cell_layout_add_attribute(). +func (v *CellLayout) AddAttribute(cell ICellRenderer, attribute string, column int) { + cstr := C.CString(attribute) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_cell_layout_add_attribute(v.native(), cell.toCellRenderer(), + (*C.gchar)(cstr), C.gint(column)) +} + +// ClearAttributes is a wrapper around gtk_cell_layout_clear_attributes() +func (v *CellLayout) ClearAttributes(cell ICellRenderer) { + C.gtk_cell_layout_clear_attributes(v.native(), cell.toCellRenderer()) +} + +/* + * GtkCellView + */ + +// TODO: +// GtkCellView +// gtk_cell_view_new(). +// gtk_cell_view_new_with_context(). +// gtk_cell_view_new_with_text(). +// gtk_cell_view_new_with_markup(). +// gtk_cell_view_new_with_pixbuf(). +// gtk_cell_view_set_model(). +// gtk_cell_view_get_model(). +// gtk_cell_view_set_displayed_row(). +// gtk_cell_view_get_displayed_row(). +// gtk_cell_view_set_background_rgba(). +// gtk_cell_view_set_draw_sensitive(). +// gtk_cell_view_get_draw_sensitive(). +// gtk_cell_view_set_fit_model(). +// gtk_cell_view_get_fit_model(). + +/* + * GtkCellEditable + */ + +// CellEditable is a representation of GTK's GtkCellEditable GInterface. +type CellEditable struct { + glib.InitiallyUnowned + // Widget +} + +// ICellEditable is an interface type implemented by all structs +// embedding an CellEditable. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkCellEditable. +type ICellEditable interface { + toCellEditable() *C.GtkCellEditable + ToEntry() *Entry +} + +// native() returns a pointer to the underlying GObject as a GtkCellEditable. +func (v *CellEditable) native() *C.GtkCellEditable { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellEditable(p) +} + +func marshalCellEditable(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellEditable(obj), nil +} + +func wrapCellEditable(obj *glib.Object) *CellEditable { + if obj == nil { + return nil + } + + // return &CellEditable{Widget{glib.InitiallyUnowned{obj}}} + return &CellEditable{glib.InitiallyUnowned{obj}} +} + +func (v *CellEditable) toCellEditable() *C.GtkCellEditable { + if v == nil { + return nil + } + return v.native() +} + +// ToEntry is a helper tool, e.g: it returns *gtk.CellEditable as a *gtk.Entry +// that embedding this CellEditable instance, then it can be used with +// CellRendererText to adding EntryCompletion tools or intercepting EntryBuffer, +// (to bypass "canceled" signal for example) then record entry, and much more. +func (v *CellEditable) ToEntry() *Entry { + return &Entry{Widget{glib.InitiallyUnowned{v.Object}}, + Editable{v.Object}, + *v} +} + +// StartEditing is a wrapper around gtk_cell_editable_start_editing(). +func (v *CellEditable) StartEditing(event *gdk.Event) { + C.gtk_cell_editable_start_editing(v.native(), + (*C.GdkEvent)(unsafe.Pointer(event.Native()))) +} + +// EditingDone is a wrapper around gtk_cell_editable_editing_done(). +func (v *CellEditable) EditingDone() { + C.gtk_cell_editable_editing_done(v.native()) +} + +// RemoveWidget is a wrapper around gtk_cell_editable_remove_widget(). +func (v *CellEditable) RemoveWidget() { + C.gtk_cell_editable_remove_widget(v.native()) +} + +/* + * GtkCellRenderer + */ + +// CellRenderer is a representation of GTK's GtkCellRenderer. +type CellRenderer struct { + glib.InitiallyUnowned +} + +// ICellRenderer is an interface type implemented by all structs +// embedding a CellRenderer. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkCellRenderer. +type ICellRenderer interface { + toCellRenderer() *C.GtkCellRenderer +} + +// native returns a pointer to the underlying GtkCellRenderer. +func (v *CellRenderer) native() *C.GtkCellRenderer { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellRenderer(p) +} + +func (v *CellRenderer) toCellRenderer() *C.GtkCellRenderer { + if v == nil { + return nil + } + return v.native() +} + +func marshalCellRenderer(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRenderer(obj), nil +} + +func wrapCellRenderer(obj *glib.Object) *CellRenderer { + if obj == nil { + return nil + } + + return &CellRenderer{glib.InitiallyUnowned{obj}} +} + +// Activate is a wrapper around gtk_cell_renderer_activate(). +func (v *CellRenderer) Activate(event *gdk.Event, widget IWidget, path string, + backgroundArea, cellArea *gdk.Rectangle, flags CellRendererState) bool { + + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + e := (*C.GdkEvent)(unsafe.Pointer(event.Native())) + + c := C.gtk_cell_renderer_activate(v.native(), e, widget.toWidget(), + (*C.gchar)(cstr), nativeGdkRectangle(*backgroundArea), + nativeGdkRectangle(*cellArea), C.GtkCellRendererState(flags)) + + return gobool(c) +} + +// StartEditing is a wrapper around gtk_cell_renderer_start_editing(). +func (v *CellRenderer) StartEditing(event *gdk.Event, widget IWidget, path string, + backgroundArea, cellArea *gdk.Rectangle, flags CellRendererState) (ICellEditable, error) { + + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + e := (*C.GdkEvent)(unsafe.Pointer(event.Native())) + + c := C.gtk_cell_renderer_start_editing(v.native(), e, widget.toWidget(), + (*C.gchar)(cstr), nativeGdkRectangle(*backgroundArea), + nativeGdkRectangle(*cellArea), C.GtkCellRendererState(flags)) + + return castCellEditable(c) +} + +// StopEditing is a wrapper around gtk_cell_renderer_stop_editing(). +func (v *CellRenderer) StopEditing(canceled bool) { + C.gtk_cell_renderer_stop_editing(v.native(), gbool(canceled)) +} + +// GetVisible is a wrapper around gtk_cell_renderer_get_visible(). +func (v *CellRenderer) GetVisible() bool { + return gobool(C.gtk_cell_renderer_get_visible(v.native())) +} + +// SetVisible is a wrapper around gtk_cell_renderer_set_visible(). +func (v *CellRenderer) SetVisible(visible bool) { + C.gtk_cell_renderer_set_visible(v.native(), gbool(visible)) +} + +// GetSensitive is a wrapper around gtk_cell_renderer_get_sensitive(). +func (v *CellRenderer) GetSensitive() bool { + return gobool(C.gtk_cell_renderer_get_sensitive(v.native())) +} + +// SetSentitive is a wrapper around gtk_cell_renderer_set_sensitive(). +func (v *CellRenderer) SetSentitive(sensitive bool) { + C.gtk_cell_renderer_set_sensitive(v.native(), gbool(sensitive)) +} + +// IsActivatable is a wrapper around gtk_cell_renderer_is_activatable(). +func (v *CellRenderer) IsActivatable() bool { + return gobool(C.gtk_cell_renderer_is_activatable(v.native())) +} + +// GetState is a wrapper around gtk_cell_renderer_get_state(). +func (v *CellRenderer) GetState(widget IWidget, + flags CellRendererState) StateFlags { + + return StateFlags(C.gtk_cell_renderer_get_state(v.native(), + widget.toWidget(), + C.GtkCellRendererState(flags))) +} + +// SetAlignment is a wrapper around gtk_tree_view_column_set_alignment(). +func (v *CellRenderer) SetAlignment(xalign float64, yalign float64) { + C.gtk_cell_renderer_set_alignment(v.native(), C.gfloat(xalign), C.gfloat(yalign)) +} + +// TODO: gtk_cell_renderer_get_aligned_area +// TODO: gtk_cell_renderer_get_size +// TODO: gtk_cell_renderer_render +// TODO: gtk_cell_renderer_activate +// TODO: gtk_cell_renderer_start_editing +// TODO: gtk_cell_renderer_stop_editing +// TODO: gtk_cell_renderer_get_fixed_size +// TODO: gtk_cell_renderer_set_fixed_size +// TODO: gtk_cell_renderer_get_visible +// TODO: gtk_cell_renderer_set_visible +// TODO: gtk_cell_renderer_get_sensitive +// TODO: gtk_cell_renderer_set_sensitive +// TODO: gtk_cell_renderer_get_alignment +// TODO: gtk_cell_renderer_set_alignment +// TODO: gtk_cell_renderer_get_padding +// TODO: gtk_cell_renderer_set_padding +// TODO: gtk_cell_renderer_get_state +// TODO: gtk_cell_renderer_is_activatable +// TODO: gtk_cell_renderer_get_preferred_height +// TODO: gtk_cell_renderer_get_preferred_height_for_width +// TODO: gtk_cell_renderer_get_preferred_size +// TODO: gtk_cell_renderer_get_preferred_width +// TODO: gtk_cell_renderer_get_preferred_width_for_height +// TODO: gtk_cell_renderer_get_request_mode + +/* + * GtkCellRendererSpinner + */ + +// CellRendererSpinner is a representation of GTK's GtkCellRendererSpinner. +type CellRendererSpinner struct { + CellRenderer +} + +// native returns a pointer to the underlying GtkCellRendererSpinner. +func (v *CellRendererSpinner) native() *C.GtkCellRendererSpinner { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellRendererSpinner(p) +} + +func marshalCellRendererSpinner(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererSpinner(obj), nil +} + +func wrapCellRendererSpinner(obj *glib.Object) *CellRendererSpinner { + if obj == nil { + return nil + } + + return &CellRendererSpinner{CellRenderer{glib.InitiallyUnowned{obj}}} +} + +// CellRendererSpinnerNew is a wrapper around gtk_cell_renderer_spinner_new(). +func CellRendererSpinnerNew() (*CellRendererSpinner, error) { + c := C.gtk_cell_renderer_spinner_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererSpinner(obj), nil +} + +/* + * GtkCellRendererPixbuf + */ + +// CellRendererPixbuf is a representation of GTK's GtkCellRendererPixbuf. +type CellRendererPixbuf struct { + CellRenderer +} + +// native returns a pointer to the underlying GtkCellRendererPixbuf. +func (v *CellRendererPixbuf) native() *C.GtkCellRendererPixbuf { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellRendererPixbuf(p) +} + +func marshalCellRendererPixbuf(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererPixbuf(obj), nil +} + +func wrapCellRendererPixbuf(obj *glib.Object) *CellRendererPixbuf { + if obj == nil { + return nil + } + + return &CellRendererPixbuf{CellRenderer{glib.InitiallyUnowned{obj}}} +} + +// CellRendererPixbufNew is a wrapper around gtk_cell_renderer_pixbuf_new(). +func CellRendererPixbufNew() (*CellRendererPixbuf, error) { + c := C.gtk_cell_renderer_pixbuf_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererPixbuf(obj), nil +} + +/* + * GtkCellRendererProgress + */ + +// CellRendererProgress is a representation of GTK's GtkCellRendererProgress. +type CellRendererProgress struct { + CellRenderer +} + +// native returns a pointer to the underlying GtkCellRendererProgress. +func (v *CellRendererProgress) native() *C.GtkCellRendererProgress { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellRendererProgress(p) +} + +func marshalCellRendererProgress(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererProgress(obj), nil +} + +func wrapCellRendererProgress(obj *glib.Object) *CellRendererProgress { + if obj == nil { + return nil + } + + return &CellRendererProgress{CellRenderer{glib.InitiallyUnowned{obj}}} +} + +// CellRendererProgressNew is a wrapper around gtk_cell_renderer_progress_new(). +func CellRendererProgressNew() (*CellRendererProgress, error) { + c := C.gtk_cell_renderer_progress_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererProgress(obj), nil +} + +/* + * GtkCellRendererText + */ + +// CellRendererText is a representation of GTK's GtkCellRendererText. +type CellRendererText struct { + CellRenderer +} + +// native returns a pointer to the underlying GtkCellRendererText. +func (v *CellRendererText) native() *C.GtkCellRendererText { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellRendererText(p) +} + +func marshalCellRendererText(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererText(obj), nil +} + +func wrapCellRendererText(obj *glib.Object) *CellRendererText { + if obj == nil { + return nil + } + + return &CellRendererText{CellRenderer{glib.InitiallyUnowned{obj}}} +} + +// CellRendererTextNew is a wrapper around gtk_cell_renderer_text_new(). +func CellRendererTextNew() (*CellRendererText, error) { + c := C.gtk_cell_renderer_text_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererText(obj), nil +} + +// SetFixedHeightFromFont is a wrapper around gtk_cell_renderer_text_set_fixed_height_from_font +func (v *CellRendererText) SetFixedHeightFromFont(numberOfRows int) { + C.gtk_cell_renderer_text_set_fixed_height_from_font(v.native(), C.gint(numberOfRows)) +} + +/* + * GtkCellRendererToggle + */ + +// CellRendererToggle is a representation of GTK's GtkCellRendererToggle. +type CellRendererToggle struct { + CellRenderer +} + +// native returns a pointer to the underlying GtkCellRendererToggle. +func (v *CellRendererToggle) native() *C.GtkCellRendererToggle { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellRendererToggle(p) +} + +func (v *CellRendererToggle) toCellRenderer() *C.GtkCellRenderer { + if v == nil { + return nil + } + return v.CellRenderer.native() +} + +func marshalCellRendererToggle(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererToggle(obj), nil +} + +func wrapCellRendererToggle(obj *glib.Object) *CellRendererToggle { + if obj == nil { + return nil + } + + return &CellRendererToggle{CellRenderer{glib.InitiallyUnowned{obj}}} +} + +// CellRendererToggleNew is a wrapper around gtk_cell_renderer_toggle_new(). +func CellRendererToggleNew() (*CellRendererToggle, error) { + c := C.gtk_cell_renderer_toggle_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererToggle(obj), nil +} + +// SetRadio is a wrapper around gtk_cell_renderer_toggle_set_radio(). +func (v *CellRendererToggle) SetRadio(set bool) { + C.gtk_cell_renderer_toggle_set_radio(v.native(), gbool(set)) +} + +// GetRadio is a wrapper around gtk_cell_renderer_toggle_get_radio(). +func (v *CellRendererToggle) GetRadio() bool { + c := C.gtk_cell_renderer_toggle_get_radio(v.native()) + return gobool(c) +} + +// SetActive is a wrapper around gtk_cell_renderer_toggle_set_active(). +func (v *CellRendererToggle) SetActive(active bool) { + C.gtk_cell_renderer_toggle_set_active(v.native(), gbool(active)) +} + +// GetActive is a wrapper around gtk_cell_renderer_toggle_get_active(). +func (v *CellRendererToggle) GetActive() bool { + c := C.gtk_cell_renderer_toggle_get_active(v.native()) + return gobool(c) +} + +// SetActivatable is a wrapper around gtk_cell_renderer_toggle_set_activatable(). +func (v *CellRendererToggle) SetActivatable(activatable bool) { + C.gtk_cell_renderer_toggle_set_activatable(v.native(), + gbool(activatable)) +} + +// GetActivatable is a wrapper around gtk_cell_renderer_toggle_get_activatable(). +func (v *CellRendererToggle) GetActivatable() bool { + c := C.gtk_cell_renderer_toggle_get_activatable(v.native()) + return gobool(c) +} + +/* + * GtkCellRendererAccel + */ + +// CellRendererAccel is a representation of GtkCellRendererAccel. +type CellRendererAccel struct { + CellRendererText +} + +// native returns a pointer to the underlying GtkCellRendererAccel. +func (v *CellRendererAccel) native() *C.GtkCellRendererAccel { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellRendererAccel(p) +} + +func marshalCellRendererAccel(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererAccel(obj), nil +} + +func wrapCellRendererAccel(obj *glib.Object) *CellRendererAccel { + if obj == nil { + return nil + } + + return &CellRendererAccel{CellRendererText{CellRenderer{glib.InitiallyUnowned{obj}}}} +} + +// CellRendererAccelNew is a wrapper around gtk_cell_renderer_accel_new(). +func CellRendererAccelNew() (*CellRendererAccel, error) { + c := C.gtk_cell_renderer_accel_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererAccel(obj), nil +} + +/* + * GtkCellRendererCombo + */ + +// CellRendererCombo is a representation of GtkCellRendererCombo. +type CellRendererCombo struct { + CellRendererText +} + +// native returns a pointer to the underlying GtkCellRendererCombo. +func (v *CellRendererCombo) native() *C.GtkCellRendererCombo { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellRendererCombo(p) +} + +func marshalCellRendererCombo(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererCombo(obj), nil +} + +func wrapCellRendererCombo(obj *glib.Object) *CellRendererCombo { + if obj == nil { + return nil + } + + return &CellRendererCombo{CellRendererText{CellRenderer{glib.InitiallyUnowned{obj}}}} +} + +// CellRendererComboNew is a wrapper around gtk_cell_renderer_combo_new(). +func CellRendererComboNew() (*CellRendererCombo, error) { + c := C.gtk_cell_renderer_combo_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererCombo(obj), nil +} + +/* + * GtkCellRendererSpin + */ + +// CellRendererSpin is a representation of GtkCellRendererSpin. +type CellRendererSpin struct { + CellRendererText +} + +// native returns a pointer to the underlying GtkCellRendererSpin. +func (v *CellRendererSpin) native() *C.GtkCellRendererSpin { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCellRendererSpin(p) +} + +func marshalCellRendererSpin(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererSpin(obj), nil +} + +func wrapCellRendererSpin(obj *glib.Object) *CellRendererSpin { + if obj == nil { + return nil + } + + return &CellRendererSpin{CellRendererText{CellRenderer{glib.InitiallyUnowned{obj}}}} +} + +// CellRendererSpinNew is a wrapper around gtk_cell_renderer_spin_new(). +func CellRendererSpinNew() (*CellRendererSpin, error) { + c := C.gtk_cell_renderer_spin_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCellRendererSpin(obj), nil +} + +/* + * GtkCheckButton + */ + +// CheckButton is a wrapper around GTK's GtkCheckButton. +type CheckButton struct { + ToggleButton +} + +// native returns a pointer to the underlying GtkCheckButton. +func (v *CheckButton) native() *C.GtkCheckButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCheckButton(p) +} + +func marshalCheckButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCheckButton(obj), nil +} + +func wrapCheckButton(obj *glib.Object) *CheckButton { + if obj == nil { + return nil + } + + actionable := wrapActionable(obj) + return &CheckButton{ToggleButton{Button{Bin{Container{Widget{ + glib.InitiallyUnowned{obj}}}}, actionable}}} +} + +// CheckButtonNew is a wrapper around gtk_check_button_new(). +func CheckButtonNew() (*CheckButton, error) { + c := C.gtk_check_button_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCheckButton(obj), nil +} + +// CheckButtonNewWithLabel is a wrapper around +// gtk_check_button_new_with_label(). +func CheckButtonNewWithLabel(label string) (*CheckButton, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_check_button_new_with_label((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapCheckButton(glib.Take(unsafe.Pointer(c))), nil +} + +// CheckButtonNewWithMnemonic is a wrapper around +// gtk_check_button_new_with_mnemonic(). +func CheckButtonNewWithMnemonic(label string) (*CheckButton, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_check_button_new_with_mnemonic((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCheckButton(obj), nil +} + +/* + * GtkCheckMenuItem + */ + +type CheckMenuItem struct { + MenuItem +} + +// native returns a pointer to the underlying GtkCheckMenuItem. +func (v *CheckMenuItem) native() *C.GtkCheckMenuItem { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCheckMenuItem(p) +} + +func marshalCheckMenuItem(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapCheckMenuItem(obj), nil +} + +func wrapCheckMenuItem(obj *glib.Object) *CheckMenuItem { + if obj == nil { + return nil + } + + return &CheckMenuItem{MenuItem{Bin{Container{Widget{ + glib.InitiallyUnowned{obj}}}}}} +} + +// CheckMenuItemNew is a wrapper around gtk_check_menu_item_new(). +func CheckMenuItemNew() (*CheckMenuItem, error) { + c := C.gtk_check_menu_item_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCheckMenuItem(obj), nil +} + +// CheckMenuItemNewWithLabel is a wrapper around gtk_check_menu_item_new_with_label(). +func CheckMenuItemNewWithLabel(label string) (*CheckMenuItem, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_check_menu_item_new_with_label((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCheckMenuItem(obj), nil +} + +// CheckMenuItemNewWithMnemonic is a wrapper around gtk_check_menu_item_new_with_mnemonic(). +func CheckMenuItemNewWithMnemonic(label string) (*CheckMenuItem, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_check_menu_item_new_with_mnemonic((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCheckMenuItem(obj), nil +} + +// GetActive is a wrapper around gtk_check_menu_item_get_active(). +func (v *CheckMenuItem) GetActive() bool { + c := C.gtk_check_menu_item_get_active(v.native()) + return gobool(c) +} + +// SetActive is a wrapper around gtk_check_menu_item_set_active(). +func (v *CheckMenuItem) SetActive(isActive bool) { + C.gtk_check_menu_item_set_active(v.native(), gbool(isActive)) +} + +// Toggled is a wrapper around gtk_check_menu_item_toggled(). +func (v *CheckMenuItem) Toggled() { + C.gtk_check_menu_item_toggled(v.native()) +} + +// GetInconsistent is a wrapper around gtk_check_menu_item_get_inconsistent(). +func (v *CheckMenuItem) GetInconsistent() bool { + c := C.gtk_check_menu_item_get_inconsistent(v.native()) + return gobool(c) +} + +// SetInconsistent is a wrapper around gtk_check_menu_item_set_inconsistent(). +func (v *CheckMenuItem) SetInconsistent(setting bool) { + C.gtk_check_menu_item_set_inconsistent(v.native(), gbool(setting)) +} + +// SetDrawAsRadio is a wrapper around gtk_check_menu_item_set_draw_as_radio(). +func (v *CheckMenuItem) SetDrawAsRadio(drawAsRadio bool) { + C.gtk_check_menu_item_set_draw_as_radio(v.native(), gbool(drawAsRadio)) +} + +// GetDrawAsRadio is a wrapper around gtk_check_menu_item_get_draw_as_radio(). +func (v *CheckMenuItem) GetDrawAsRadio() bool { + c := C.gtk_check_menu_item_get_draw_as_radio(v.native()) + return gobool(c) +} + +/* + * GtkClipboard + */ + +// Clipboard is a wrapper around GTK's GtkClipboard. +type Clipboard struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkClipboard. +func (v *Clipboard) native() *C.GtkClipboard { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkClipboard(p) +} + +func marshalClipboard(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapClipboard(obj), nil +} + +func wrapClipboard(obj *glib.Object) *Clipboard { + if obj == nil { + return nil + } + + return &Clipboard{obj} +} + +// Store is a wrapper around gtk_clipboard_store +func (v *Clipboard) Store() { + C.gtk_clipboard_store(v.native()) +} + +// ClipboardGet() is a wrapper around gtk_clipboard_get(). +func ClipboardGet(atom gdk.Atom) (*Clipboard, error) { + c := C.gtk_clipboard_get(C.GdkAtom(unsafe.Pointer(atom))) + if c == nil { + return nil, nilPtrErr + } + + cb := &Clipboard{glib.Take(unsafe.Pointer(c))} + return cb, nil +} + +// ClipboardGetForDisplay() is a wrapper around gtk_clipboard_get_for_display(). +func ClipboardGetForDisplay(display *gdk.Display, atom gdk.Atom) (*Clipboard, error) { + displayPtr := (*C.GdkDisplay)(unsafe.Pointer(display.Native())) + c := C.gtk_clipboard_get_for_display(displayPtr, + C.GdkAtom(unsafe.Pointer(atom))) + if c == nil { + return nil, nilPtrErr + } + + cb := &Clipboard{glib.Take(unsafe.Pointer(c))} + return cb, nil +} + +// WaitIsTextAvailable is a wrapper around gtk_clipboard_wait_is_text_available +func (v *Clipboard) WaitIsTextAvailable() bool { + c := C.gtk_clipboard_wait_is_text_available(v.native()) + return gobool(c) +} + +// WaitForText is a wrapper around gtk_clipboard_wait_for_text +func (v *Clipboard) WaitForText() (string, error) { + c := C.gtk_clipboard_wait_for_text(v.native()) + if c == nil { + return "", nilPtrErr + } + defer C.g_free(C.gpointer(c)) + return goString(c), nil +} + +// SetText() is a wrapper around gtk_clipboard_set_text(). +func (v *Clipboard) SetText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_clipboard_set_text(v.native(), (*C.gchar)(cstr), + C.gint(len(text))) +} + +// WaitIsRichTextAvailable is a wrapper around gtk_clipboard_wait_is_rich_text_available +func (v *Clipboard) WaitIsRichTextAvailable(buf *TextBuffer) bool { + c := C.gtk_clipboard_wait_is_rich_text_available(v.native(), buf.native()) + return gobool(c) +} + +// WaitIsUrisAvailable is a wrapper around gtk_clipboard_wait_is_uris_available +func (v *Clipboard) WaitIsUrisAvailable() bool { + c := C.gtk_clipboard_wait_is_uris_available(v.native()) + return gobool(c) +} + +// WaitIsImageAvailable is a wrapper around gtk_clipboard_wait_is_image_available +func (v *Clipboard) WaitIsImageAvailable() bool { + c := C.gtk_clipboard_wait_is_image_available(v.native()) + return gobool(c) +} + +// SetImage is a wrapper around gtk_clipboard_set_image +func (v *Clipboard) SetImage(pixbuf *gdk.Pixbuf) { + C.gtk_clipboard_set_image(v.native(), (*C.GdkPixbuf)(unsafe.Pointer(pixbuf.Native()))) +} + +// WaitForImage is a wrapper around gtk_clipboard_wait_for_image +func (v *Clipboard) WaitForImage() (*gdk.Pixbuf, error) { + c := C.gtk_clipboard_wait_for_image(v.native()) + if c == nil { + return nil, nilPtrErr + } + + p := &gdk.Pixbuf{glib.Take(unsafe.Pointer(c))} + return p, nil +} + +// WaitIsTargetAvailable is a wrapper around gtk_clipboard_wait_is_target_available +func (v *Clipboard) WaitIsTargetAvailable(target gdk.Atom) bool { + c := C.gtk_clipboard_wait_is_target_available(v.native(), C.GdkAtom(unsafe.Pointer(target))) + return gobool(c) +} + +// WaitForContents is a wrapper around gtk_clipboard_wait_for_contents +func (v *Clipboard) WaitForContents(target gdk.Atom) (*SelectionData, error) { + c := C.gtk_clipboard_wait_for_contents(v.native(), C.GdkAtom(unsafe.Pointer(target))) + if c == nil { + return nil, nilPtrErr + } + p := &SelectionData{c} + runtime.SetFinalizer(p, (*SelectionData).free) + return p, nil +} + +/* + * GtkContainer + */ + +// Container is a representation of GTK's GtkContainer. +type Container struct { + Widget +} + +// native returns a pointer to the underlying GtkContainer. +func (v *Container) native() *C.GtkContainer { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkContainer(p) +} + +func marshalContainer(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapContainer(obj), nil +} + +func wrapContainer(obj *glib.Object) *Container { + if obj == nil { + return nil + } + + return &Container{Widget{glib.InitiallyUnowned{obj}}} +} + +// Add is a wrapper around gtk_container_add(). +func (v *Container) Add(w IWidget) { + C.gtk_container_add(v.native(), w.toWidget()) +} + +// Remove is a wrapper around gtk_container_remove(). +func (v *Container) Remove(w IWidget) { + C.gtk_container_remove(v.native(), w.toWidget()) +} + +// TODO: gtk_container_add_with_properties + +// CheckResize is a wrapper around gtk_container_check_resize(). +func (v *Container) CheckResize() { + C.gtk_container_check_resize(v.native()) +} + +// TODO: gtk_container_foreach + +// GetChildren is a wrapper around gtk_container_get_children(). +func (v *Container) GetChildren() *glib.List { + clist := C.gtk_container_get_children(v.native()) + if clist == nil { + return nil + } + + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return wrapWidget(glib.Take(ptr)) + }) + + return glist +} + +// TODO: gtk_container_get_path_for_child + +// GetFocusChild is a wrapper around gtk_container_get_focus_child(). +func (v *Container) GetFocusChild() (IWidget, error) { + c := C.gtk_container_get_focus_child(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// SetFocusChild is a wrapper around gtk_container_set_focus_child(). +func (v *Container) SetFocusChild(child IWidget) { + C.gtk_container_set_focus_child(v.native(), child.toWidget()) +} + +// GetFocusVAdjustment is a wrapper around gtk_container_get_focus_vadjustment(). +func (v *Container) GetFocusVAdjustment() *Adjustment { + c := C.gtk_container_get_focus_vadjustment(v.native()) + if c == nil { + return nil + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapAdjustment(obj) +} + +// SetFocusVAdjustment is a wrapper around gtk_container_set_focus_vadjustment(). +func (v *Container) SetFocusVAdjustment(adjustment *Adjustment) { + C.gtk_container_set_focus_vadjustment(v.native(), adjustment.native()) +} + +// GetFocusHAdjustment is a wrapper around gtk_container_get_focus_hadjustment(). +func (v *Container) GetFocusHAdjustment() *Adjustment { + c := C.gtk_container_get_focus_hadjustment(v.native()) + if c == nil { + return nil + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapAdjustment(obj) +} + +// SetFocusHAdjustment is a wrapper around gtk_container_set_focus_hadjustment(). +func (v *Container) SetFocusHAdjustment(adjustment *Adjustment) { + C.gtk_container_set_focus_hadjustment(v.native(), adjustment.native()) +} + +// ChildType is a wrapper around gtk_container_child_type(). +func (v *Container) ChildType() glib.Type { + c := C.gtk_container_child_type(v.native()) + return glib.Type(c) +} + +// TODO: +// gtk_container_child_get(). +// gtk_container_child_set(). + +// ChildNotify is a wrapper around gtk_container_child_notify(). +func (v *Container) ChildNotify(child IWidget, childProperty string) { + cstr := C.CString(childProperty) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_container_child_notify(v.native(), child.toWidget(), + (*C.gchar)(cstr)) +} + +// ChildGetProperty is a wrapper around gtk_container_child_get_property(). +func (v *Container) ChildGetProperty(child IWidget, name string, valueType glib.Type) (interface{}, error) { + gv, e := glib.ValueInit(valueType) + if e != nil { + return nil, e + } + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_container_child_get_property(v.native(), child.toWidget(), (*C.gchar)(cstr), (*C.GValue)(unsafe.Pointer(gv.Native()))) + return gv.GoValue() +} + +// ChildSetProperty is a wrapper around gtk_container_child_set_property(). +func (v *Container) ChildSetProperty(child IWidget, name string, value interface{}) error { + gv, e := glib.GValue(value) + if e != nil { + return e + } + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_container_child_set_property(v.native(), child.toWidget(), (*C.gchar)(cstr), (*C.GValue)(unsafe.Pointer(gv.Native()))) + return nil +} + +// TODO: +// gtk_container_child_get_valist(). +// gtk_container_child_set_valist(). +// gtk_container_child_notify_by_pspec(). +// gtk_container_forall(). + +// GetBorderWidth is a wrapper around gtk_container_get_border_width(). +func (v *Container) GetBorderWidth() uint { + c := C.gtk_container_get_border_width(v.native()) + return uint(c) +} + +// SetBorderWidth is a wrapper around gtk_container_set_border_width(). +func (v *Container) SetBorderWidth(borderWidth uint) { + C.gtk_container_set_border_width(v.native(), C.guint(borderWidth)) +} + +// PropagateDraw is a wrapper around gtk_container_propagate_draw(). +func (v *Container) PropagateDraw(child IWidget, cr *cairo.Context) { + context := (*C.cairo_t)(unsafe.Pointer(cr.Native())) + C.gtk_container_propagate_draw(v.native(), child.toWidget(), context) +} + +// TODO: +// gtk_container_class_find_child_property(). +// gtk_container_class_install_child_property(). +// gtk_container_class_install_child_properties(). +// gtk_container_class_list_child_properties(). +// gtk_container_class_handle_border_width(). +// GtkResizeMode + +// GdkCairoSetSourcePixBuf() is a wrapper around gdk_cairo_set_source_pixbuf(). +func GdkCairoSetSourcePixBuf(cr *cairo.Context, pixbuf *gdk.Pixbuf, pixbufX, pixbufY float64) { + context := (*C.cairo_t)(unsafe.Pointer(cr.Native())) + ptr := (*C.GdkPixbuf)(unsafe.Pointer(pixbuf.Native())) + C.gdk_cairo_set_source_pixbuf(context, ptr, C.gdouble(pixbufX), C.gdouble(pixbufY)) +} + +/* + * GtkCssProvider + */ + +// CssProvider is a representation of GTK's GtkCssProvider. +type CssProvider struct { + *glib.Object +} + +func (v *CssProvider) toStyleProvider() *C.GtkStyleProvider { + if v == nil { + return nil + } + return C.toGtkStyleProvider(unsafe.Pointer(v.native())) +} + +// native returns a pointer to the underlying GtkCssProvider. +func (v *CssProvider) native() *C.GtkCssProvider { + if v == nil || v.Object == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkCssProvider(p) +} + +func wrapCssProvider(obj *glib.Object) *CssProvider { + if obj == nil { + return nil + } + + return &CssProvider{obj} +} + +// CssProviderNew is a wrapper around gtk_css_provider_new(). +func CssProviderNew() (*CssProvider, error) { + c := C.gtk_css_provider_new() + if c == nil { + return nil, nilPtrErr + } + + return wrapCssProvider(glib.Take(unsafe.Pointer(c))), nil +} + +// LoadFromPath is a wrapper around gtk_css_provider_load_from_path(). +func (v *CssProvider) LoadFromPath(path string) error { + cpath := C.CString(path) + defer C.free(unsafe.Pointer(cpath)) + var gerr *C.GError + if C.gtk_css_provider_load_from_path(v.native(), (*C.gchar)(cpath), &gerr) == 0 { + defer C.g_error_free(gerr) + return errors.New(goString(gerr.message)) + } + return nil +} + +// LoadFromData is a wrapper around gtk_css_provider_load_from_data(). +func (v *CssProvider) LoadFromData(data string) error { + cdata := C.CString(data) + defer C.free(unsafe.Pointer(cdata)) + var gerr *C.GError + if C.gtk_css_provider_load_from_data(v.native(), (*C.gchar)(unsafe.Pointer(cdata)), C.gssize(len(data)), &gerr) == 0 { + defer C.g_error_free(gerr) + return errors.New(goString(gerr.message)) + } + return nil +} + +// ToString is a wrapper around gtk_css_provider_to_string(). +func (v *CssProvider) ToString() (string, error) { + c := C.gtk_css_provider_to_string(v.native()) + if c == nil { + return "", nilPtrErr + } + return C.GoString(c), nil +} + +// CssProviderGetNamed is a wrapper around gtk_css_provider_get_named(). +func CssProviderGetNamed(name string, variant string) (*CssProvider, error) { + cname := C.CString(name) + defer C.free(unsafe.Pointer(cname)) + cvariant := C.CString(variant) + defer C.free(unsafe.Pointer(cvariant)) + + c := C.gtk_css_provider_get_named((*C.gchar)(cname), (*C.gchar)(cvariant)) + if c == nil { + return nil, nilPtrErr + } + + obj := glib.Take(unsafe.Pointer(c)) + return wrapCssProvider(obj), nil +} + +/* + * GtkDialog + */ + +// Dialog is a representation of GTK's GtkDialog. +type Dialog struct { + Window +} + +// native returns a pointer to the underlying GtkDialog. +func (v *Dialog) native() *C.GtkDialog { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkDialog(p) +} + +func marshalDialog(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapDialog(obj), nil +} + +func wrapDialog(obj *glib.Object) *Dialog { + if obj == nil { + return nil + } + + return &Dialog{Window{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}}} +} + +// DialogNew() is a wrapper around gtk_dialog_new(). +func DialogNew() (*Dialog, error) { + c := C.gtk_dialog_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapDialog(obj), nil +} + +// Run() is a wrapper around gtk_dialog_run(). +func (v *Dialog) Run() ResponseType { + c := C.gtk_dialog_run(v.native()) + return ResponseType(c) +} + +// Response() is a wrapper around gtk_dialog_response(). +func (v *Dialog) Response(response ResponseType) { + C.gtk_dialog_response(v.native(), C.gint(response)) +} + +// AddButton() is a wrapper around gtk_dialog_add_button(). text may +// be either the literal button text, or if using GTK 3.8 or earlier, a +// Stock type converted to a string. +func (v *Dialog) AddButton(text string, id ResponseType) (*Button, error) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_dialog_add_button(v.native(), (*C.gchar)(cstr), C.gint(id)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapButton(obj), nil +} + +// TODO: +// gtk_dialog_add_buttons(). + +// AddActionWidget() is a wrapper around gtk_dialog_add_action_widget(). +func (v *Dialog) AddActionWidget(child IWidget, id ResponseType) { + C.gtk_dialog_add_action_widget(v.native(), child.toWidget(), C.gint(id)) +} + +// SetDefaultResponse() is a wrapper around gtk_dialog_set_default_response(). +func (v *Dialog) SetDefaultResponse(id ResponseType) { + C.gtk_dialog_set_default_response(v.native(), C.gint(id)) +} + +// SetResponseSensitive() is a wrapper around gtk_dialog_set_response_sensitive(). +func (v *Dialog) SetResponseSensitive(id ResponseType, setting bool) { + C.gtk_dialog_set_response_sensitive(v.native(), C.gint(id), + gbool(setting)) +} + +// GetResponseForWidget is a wrapper around gtk_dialog_get_response_for_widget(). +func (v *Dialog) GetResponseForWidget(widget IWidget) ResponseType { + c := C.gtk_dialog_get_response_for_widget(v.native(), widget.toWidget()) + return ResponseType(c) +} + +// GetWidgetForResponse is a wrapper around gtk_dialog_get_widget_for_response(). +func (v *Dialog) GetWidgetForResponse(id ResponseType) (IWidget, error) { + c := C.gtk_dialog_get_widget_for_response(v.native(), C.gint(id)) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// GetContentArea() is a wrapper around gtk_dialog_get_content_area(). +func (v *Dialog) GetContentArea() (*Box, error) { + c := C.gtk_dialog_get_content_area(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + b := &Box{Container{Widget{glib.InitiallyUnowned{obj}}}} + return b, nil +} + +// DialogNewWithButtons() is a wrapper around gtk_dialog_new_with_buttons(). +// i.e: []interface{}{"Accept", gtk.RESPONSE_ACCEPT}. +func DialogNewWithButtons(title string, parent IWindow, flags DialogFlags, buttons ...[]interface{}) (dialog *Dialog, err error) { + cstr := (*C.gchar)(C.CString(title)) + defer C.free(unsafe.Pointer(cstr)) + + var w *C.GtkWindow = nil + if parent != nil { + w = parent.toWindow() + } + + var cbutton *C.gchar = nil + c := C._gtk_dialog_new_with_buttons(cstr, w, C.GtkDialogFlags(flags), cbutton) + if c == nil { + return nil, nilPtrErr + } + dialog = wrapDialog(glib.Take(unsafe.Pointer(c))) + + for idx := 0; idx < len(buttons); idx++ { + cbutton = (*C.gchar)(C.CString(buttons[idx][0].(string))) + defer C.free(unsafe.Pointer(cbutton)) + + if C.gtk_dialog_add_button(dialog.native(), cbutton, C.gint(buttons[idx][1].(ResponseType))) == nil { + return nil, nilPtrErr + } + } + return +} + +/* + * GtkDrawingArea + */ + +// DrawingArea is a representation of GTK's GtkDrawingArea. +type DrawingArea struct { + Widget +} + +// native returns a pointer to the underlying GtkDrawingArea. +func (v *DrawingArea) native() *C.GtkDrawingArea { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkDrawingArea(p) +} + +func marshalDrawingArea(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapDrawingArea(obj), nil +} + +func wrapDrawingArea(obj *glib.Object) *DrawingArea { + if obj == nil { + return nil + } + + return &DrawingArea{Widget{glib.InitiallyUnowned{obj}}} +} + +// DrawingAreaNew is a wrapper around gtk_drawing_area_new(). +func DrawingAreaNew() (*DrawingArea, error) { + c := C.gtk_drawing_area_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapDrawingArea(obj), nil +} + +/* + * GtkEditable + */ + +// Editable is a representation of GTK's GtkEditable GInterface. +type Editable struct { + *glib.Object +} + +// IEditable is an interface type implemented by all structs +// embedding an Editable. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkEditable. +type IEditable interface { + toEditable() *C.GtkEditable +} + +// native() returns a pointer to the underlying GObject as a GtkEditable. +func (v *Editable) native() *C.GtkEditable { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkEditable(p) +} + +func marshalEditable(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapEditable(obj), nil +} + +func wrapEditable(obj *glib.Object) *Editable { + if obj == nil { + return nil + } + + return &Editable{obj} +} + +func (v *Editable) toEditable() *C.GtkEditable { + if v == nil { + return nil + } + return v.native() +} + +// SelectRegion is a wrapper around gtk_editable_select_region(). +func (v *Editable) SelectRegion(startPos, endPos int) { + C.gtk_editable_select_region(v.native(), C.gint(startPos), + C.gint(endPos)) +} + +// GetSelectionBounds is a wrapper around gtk_editable_get_selection_bounds(). +func (v *Editable) GetSelectionBounds() (start, end int, nonEmpty bool) { + var cstart, cend C.gint + c := C.gtk_editable_get_selection_bounds(v.native(), &cstart, &cend) + return int(cstart), int(cend), gobool(c) +} + +// InsertText is a wrapper around gtk_editable_insert_text(). The returned +// int is the position after the inserted text. +func (v *Editable) InsertText(newText string, position int) int { + cstr := C.CString(newText) + defer C.free(unsafe.Pointer(cstr)) + pos := new(C.gint) + *pos = C.gint(position) + C.gtk_editable_insert_text(v.native(), (*C.gchar)(cstr), + C.gint(len(newText)), pos) + return int(*pos) +} + +// DeleteText is a wrapper around gtk_editable_delete_text(). +func (v *Editable) DeleteText(startPos, endPos int) { + C.gtk_editable_delete_text(v.native(), C.gint(startPos), C.gint(endPos)) +} + +// GetChars is a wrapper around gtk_editable_get_chars(). +func (v *Editable) GetChars(startPos, endPos int) string { + c := C.gtk_editable_get_chars(v.native(), C.gint(startPos), + C.gint(endPos)) + defer C.free(unsafe.Pointer(c)) + return goString(c) +} + +// CutClipboard is a wrapper around gtk_editable_cut_clipboard(). +func (v *Editable) CutClipboard() { + C.gtk_editable_cut_clipboard(v.native()) +} + +// CopyClipboard is a wrapper around gtk_editable_copy_clipboard(). +func (v *Editable) CopyClipboard() { + C.gtk_editable_copy_clipboard(v.native()) +} + +// PasteClipboard is a wrapper around gtk_editable_paste_clipboard(). +func (v *Editable) PasteClipboard() { + C.gtk_editable_paste_clipboard(v.native()) +} + +// DeleteSelection is a wrapper around gtk_editable_delete_selection(). +func (v *Editable) DeleteSelection() { + C.gtk_editable_delete_selection(v.native()) +} + +// SetPosition is a wrapper around gtk_editable_set_position(). +func (v *Editable) SetPosition(position int) { + C.gtk_editable_set_position(v.native(), C.gint(position)) +} + +// GetPosition is a wrapper around gtk_editable_get_position(). +func (v *Editable) GetPosition() int { + c := C.gtk_editable_get_position(v.native()) + return int(c) +} + +// SetEditable is a wrapper around gtk_editable_set_editable(). +func (v *Editable) SetEditable(isEditable bool) { + C.gtk_editable_set_editable(v.native(), gbool(isEditable)) +} + +// GetEditable is a wrapper around gtk_editable_get_editable(). +func (v *Editable) GetEditable() bool { + c := C.gtk_editable_get_editable(v.native()) + return gobool(c) +} + +/* + * GtkEntry + */ + +// Entry is a representation of GTK's GtkEntry. +type Entry struct { + Widget + + // Interfaces + Editable + CellEditable +} + +type IEntry interface { + toEntry() *C.GtkEntry +} + +func (v *Entry) toEntry() *C.GtkEntry { + return v.native() +} + +// native returns a pointer to the underlying GtkEntry. +func (v *Entry) native() *C.GtkEntry { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkEntry(p) +} + +func marshalEntry(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapEntry(obj), nil +} + +func wrapEntry(obj *glib.Object) *Entry { + if obj == nil { + return nil + } + + e := wrapEditable(obj) + ce := wrapCellEditable(obj) + return &Entry{Widget{glib.InitiallyUnowned{obj}}, *e, *ce} +} + +// EntryNew() is a wrapper around gtk_entry_new(). +func EntryNew() (*Entry, error) { + c := C.gtk_entry_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapEntry(obj), nil +} + +// EntryNewWithBuffer() is a wrapper around gtk_entry_new_with_buffer(). +func EntryNewWithBuffer(buffer *EntryBuffer) (*Entry, error) { + c := C.gtk_entry_new_with_buffer(buffer.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapEntry(obj), nil +} + +// GetBuffer() is a wrapper around gtk_entry_get_buffer(). +func (v *Entry) GetBuffer() (*EntryBuffer, error) { + c := C.gtk_entry_get_buffer(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return &EntryBuffer{obj}, nil +} + +// SetBuffer() is a wrapper around gtk_entry_set_buffer(). +func (v *Entry) SetBuffer(buffer *EntryBuffer) { + C.gtk_entry_set_buffer(v.native(), buffer.native()) +} + +// SetText() is a wrapper around gtk_entry_set_text(). +func (v *Entry) SetText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_entry_set_text(v.native(), (*C.gchar)(cstr)) +} + +// GetText() is a wrapper around gtk_entry_get_text(). +func (v *Entry) GetText() (string, error) { + c := C.gtk_entry_get_text(v.native()) + if c == nil { + return "", nilPtrErr + } + return goString(c), nil +} + +// GetTextLength() is a wrapper around gtk_entry_get_text_length(). +func (v *Entry) GetTextLength() uint16 { + c := C.gtk_entry_get_text_length(v.native()) + return uint16(c) +} + +// GetTextArea is a wrapper around gtk_entry_get_text_area(). +func (v *Entry) GetTextArea() *gdk.Rectangle { + var cRect *C.GdkRectangle + C.gtk_entry_get_text_area(v.native(), cRect) + textArea := gdk.WrapRectangle(uintptr(unsafe.Pointer(cRect))) + return textArea +} + +// SetVisibility is a wrapper around gtk_entry_set_visibility(). +func (v *Entry) SetVisibility(visible bool) { + C.gtk_entry_set_visibility(v.native(), gbool(visible)) +} + +// SetInvisibleChar is a wrapper around gtk_entry_set_invisible_char(). +func (v *Entry) SetInvisibleChar(ch rune) { + C.gtk_entry_set_invisible_char(v.native(), C.gunichar(ch)) +} + +// UnsetInvisibleChar is a wrapper around gtk_entry_unset_invisible_char(). +func (v *Entry) UnsetInvisibleChar() { + C.gtk_entry_unset_invisible_char(v.native()) +} + +// SetMaxLength is a wrapper around gtk_entry_set_max_length(). +func (v *Entry) SetMaxLength(len int) { + C.gtk_entry_set_max_length(v.native(), C.gint(len)) +} + +// GetActivatesDefault is a wrapper around gtk_entry_get_activates_default(). +func (v *Entry) GetActivatesDefault() bool { + c := C.gtk_entry_get_activates_default(v.native()) + return gobool(c) +} + +// GetHasFrame is a wrapper around gtk_entry_get_has_frame(). +func (v *Entry) GetHasFrame() bool { + c := C.gtk_entry_get_has_frame(v.native()) + return gobool(c) +} + +// GetWidthChars is a wrapper around gtk_entry_get_width_chars(). +func (v *Entry) GetWidthChars() int { + c := C.gtk_entry_get_width_chars(v.native()) + return int(c) +} + +// SetActivatesDefault is a wrapper around gtk_entry_set_activates_default(). +func (v *Entry) SetActivatesDefault(setting bool) { + C.gtk_entry_set_activates_default(v.native(), gbool(setting)) +} + +// SetHasFrame is a wrapper around gtk_entry_set_has_frame(). +func (v *Entry) SetHasFrame(setting bool) { + C.gtk_entry_set_has_frame(v.native(), gbool(setting)) +} + +// SetWidthChars is a wrapper around gtk_entry_set_width_chars(). +func (v *Entry) SetWidthChars(nChars int) { + C.gtk_entry_set_width_chars(v.native(), C.gint(nChars)) +} + +// GetInvisibleChar is a wrapper around gtk_entry_get_invisible_char(). +func (v *Entry) GetInvisibleChar() rune { + c := C.gtk_entry_get_invisible_char(v.native()) + return rune(c) +} + +// SetAlignment is a wrapper around gtk_entry_set_alignment(). +func (v *Entry) SetAlignment(xalign float32) { + C.gtk_entry_set_alignment(v.native(), C.gfloat(xalign)) +} + +// GetAlignment is a wrapper around gtk_entry_get_alignment(). +func (v *Entry) GetAlignment() float32 { + c := C.gtk_entry_get_alignment(v.native()) + return float32(c) +} + +// SetPlaceholderText is a wrapper around gtk_entry_set_placeholder_text(). +func (v *Entry) SetPlaceholderText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_entry_set_placeholder_text(v.native(), (*C.gchar)(cstr)) +} + +// GetPlaceholderText is a wrapper around gtk_entry_get_placeholder_text(). +func (v *Entry) GetPlaceholderText() (string, error) { + c := C.gtk_entry_get_placeholder_text(v.native()) + if c == nil { + return "", nilPtrErr + } + return goString(c), nil +} + +// SetOverwriteMode is a wrapper around gtk_entry_set_overwrite_mode(). +func (v *Entry) SetOverwriteMode(overwrite bool) { + C.gtk_entry_set_overwrite_mode(v.native(), gbool(overwrite)) +} + +// GetOverwriteMode is a wrapper around gtk_entry_get_overwrite_mode(). +func (v *Entry) GetOverwriteMode() bool { + c := C.gtk_entry_get_overwrite_mode(v.native()) + return gobool(c) +} + +// GetLayout is a wrapper around gtk_entry_get_layout(). +func (v *Entry) GetLayout() *pango.Layout { + c := C.gtk_entry_get_layout(v.native()) + return pango.WrapLayout(uintptr(unsafe.Pointer(c))) +} + +// GetLayoutOffsets is a wrapper around gtk_entry_get_layout_offsets(). +func (v *Entry) GetLayoutOffsets() (x, y int) { + var gx, gy C.gint + C.gtk_entry_get_layout_offsets(v.native(), &gx, &gy) + return int(gx), int(gy) +} + +// LayoutIndexToTextIndex is a wrapper around gtk_entry_layout_index_to_text_index(). +func (v *Entry) LayoutIndexToTextIndex(layoutIndex int) int { + c := C.gtk_entry_layout_index_to_text_index(v.native(), + C.gint(layoutIndex)) + return int(c) +} + +// TextIndexToLayoutIndex is a wrapper around gtk_entry_text_index_to_layout_index(). +func (v *Entry) TextIndexToLayoutIndex(textIndex int) int { + c := C.gtk_entry_text_index_to_layout_index(v.native(), + C.gint(textIndex)) + return int(c) +} + +// TODO: depends on PandoAttrList +// SetAttributes is a wrapper around gtk_entry_set_attributes(). +// func (v *Entry) SetAttributes(attrList *pango.AttrList) { +// C.gtk_entry_set_attributes(v.native(), (*C.PangoAttrList)(unsafe.Pointer(attrList.Native()))) +// } + +// TODO: depends on PandoAttrList +// GetAttributes is a wrapper around gtk_entry_get_attributes(). +// func (v *Entry) GetAttributes() (*pango.AttrList, error) { +// c := C.gtk_entry_get_attributes(v.native()) +// if c == nil { +// return nil, nilPtrErr +// } +// return &pango.AttrList{unsafe.Pointer(c)}, nil +// } + +// GetMaxLength is a wrapper around gtk_entry_get_max_length(). +func (v *Entry) GetMaxLength() int { + c := C.gtk_entry_get_max_length(v.native()) + return int(c) +} + +// GetVisibility is a wrapper around gtk_entry_get_visibility(). +func (v *Entry) GetVisibility() bool { + c := C.gtk_entry_get_visibility(v.native()) + return gobool(c) +} + +// SetCompletion is a wrapper around gtk_entry_set_completion(). +func (v *Entry) SetCompletion(completion *EntryCompletion) { + C.gtk_entry_set_completion(v.native(), completion.native()) +} + +// GetCompletion is a wrapper around gtk_entry_get_completion(). +func (v *Entry) GetCompletion() (*EntryCompletion, error) { + c := C.gtk_entry_get_completion(v.native()) + if c == nil { + return nil, nilPtrErr + } + + e := &EntryCompletion{glib.Take(unsafe.Pointer(c))} + return e, nil +} + +// SetCursorHAdjustment is a wrapper around gtk_entry_set_cursor_hadjustment(). +func (v *Entry) SetCursorHAdjustment(adjustment *Adjustment) { + C.gtk_entry_set_cursor_hadjustment(v.native(), adjustment.native()) +} + +// GetCursorHAdjustment is a wrapper around gtk_entry_get_cursor_hadjustment(). +func (v *Entry) GetCursorHAdjustment() (*Adjustment, error) { + c := C.gtk_entry_get_cursor_hadjustment(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return &Adjustment{glib.InitiallyUnowned{obj}}, nil +} + +// SetProgressFraction is a wrapper around gtk_entry_set_progress_fraction(). +func (v *Entry) SetProgressFraction(fraction float64) { + C.gtk_entry_set_progress_fraction(v.native(), C.gdouble(fraction)) +} + +// GetProgressFraction is a wrapper around gtk_entry_get_progress_fraction(). +func (v *Entry) GetProgressFraction() float64 { + c := C.gtk_entry_get_progress_fraction(v.native()) + return float64(c) +} + +// SetProgressPulseStep is a wrapper around gtk_entry_set_progress_pulse_step(). +func (v *Entry) SetProgressPulseStep(fraction float64) { + C.gtk_entry_set_progress_pulse_step(v.native(), C.gdouble(fraction)) +} + +// GetProgressPulseStep is a wrapper around gtk_entry_get_progress_pulse_step(). +func (v *Entry) GetProgressPulseStep() float64 { + c := C.gtk_entry_get_progress_pulse_step(v.native()) + return float64(c) +} + +// ProgressPulse is a wrapper around gtk_entry_progress_pulse(). +func (v *Entry) ProgressPulse() { + C.gtk_entry_progress_pulse(v.native()) +} + +// IMContextFilterKeypress is a wrapper around gtk_entry_im_context_filter_keypress(). +func (v *Entry) IMContextFilterKeypress(eventKey *gdk.EventKey) bool { + key := (*C.GdkEventKey)(unsafe.Pointer(eventKey.Native())) + c := C.gtk_entry_im_context_filter_keypress(v.native(), key) + return gobool(c) +} + +// ResetIMContext is a wrapper around gtk_entry_reset_im_context(). +func (v *Entry) ResetIMContext() { + C.gtk_entry_reset_im_context(v.native()) +} + +// SetIconFromPixbuf is a wrapper around gtk_entry_set_icon_from_pixbuf(). +func (v *Entry) SetIconFromPixbuf(iconPos EntryIconPosition, pixbuf *gdk.Pixbuf) { + var pb *C.GdkPixbuf + if pixbuf != nil { + pb = (*C.GdkPixbuf)(unsafe.Pointer(pixbuf.Native())) + } + + C.gtk_entry_set_icon_from_pixbuf(v.native(), C.GtkEntryIconPosition(iconPos), pb) +} + +// SetIconFromIconName is a wrapper around gtk_entry_set_icon_from_icon_name(). +func (v *Entry) SetIconFromIconName(iconPos EntryIconPosition, name string) { + var icon *C.gchar + if name != "" { + n := C.CString(name) + defer C.free(unsafe.Pointer(n)) + icon = (*C.gchar)(n) + } + + C.gtk_entry_set_icon_from_icon_name(v.native(), C.GtkEntryIconPosition(iconPos), icon) +} + +// RemoveIcon is a convenience func to set a nil pointer to the icon name. +func (v *Entry) RemoveIcon(iconPos EntryIconPosition) { + C.gtk_entry_set_icon_from_icon_name(v.native(), C.GtkEntryIconPosition(iconPos), nil) +} + +// TODO: Needs gio/GIcon implemented first +// SetIconFromGIcon is a wrapper around gtk_entry_set_icon_from_gicon(). +func (v *Entry) SetIconFromGIcon(iconPos EntryIconPosition, icon *glib.Icon) { + C.gtk_entry_set_icon_from_gicon(v.native(), + C.GtkEntryIconPosition(iconPos), + (*C.GIcon)(icon.NativePrivate())) +} + +// GetIconStorageType is a wrapper around gtk_entry_get_icon_storage_type(). +func (v *Entry) GetIconStorageType(iconPos EntryIconPosition) ImageType { + c := C.gtk_entry_get_icon_storage_type(v.native(), C.GtkEntryIconPosition(iconPos)) + return ImageType(c) +} + +// GetIconPixbuf is a wrapper around gtk_entry_get_icon_pixbuf(). +func (v *Entry) GetIconPixbuf(iconPos EntryIconPosition) (*gdk.Pixbuf, error) { + c := C.gtk_entry_get_icon_pixbuf(v.native(), C.GtkEntryIconPosition(iconPos)) + if c == nil { + return nil, nilPtrErr + } + return &gdk.Pixbuf{glib.Take(unsafe.Pointer(c))}, nil +} + +// GetIconName is a wrapper around gtk_entry_get_icon_name(). +func (v *Entry) GetIconName(iconPos EntryIconPosition) (string, error) { + c := C.gtk_entry_get_icon_name(v.native(), C.GtkEntryIconPosition(iconPos)) + if c == nil { + return "", nilPtrErr + } + return goString(c), nil +} + +// GetIconGIcon is a wrapper around gtk_entry_get_icon_gicon(). +func (v *Entry) GetIconGIcon(iconPos EntryIconPosition) (*glib.Icon, error) { + c := C.gtk_entry_get_icon_gicon(v.native(), C.GtkEntryIconPosition(iconPos)) + if c == nil { + return nil, nilPtrErr + } + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + i := &glib.Icon{obj} + runtime.SetFinalizer(i, func(_ interface{}) { obj.Unref() }) + return i, nil +} + +// SetIconActivatable is a wrapper around gtk_entry_set_icon_activatable(). +func (v *Entry) SetIconActivatable(iconPos EntryIconPosition, activatable bool) { + C.gtk_entry_set_icon_activatable(v.native(), C.GtkEntryIconPosition(iconPos), gbool(activatable)) +} + +// GetIconActivatable is a wrapper around gtk_entry_get_icon_activatable(). +func (v *Entry) GetIconActivatable(iconPos EntryIconPosition) bool { + c := C.gtk_entry_get_icon_activatable(v.native(), C.GtkEntryIconPosition(iconPos)) + return gobool(c) +} + +// SetIconSensitive is a wrapper around gtk_entry_set_icon_sensitive(). +func (v *Entry) SetIconSensitive(iconPos EntryIconPosition, sensitive bool) { + C.gtk_entry_set_icon_sensitive(v.native(), C.GtkEntryIconPosition(iconPos), gbool(sensitive)) +} + +// GetIconSensitive is a wrapper around gtk_entry_get_icon_sensitive(). +func (v *Entry) GetIconSensitive(iconPos EntryIconPosition) bool { + c := C.gtk_entry_get_icon_sensitive(v.native(), C.GtkEntryIconPosition(iconPos)) + return gobool(c) +} + +// GetIconAtPos is a wrapper around gtk_entry_get_icon_at_pos(). +func (v *Entry) GetIconAtPos(x, y int) int { + c := C.gtk_entry_get_icon_at_pos(v.native(), C.gint(x), C.gint(y)) + return int(c) +} + +// SetIconTooltipText is a wrapper around gtk_entry_set_icon_tooltip_text(). +func (v *Entry) SetIconTooltipText(iconPos EntryIconPosition, tooltip string) { + var text *C.gchar + if tooltip != "" { + cstr := C.CString(tooltip) + defer C.free(unsafe.Pointer(cstr)) + text = cstr + } + + C.gtk_entry_set_icon_tooltip_text(v.native(), C.GtkEntryIconPosition(iconPos), text) +} + +// GetIconTooltipText is a wrapper around gtk_entry_get_icon_tooltip_text(). +func (v *Entry) GetIconTooltipText(iconPos EntryIconPosition) (string, error) { + c := C.gtk_entry_get_icon_tooltip_text(v.native(), + C.GtkEntryIconPosition(iconPos)) + if c == nil { + return "", nilPtrErr + } + return goString(c), nil +} + +// SetIconTooltipMarkup is a wrapper around gtk_entry_set_icon_tooltip_markup(). +func (v *Entry) SetIconTooltipMarkup(iconPos EntryIconPosition, tooltip string) { + var text *C.gchar + if tooltip != "" { + cstr := C.CString(tooltip) + defer C.free(unsafe.Pointer(cstr)) + text = cstr + } + + C.gtk_entry_set_icon_tooltip_markup(v.native(), C.GtkEntryIconPosition(iconPos), text) +} + +// GetIconTooltipMarkup is a wrapper around gtk_entry_get_icon_tooltip_markup(). +func (v *Entry) GetIconTooltipMarkup(iconPos EntryIconPosition) (string, error) { + c := C.gtk_entry_get_icon_tooltip_markup(v.native(), + C.GtkEntryIconPosition(iconPos)) + if c == nil { + return "", nilPtrErr + } + return goString(c), nil +} + +// TODO: depends on GtkTargetList +// SetIconDragSource is a wrapper around gtk_entry_set_icon_drag_source(). +// func (v *Entry) SetIconDragSource(iconPos EntryIconPosition, targetList *TargetList, action gdk.DragAction) { +// C.gtk_entry_set_icon_drag_source(v.native(), C.GtkEntryIconPosition(iconPos), +// targetList.native(), C.GdkDragAction(action)) +// } + +// GetCurrentIconDragSource is a wrapper around gtk_entry_get_current_icon_drag_source(). +func (v *Entry) GetCurrentIconDragSource() int { + c := C.gtk_entry_get_current_icon_drag_source(v.native()) + return int(c) +} + +// GetIconArea is a wrapper around gtk_entry_get_icon_area(). +func (v *Entry) GetIconArea(iconPos EntryIconPosition) *gdk.Rectangle { + var cRect *C.GdkRectangle + C.gtk_entry_get_icon_area(v.native(), C.GtkEntryIconPosition(iconPos), cRect) + iconArea := gdk.WrapRectangle(uintptr(unsafe.Pointer(cRect))) + return iconArea +} + +// SetInputPurpose is a wrapper around gtk_entry_set_input_purpose(). +func (v *Entry) SetInputPurpose(purpose InputPurpose) { + C.gtk_entry_set_input_purpose(v.native(), C.GtkInputPurpose(purpose)) +} + +// GetInputPurpose is a wrapper around gtk_entry_get_input_purpose(). +func (v *Entry) GetInputPurpose() InputPurpose { + c := C.gtk_entry_get_input_purpose(v.native()) + return InputPurpose(c) +} + +// SetInputHints is a wrapper around gtk_entry_set_input_hints(). +func (v *Entry) SetInputHints(hints InputHints) { + C.gtk_entry_set_input_hints(v.native(), C.GtkInputHints(hints)) +} + +// GetInputHints is a wrapper around gtk_entry_get_input_hints(). +func (v *Entry) GetInputHints() InputHints { + c := C.gtk_entry_get_input_hints(v.native()) + return InputHints(c) +} + +/* + * GtkEntryBuffer + */ + +// EntryBuffer is a representation of GTK's GtkEntryBuffer. +type EntryBuffer struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkEntryBuffer. +func (v *EntryBuffer) native() *C.GtkEntryBuffer { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkEntryBuffer(p) +} + +func marshalEntryBuffer(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapEntryBuffer(obj), nil +} + +func wrapEntryBuffer(obj *glib.Object) *EntryBuffer { + if obj == nil { + return nil + } + + return &EntryBuffer{obj} +} + +// EntryBufferNew() is a wrapper around gtk_entry_buffer_new(). +func EntryBufferNew(initialChars string, nInitialChars int) (*EntryBuffer, error) { + cstr := C.CString(initialChars) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_entry_buffer_new((*C.gchar)(cstr), C.gint(nInitialChars)) + if c == nil { + return nil, nilPtrErr + } + + e := wrapEntryBuffer(glib.Take(unsafe.Pointer(c))) + return e, nil +} + +// GetText() is a wrapper around gtk_entry_buffer_get_text(). A +// non-nil error is returned in the case that gtk_entry_buffer_get_text +// returns NULL to differentiate between NULL and an empty string. +func (v *EntryBuffer) GetText() (string, error) { + c := C.gtk_entry_buffer_get_text(v.native()) + if c == nil { + return "", nilPtrErr + } + return goString(c), nil +} + +// SetText() is a wrapper around gtk_entry_buffer_set_text(). +func (v *EntryBuffer) SetText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_entry_buffer_set_text(v.native(), (*C.gchar)(cstr), + C.gint(len(text))) +} + +// GetBytes() is a wrapper around gtk_entry_buffer_get_bytes(). +func (v *EntryBuffer) GetBytes() uint { + c := C.gtk_entry_buffer_get_bytes(v.native()) + return uint(c) +} + +// GetLength() is a wrapper around gtk_entry_buffer_get_length(). +func (v *EntryBuffer) GetLength() uint { + c := C.gtk_entry_buffer_get_length(v.native()) + return uint(c) +} + +// GetMaxLength() is a wrapper around gtk_entry_buffer_get_max_length(). +func (v *EntryBuffer) GetMaxLength() int { + c := C.gtk_entry_buffer_get_max_length(v.native()) + return int(c) +} + +// SetMaxLength() is a wrapper around gtk_entry_buffer_set_max_length(). +func (v *EntryBuffer) SetMaxLength(maxLength int) { + C.gtk_entry_buffer_set_max_length(v.native(), C.gint(maxLength)) +} + +// InsertText() is a wrapper around gtk_entry_buffer_insert_text(). +func (v *EntryBuffer) InsertText(position uint, text string) uint { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_entry_buffer_insert_text(v.native(), C.guint(position), + (*C.gchar)(cstr), C.gint(len(text))) + return uint(c) +} + +// DeleteText() is a wrapper around gtk_entry_buffer_delete_text(). +func (v *EntryBuffer) DeleteText(position uint, nChars int) uint { + c := C.gtk_entry_buffer_delete_text(v.native(), C.guint(position), + C.gint(nChars)) + return uint(c) +} + +// EmitDeletedText() is a wrapper around gtk_entry_buffer_emit_deleted_text(). +func (v *EntryBuffer) EmitDeletedText(pos, nChars uint) { + C.gtk_entry_buffer_emit_deleted_text(v.native(), C.guint(pos), + C.guint(nChars)) +} + +// EmitInsertedText() is a wrapper around gtk_entry_buffer_emit_inserted_text(). +func (v *EntryBuffer) EmitInsertedText(pos uint, text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_entry_buffer_emit_inserted_text(v.native(), C.guint(pos), + (*C.gchar)(cstr), C.guint(len(text))) +} + +/* + * GtkEntryCompletion + */ + +// EntryCompletion is a representation of GTK's GtkEntryCompletion. +type EntryCompletion struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkEntryCompletion. +func (v *EntryCompletion) native() *C.GtkEntryCompletion { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkEntryCompletion(p) +} + +func marshalEntryCompletion(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapEntryCompletion(obj), nil +} + +func wrapEntryCompletion(obj *glib.Object) *EntryCompletion { + if obj == nil { + return nil + } + + return &EntryCompletion{obj} +} + +// TODO: +// GtkEntryCompletionMatchFunc + +// EntryCompletionNew is a wrapper around gtk_entry_completion_new +func EntryCompletionNew() (*EntryCompletion, error) { + c := C.gtk_entry_completion_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapEntryCompletion(obj), nil +} + +// TODO: +// gtk_entry_completion_new_with_area(). +// gtk_entry_completion_get_entry(). + +// SetModel is a wrapper around gtk_entry_completion_set_model +func (v *EntryCompletion) SetModel(model ITreeModel) { + var mptr *C.GtkTreeModel + if model != nil { + mptr = model.toTreeModel() + } + C.gtk_entry_completion_set_model(v.native(), mptr) +} + +// GetModel is a wrapper around gtk_entry_completion_get_model +func (v *EntryCompletion) GetModel() (ITreeModel, error) { + c := C.gtk_entry_completion_get_model(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castTreeModel(c) +} + +// TODO: +// gtk_entry_completion_set_match_func(). + +// SetMinimumKeyLength is a wrapper around gtk_entry_completion_set_minimum_key_length +func (v *EntryCompletion) SetMinimumKeyLength(minimumLength int) { + C.gtk_entry_completion_set_minimum_key_length(v.native(), C.gint(minimumLength)) +} + +// GetMinimumKeyLength is a wrapper around gtk_entry_completion_get_minimum_key_length +func (v *EntryCompletion) GetMinimumKeyLength() int { + c := C.gtk_entry_completion_get_minimum_key_length(v.native()) + return int(c) +} + +// TODO: +// gtk_entry_completion_compute_prefix(). +// gtk_entry_completion_complete(). +// gtk_entry_completion_get_completion_prefix(). +// gtk_entry_completion_insert_prefix(). +// gtk_entry_completion_insert_action_text(). +// gtk_entry_completion_insert_action_markup(). +// gtk_entry_completion_delete_action(). + +// SetTextColumn is a wrapper around gtk_entry_completion_set_text_column +func (v *EntryCompletion) SetTextColumn(textColumn int) { + C.gtk_entry_completion_set_text_column(v.native(), C.gint(textColumn)) +} + +// GetTextColumn is a wrapper around gtk_entry_completion_get_text_column +func (v *EntryCompletion) GetTextColumn() int { + c := C.gtk_entry_completion_get_text_column(v.native()) + return int(c) +} + +// SetInlineCompletion is a wrapper around gtk_entry_completion_set_inline_completion +func (v *EntryCompletion) SetInlineCompletion(inlineCompletion bool) { + C.gtk_entry_completion_set_inline_completion(v.native(), gbool(inlineCompletion)) +} + +// GetInlineCompletion is a wrapper around gtk_entry_completion_get_inline_completion +func (v *EntryCompletion) GetInlineCompletion() bool { + c := C.gtk_entry_completion_get_inline_completion(v.native()) + return gobool(c) +} + +// TODO +// gtk_entry_completion_set_inline_selection(). +// gtk_entry_completion_get_inline_selection(). + +// SetPopupCompletion is a wrapper around gtk_entry_completion_set_popup_completion +func (v *EntryCompletion) SetPopupCompletion(popupCompletion bool) { + C.gtk_entry_completion_set_popup_completion(v.native(), gbool(popupCompletion)) +} + +// GetPopupCompletion is a wrapper around gtk_entry_completion_get_popup_completion +func (v *EntryCompletion) GetPopupCompletion() bool { + c := C.gtk_entry_completion_get_popup_completion(v.native()) + return gobool(c) +} + +// SetPopupSetWidth is a wrapper around gtk_entry_completion_set_popup_set_width +func (v *EntryCompletion) SetPopupSetWidth(popupSetWidth bool) { + C.gtk_entry_completion_set_popup_set_width(v.native(), gbool(popupSetWidth)) +} + +// GetPopupSetWidth is a wrapper around gtk_entry_completion_get_popup_set_width +func (v *EntryCompletion) GetPopupSetWidth() bool { + c := C.gtk_entry_completion_get_popup_set_width(v.native()) + return gobool(c) +} + +// TODO: +// gtk_entry_completion_set_popup_single_match(). +// gtk_entry_completion_get_popup_single_match(). + +/* + * GtkEventBox + */ + +// EventBox is a representation of GTK's GtkEventBox. +type EventBox struct { + Bin +} + +// native returns a pointer to the underlying GtkEventBox. +func (v *EventBox) native() *C.GtkEventBox { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkEventBox(p) +} + +func marshalEventBox(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapEventBox(obj), nil +} + +func wrapEventBox(obj *glib.Object) *EventBox { + if obj == nil { + return nil + } + + return &EventBox{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// EventBoxNew is a wrapper around gtk_event_box_new(). +func EventBoxNew() (*EventBox, error) { + c := C.gtk_event_box_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapEventBox(obj), nil +} + +// SetAboveChild is a wrapper around gtk_event_box_set_above_child(). +func (v *EventBox) SetAboveChild(aboveChild bool) { + C.gtk_event_box_set_above_child(v.native(), gbool(aboveChild)) +} + +// GetAboveChild is a wrapper around gtk_event_box_get_above_child(). +func (v *EventBox) GetAboveChild() bool { + c := C.gtk_event_box_get_above_child(v.native()) + return gobool(c) +} + +// SetVisibleWindow is a wrapper around gtk_event_box_set_visible_window(). +func (v *EventBox) SetVisibleWindow(visibleWindow bool) { + C.gtk_event_box_set_visible_window(v.native(), gbool(visibleWindow)) +} + +// GetVisibleWindow is a wrapper around gtk_event_box_get_visible_window(). +func (v *EventBox) GetVisibleWindow() bool { + c := C.gtk_event_box_get_visible_window(v.native()) + return gobool(c) +} + +/* + * GtkExpander + */ + +// Expander is a representation of GTK's GtkExpander. +type Expander struct { + Bin +} + +// native returns a pointer to the underlying GtkExpander. +func (v *Expander) native() *C.GtkExpander { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkExpander(p) +} + +func marshalExpander(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapExpander(obj), nil +} + +func wrapExpander(obj *glib.Object) *Expander { + if obj == nil { + return nil + } + + return &Expander{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// ExpanderNew is a wrapper around gtk_expander_new(). +func ExpanderNew(label string) (*Expander, error) { + var cstr *C.gchar + if label != "" { + cstr = (*C.gchar)(C.CString(label)) + defer C.free(unsafe.Pointer(cstr)) + } + c := C.gtk_expander_new(cstr) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapExpander(obj), nil +} + +// TODO: +// gtk_expander_new_with_mnemonic(). + +// SetExpanded is a wrapper around gtk_expander_set_expanded(). +func (v *Expander) SetExpanded(expanded bool) { + C.gtk_expander_set_expanded(v.native(), gbool(expanded)) +} + +// GetExpanded is a wrapper around gtk_expander_get_expanded(). +func (v *Expander) GetExpanded() bool { + c := C.gtk_expander_get_expanded(v.native()) + return gobool(c) +} + +// SetLabel is a wrapper around gtk_expander_set_label(). +func (v *Expander) SetLabel(label string) { + var cstr *C.char + if label != "" { + cstr = C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + } + C.gtk_expander_set_label(v.native(), (*C.gchar)(cstr)) +} + +// GetLabel is a wrapper around gtk_expander_get_label(). +func (v *Expander) GetLabel() string { + c := C.gtk_expander_get_label(v.native()) + return goString(c) +} + +// TODO: +// gtk_expander_set_use_underline(). +// gtk_expander_get_use_underline(). +// gtk_expander_set_use_markup(). +// gtk_expander_get_use_markup(). + +// SetLabelWidget is a wrapper around gtk_expander_set_label_widget(). +func (v *Expander) SetLabelWidget(widget IWidget) { + C.gtk_expander_set_label_widget(v.native(), widget.toWidget()) +} + +// TODO: +// gtk_expander_get_label_widget(). +// gtk_expander_set_label_fill(). +// gtk_expander_get_label_fill(). +// gtk_expander_set_resize_toplevel(). +// gtk_expander_get_resize_toplevel(). + +/* + * GtkFileChooser + */ + +// FileChoser is a representation of GTK's GtkFileChooser GInterface. +type FileChooser struct { + *glib.Object +} + +// native returns a pointer to the underlying GObject as a GtkFileChooser. +func (v *FileChooser) native() *C.GtkFileChooser { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkFileChooser(p) +} + +func marshalFileChooser(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapFileChooser(obj), nil +} + +func wrapFileChooser(obj *glib.Object) *FileChooser { + if obj == nil { + return nil + } + + return &FileChooser{obj} +} + +// SetFilename is a wrapper around gtk_file_chooser_set_filename(). +func (v *FileChooser) SetFilename(filename string) bool { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_file_chooser_set_filename(v.native(), cstr) + return gobool(c) +} + +// GetFilename is a wrapper around gtk_file_chooser_get_filename(). +func (v *FileChooser) GetFilename() string { + c := C.gtk_file_chooser_get_filename(v.native()) + s := goString(c) + defer C.g_free((C.gpointer)(c)) + return s +} + +// SelectFilename is a wrapper around gtk_file_chooser_select_filename(). +func (v *FileChooser) SelectFilename(filename string) bool { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_file_chooser_select_filename(v.native(), cstr) + return gobool(c) +} + +// UnselectFilename is a wrapper around gtk_file_chooser_unselect_filename(). +func (v *FileChooser) UnselectFilename(filename string) { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_file_chooser_unselect_filename(v.native(), cstr) +} + +// SelectAll is a wrapper around gtk_file_chooser_select_all(). +func (v *FileChooser) SelectAll() { + C.gtk_file_chooser_select_all(v.native()) +} + +// UnselectAll is a wrapper around gtk_file_chooser_unselect_all(). +func (v *FileChooser) UnselectAll() { + C.gtk_file_chooser_unselect_all(v.native()) +} + +// GetFilenames is a wrapper around gtk_file_chooser_get_filenames(). +func (v *FileChooser) GetFilenames() ([]string, error) { + clist := C.gtk_file_chooser_get_filenames(v.native()) + if clist == nil { + return nil, nilPtrErr + } + + slist := glib.WrapSList(uintptr(unsafe.Pointer(clist))) + defer slist.Free() + + var filenames = make([]string, 0, slist.Length()) + for ; slist.DataRaw() != nil; slist = slist.Next() { + w := (*C.char)(slist.DataRaw()) + defer C.free(unsafe.Pointer(w)) + + filenames = append(filenames, C.GoString(w)) + } + + return filenames, nil +} + +// GetURIs is a wrapper around gtk_file_chooser_get_uris(). +func (v FileChooser) GetURIs() ([]string, error) { + // TODO: do the same as in (v *FileChooser) GetFilenames() + clist := C.gtk_file_chooser_get_uris(v.native()) + if clist == nil { + return nil, nilPtrErr + } + + slist := glib.WrapSList(uintptr(unsafe.Pointer(clist))) + defer slist.Free() + + var uris = make([]string, 0, slist.Length()) + for ; slist.DataRaw() != nil; slist = slist.Next() { + w := (*C.char)(slist.DataRaw()) + defer C.free(unsafe.Pointer(w)) + + uris = append(uris, C.GoString(w)) + } + + return uris, nil +} + +// SetDoOverwriteConfirmation is a wrapper around gtk_file_chooser_set_do_overwrite_confirmation(). +func (v *FileChooser) SetDoOverwriteConfirmation(value bool) { + C.gtk_file_chooser_set_do_overwrite_confirmation(v.native(), gbool(value)) +} + +// GetDoOverwriteConfirmation is a wrapper around gtk_file_chooser_get_do_overwrite_confirmation(). +func (v *FileChooser) GetDoOverwriteConfirmation() bool { + c := C.gtk_file_chooser_get_do_overwrite_confirmation(v.native()) + return gobool(c) +} + +// SetCreateFolders is a wrapper around gtk_file_chooser_set_create_folders(). +func (v *FileChooser) SetCreateFolders(value bool) { + C.gtk_file_chooser_set_create_folders(v.native(), gbool(value)) +} + +// GetCreateFolders is a wrapper around gtk_file_chooser_get_create_folders(). +func (v *FileChooser) GetCreateFolders() bool { + c := C.gtk_file_chooser_get_create_folders(v.native()) + return gobool(c) +} + +// SetCurrentName is a wrapper around gtk_file_chooser_set_current_name(). +func (v *FileChooser) SetCurrentName(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_file_chooser_set_current_name(v.native(), (*C.gchar)(cstr)) + return +} + +// SetCurrentFolder is a wrapper around gtk_file_chooser_set_current_folder(). +func (v *FileChooser) SetCurrentFolder(folder string) bool { + cstr := C.CString(folder) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_file_chooser_set_current_folder(v.native(), (*C.gchar)(cstr)) + return gobool(c) +} + +// GetCurrentFolder is a wrapper around gtk_file_chooser_get_current_folder(). +func (v *FileChooser) GetCurrentFolder() (string, error) { + c := C.gtk_file_chooser_get_current_folder(v.native()) + if c == nil { + return "", nilPtrErr + } + defer C.free(unsafe.Pointer(c)) + return goString(c), nil +} + +// SetPreviewWidget is a wrapper around gtk_file_chooser_set_preview_widget(). +func (v *FileChooser) SetPreviewWidget(widget IWidget) { + C.gtk_file_chooser_set_preview_widget(v.native(), widget.toWidget()) +} + +// SetPreviewWidgetActive is a wrapper around gtk_file_chooser_set_preview_widget_active(). +func (v *FileChooser) SetPreviewWidgetActive(active bool) { + C.gtk_file_chooser_set_preview_widget_active(v.native(), gbool(active)) +} + +// GetPreviewFilename is a wrapper around gtk_file_chooser_get_preview_filename(). +func (v *FileChooser) GetPreviewFilename() string { + c := C.gtk_file_chooser_get_preview_filename(v.native()) + defer C.free(unsafe.Pointer(c)) + return C.GoString(c) +} + +// GetURI is a wrapper around gtk_file_chooser_get_uri(). +func (v *FileChooser) GetURI() string { + c := C.gtk_file_chooser_get_uri(v.native()) + s := goString(c) + defer C.g_free((C.gpointer)(c)) + return s +} + +// AddFilter is a wrapper around gtk_file_chooser_add_filter(). +func (v *FileChooser) AddFilter(filter *FileFilter) { + C.gtk_file_chooser_add_filter(v.native(), filter.native()) +} + +// RemoveFilter is a wrapper around gtk_file_chooser_remove_filter(). +func (v *FileChooser) RemoveFilter(filter *FileFilter) { + C.gtk_file_chooser_remove_filter(v.native(), filter.native()) +} + +// SetFilter is a wrapper around gtk_file_chooser_set_filter(). +func (v *FileChooser) SetFilter(filter *FileFilter) { + C.gtk_file_chooser_set_filter(v.native(), filter.native()) +} + +// AddShortcutFolder is a wrapper around gtk_file_chooser_add_shortcut_folder(). +func (v *FileChooser) AddShortcutFolder(folder string) bool { + cstr := C.CString(folder) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_file_chooser_add_shortcut_folder(v.native(), cstr, nil) + return gobool(c) +} + +// SetLocalOnly is a wrapper around gtk_file_chooser_set_local_only(). +func (v *FileChooser) SetLocalOnly(value bool) { + C.gtk_file_chooser_set_local_only(v.native(), gbool(value)) +} + +// GetLocalOnly is a wrapper around gtk_file_chooser_get_local_only(). +func (v *FileChooser) GetLocalOnly() bool { + c := C.gtk_file_chooser_get_local_only(v.native()) + return gobool(c) +} + +// SetSelectMultiple is a wrapper around gtk_file_chooser_set_select_multiple(). +func (v *FileChooser) SetSelectMultiple(value bool) { + C.gtk_file_chooser_set_select_multiple(v.native(), gbool(value)) +} + +// GetSelectMultiple is a wrapper around gtk_file_chooser_get_select_multiple(). +func (v *FileChooser) GetSelectMultiple() bool { + c := C.gtk_file_chooser_get_select_multiple(v.native()) + return gobool(c) +} + +/* + * GtkFileChooserButton + */ + +// FileChooserButton is a representation of GTK's GtkFileChooserButton. +type FileChooserButton struct { + Box + + // Interfaces + FileChooser +} + +// native returns a pointer to the underlying GtkFileChooserButton. +func (v *FileChooserButton) native() *C.GtkFileChooserButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkFileChooserButton(p) +} + +func marshalFileChooserButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapFileChooserButton(obj), nil +} + +func wrapFileChooserButton(obj *glib.Object) *FileChooserButton { + if obj == nil { + return nil + } + + fc := wrapFileChooser(obj) + return &FileChooserButton{Box{Container{Widget{glib.InitiallyUnowned{obj}}}}, *fc} +} + +// FileChooserButtonNew is a wrapper around gtk_file_chooser_button_new(). +func FileChooserButtonNew(title string, action FileChooserAction) (*FileChooserButton, error) { + cstr := C.CString(title) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_file_chooser_button_new((*C.gchar)(cstr), + (C.GtkFileChooserAction)(action)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapFileChooserButton(obj), nil +} + +// FileChooserButtonNewWithDialog is a wrapper around gtk_file_chooser_button_new_with_dialog(). +func FileChooserButtonNewWithDialog(dialog IWidget) (*FileChooserButton, error) { + c := C.gtk_file_chooser_button_new_with_dialog(dialog.toWidget()) + if c == nil { + return nil, nilPtrErr + } + return wrapFileChooserButton(glib.Take(unsafe.Pointer(c))), nil +} + +// GetTitle is a wrapper around gtk_file_chooser_button_get_title(). +func (v *FileChooserButton) GetTitle() string { + // docs say: The returned value should not be modified or freed. + return goString(C.gtk_file_chooser_button_get_title(v.native())) +} + +// SetTitle is a wrapper around gtk_file_chooser_button_set_title(). +func (v *FileChooserButton) SetTitle(title string) { + cstr := C.CString(title) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_file_chooser_button_set_title(v.native(), (*C.gchar)(cstr)) +} + +// GetWidthChars is a wrapper around gtk_file_chooser_button_get_width_chars(). +func (v *FileChooserButton) GetWidthChars() int { + return int(C.gtk_file_chooser_button_get_width_chars(v.native())) +} + +// SetWidthChars is a wrapper around gtk_file_chooser_button_set_width_chars(). +func (v *FileChooserButton) SetWidthChars(width int) { + C.gtk_file_chooser_button_set_width_chars(v.native(), C.gint(width)) +} + +/* + * GtkFileChooserDialog + */ + +// FileChooserDialog is a representation of GTK's GtkFileChooserDialog. +type FileChooserDialog struct { + Dialog + + // Interfaces + FileChooser +} + +// native returns a pointer to the underlying GtkFileChooserDialog. +func (v *FileChooserDialog) native() *C.GtkFileChooserDialog { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkFileChooserDialog(p) +} + +func marshalFileChooserDialog(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapFileChooserDialog(obj), nil +} + +func wrapFileChooserDialog(obj *glib.Object) *FileChooserDialog { + if obj == nil { + return nil + } + + fc := wrapFileChooser(obj) + return &FileChooserDialog{Dialog{Window{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}}}, *fc} +} + +// FileChooserDialogNewWith1Button is a wrapper around gtk_file_chooser_dialog_new() with one button. +func FileChooserDialogNewWith1Button( + title string, + parent IWindow, + action FileChooserAction, + first_button_text string, + first_button_id ResponseType) (*FileChooserDialog, error) { + + var w *C.GtkWindow = nil + if parent != nil { + w = parent.toWindow() + } + + c_title := C.CString(title) + defer C.free(unsafe.Pointer(c_title)) + c_first_button_text := C.CString(first_button_text) + defer C.free(unsafe.Pointer(c_first_button_text)) + c := C.gtk_file_chooser_dialog_new_1( + (*C.gchar)(c_title), w, C.GtkFileChooserAction(action), + (*C.gchar)(c_first_button_text), C.int(first_button_id)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapFileChooserDialog(obj), nil +} + +// FileChooserDialogNewWith2Buttons is a wrapper around gtk_file_chooser_dialog_new() with two buttons. +func FileChooserDialogNewWith2Buttons( + title string, + parent IWindow, + action FileChooserAction, + first_button_text string, + first_button_id ResponseType, + second_button_text string, + second_button_id ResponseType) (*FileChooserDialog, error) { + + var w *C.GtkWindow = nil + if parent != nil { + w = parent.toWindow() + } + + c_title := C.CString(title) + defer C.free(unsafe.Pointer(c_title)) + c_first_button_text := C.CString(first_button_text) + defer C.free(unsafe.Pointer(c_first_button_text)) + c_second_button_text := C.CString(second_button_text) + defer C.free(unsafe.Pointer(c_second_button_text)) + c := C.gtk_file_chooser_dialog_new_2( + (*C.gchar)(c_title), w, C.GtkFileChooserAction(action), + (*C.gchar)(c_first_button_text), C.int(first_button_id), + (*C.gchar)(c_second_button_text), C.int(second_button_id)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapFileChooserDialog(obj), nil +} + +/* + * GtkFileChooserWidget + */ + +// FileChooserWidget is a representation of GTK's GtkFileChooserWidget. +type FileChooserWidget struct { + Box + + // Interfaces + FileChooser +} + +// native returns a pointer to the underlying GtkFileChooserWidget. +func (v *FileChooserWidget) native() *C.GtkFileChooserWidget { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkFileChooserWidget(p) +} + +func marshalFileChooserWidget(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapFileChooserWidget(obj), nil +} + +func wrapFileChooserWidget(obj *glib.Object) *FileChooserWidget { + if obj == nil { + return nil + } + + fc := wrapFileChooser(obj) + return &FileChooserWidget{Box{Container{Widget{glib.InitiallyUnowned{obj}}}}, *fc} +} + +// FileChooserWidgetNew is a wrapper around gtk_file_chooser_widget_new(). +func FileChooserWidgetNew(action FileChooserAction) (*FileChooserWidget, error) { + c := C.gtk_file_chooser_widget_new((C.GtkFileChooserAction)(action)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapFileChooserWidget(obj), nil +} + +/* + * GtkFileFilter + */ + +// FileChoser is a representation of GTK's GtkFileFilter GInterface. +type FileFilter struct { + *glib.Object +} + +// native returns a pointer to the underlying GObject as a GtkFileFilter. +func (v *FileFilter) native() *C.GtkFileFilter { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkFileFilter(p) +} + +func marshalFileFilter(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapFileFilter(obj), nil +} + +func wrapFileFilter(obj *glib.Object) *FileFilter { + if obj == nil { + return nil + } + + return &FileFilter{obj} +} + +// FileFilterNew is a wrapper around gtk_file_filter_new(). +func FileFilterNew() (*FileFilter, error) { + c := C.gtk_file_filter_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapFileFilter(obj), nil +} + +// SetName is a wrapper around gtk_file_filter_set_name(). +func (v *FileFilter) SetName(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_file_filter_set_name(v.native(), (*C.gchar)(cstr)) +} + +// GetName is a wrapper around gtk_file_filter_get_name(). +func (v *FileFilter) GetName() (name string) { + cstr := C.gtk_file_filter_get_name(v.native()) + if cstr != nil { + name = goString(cstr) + } + return +} + +// AddMimeType is a wrapper around gtk_file_filter_add_mime_type(). +func (v *FileFilter) AddMimeType(mimeType string) { + cstr := C.CString(mimeType) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_file_filter_add_mime_type(v.native(), (*C.gchar)(cstr)) +} + +// AddPattern is a wrapper around gtk_file_filter_add_pattern(). +func (v *FileFilter) AddPattern(pattern string) { + cstr := C.CString(pattern) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_file_filter_add_pattern(v.native(), (*C.gchar)(cstr)) +} + +// AddPixbufFormats is a wrapper around gtk_file_filter_add_pixbuf_formats(). +func (v *FileFilter) AddPixbufFormats() { + C.gtk_file_filter_add_pixbuf_formats(v.native()) +} + +/* + * GtkFrame + */ + +// Frame is a representation of GTK's GtkFrame. +type Frame struct { + Bin +} + +// native returns a pointer to the underlying GtkFrame. +func (v *Frame) native() *C.GtkFrame { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkFrame(p) +} + +func marshalFrame(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapFrame(obj), nil +} + +func wrapFrame(obj *glib.Object) *Frame { + if obj == nil { + return nil + } + + return &Frame{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// FrameNew is a wrapper around gtk_frame_new(). +func FrameNew(label string) (*Frame, error) { + var cstr *C.char + if label != "" { + cstr = C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + } + c := C.gtk_frame_new((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapFrame(obj), nil +} + +// SetLabel is a wrapper around gtk_frame_set_label(). +func (v *Frame) SetLabel(label string) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_frame_set_label(v.native(), (*C.gchar)(cstr)) +} + +// SetLabelWidget is a wrapper around gtk_frame_set_label_widget(). +func (v *Frame) SetLabelWidget(labelWidget IWidget) { + C.gtk_frame_set_label_widget(v.native(), labelWidget.toWidget()) +} + +// SetLabelAlign is a wrapper around gtk_frame_set_label_align(). +func (v *Frame) SetLabelAlign(xAlign, yAlign float32) { + C.gtk_frame_set_label_align(v.native(), C.gfloat(xAlign), + C.gfloat(yAlign)) +} + +// SetShadowType is a wrapper around gtk_frame_set_shadow_type(). +func (v *Frame) SetShadowType(t ShadowType) { + C.gtk_frame_set_shadow_type(v.native(), C.GtkShadowType(t)) +} + +// GetLabel is a wrapper around gtk_frame_get_label(). +func (v *Frame) GetLabel() string { + c := C.gtk_frame_get_label(v.native()) + return goString(c) +} + +// GetLabelAlign is a wrapper around gtk_frame_get_label_align(). +func (v *Frame) GetLabelAlign() (xAlign, yAlign float32) { + var x, y C.gfloat + C.gtk_frame_get_label_align(v.native(), &x, &y) + return float32(x), float32(y) +} + +// GetLabelWidget is a wrapper around gtk_frame_get_label_widget(). +func (v *Frame) GetLabelWidget() (IWidget, error) { + c := C.gtk_frame_get_label_widget(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// GetShadowType is a wrapper around gtk_frame_get_shadow_type(). +func (v *Frame) GetShadowType() ShadowType { + c := C.gtk_frame_get_shadow_type(v.native()) + return ShadowType(c) +} + +/* + * GtkAspectFrame + */ + +// AspectFrame is a representation of GTK's GtkAspectFrame. +type AspectFrame struct { + Frame +} + +// native returns a pointer to the underlying GtkAspectFrame. +func (v *AspectFrame) native() *C.GtkAspectFrame { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkAspectFrame(p) +} + +func marshalAspectFrame(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapAspectFrame(obj), nil +} + +func wrapAspectFrame(obj *glib.Object) *AspectFrame { + if obj == nil { + return nil + } + + return &AspectFrame{Frame{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}}} +} + +// AspectFrameNew is a wrapper around gtk_aspect_frame_new(). +func AspectFrameNew(label string, xalign, yalign, ratio float32, obeyChild bool) (*AspectFrame, error) { + var cstr *C.char + if label != "" { + cstr = C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + } + c := C.gtk_aspect_frame_new((*C.gchar)(cstr), (C.gfloat)(xalign), (C.gfloat)(yalign), (C.gfloat)(ratio), gbool(obeyChild)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapAspectFrame(obj), nil +} + +// TODO: +// gtk_aspect_frame_set(). + +/* + * GtkGrid + */ + +// Grid is a representation of GTK's GtkGrid. +type Grid struct { + Container + + // Interfaces + Orientable +} + +// native returns a pointer to the underlying GtkGrid. +func (v *Grid) native() *C.GtkGrid { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkGrid(p) +} + +func (v *Grid) toOrientable() *C.GtkOrientable { + if v == nil { + return nil + } + return C.toGtkOrientable(unsafe.Pointer(v.GObject)) +} + +func marshalGrid(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapGrid(obj), nil +} + +func wrapGrid(obj *glib.Object) *Grid { + if obj == nil { + return nil + } + + o := wrapOrientable(obj) + return &Grid{Container{Widget{glib.InitiallyUnowned{obj}}}, *o} +} + +// GridNew() is a wrapper around gtk_grid_new(). +func GridNew() (*Grid, error) { + c := C.gtk_grid_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapGrid(obj), nil +} + +// Attach() is a wrapper around gtk_grid_attach(). +func (v *Grid) Attach(child IWidget, left, top, width, height int) { + C.gtk_grid_attach(v.native(), child.toWidget(), C.gint(left), + C.gint(top), C.gint(width), C.gint(height)) +} + +// AttachNextTo() is a wrapper around gtk_grid_attach_next_to(). +func (v *Grid) AttachNextTo(child, sibling IWidget, side PositionType, width, height int) { + C.gtk_grid_attach_next_to(v.native(), child.toWidget(), + sibling.toWidget(), C.GtkPositionType(side), C.gint(width), + C.gint(height)) +} + +// GetChildAt() is a wrapper around gtk_grid_get_child_at(). +func (v *Grid) GetChildAt(left, top int) (IWidget, error) { + c := C.gtk_grid_get_child_at(v.native(), C.gint(left), C.gint(top)) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// InsertRow() is a wrapper around gtk_grid_insert_row(). +func (v *Grid) InsertRow(position int) { + C.gtk_grid_insert_row(v.native(), C.gint(position)) +} + +// InsertColumn() is a wrapper around gtk_grid_insert_column(). +func (v *Grid) InsertColumn(position int) { + C.gtk_grid_insert_column(v.native(), C.gint(position)) +} + +// InsertNextTo() is a wrapper around gtk_grid_insert_next_to() +func (v *Grid) InsertNextTo(sibling IWidget, side PositionType) { + C.gtk_grid_insert_next_to(v.native(), sibling.toWidget(), + C.GtkPositionType(side)) +} + +// SetRowHomogeneous() is a wrapper around gtk_grid_set_row_homogeneous(). +func (v *Grid) SetRowHomogeneous(homogeneous bool) { + C.gtk_grid_set_row_homogeneous(v.native(), gbool(homogeneous)) +} + +// GetRowHomogeneous() is a wrapper around gtk_grid_get_row_homogeneous(). +func (v *Grid) GetRowHomogeneous() bool { + c := C.gtk_grid_get_row_homogeneous(v.native()) + return gobool(c) +} + +// SetRowSpacing() is a wrapper around gtk_grid_set_row_spacing(). +func (v *Grid) SetRowSpacing(spacing uint) { + C.gtk_grid_set_row_spacing(v.native(), C.guint(spacing)) +} + +// GetRowSpacing() is a wrapper around gtk_grid_get_row_spacing(). +func (v *Grid) GetRowSpacing() uint { + c := C.gtk_grid_get_row_spacing(v.native()) + return uint(c) +} + +// SetColumnHomogeneous() is a wrapper around gtk_grid_set_column_homogeneous(). +func (v *Grid) SetColumnHomogeneous(homogeneous bool) { + C.gtk_grid_set_column_homogeneous(v.native(), gbool(homogeneous)) +} + +// GetColumnHomogeneous() is a wrapper around gtk_grid_get_column_homogeneous(). +func (v *Grid) GetColumnHomogeneous() bool { + c := C.gtk_grid_get_column_homogeneous(v.native()) + return gobool(c) +} + +// SetColumnSpacing() is a wrapper around gtk_grid_set_column_spacing(). +func (v *Grid) SetColumnSpacing(spacing uint) { + C.gtk_grid_set_column_spacing(v.native(), C.guint(spacing)) +} + +// GetColumnSpacing() is a wrapper around gtk_grid_get_column_spacing(). +func (v *Grid) GetColumnSpacing() uint { + c := C.gtk_grid_get_column_spacing(v.native()) + return uint(c) +} + +/* + * GtkIconTheme + */ + +// IconTheme is a representation of GTK's GtkIconTheme +type IconTheme struct { + Theme *C.GtkIconTheme +} + +// IconThemeGetDefault is a wrapper around gtk_icon_theme_get_default(). +func IconThemeGetDefault() (*IconTheme, error) { + c := C.gtk_icon_theme_get_default() + if c == nil { + return nil, nilPtrErr + } + return &IconTheme{c}, nil +} + +// IconThemeGetForScreen is a wrapper around gtk_icon_theme_get_for_screen(). +func IconThemeGetForScreen(screen gdk.Screen) (*IconTheme, error) { + cScreen := (*C.GdkScreen)(unsafe.Pointer(screen.Native())) + c := C.gtk_icon_theme_get_for_screen(cScreen) + if c == nil { + return nil, nilPtrErr + } + return &IconTheme{c}, nil +} + +// LoadIcon is a wrapper around gtk_icon_theme_load_icon(). +func (v *IconTheme) LoadIcon(iconName string, size int, flags IconLookupFlags) (*gdk.Pixbuf, error) { + cstr := C.CString(iconName) + defer C.free(unsafe.Pointer(cstr)) + var err *C.GError = nil + c := C.gtk_icon_theme_load_icon(v.Theme, (*C.gchar)(cstr), C.gint(size), C.GtkIconLookupFlags(flags), &err) + if c == nil { + defer C.g_error_free(err) + return nil, errors.New(goString(err.message)) + } + return &gdk.Pixbuf{glib.Take(unsafe.Pointer(c))}, nil +} + +// HasIcon is a wrapper around gtk_icon_theme_has_icon(). +func (v *IconTheme) HasIcon(iconName string) bool { + cstr := C.CString(iconName) + defer C.free(unsafe.Pointer(cstr)) + + c := C.gtk_icon_theme_has_icon(v.Theme, (*C.gchar)(cstr)) + return gobool(c) +} + +/* + * GtkImage + */ + +// Image is a representation of GTK's GtkImage. +type Image struct { + Widget +} + +// native returns a pointer to the underlying GtkImage. +func (v *Image) native() *C.GtkImage { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkImage(p) +} + +func marshalImage(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapImage(obj), nil +} + +func wrapImage(obj *glib.Object) *Image { + if obj == nil { + return nil + } + + return &Image{Widget{glib.InitiallyUnowned{obj}}} +} + +// ImageNew() is a wrapper around gtk_image_new(). +func ImageNew() (*Image, error) { + c := C.gtk_image_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapImage(obj), nil +} + +// ImageNewFromFile() is a wrapper around gtk_image_new_from_file(). +func ImageNewFromFile(filename string) (*Image, error) { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_image_new_from_file((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapImage(obj), nil +} + +// ImageNewFromResource() is a wrapper around gtk_image_new_from_resource(). +func ImageNewFromResource(resourcePath string) (*Image, error) { + cstr := C.CString(resourcePath) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_image_new_from_resource((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapImage(obj), nil +} + +// ImageNewFromPixbuf is a wrapper around gtk_image_new_from_pixbuf(). +func ImageNewFromPixbuf(pixbuf *gdk.Pixbuf) (*Image, error) { + c := C.gtk_image_new_from_pixbuf((*C.GdkPixbuf)(pixbuf.NativePrivate())) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapImage(obj), nil +} + +// ImageNewFromIconName() is a wrapper around gtk_image_new_from_icon_name(). +func ImageNewFromIconName(iconName string, size IconSize) (*Image, error) { + cstr := C.CString(iconName) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_image_new_from_icon_name((*C.gchar)(cstr), + C.GtkIconSize(size)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapImage(obj), nil +} + +// ImageNewFromGIcon is a wrapper around gtk_image_new_from_gicon() +func ImageNewFromGIcon(icon *glib.Icon, size IconSize) (*Image, error) { + c := C.gtk_image_new_from_gicon( + (*C.GIcon)(icon.NativePrivate()), + C.GtkIconSize(size)) + + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapImage(obj), nil +} + +// Clear() is a wrapper around gtk_image_clear(). +func (v *Image) Clear() { + C.gtk_image_clear(v.native()) +} + +// SetFromFile() is a wrapper around gtk_image_set_from_file(). +func (v *Image) SetFromFile(filename string) { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_image_set_from_file(v.native(), (*C.gchar)(cstr)) +} + +// SetFromResource() is a wrapper around gtk_image_set_from_resource(). +func (v *Image) SetFromResource(resourcePath string) { + cstr := C.CString(resourcePath) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_image_set_from_resource(v.native(), (*C.gchar)(cstr)) +} + +// SetFromFixbuf is a wrapper around gtk_image_set_from_pixbuf(). +func (v *Image) SetFromPixbuf(pixbuf *gdk.Pixbuf) { + pbptr := (*C.GdkPixbuf)(unsafe.Pointer(pixbuf.Native())) + C.gtk_image_set_from_pixbuf(v.native(), pbptr) +} + +// SetFromIconName() is a wrapper around gtk_image_set_from_icon_name(). +func (v *Image) SetFromIconName(iconName string, size IconSize) { + cstr := C.CString(iconName) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_image_set_from_icon_name(v.native(), (*C.gchar)(cstr), + C.GtkIconSize(size)) +} + +// SetFromGIcon is a wrapper around gtk_image_set_from_gicon() +func (v *Image) SetFromGIcon(icon *glib.Icon, size IconSize) { + C.gtk_image_set_from_gicon( + v.native(), + (*C.GIcon)(icon.NativePrivate()), + C.GtkIconSize(size)) +} + +// SetPixelSize() is a wrapper around gtk_image_set_pixel_size(). +func (v *Image) SetPixelSize(pixelSize int) { + C.gtk_image_set_pixel_size(v.native(), C.gint(pixelSize)) +} + +// GetStorageType() is a wrapper around gtk_image_get_storage_type(). +func (v *Image) GetStorageType() ImageType { + c := C.gtk_image_get_storage_type(v.native()) + return ImageType(c) +} + +// GetPixbuf() is a wrapper around gtk_image_get_pixbuf(). +func (v *Image) GetPixbuf() *gdk.Pixbuf { + c := C.gtk_image_get_pixbuf(v.native()) + if c == nil { + return nil + } + + pb := &gdk.Pixbuf{glib.Take(unsafe.Pointer(c))} + return pb +} + +// GetAnimation() is a wrapper around gtk_image_get_animation() +func (v *Image) GetAnimation() *gdk.PixbufAnimation { + c := C.gtk_image_get_animation(v.native()) + if c == nil { + return nil + } + return &gdk.PixbufAnimation{glib.Take(unsafe.Pointer(c))} +} + +// ImageNewFromAnimation() is a wrapper around gtk_image_new_from_animation() +func ImageNewFromAnimation(animation *gdk.PixbufAnimation) (*Image, error) { + c := C.gtk_image_new_from_animation((*C.GdkPixbufAnimation)(animation.NativePrivate())) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapImage(obj), nil +} + +// SetFromAnimation is a wrapper around gtk_image_set_from_animation(). +func (v *Image) SetFromAnimation(animation *gdk.PixbufAnimation) { + pbaptr := (*C.GdkPixbufAnimation)(unsafe.Pointer(animation.NativePrivate())) + C.gtk_image_set_from_animation(v.native(), pbaptr) +} + +// GetIconName() is a wrapper around gtk_image_get_icon_name(). +func (v *Image) GetIconName() (string, IconSize) { + var iconName *C.gchar + var size C.GtkIconSize + C.gtk_image_get_icon_name(v.native(), &iconName, &size) + return goString(iconName), IconSize(size) +} + +// GetGIcon is a wrapper around gtk_image_get_gicon() +func (v *Image) GetGIcon() (*glib.Icon, IconSize, error) { + var gicon *C.GIcon + var size *C.GtkIconSize + C.gtk_image_get_gicon( + v.native(), + &gicon, + size) + + if gicon == nil { + return nil, ICON_SIZE_INVALID, nilPtrErr + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(gicon))} + i := &glib.Icon{obj} + + runtime.SetFinalizer(i, func(_ interface{}) { obj.Unref() }) + return i, IconSize(*size), nil +} + +// GetPixelSize() is a wrapper around gtk_image_get_pixel_size(). +func (v *Image) GetPixelSize() int { + c := C.gtk_image_get_pixel_size(v.native()) + return int(c) +} + +// added by terrak +/* + * GtkLayout + */ + +// Layout is a representation of GTK's GtkLayout. +type Layout struct { + Container +} + +// native returns a pointer to the underlying GtkDrawingArea. +func (v *Layout) native() *C.GtkLayout { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkLayout(p) +} + +func marshalLayout(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapLayout(obj), nil +} + +func wrapLayout(obj *glib.Object) *Layout { + if obj == nil { + return nil + } + + return &Layout{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// LayoutNew is a wrapper around gtk_layout_new(). +func LayoutNew(hadjustment, vadjustment *Adjustment) (*Layout, error) { + c := C.gtk_layout_new(hadjustment.native(), vadjustment.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapLayout(obj), nil +} + +// Layout.Put is a wrapper around gtk_layout_put(). +func (v *Layout) Put(w IWidget, x, y int) { + C.gtk_layout_put(v.native(), w.toWidget(), C.gint(x), C.gint(y)) +} + +// Layout.Move is a wrapper around gtk_layout_move(). +func (v *Layout) Move(w IWidget, x, y int) { + C.gtk_layout_move(v.native(), w.toWidget(), C.gint(x), C.gint(y)) +} + +// Layout.SetSize is a wrapper around gtk_layout_set_size +func (v *Layout) SetSize(width, height uint) { + C.gtk_layout_set_size(v.native(), C.guint(width), C.guint(height)) +} + +// Layout.GetSize is a wrapper around gtk_layout_get_size +func (v *Layout) GetSize() (width, height uint) { + var w, h C.guint + C.gtk_layout_get_size(v.native(), &w, &h) + return uint(w), uint(h) +} + +// TODO: +// gtk_layout_get_bin_window(). + +/* + * GtkLinkButton + */ + +// LinkButton is a representation of GTK's GtkLinkButton. +type LinkButton struct { + Button +} + +// native returns a pointer to the underlying GtkLinkButton. +func (v *LinkButton) native() *C.GtkLinkButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkLinkButton(p) +} + +func marshalLinkButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapLinkButton(obj), nil +} + +func wrapLinkButton(obj *glib.Object) *LinkButton { + if obj == nil { + return nil + } + + actionable := wrapActionable(obj) + return &LinkButton{Button{Bin{Container{Widget{ + glib.InitiallyUnowned{obj}}}}, actionable}} +} + +// LinkButtonNew is a wrapper around gtk_link_button_new(). +func LinkButtonNew(label string) (*LinkButton, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_link_button_new((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapLinkButton(glib.Take(unsafe.Pointer(c))), nil +} + +// LinkButtonNewWithLabel is a wrapper around gtk_link_button_new_with_label(). +func LinkButtonNewWithLabel(uri, label string) (*LinkButton, error) { + curi := C.CString(uri) + defer C.free(unsafe.Pointer(curi)) + clabel := C.CString(label) + defer C.free(unsafe.Pointer(clabel)) + c := C.gtk_link_button_new_with_label((*C.gchar)(curi), (*C.gchar)(clabel)) + if c == nil { + return nil, nilPtrErr + } + return wrapLinkButton(glib.Take(unsafe.Pointer(c))), nil +} + +// GetUri is a wrapper around gtk_link_button_get_uri(). +func (v *LinkButton) GetUri() string { + c := C.gtk_link_button_get_uri(v.native()) + return goString(c) +} + +// SetUri is a wrapper around gtk_link_button_set_uri(). +func (v *LinkButton) SetUri(uri string) { + cstr := C.CString(uri) + C.gtk_link_button_set_uri(v.native(), (*C.gchar)(cstr)) +} + +// GetVisited is a wrapper around gtk_link_button_get_visited(). +func (v *LinkButton) GetVisited() bool { + c := C.gtk_link_button_get_visited(v.native()) + return gobool(c) +} + +// SetVisited is a wrapper around gtk_link_button_set_visited(). +func (v *LinkButton) SetVisited(visited bool) { + C.gtk_link_button_set_visited(v.native(), gbool(visited)) +} + +/* + * GtkLockButton + */ + +// LockButton is a representation of GTK's GtkLockButton. +type LockButton struct { + Button +} + +// native returns a pointer to the underlying GtkLockButton. +func (v *LockButton) native() *C.GtkLockButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkLockButton(p) +} + +func marshalLockButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapLockButton(obj), nil +} + +func wrapLockButton(obj *glib.Object) *LockButton { + if obj == nil { + return nil + } + + actionable := wrapActionable(obj) + return &LockButton{Button{Bin{Container{Widget{ + glib.InitiallyUnowned{obj}}}}, actionable}} +} + +// LockButtonNew is a wrapper around gtk_lock_button_new(). +func LockButtonNew(permission *glib.Permission) (*LockButton, error) { + c := C.gtk_lock_button_new(nativeGPermission(permission)) + if c == nil { + return nil, nilPtrErr + } + return wrapLockButton(glib.Take(unsafe.Pointer(c))), nil +} + +// GetPermission is a wrapper around gtk_lock_button_get_permission(). +func (v *LockButton) GetPermission() *glib.Permission { + c := C.gtk_lock_button_get_permission(v.native()) + return glib.WrapPermission(unsafe.Pointer(c)) +} + +// SetPermission is a wrapper around gtk_lock_button_set_permission(). +func (v *LockButton) SetPermission(permission *glib.Permission) { + C.gtk_lock_button_set_permission(v.native(), nativeGPermission(permission)) +} + +/* + * GtkListStore + */ + +// ListStore is a representation of GTK's GtkListStore. +type ListStore struct { + *glib.Object + + // Interfaces + TreeModel + TreeSortable +} + +// native returns a pointer to the underlying GtkListStore. +func (v *ListStore) native() *C.GtkListStore { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkListStore(p) +} + +func marshalListStore(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapListStore(obj), nil +} + +func wrapListStore(obj *glib.Object) *ListStore { + if obj == nil { + return nil + } + + tm := wrapTreeModel(obj) + ts := wrapTreeSortable(obj) + return &ListStore{obj, *tm, *ts} +} + +func (v *ListStore) toTreeModel() *C.GtkTreeModel { + if v == nil { + return nil + } + return C.toGtkTreeModel(unsafe.Pointer(v.GObject)) +} + +func (v *ListStore) toTreeSortable() *C.GtkTreeSortable { + if v == nil { + return nil + } + return C.toGtkTreeSortable(unsafe.Pointer(v.GObject)) +} + +// ListStoreNew is a wrapper around gtk_list_store_newv(). +func ListStoreNew(types ...glib.Type) (*ListStore, error) { + gtypes := C.alloc_types(C.int(len(types))) + for n, val := range types { + C.set_type(gtypes, C.int(n), C.GType(val)) + } + defer C.g_free(C.gpointer(gtypes)) + c := C.gtk_list_store_newv(C.gint(len(types)), gtypes) + if c == nil { + return nil, nilPtrErr + } + + ls := wrapListStore(glib.Take(unsafe.Pointer(c))) + return ls, nil +} + +// Remove is a wrapper around gtk_list_store_remove(). +func (v *ListStore) Remove(iter *TreeIter) bool { + c := C.gtk_list_store_remove(v.native(), iter.native()) + return gobool(c) +} + +// SetColumnTypes is a wrapper around gtk_list_store_set_column_types(). +// The size of glib.Type must match the number of columns +func (v *ListStore) SetColumnTypes(types ...glib.Type) { + gtypes := C.alloc_types(C.int(len(types))) + for n, val := range types { + C.set_type(gtypes, C.int(n), C.GType(val)) + } + defer C.g_free(C.gpointer(gtypes)) + C.gtk_list_store_set_column_types(v.native(), C.gint(len(types)), gtypes) +} + +// Set() is a wrapper around gtk_list_store_set_value() but provides +// a function similar to gtk_list_store_set() in that multiple columns +// may be set by one call. The length of columns and values slices must +// match, or Set() will return a non-nil error. +// +// As an example, a call to: +// store.Set(iter, []int{0, 1}, []interface{}{"Foo", "Bar"}) +// is functionally equivalent to calling the native C GTK function: +// gtk_list_store_set(store, iter, 0, "Foo", 1, "Bar", -1); +func (v *ListStore) Set(iter *TreeIter, columns []int, values []interface{}) error { + if len(columns) != len(values) { + return errors.New("columns and values lengths do not match") + } + for i, val := range values { + v.SetValue(iter, columns[i], val) + } + return nil +} + +// SetValue is a wrapper around gtk_list_store_set_value(). +func (v *ListStore) SetValue(iter *TreeIter, column int, value interface{}) error { + switch value.(type) { + case *gdk.Pixbuf: + pix := value.(*gdk.Pixbuf) + C._gtk_list_store_set(v.native(), iter.native(), C.gint(column), unsafe.Pointer(pix.Native())) + + default: + gv, err := glib.GValue(value) + if err != nil { + return err + } + + C.gtk_list_store_set_value(v.native(), iter.native(), + C.gint(column), + (*C.GValue)(unsafe.Pointer(gv.Native()))) + } + + return nil +} + +// func (v *ListStore) Model(model ITreeModel) { +// obj := &glib.Object{glib.ToGObject(unsafe.Pointer(model.toTreeModel()))} +// v.TreeModel = *wrapTreeModel(obj) +//} + +func (v *ListStore) SetCols(iter *TreeIter, cols Cols) error { + for key, value := range cols { + err := v.SetValue(iter, key, value) + if err != nil { + return err + } + } + return nil +} + +// Convenient map for Columns and values (See ListStore, TreeStore) +type Cols map[int]interface{} + +// InsertWithValues() is a wrapper around gtk_list_store_insert_with_valuesv(). +func (v *ListStore) InsertWithValues(iter *TreeIter, position int, inColumns []int, inValues []interface{}) error { + length := len(inColumns) + if len(inValues) < length { + length = len(inValues) + } + + var cColumns []C.gint + var cValues []C.GValue + for i := 0; i < length; i++ { + cColumns = append(cColumns, C.gint(inColumns[i])) + + gv, err := glib.GValue(inValues[i]) + if err != nil { + return err + } + + var cvp *C.GValue = (*C.GValue)(unsafe.Pointer(gv.Native())) + cValues = append(cValues, *cvp) + } + var cColumnsPointer *C.gint + if len(cColumns) > 0 { + cColumnsPointer = &cColumns[0] + } + var cValuesPointer *C.GValue + if len(cValues) > 0 { + cValuesPointer = &cValues[0] + } + + C.gtk_list_store_insert_with_valuesv(v.native(), iter.native(), C.gint(position), cColumnsPointer, cValuesPointer, C.gint(length)) + + return nil +} + +// Insert() is a wrapper around gtk_list_store_insert(). +func (v *ListStore) Insert(position int) *TreeIter { + var ti C.GtkTreeIter + C.gtk_list_store_insert(v.native(), &ti, C.gint(position)) + iter := &TreeIter{ti} + return iter +} + +// InsertBefore() is a wrapper around gtk_list_store_insert_before(). +func (v *ListStore) InsertBefore(sibling *TreeIter) *TreeIter { + var ti C.GtkTreeIter + C.gtk_list_store_insert_before(v.native(), &ti, sibling.native()) + iter := &TreeIter{ti} + return iter +} + +// InsertAfter() is a wrapper around gtk_list_store_insert_after(). +func (v *ListStore) InsertAfter(sibling *TreeIter) *TreeIter { + var ti C.GtkTreeIter + C.gtk_list_store_insert_after(v.native(), &ti, sibling.native()) + iter := &TreeIter{ti} + return iter +} + +// Prepend() is a wrapper around gtk_list_store_prepend(). +func (v *ListStore) Prepend() *TreeIter { + var ti C.GtkTreeIter + C.gtk_list_store_prepend(v.native(), &ti) + iter := &TreeIter{ti} + return iter +} + +// Append() is a wrapper around gtk_list_store_append(). +func (v *ListStore) Append() *TreeIter { + var ti C.GtkTreeIter + C.gtk_list_store_append(v.native(), &ti) + iter := &TreeIter{ti} + return iter +} + +// Clear() is a wrapper around gtk_list_store_clear(). +func (v *ListStore) Clear() { + C.gtk_list_store_clear(v.native()) +} + +// IterIsValid() is a wrapper around gtk_list_store_iter_is_valid(). +func (v *ListStore) IterIsValid(iter *TreeIter) bool { + c := C.gtk_list_store_iter_is_valid(v.native(), iter.native()) + return gobool(c) +} + +// TODO(jrick) +/* +func (v *ListStore) Reorder(newOrder []int) { +} +*/ + +// Swap() is a wrapper around gtk_list_store_swap(). +func (v *ListStore) Swap(a, b *TreeIter) { + C.gtk_list_store_swap(v.native(), a.native(), b.native()) +} + +// MoveBefore() is a wrapper around gtk_list_store_move_before(). +func (v *ListStore) MoveBefore(iter, position *TreeIter) { + C.gtk_list_store_move_before(v.native(), iter.native(), + position.native()) +} + +// MoveAfter() is a wrapper around gtk_list_store_move_after(). +func (v *ListStore) MoveAfter(iter, position *TreeIter) { + C.gtk_list_store_move_after(v.native(), iter.native(), + position.native()) +} + +/* + * GtkMenuBar + */ + +// MenuBar is a representation of GTK's GtkMenuBar. +type MenuBar struct { + MenuShell +} + +// native() returns a pointer to the underlying GtkMenuBar. +func (v *MenuBar) native() *C.GtkMenuBar { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkMenuBar(p) +} + +func marshalMenuBar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapMenuBar(obj), nil +} + +func wrapMenuBar(obj *glib.Object) *MenuBar { + if obj == nil { + return nil + } + + return &MenuBar{MenuShell{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// MenuBarNew() is a wrapper around gtk_menu_bar_new(). +func MenuBarNew() (*MenuBar, error) { + c := C.gtk_menu_bar_new() + if c == nil { + return nil, nilPtrErr + } + return wrapMenuBar(glib.Take(unsafe.Pointer(c))), nil +} + +/* + * GtkMenuButton + */ + +// MenuButton is a representation of GTK's GtkMenuButton. +type MenuButton struct { + ToggleButton +} + +// native returns a pointer to the underlying GtkMenuButton. +func (v *MenuButton) native() *C.GtkMenuButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkMenuButton(p) +} + +func marshalMenuButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapMenuButton(obj), nil +} + +func wrapMenuButton(obj *glib.Object) *MenuButton { + if obj == nil { + return nil + } + + actionable := wrapActionable(obj) + return &MenuButton{ToggleButton{Button{Bin{Container{Widget{ + glib.InitiallyUnowned{obj}}}}, actionable}}} +} + +// MenuButtonNew is a wrapper around gtk_menu_button_new(). +func MenuButtonNew() (*MenuButton, error) { + c := C.gtk_menu_button_new() + if c == nil { + return nil, nilPtrErr + } + return wrapMenuButton(glib.Take(unsafe.Pointer(c))), nil +} + +// SetPopup is a wrapper around gtk_menu_button_set_popup(). +func (v *MenuButton) SetPopup(menu IMenu) { + C.gtk_menu_button_set_popup(v.native(), menu.toWidget()) +} + +// GetPopup is a wrapper around gtk_menu_button_get_popup(). +func (v *MenuButton) GetPopup() *Menu { + c := C.gtk_menu_button_get_popup(v.native()) + if c == nil { + return nil + } + return wrapMenu(glib.Take(unsafe.Pointer(c))) +} + +// SetMenuModel is a wrapper around gtk_menu_button_set_menu_model(). +func (v *MenuButton) SetMenuModel(menuModel *glib.MenuModel) { + C.gtk_menu_button_set_menu_model(v.native(), C.toGMenuModel(unsafe.Pointer(menuModel.Native()))) +} + +// GetMenuModel is a wrapper around gtk_menu_button_get_menu_model(). +func (v *MenuButton) GetMenuModel() *glib.MenuModel { + c := C.gtk_menu_button_get_menu_model(v.native()) + if c == nil { + return nil + } + return &glib.MenuModel{glib.Take(unsafe.Pointer(c))} +} + +// SetDirection is a wrapper around gtk_menu_button_set_direction(). +func (v *MenuButton) SetDirection(direction ArrowType) { + C.gtk_menu_button_set_direction(v.native(), C.GtkArrowType(direction)) +} + +// GetDirection is a wrapper around gtk_menu_button_get_direction(). +func (v *MenuButton) GetDirection() ArrowType { + c := C.gtk_menu_button_get_direction(v.native()) + return ArrowType(c) +} + +// SetAlignWidget is a wrapper around gtk_menu_button_set_align_widget(). +func (v *MenuButton) SetAlignWidget(alignWidget IWidget) { + C.gtk_menu_button_set_align_widget(v.native(), alignWidget.toWidget()) +} + +// GetAlignWidget is a wrapper around gtk_menu_button_get_align_widget(). +func (v *MenuButton) GetAlignWidget() (IWidget, error) { + c := C.gtk_menu_button_get_align_widget(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +/* + * GtkMenuItem + */ + +// MenuItem is a representation of GTK's GtkMenuItem. +type MenuItem struct { + Bin +} + +// IMenuItem is an interface type implemented by all structs +// embedding a MenuItem. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkMenuItem. +type IMenuItem interface { + toMenuItem() *C.GtkMenuItem + toWidget() *C.GtkWidget +} + +// native returns a pointer to the underlying GtkMenuItem. +func (v *MenuItem) native() *C.GtkMenuItem { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkMenuItem(p) +} + +func (v *MenuItem) toMenuItem() *C.GtkMenuItem { + if v == nil { + return nil + } + return v.native() +} + +func marshalMenuItem(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapMenuItem(obj), nil +} + +func wrapMenuItem(obj *glib.Object) *MenuItem { + if obj == nil { + return nil + } + + return &MenuItem{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// MenuItemNew() is a wrapper around gtk_menu_item_new(). +func MenuItemNew() (*MenuItem, error) { + c := C.gtk_menu_item_new() + if c == nil { + return nil, nilPtrErr + } + return wrapMenuItem(glib.Take(unsafe.Pointer(c))), nil +} + +// MenuItemNewWithLabel() is a wrapper around gtk_menu_item_new_with_label(). +func MenuItemNewWithLabel(label string) (*MenuItem, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_menu_item_new_with_label((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapMenuItem(glib.Take(unsafe.Pointer(c))), nil +} + +// MenuItemNewWithMnemonic() is a wrapper around gtk_menu_item_new_with_mnemonic(). +func MenuItemNewWithMnemonic(label string) (*MenuItem, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_menu_item_new_with_mnemonic((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapMenuItem(glib.Take(unsafe.Pointer(c))), nil +} + +// SetSubmenu() is a wrapper around gtk_menu_item_set_submenu(). +func (v *MenuItem) SetSubmenu(submenu IWidget) { + C.gtk_menu_item_set_submenu(v.native(), submenu.toWidget()) +} + +// GetSubmenu is a wrapper around gtk_menu_item_get_submenu(). +func (v *MenuItem) GetSubmenu() (IMenu, error) { + c := C.gtk_menu_item_get_submenu(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapMenu(obj), nil +} + +// SetLabel is a wrapper around gtk_menu_item_set_label(). +func (v *MenuItem) SetLabel(label string) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_menu_item_set_label(v.native(), (*C.gchar)(cstr)) +} + +// GetLabel is a wrapper around gtk_menu_item_get_label(). +func (v *MenuItem) GetLabel() string { + l := C.gtk_menu_item_get_label(v.native()) + return goString(l) +} + +// SetUseUnderline() is a wrapper around gtk_menu_item_set_use_underline() +func (v *MenuItem) SetUseUnderline(settings bool) { + C.gtk_menu_item_set_use_underline(v.native(), gbool(settings)) +} + +// GetUseUnderline() is a wrapper around gtk_menu_item_get_use_underline() +func (v *MenuItem) GetUseUnderline() bool { + c := C.gtk_menu_item_get_use_underline(v.native()) + return gobool(c) +} + +// Select is a wrapper around gtk_menu_item_select() +func (v *MenuItem) Select() { + C.gtk_menu_item_select(v.native()) +} + +// Deselect is a wrapper around gtk_menu_item_deselect() +func (v *MenuItem) Deselect() { + C.gtk_menu_item_deselect(v.native()) +} + +// Activate is a wrapper around gtk_menu_item_activate() +func (v *MenuItem) Activate() { + C.gtk_menu_item_activate(v.native()) +} + +// ToggleSizeRequest is a wrapper around gtk_menu_item_toggle_size_request() +func (v *MenuItem) ToggleSizeRequest(requisition int) int { + cint := new(C.gint) + *cint = C.gint(requisition) + C.gtk_menu_item_toggle_size_request(v.native(), cint) + return int(*cint) +} + +// ToggleSizeAllocate is a wrapper around gtk_menu_item_toggle_size_allocate() +func (v *MenuItem) ToggleSizeAllocate(allocation int) { + C.gtk_menu_item_toggle_size_allocate(v.native(), C.gint(allocation)) +} + +// GetReserveIndicator is a wrapper around gtk_menu_item_get_reserve_indicator(). +func (v *MenuItem) GetReserveIndicator() bool { + return gobool(C.gtk_menu_item_get_reserve_indicator(v.native())) +} + +// SetReserveIndicator is a wrapper around gtk_menu_item_set_reserve_indicator(). +func (v *MenuItem) SetReserveIndicator(reserve bool) { + C.gtk_menu_item_set_reserve_indicator(v.native(), gbool(reserve)) +} + +/* + * GtkMessageDialog + */ + +// MessageDialog is a representation of GTK's GtkMessageDialog. +type MessageDialog struct { + Dialog +} + +// native returns a pointer to the underlying GtkMessageDialog. +func (v *MessageDialog) native() *C.GtkMessageDialog { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkMessageDialog(p) +} + +func marshalMessageDialog(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapMessageDialog(obj), nil +} + +func wrapMessageDialog(obj *glib.Object) *MessageDialog { + if obj == nil { + return nil + } + + return &MessageDialog{Dialog{Window{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}}}} +} + +// MessageDialogNew() is a wrapper around gtk_message_dialog_new(). +// The text is created and formatted by the format specifier and any +// additional arguments. +func MessageDialogNew(parent IWindow, flags DialogFlags, mType MessageType, buttons ButtonsType, format string, args ...interface{}) *MessageDialog { + s := fmt.Sprintf(format, args...) + cstr := C.CString(s) + defer C.free(unsafe.Pointer(cstr)) + var w *C.GtkWindow = nil + if parent != nil { + w = parent.toWindow() + } + c := C._gtk_message_dialog_new(w, + C.GtkDialogFlags(flags), C.GtkMessageType(mType), + C.GtkButtonsType(buttons), cstr) + return wrapMessageDialog(glib.Take(unsafe.Pointer(c))) +} + +// MessageDialogNewWithMarkup is a wrapper around +// gtk_message_dialog_new_with_markup(). +func MessageDialogNewWithMarkup(parent IWindow, flags DialogFlags, mType MessageType, buttons ButtonsType, format string, args ...interface{}) *MessageDialog { + s := fmt.Sprintf(format, args...) + cstr := C.CString(s) + defer C.free(unsafe.Pointer(cstr)) + var w *C.GtkWindow = nil + if parent != nil { + w = parent.toWindow() + } + c := C._gtk_message_dialog_new_with_markup(w, + C.GtkDialogFlags(flags), C.GtkMessageType(mType), + C.GtkButtonsType(buttons), cstr) + return wrapMessageDialog(glib.Take(unsafe.Pointer(c))) +} + +// SetMarkup is a wrapper around gtk_message_dialog_set_markup(). +func (v *MessageDialog) SetMarkup(str string) { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_message_dialog_set_markup(v.native(), (*C.gchar)(cstr)) +} + +// FormatSecondaryText is a wrapper around +// gtk_message_dialog_format_secondary_text(). +func (v *MessageDialog) FormatSecondaryText(format string, args ...interface{}) { + s := fmt.Sprintf(format, args...) + cstr := C.CString(s) + defer C.free(unsafe.Pointer(cstr)) + C._gtk_message_dialog_format_secondary_text(v.native(), + (*C.gchar)(cstr)) +} + +// FormatSecondaryMarkup is a wrapper around +// gtk_message_dialog_format_secondary_text(). +func (v *MessageDialog) FormatSecondaryMarkup(format string, args ...interface{}) { + s := fmt.Sprintf(format, args...) + cstr := C.CString(s) + defer C.free(unsafe.Pointer(cstr)) + C._gtk_message_dialog_format_secondary_markup(v.native(), + (*C.gchar)(cstr)) +} + +// GetMessageArea() is a wrapper around gtk_message_dialog_get_message_area(). +func (v *MessageDialog) GetMessageArea() (*Box, error) { + c := C.gtk_message_dialog_get_message_area(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + b := &Box{Container{Widget{glib.InitiallyUnowned{obj}}}} + return b, nil +} + +/* + * GtkNotebook + */ + +// Notebook is a representation of GTK's GtkNotebook. +type Notebook struct { + Container +} + +// native returns a pointer to the underlying GtkNotebook. +func (v *Notebook) native() *C.GtkNotebook { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkNotebook(p) +} + +func marshalNotebook(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapNotebook(obj), nil +} + +func wrapNotebook(obj *glib.Object) *Notebook { + if obj == nil { + return nil + } + + return &Notebook{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// NotebookNew() is a wrapper around gtk_notebook_new(). +func NotebookNew() (*Notebook, error) { + c := C.gtk_notebook_new() + if c == nil { + return nil, nilPtrErr + } + return wrapNotebook(glib.Take(unsafe.Pointer(c))), nil +} + +// AppendPage() is a wrapper around gtk_notebook_append_page(). +func (v *Notebook) AppendPage(child IWidget, tabLabel IWidget) int { + cTabLabel := nullableWidget(tabLabel) + c := C.gtk_notebook_append_page(v.native(), child.toWidget(), cTabLabel) + return int(c) +} + +// AppendPageMenu() is a wrapper around gtk_notebook_append_page_menu(). +func (v *Notebook) AppendPageMenu(child IWidget, tabLabel IWidget, menuLabel IWidget) int { + c := C.gtk_notebook_append_page_menu(v.native(), child.toWidget(), + tabLabel.toWidget(), menuLabel.toWidget()) + return int(c) +} + +// PrependPage() is a wrapper around gtk_notebook_prepend_page(). +func (v *Notebook) PrependPage(child IWidget, tabLabel IWidget) int { + cTabLabel := nullableWidget(tabLabel) + c := C.gtk_notebook_prepend_page(v.native(), child.toWidget(), cTabLabel) + return int(c) +} + +// PrependPageMenu() is a wrapper around gtk_notebook_prepend_page_menu(). +func (v *Notebook) PrependPageMenu(child IWidget, tabLabel IWidget, menuLabel IWidget) int { + c := C.gtk_notebook_prepend_page_menu(v.native(), child.toWidget(), + tabLabel.toWidget(), menuLabel.toWidget()) + return int(c) +} + +// InsertPage() is a wrapper around gtk_notebook_insert_page(). +func (v *Notebook) InsertPage(child IWidget, tabLabel IWidget, position int) int { + label := nullableWidget(tabLabel) + c := C.gtk_notebook_insert_page(v.native(), child.toWidget(), label, C.gint(position)) + + return int(c) +} + +// InsertPageMenu() is a wrapper around gtk_notebook_insert_page_menu(). +func (v *Notebook) InsertPageMenu(child IWidget, tabLabel IWidget, menuLabel IWidget, position int) int { + c := C.gtk_notebook_insert_page_menu(v.native(), child.toWidget(), + tabLabel.toWidget(), menuLabel.toWidget(), C.gint(position)) + return int(c) +} + +// RemovePage() is a wrapper around gtk_notebook_remove_page(). +func (v *Notebook) RemovePage(pageNum int) { + C.gtk_notebook_remove_page(v.native(), C.gint(pageNum)) +} + +// PageNum() is a wrapper around gtk_notebook_page_num(). +func (v *Notebook) PageNum(child IWidget) int { + c := C.gtk_notebook_page_num(v.native(), child.toWidget()) + return int(c) +} + +// NextPage() is a wrapper around gtk_notebook_next_page(). +func (v *Notebook) NextPage() { + C.gtk_notebook_next_page(v.native()) +} + +// PrevPage() is a wrapper around gtk_notebook_prev_page(). +func (v *Notebook) PrevPage() { + C.gtk_notebook_prev_page(v.native()) +} + +// ReorderChild() is a wrapper around gtk_notebook_reorder_child(). +func (v *Notebook) ReorderChild(child IWidget, position int) { + C.gtk_notebook_reorder_child(v.native(), child.toWidget(), + C.gint(position)) +} + +// SetTabPos() is a wrapper around gtk_notebook_set_tab_pos(). +func (v *Notebook) SetTabPos(pos PositionType) { + C.gtk_notebook_set_tab_pos(v.native(), C.GtkPositionType(pos)) +} + +// SetShowTabs() is a wrapper around gtk_notebook_set_show_tabs(). +func (v *Notebook) SetShowTabs(showTabs bool) { + C.gtk_notebook_set_show_tabs(v.native(), gbool(showTabs)) +} + +// SetShowBorder() is a wrapper around gtk_notebook_set_show_border(). +func (v *Notebook) SetShowBorder(showBorder bool) { + C.gtk_notebook_set_show_border(v.native(), gbool(showBorder)) +} + +// SetScrollable() is a wrapper around gtk_notebook_set_scrollable(). +func (v *Notebook) SetScrollable(scrollable bool) { + C.gtk_notebook_set_scrollable(v.native(), gbool(scrollable)) +} + +// PopupEnable() is a wrapper around gtk_notebook_popup_enable(). +func (v *Notebook) PopupEnable() { + C.gtk_notebook_popup_enable(v.native()) +} + +// PopupDisable() is a wrapper around gtk_notebook_popup_disable(). +func (v *Notebook) PopupDisable() { + C.gtk_notebook_popup_disable(v.native()) +} + +// GetCurrentPage() is a wrapper around gtk_notebook_get_current_page(). +func (v *Notebook) GetCurrentPage() int { + c := C.gtk_notebook_get_current_page(v.native()) + return int(c) +} + +// GetMenuLabel() is a wrapper around gtk_notebook_get_menu_label(). +func (v *Notebook) GetMenuLabel(child IWidget) (IWidget, error) { + c := C.gtk_notebook_get_menu_label(v.native(), child.toWidget()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// GetNthPage() is a wrapper around gtk_notebook_get_nth_page(). +func (v *Notebook) GetNthPage(pageNum int) (IWidget, error) { + c := C.gtk_notebook_get_nth_page(v.native(), C.gint(pageNum)) + if c == nil { + return nil, fmt.Errorf("page %d is out of bounds", pageNum) + } + return castWidget(c) +} + +// GetNPages() is a wrapper around gtk_notebook_get_n_pages(). +func (v *Notebook) GetNPages() int { + c := C.gtk_notebook_get_n_pages(v.native()) + return int(c) +} + +// GetTabLabel() is a wrapper around gtk_notebook_get_tab_label(). +func (v *Notebook) GetTabLabel(child IWidget) (IWidget, error) { + c := C.gtk_notebook_get_tab_label(v.native(), child.toWidget()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// SetMenuLabel() is a wrapper around gtk_notebook_set_menu_label(). +func (v *Notebook) SetMenuLabel(child, menuLabel IWidget) { + C.gtk_notebook_set_menu_label(v.native(), child.toWidget(), + menuLabel.toWidget()) +} + +// SetMenuLabelText() is a wrapper around gtk_notebook_set_menu_label_text(). +func (v *Notebook) SetMenuLabelText(child IWidget, menuText string) { + cstr := C.CString(menuText) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_notebook_set_menu_label_text(v.native(), child.toWidget(), + (*C.gchar)(cstr)) +} + +// SetTabLabel() is a wrapper around gtk_notebook_set_tab_label(). +func (v *Notebook) SetTabLabel(child, tabLabel IWidget) { + C.gtk_notebook_set_tab_label(v.native(), child.toWidget(), + tabLabel.toWidget()) +} + +// SetTabLabelText() is a wrapper around gtk_notebook_set_tab_label_text(). +func (v *Notebook) SetTabLabelText(child IWidget, tabText string) { + cstr := C.CString(tabText) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_notebook_set_tab_label_text(v.native(), child.toWidget(), + (*C.gchar)(cstr)) +} + +// SetTabReorderable() is a wrapper around gtk_notebook_set_tab_reorderable(). +func (v *Notebook) SetTabReorderable(child IWidget, reorderable bool) { + C.gtk_notebook_set_tab_reorderable(v.native(), child.toWidget(), + gbool(reorderable)) +} + +// SetTabDetachable() is a wrapper around gtk_notebook_set_tab_detachable(). +func (v *Notebook) SetTabDetachable(child IWidget, detachable bool) { + C.gtk_notebook_set_tab_detachable(v.native(), child.toWidget(), + gbool(detachable)) +} + +// GetMenuLabelText() is a wrapper around gtk_notebook_get_menu_label_text(). +func (v *Notebook) GetMenuLabelText(child IWidget) (string, error) { + c := C.gtk_notebook_get_menu_label_text(v.native(), child.toWidget()) + if c == nil { + return "", errors.New("No menu label for widget") + } + return goString(c), nil +} + +// GetScrollable() is a wrapper around gtk_notebook_get_scrollable(). +func (v *Notebook) GetScrollable() bool { + c := C.gtk_notebook_get_scrollable(v.native()) + return gobool(c) +} + +// GetShowBorder() is a wrapper around gtk_notebook_get_show_border(). +func (v *Notebook) GetShowBorder() bool { + c := C.gtk_notebook_get_show_border(v.native()) + return gobool(c) +} + +// GetShowTabs() is a wrapper around gtk_notebook_get_show_tabs(). +func (v *Notebook) GetShowTabs() bool { + c := C.gtk_notebook_get_show_tabs(v.native()) + return gobool(c) +} + +// GetTabLabelText() is a wrapper around gtk_notebook_get_tab_label_text(). +func (v *Notebook) GetTabLabelText(child IWidget) (string, error) { + c := C.gtk_notebook_get_tab_label_text(v.native(), child.toWidget()) + if c == nil { + return "", errors.New("No tab label for widget") + } + return goString(c), nil +} + +// GetTabPos() is a wrapper around gtk_notebook_get_tab_pos(). +func (v *Notebook) GetTabPos() PositionType { + c := C.gtk_notebook_get_tab_pos(v.native()) + return PositionType(c) +} + +// GetTabReorderable() is a wrapper around gtk_notebook_get_tab_reorderable(). +func (v *Notebook) GetTabReorderable(child IWidget) bool { + c := C.gtk_notebook_get_tab_reorderable(v.native(), child.toWidget()) + return gobool(c) +} + +// GetTabDetachable() is a wrapper around gtk_notebook_get_tab_detachable(). +func (v *Notebook) GetTabDetachable(child IWidget) bool { + c := C.gtk_notebook_get_tab_detachable(v.native(), child.toWidget()) + return gobool(c) +} + +// SetCurrentPage() is a wrapper around gtk_notebook_set_current_page(). +func (v *Notebook) SetCurrentPage(pageNum int) { + C.gtk_notebook_set_current_page(v.native(), C.gint(pageNum)) +} + +// SetGroupName() is a wrapper around gtk_notebook_set_group_name(). +func (v *Notebook) SetGroupName(groupName string) { + cstr := C.CString(groupName) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_notebook_set_group_name(v.native(), (*C.gchar)(cstr)) +} + +// GetGroupName() is a wrapper around gtk_notebook_get_group_name(). +func (v *Notebook) GetGroupName() (string, error) { + c := C.gtk_notebook_get_group_name(v.native()) + if c == nil { + return "", errors.New("No group name") + } + return goString(c), nil +} + +// SetActionWidget() is a wrapper around gtk_notebook_set_action_widget(). +func (v *Notebook) SetActionWidget(widget IWidget, packType PackType) { + C.gtk_notebook_set_action_widget(v.native(), widget.toWidget(), + C.GtkPackType(packType)) +} + +// GetActionWidget() is a wrapper around gtk_notebook_get_action_widget(). +func (v *Notebook) GetActionWidget(packType PackType) (IWidget, error) { + c := C.gtk_notebook_get_action_widget(v.native(), C.GtkPackType(packType)) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +/* + * GtkOffscreenWindow + */ + +// OffscreenWindow is a representation of GTK's GtkOffscreenWindow. +type OffscreenWindow struct { + Window +} + +// native returns a pointer to the underlying GtkOffscreenWindow. +func (v *OffscreenWindow) native() *C.GtkOffscreenWindow { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkOffscreenWindow(p) +} + +func marshalOffscreenWindow(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapOffscreenWindow(obj), nil +} + +func wrapOffscreenWindow(obj *glib.Object) *OffscreenWindow { + if obj == nil { + return nil + } + + return &OffscreenWindow{Window{Bin{Container{Widget{ + glib.InitiallyUnowned{obj}}}}}} +} + +// OffscreenWindowNew is a wrapper around gtk_offscreen_window_new(). +func OffscreenWindowNew() (*OffscreenWindow, error) { + c := C.gtk_offscreen_window_new() + if c == nil { + return nil, nilPtrErr + } + return wrapOffscreenWindow(glib.Take(unsafe.Pointer(c))), nil +} + +// GetSurface is a wrapper around gtk_offscreen_window_get_surface(). +// The returned surface is safe to use over window resizes. +func (v *OffscreenWindow) GetSurface() (*cairo.Surface, error) { + c := C.gtk_offscreen_window_get_surface(v.native()) + if c == nil { + return nil, nilPtrErr + } + cairoPtr := (uintptr)(unsafe.Pointer(c)) + s := cairo.NewSurface(cairoPtr, true) + return s, nil +} + +// GetPixbuf is a wrapper around gtk_offscreen_window_get_pixbuf(). +func (v *OffscreenWindow) GetPixbuf() (*gdk.Pixbuf, error) { + c := C.gtk_offscreen_window_get_pixbuf(v.native()) + if c == nil { + return nil, nilPtrErr + } + + // Pixbuf is returned with ref count of 1, so don't increment. + // Is it a floating reference? + pb := &gdk.Pixbuf{glib.Take(unsafe.Pointer(c))} + return pb, nil +} + +/* + * GtkOrientable + */ + +// Orientable is a representation of GTK's GtkOrientable GInterface. +type Orientable struct { + *glib.Object +} + +// IOrientable is an interface type implemented by all structs +// embedding an Orientable. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkOrientable. +type IOrientable interface { + toOrientable() *C.GtkOrientable +} + +// native returns a pointer to the underlying GObject as a GtkOrientable. +func (v *Orientable) native() *C.GtkOrientable { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkOrientable(p) +} + +func marshalOrientable(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapOrientable(obj), nil +} + +func wrapOrientable(obj *glib.Object) *Orientable { + if obj == nil { + return nil + } + + return &Orientable{obj} +} + +// GetOrientation is a wrapper around gtk_orientable_get_orientation(). +func (v *Orientable) GetOrientation() Orientation { + c := C.gtk_orientable_get_orientation(v.native()) + return Orientation(c) +} + +// SetOrientation is a wrapper around gtk_orientable_set_orientation(). +func (v *Orientable) SetOrientation(orientation Orientation) { + C.gtk_orientable_set_orientation(v.native(), + C.GtkOrientation(orientation)) +} + +/* + * GtkOverlay + */ + +// Overlay is a representation of GTK's GtkOverlay. +type Overlay struct { + Bin +} + +// native returns a pointer to the underlying GtkOverlay. +func (v *Overlay) native() *C.GtkOverlay { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkOverlay(p) +} + +func marshalOverlay(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapOverlay(obj), nil +} + +func wrapOverlay(obj *glib.Object) *Overlay { + if obj == nil { + return nil + } + + return &Overlay{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// OverlayNew() is a wrapper around gtk_overlay_new(). +func OverlayNew() (*Overlay, error) { + c := C.gtk_overlay_new() + if c == nil { + return nil, nilPtrErr + } + return wrapOverlay(glib.Take(unsafe.Pointer(c))), nil +} + +// AddOverlay() is a wrapper around gtk_overlay_add_overlay(). +func (v *Overlay) AddOverlay(widget IWidget) { + C.gtk_overlay_add_overlay(v.native(), widget.toWidget()) +} + +/* + * GtkPaned + */ + +// Paned is a representation of GTK's GtkPaned. +type Paned struct { + Bin +} + +// native returns a pointer to the underlying GtkPaned. +func (v *Paned) native() *C.GtkPaned { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkPaned(p) +} + +func marshalPaned(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapPaned(obj), nil +} + +func wrapPaned(obj *glib.Object) *Paned { + if obj == nil { + return nil + } + + return &Paned{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// PanedNew() is a wrapper around gtk_paned_new(). +func PanedNew(orientation Orientation) (*Paned, error) { + c := C.gtk_paned_new(C.GtkOrientation(orientation)) + if c == nil { + return nil, nilPtrErr + } + return wrapPaned(glib.Take(unsafe.Pointer(c))), nil +} + +// Add1() is a wrapper around gtk_paned_add1(). +func (v *Paned) Add1(child IWidget) { + C.gtk_paned_add1(v.native(), child.toWidget()) +} + +// Add2() is a wrapper around gtk_paned_add2(). +func (v *Paned) Add2(child IWidget) { + C.gtk_paned_add2(v.native(), child.toWidget()) +} + +// Pack1() is a wrapper around gtk_paned_pack1(). +func (v *Paned) Pack1(child IWidget, resize, shrink bool) { + C.gtk_paned_pack1(v.native(), child.toWidget(), gbool(resize), gbool(shrink)) +} + +// Pack2() is a wrapper around gtk_paned_pack2(). +func (v *Paned) Pack2(child IWidget, resize, shrink bool) { + C.gtk_paned_pack2(v.native(), child.toWidget(), gbool(resize), gbool(shrink)) +} + +// SetPosition() is a wrapper around gtk_paned_set_position(). +func (v *Paned) SetPosition(position int) { + C.gtk_paned_set_position(v.native(), C.gint(position)) +} + +// GetChild1() is a wrapper around gtk_paned_get_child1(). +func (v *Paned) GetChild1() (IWidget, error) { + c := C.gtk_paned_get_child1(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// GetChild2() is a wrapper around gtk_paned_get_child2(). +func (v *Paned) GetChild2() (IWidget, error) { + c := C.gtk_paned_get_child2(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// GetHandleWindow() is a wrapper around gtk_paned_get_handle_window(). +func (v *Paned) GetHandleWindow() (*Window, error) { + c := C.gtk_paned_get_handle_window(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapWindow(glib.Take(unsafe.Pointer(c))), nil +} + +// GetPosition() is a wrapper around gtk_paned_get_position(). +func (v *Paned) GetPosition() int { + return int(C.gtk_paned_get_position(v.native())) +} + +/* + * GtkInvisible + */ + +// TODO: +// gtk_invisible_new(). +// gtk_invisible_new_for_screen(). +// gtk_invisible_set_screen(). +// gtk_invisible_get_screen(). + +/* + * GtkProgressBar + */ + +// ProgressBar is a representation of GTK's GtkProgressBar. +type ProgressBar struct { + Widget + // Interfaces + Orientable +} + +// native returns a pointer to the underlying GtkProgressBar. +func (v *ProgressBar) native() *C.GtkProgressBar { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkProgressBar(p) +} + +func marshalProgressBar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapProgressBar(obj), nil +} + +func wrapProgressBar(obj *glib.Object) *ProgressBar { + if obj == nil { + return nil + } + + o := wrapOrientable(obj) + return &ProgressBar{Widget{glib.InitiallyUnowned{obj}}, *o} +} + +// ProgressBarNew is a wrapper around gtk_progress_bar_new(). +func ProgressBarNew() (*ProgressBar, error) { + c := C.gtk_progress_bar_new() + if c == nil { + return nil, nilPtrErr + } + return wrapProgressBar(glib.Take(unsafe.Pointer(c))), nil +} + +// SetFraction is a wrapper around gtk_progress_bar_set_fraction(). +func (v *ProgressBar) SetFraction(fraction float64) { + C.gtk_progress_bar_set_fraction(v.native(), C.gdouble(fraction)) +} + +// GetFraction is a wrapper around gtk_progress_bar_get_fraction(). +func (v *ProgressBar) GetFraction() float64 { + c := C.gtk_progress_bar_get_fraction(v.native()) + return float64(c) +} + +// SetShowText is a wrapper around gtk_progress_bar_set_show_text(). +func (v *ProgressBar) SetShowText(showText bool) { + C.gtk_progress_bar_set_show_text(v.native(), gbool(showText)) +} + +// GetShowText is a wrapper around gtk_progress_bar_get_show_text(). +func (v *ProgressBar) GetShowText() bool { + c := C.gtk_progress_bar_get_show_text(v.native()) + return gobool(c) +} + +// SetText is a wrapper around gtk_progress_bar_set_text(). +func (v *ProgressBar) SetText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_progress_bar_set_text(v.native(), (*C.gchar)(cstr)) +} + +// TODO: +// gtk_progress_bar_get_text(). +// gtk_progress_bar_set_ellipsize(). +// gtk_progress_bar_get_ellipsize(). + +// SetPulseStep is a wrapper around gtk_progress_bar_set_pulse_step(). +func (v *ProgressBar) SetPulseStep(fraction float64) { + C.gtk_progress_bar_set_pulse_step(v.native(), C.gdouble(fraction)) +} + +// GetPulseStep is a wrapper around gtk_progress_bar_get_pulse_step(). +func (v *ProgressBar) GetPulseStep() float64 { + c := C.gtk_progress_bar_get_pulse_step(v.native()) + return float64(c) +} + +// Pulse is a wrapper arountd gtk_progress_bar_pulse(). +func (v *ProgressBar) Pulse() { + C.gtk_progress_bar_pulse(v.native()) +} + +// SetInverted is a wrapper around gtk_progress_bar_set_inverted(). +func (v *ProgressBar) SetInverted(inverted bool) { + C.gtk_progress_bar_set_inverted(v.native(), gbool(inverted)) +} + +// GetInverted is a wrapper around gtk_progress_bar_get_inverted(). +func (v *ProgressBar) GetInverted() bool { + c := C.gtk_progress_bar_get_inverted(v.native()) + return gobool(c) +} + +/* + * GtkRadioButton + */ + +// RadioButton is a representation of GTK's GtkRadioButton. +type RadioButton struct { + CheckButton +} + +// native returns a pointer to the underlying GtkRadioButton. +func (v *RadioButton) native() *C.GtkRadioButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkRadioButton(p) +} + +func marshalRadioButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapRadioButton(obj), nil +} + +func wrapRadioButton(obj *glib.Object) *RadioButton { + if obj == nil { + return nil + } + + actionable := wrapActionable(obj) + return &RadioButton{CheckButton{ToggleButton{Button{Bin{Container{ + Widget{glib.InitiallyUnowned{obj}}}}, actionable}}}} +} + +// RadioButtonNew is a wrapper around gtk_radio_button_new(). +func RadioButtonNew(group *glib.SList) (*RadioButton, error) { + c := C.gtk_radio_button_new(cGSList(group)) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioButton(glib.Take(unsafe.Pointer(c))), nil +} + +// RadioButtonNewFromWidget is a wrapper around gtk_radio_button_new_from_widget(). +func RadioButtonNewFromWidget(radioGroupMember *RadioButton) (*RadioButton, error) { + c := C.gtk_radio_button_new_from_widget(radioGroupMember.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioButton(glib.Take(unsafe.Pointer(c))), nil +} + +// RadioButtonNewWithLabel is a wrapper around gtk_radio_button_new_with_label(). +func RadioButtonNewWithLabel(group *glib.SList, label string) (*RadioButton, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_radio_button_new_with_label(cGSList(group), (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioButton(glib.Take(unsafe.Pointer(c))), nil +} + +// RadioButtonNewWithLabelFromWidget is a wrapper around gtk_radio_button_new_with_label_from_widget(). +func RadioButtonNewWithLabelFromWidget(radioGroupMember *RadioButton, label string) (*RadioButton, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + var cradio *C.GtkRadioButton + if radioGroupMember != nil { + cradio = radioGroupMember.native() + } + c := C.gtk_radio_button_new_with_label_from_widget(cradio, (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioButton(glib.Take(unsafe.Pointer(c))), nil +} + +// RadioButtonNewWithMnemonic is a wrapper around gtk_radio_button_new_with_mnemonic(). +func RadioButtonNewWithMnemonic(group *glib.SList, label string) (*RadioButton, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_radio_button_new_with_mnemonic(cGSList(group), (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioButton(glib.Take(unsafe.Pointer(c))), nil +} + +// RadioButtonNewWithMnemonicFromWidget is a wrapper around gtk_radio_button_new_with_mnemonic_from_widget(). +func RadioButtonNewWithMnemonicFromWidget(radioGroupMember *RadioButton, label string) (*RadioButton, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + var cradio *C.GtkRadioButton + if radioGroupMember != nil { + cradio = radioGroupMember.native() + } + c := C.gtk_radio_button_new_with_mnemonic_from_widget(cradio, + (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioButton(glib.Take(unsafe.Pointer(c))), nil +} + +// SetGroup is a wrapper around gtk_radio_button_set_group(). +func (v *RadioButton) SetGroup(group *glib.SList) { + C.gtk_radio_button_set_group(v.native(), cGSList(group)) +} + +// GetGroup is a wrapper around gtk_radio_button_get_group(). +func (v *RadioButton) GetGroup() (*glib.SList, error) { + c := C.gtk_radio_button_get_group(v.native()) + if c == nil { + return nil, nilPtrErr + } + + // TODO: call DataWrapper on SList and wrap them to gtk.RadioButton + + return glib.WrapSList(uintptr(unsafe.Pointer(c))), nil +} + +// JoinGroup is a wrapper around gtk_radio_button_join_group(). +func (v *RadioButton) JoinGroup(groupSource *RadioButton) { + var cgroup *C.GtkRadioButton + if groupSource != nil { + cgroup = groupSource.native() + } + C.gtk_radio_button_join_group(v.native(), cgroup) +} + +/* + * GtkRadioMenuItem + */ + +// RadioMenuItem is a representation of GTK's GtkRadioMenuItem. +type RadioMenuItem struct { + CheckMenuItem +} + +// native returns a pointer to the underlying GtkRadioMenuItem. +func (v *RadioMenuItem) native() *C.GtkRadioMenuItem { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkRadioMenuItem(p) +} + +func marshalRadioMenuItem(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapRadioMenuItem(obj), nil +} + +func wrapRadioMenuItem(obj *glib.Object) *RadioMenuItem { + if obj == nil { + return nil + } + + return &RadioMenuItem{CheckMenuItem{MenuItem{Bin{Container{ + Widget{glib.InitiallyUnowned{obj}}}}}}} +} + +// RadioMenuItemNew is a wrapper around gtk_radio_menu_item_new(). +func RadioMenuItemNew(group *glib.SList) (*RadioMenuItem, error) { + c := C.gtk_radio_menu_item_new(cGSList(group)) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioMenuItem(glib.Take(unsafe.Pointer(c))), nil +} + +// RadioMenuItemNewWithLabel is a wrapper around gtk_radio_menu_item_new_with_label(). +func RadioMenuItemNewWithLabel(group *glib.SList, label string) (*RadioMenuItem, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_radio_menu_item_new_with_label(cGSList(group), (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioMenuItem(glib.Take(unsafe.Pointer(c))), nil +} + +// RadioMenuItemNewWithMnemonic is a wrapper around gtk_radio_menu_item_new_with_mnemonic(). +func RadioMenuItemNewWithMnemonic(group *glib.SList, label string) (*RadioMenuItem, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_radio_menu_item_new_with_mnemonic(cGSList(group), (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioMenuItem(glib.Take(unsafe.Pointer(c))), nil +} + +// RadioMenuItemNewFromWidget is a wrapper around gtk_radio_menu_item_new_from_widget(). +func RadioMenuItemNewFromWidget(group *RadioMenuItem) (*RadioMenuItem, error) { + c := C.gtk_radio_menu_item_new_from_widget(group.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioMenuItem(glib.Take(unsafe.Pointer(c))), nil +} + +// RadioMenuItemNewWithLabelFromWidget is a wrapper around gtk_radio_menu_item_new_with_label_from_widget(). +func RadioMenuItemNewWithLabelFromWidget(group *RadioMenuItem, label string) (*RadioMenuItem, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_radio_menu_item_new_with_label_from_widget(group.native(), + (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioMenuItem(glib.Take(unsafe.Pointer(c))), nil +} + +// RadioMenuItemNewWithMnemonicFromWidget is a wrapper around gtk_radio_menu_item_new_with_mnemonic_from_widget(). +func RadioMenuItemNewWithMnemonicFromWidget(group *RadioMenuItem, label string) (*RadioMenuItem, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_radio_menu_item_new_with_mnemonic_from_widget(group.native(), + (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapRadioMenuItem(glib.Take(unsafe.Pointer(c))), nil +} + +// SetGroup is a wrapper around gtk_radio_menu_item_set_group(). +func (v *RadioMenuItem) SetGroup(group *glib.SList) { + C.gtk_radio_menu_item_set_group(v.native(), cGSList(group)) +} + +// GetGroup is a wrapper around gtk_radio_menu_item_get_group(). +func (v *RadioMenuItem) GetGroup() (*glib.SList, error) { + c := C.gtk_radio_menu_item_get_group(v.native()) + if c == nil { + return nil, nilPtrErr + } + + // TODO: call DataWrapper on SList and wrap them to gtk.RadioMenuItem + + return glib.WrapSList(uintptr(unsafe.Pointer(c))), nil +} + +/* + * GtkRange + */ + +// Range is a representation of GTK's GtkRange. +type Range struct { + Widget +} + +// native returns a pointer to the underlying GtkRange. +func (v *Range) native() *C.GtkRange { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkRange(p) +} + +func marshalRange(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapRange(obj), nil +} + +func wrapRange(obj *glib.Object) *Range { + if obj == nil { + return nil + } + + return &Range{Widget{glib.InitiallyUnowned{obj}}} +} + +// GetFillLevel is a wrapper around gtk_range_get_fill_level(). +func (v *Range) GetFillLevel() float64 { + return float64(C.gtk_range_get_fill_level(v.native())) +} + +// GetRestrictToFillLevel is a wrapper around gtk_range_get_restrict_to_fill_level(). +func (v *Range) GetRestrictToFillLevel() bool { + return gobool(C.gtk_range_get_restrict_to_fill_level(v.native())) +} + +// GetShowFillLevel is a wrapper around gtk_range_get_show_fill_level(). +func (v *Range) GetShowFillLevel() bool { + return gobool(C.gtk_range_get_show_fill_level(v.native())) +} + +// SetFillLevel is a wrapper around gtk_range_set_fill_level(). +func (v *Range) SetFillLevel(fill_level float64) { + C.gtk_range_set_fill_level(v.native(), C.gdouble(fill_level)) +} + +// RestrictToFillLevel is a wrapper around gtk_range_set_restrict_to_fill_level(). +func (v *Range) RestrictToFillLevel(restrict_to_fill_level bool) { + C.gtk_range_set_restrict_to_fill_level(v.native(), gbool(restrict_to_fill_level)) +} + +// SetShowFillLevel is a wrapper around gtk_range_set_show_fill_level(). +func (v *Range) SetShowFillLevel(show_fill_level bool) { + C.gtk_range_set_show_fill_level(v.native(), gbool(show_fill_level)) +} + +// GetAdjustment is a wrapper around gtk_range_get_adjustment(). +func (v *Range) GetAdjustment() *Adjustment { + + c := C.gtk_range_get_adjustment(v.native()) + if c == nil { + return nil + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapAdjustment(obj) +} + +// SetAdjustment is a wrapper around gtk_range_set_adjustment(). +func (v *Range) SetAdjustment(adjustment *Adjustment) { + C.gtk_range_set_adjustment(v.native(), adjustment.native()) +} + +// GetValue is a wrapper around gtk_range_get_value(). +func (v *Range) GetValue() float64 { + c := C.gtk_range_get_value(v.native()) + return float64(c) +} + +// SetValue is a wrapper around gtk_range_set_value(). +func (v *Range) SetValue(value float64) { + C.gtk_range_set_value(v.native(), C.gdouble(value)) +} + +// SetIncrements is a wrapper around gtk_range_set_increments(). +func (v *Range) SetIncrements(step, page float64) { + C.gtk_range_set_increments(v.native(), C.gdouble(step), C.gdouble(page)) +} + +// SetRange is a wrapper around gtk_range_set_range(). +func (v *Range) SetRange(min, max float64) { + C.gtk_range_set_range(v.native(), C.gdouble(min), C.gdouble(max)) +} + +// GetInverted is a wrapper around gtk_range_get_inverted(). +func (v *Range) GetInverted() bool { + c := C.gtk_range_get_inverted(v.native()) + return gobool(c) +} + +// SetInverted is a wrapper around gtk_range_set_inverted(). +func (v *Range) SetInverted(inverted bool) { + C.gtk_range_set_inverted(v.native(), gbool(inverted)) +} + +// GetRoundDigits is a wrapper around gtk_range_get_round_digits(). +func (v *Range) GetRoundDigits() int { + return int(C.gtk_range_get_round_digits(v.native())) +} + +// SetRoundDigits is a wrapper around gtk_range_set_round_digits(). +func (v *Range) SetRoundDigits(round_digits int) { + C.gtk_range_set_round_digits(v.native(), C.gint(round_digits)) +} + +// SetLowerStepperSensitivity is a wrapper around gtk_range_set_lower_stepper_sensitivity(). +func (v *Range) SetLowerStepperSensitivity(sensitivity SensitivityType) { + C.gtk_range_set_lower_stepper_sensitivity( + v.native(), + C.GtkSensitivityType(sensitivity)) +} + +// GetLowerStepperSensitivity is a wrapper around gtk_range_get_lower_stepper_sensitivity(). +func (v *Range) GetLowerStepperSensitivity() SensitivityType { + return SensitivityType(C.gtk_range_get_lower_stepper_sensitivity( + v.native())) +} + +// SetUpperStepperSensitivity is a wrapper around gtk_range_set_upper_stepper_sensitivity(). +func (v *Range) SetUpperStepperSensitivity(sensitivity SensitivityType) { + C.gtk_range_set_upper_stepper_sensitivity( + v.native(), + C.GtkSensitivityType(sensitivity)) +} + +// GetUpperStepperSensitivity is a wrapper around gtk_range_get_upper_stepper_sensitivity(). +func (v *Range) GetUpperStepperSensitivity() SensitivityType { + return SensitivityType(C.gtk_range_get_upper_stepper_sensitivity( + v.native())) +} + +// GetFlippable is a wrapper around gtk_range_get_flippable(). +func (v *Range) GetFlippable() bool { + return gobool(C.gtk_range_get_flippable(v.native())) +} + +// SetFlippable is a wrapper around gtk_range_set_flippable(). +func (v *Range) SetFlippable(flippable bool) { + C.gtk_range_set_flippable(v.native(), gbool(flippable)) +} + +// GetRangeRect is a wrapper around gtk_range_get_range_rect(). +func (v *Range) GetRangeRect() *gdk.Rectangle { + var cRect *C.GdkRectangle + C.gtk_range_get_range_rect(v.native(), cRect) + return gdk.WrapRectangle(uintptr(unsafe.Pointer(cRect))) +} + +// GetSliderRange is a wrapper around gtk_range_get_slider_range(). +func (v *Range) GetSliderRange() (int, int) { + var cStart, cEnd C.gint + C.gtk_range_get_slider_range(v.native(), &cStart, &cEnd) + return int(cStart), int(cEnd) +} + +// GetSliderFixedSize is a wrapper gtk_range_get_slider_size_fixed(). +func (v *Range) GetSliderFixedSize() bool { + return gobool(C.gtk_range_get_slider_size_fixed(v.native())) +} + +// SetSliderFixedSize is a wrapper around gtk_range_set_slider_size_fixed(). +func (v *Range) SetSliderFixedSize(size_fixed bool) { + C.gtk_range_set_slider_size_fixed(v.native(), gbool(size_fixed)) +} + +// IRecentChooser is an interface type implemented by all structs +// embedding a RecentChooser. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkWidget. +type IRecentChooser interface { + toRecentChooser() *C.GtkRecentChooser +} + +/* + * GtkRecentChooser + */ + +// RecentChooser is a representation of GTK's GtkRecentChooser. +type RecentChooser struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkRecentChooser. +func (v *RecentChooser) native() *C.GtkRecentChooser { + if v == nil || v.Object == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkRecentChooser(p) +} + +func wrapRecentChooser(obj *glib.Object) *RecentChooser { + if obj == nil { + return nil + } + + return &RecentChooser{obj} +} + +func (v *RecentChooser) toRecentChooser() *C.GtkRecentChooser { + return v.native() +} + +func (v *RecentChooser) GetCurrentUri() string { + curi := C.gtk_recent_chooser_get_current_uri(v.native()) + return goString(curi) +} + +func (v *RecentChooser) AddFilter(filter *RecentFilter) { + C.gtk_recent_chooser_add_filter(v.native(), filter.native()) +} + +func (v *RecentChooser) RemoveFilter(filter *RecentFilter) { + C.gtk_recent_chooser_remove_filter(v.native(), filter.native()) +} + +/* + * GtkRecentChooserWidget + */ + +// TODO: +// gtk_recent_chooser_widget_new(). +// gtk_recent_chooser_widget_new_for_manager(). + +/* + * GtkRecentChooserMenu + */ + +// RecentChooserMenu is a representation of GTK's GtkRecentChooserMenu. +type RecentChooserMenu struct { + Menu + RecentChooser +} + +// native returns a pointer to the underlying GtkRecentManager. +func (v *RecentChooserMenu) native() *C.GtkRecentChooserMenu { + if v == nil || v.Object == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkRecentChooserMenu(p) +} + +func wrapRecentChooserMenu(obj *glib.Object) *RecentChooserMenu { + if obj == nil { + return nil + } + + return &RecentChooserMenu{ + Menu{MenuShell{Container{Widget{glib.InitiallyUnowned{obj}}}}}, + RecentChooser{obj}, + } +} + +/* + * GtkRecentFilter + */ + +// RecentFilter is a representation of GTK's GtkRecentFilter. +type RecentFilter struct { + glib.InitiallyUnowned +} + +// native returns a pointer to the underlying GtkRecentFilter. +func (v *RecentFilter) native() *C.GtkRecentFilter { + if v == nil || v.Object == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkRecentFilter(p) +} + +func wrapRecentFilter(obj *glib.Object) *RecentFilter { + if obj == nil { + return nil + } + + return &RecentFilter{glib.InitiallyUnowned{obj}} +} + +// RecentFilterNew is a wrapper around gtk_recent_filter_new(). +func RecentFilterNew() (*RecentFilter, error) { + c := C.gtk_recent_filter_new() + if c == nil { + return nil, nilPtrErr + } + return wrapRecentFilter(glib.Take(unsafe.Pointer(c))), nil +} + +/* + * GtkRecentManager + */ + +// RecentManager is a representation of GTK's GtkRecentManager. +type RecentManager struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkRecentManager. +func (v *RecentManager) native() *C.GtkRecentManager { + if v == nil || v.Object == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkRecentManager(p) +} + +func marshalRecentManager(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapRecentManager(obj), nil +} + +func wrapRecentManager(obj *glib.Object) *RecentManager { + if obj == nil { + return nil + } + + return &RecentManager{obj} +} + +// RecentManagerGetDefault is a wrapper around gtk_recent_manager_get_default(). +func RecentManagerGetDefault() (*RecentManager, error) { + c := C.gtk_recent_manager_get_default() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + v := wrapRecentManager(obj) + return v, nil +} + +// AddItem is a wrapper around gtk_recent_manager_add_item(). +func (v *RecentManager) AddItem(fileURI string) bool { + cstr := C.CString(fileURI) + defer C.free(unsafe.Pointer(cstr)) + cok := C.gtk_recent_manager_add_item(v.native(), (*C.gchar)(cstr)) + return gobool(cok) +} + +/* + * GtkScale + */ + +// Scale is a representation of GTK's GtkScale. +type Scale struct { + Range +} + +// native returns a pointer to the underlying GtkScale. +func (v *Scale) native() *C.GtkScale { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkScale(p) +} + +func marshalScale(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapScale(obj), nil +} + +func wrapScale(obj *glib.Object) *Scale { + if obj == nil { + return nil + } + + return &Scale{Range{Widget{glib.InitiallyUnowned{obj}}}} +} + +// ScaleNew is a wrapper around gtk_scale_new(). +func ScaleNew(orientation Orientation, adjustment *Adjustment) (*Scale, error) { + c := C.gtk_scale_new(C.GtkOrientation(orientation), adjustment.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapScale(glib.Take(unsafe.Pointer(c))), nil +} + +// ScaleNewWithRange is a wrapper around gtk_scale_new_with_range(). +func ScaleNewWithRange(orientation Orientation, min, max, step float64) (*Scale, error) { + c := C.gtk_scale_new_with_range(C.GtkOrientation(orientation), + C.gdouble(min), C.gdouble(max), C.gdouble(step)) + + if c == nil { + return nil, nilPtrErr + } + return wrapScale(glib.Take(unsafe.Pointer(c))), nil +} + +// TODO: +// gtk_scale_set_digits(). + +// SetDrawValue is a wrapper around gtk_scale_set_draw_value(). +func (v *Scale) SetDrawValue(drawValue bool) { + C.gtk_scale_set_draw_value(v.native(), gbool(drawValue)) +} + +// TODO: +// gtk_scale_set_has_origin(). +// gtk_scale_set_value_pos(). +// gtk_scale_get_digits(). +// gtk_scale_get_draw_value(). +// gtk_scale_get_has_origin(). +// gtk_scale_get_value_pos(). +// gtk_scale_get_layout(). +// gtk_scale_get_layout_offsets(). + +// AddMark is a wrpaper around gtk_scale_add_mark. +func (v *Scale) AddMark(value float64, pos PositionType, markup string) { + var markupchar *C.gchar + if markup != "" { + markupchar = (*C.gchar)(C.CString(markup)) + defer C.free(unsafe.Pointer(markupchar)) + } + + C.gtk_scale_add_mark(v.native(), C.gdouble(value), C.GtkPositionType(pos), markupchar) +} + +// ClearMarks is a wrapper around gtk_scale_clear_marks. +func (v *Scale) ClearMarks() { + C.gtk_scale_clear_marks(v.native()) +} + +/* + * GtkScaleButton + */ + +// ScaleButton is a representation of GTK's GtkScaleButton. +type ScaleButton struct { + Button +} + +// native returns a pointer to the underlying GtkScaleButton. +func (v *ScaleButton) native() *C.GtkScaleButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkScaleButton(p) +} + +func marshalScaleButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapScaleButton(obj), nil +} + +func wrapScaleButton(obj *glib.Object) *ScaleButton { + if obj == nil { + return nil + } + + actionable := wrapActionable(obj) + return &ScaleButton{Button{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}, actionable}} +} + +// ScaleButtonNew is a wrapper around gtk_scale_button_new(). +func ScaleButtonNew(size IconSize, min, max, step float64, icons []string) (*ScaleButton, error) { + cicons := make([]*C.gchar, len(icons)) + for i, icon := range icons { + cicons[i] = (*C.gchar)(C.CString(icon)) + defer C.free(unsafe.Pointer(cicons[i])) + } + cicons = append(cicons, nil) + + c := C.gtk_scale_button_new(C.GtkIconSize(size), + C.gdouble(min), + C.gdouble(max), + C.gdouble(step), + &cicons[0]) + if c == nil { + return nil, nilPtrErr + } + return wrapScaleButton(glib.Take(unsafe.Pointer(c))), nil +} + +// GetPopup is a wrapper around gtk_scale_button_get_popup(). +func (v *ScaleButton) GetPopup() (IWidget, error) { + c := C.gtk_scale_button_get_popup(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castWidget(c) +} + +// GetValue is a wrapper around gtk_scale_button_get_value(). +func (v *ScaleButton) GetValue() float64 { + return float64(C.gtk_scale_button_get_value(v.native())) +} + +// SetValue is a wrapper around gtk_scale_button_set_value(). +func (v *ScaleButton) SetValue(value float64) { + C.gtk_scale_button_set_value(v.native(), C.gdouble(value)) +} + +// SetIcons is a wrapper around gtk_scale_button_set_icons(). +func (v *ScaleButton) SetIcons() []string { + var iconNames *C.gchar = nil + C.gtk_scale_button_set_icons(v.native(), &iconNames) + return toGoStringArray(&iconNames) +} + +// GetAdjustment is a wrapper around gtk_scale_button_get_adjustment(). +func (v *ScaleButton) GetAdjustment() *Adjustment { + c := C.gtk_scale_button_get_adjustment(v.native()) + obj := glib.Take(unsafe.Pointer(c)) + return &Adjustment{glib.InitiallyUnowned{obj}} +} + +// SetAdjustment is a wrapper around gtk_scale_button_set_adjustment(). +func (v *ScaleButton) SetAdjustment(adjustment *Adjustment) { + C.gtk_scale_button_set_adjustment(v.native(), adjustment.native()) +} + +// GetPlusButton is a wrapper around gtk_scale_button_get_plus_button(). +func (v *ScaleButton) GetPlusButton() (IWidget, error) { + c := C.gtk_scale_button_get_plus_button(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castWidget(c) +} + +// GetMinusButton is a wrapper around gtk_scale_button_get_minus_button(). +func (v *ScaleButton) GetMinusButton() (IWidget, error) { + c := C.gtk_scale_button_get_minus_button(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castWidget(c) +} + +/* + * GtkScrollable + */ + +// IScrollable is an interface type implemented by all structs +// embedding a Scrollable. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkScrollable. +type IScrollable interface { + toScrollable() *C.GtkScrollable +} + +// Scrollable is a representation of GTK's GtkScrollable GInterface. +type Scrollable struct { + *glib.Object +} + +// native() returns a pointer to the underlying GObject as a GtkScrollable. +func (v *Scrollable) native() *C.GtkScrollable { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkScrollable(p) +} + +func wrapScrollable(obj *glib.Object) *Scrollable { + if obj == nil { + return nil + } + + return &Scrollable{obj} +} + +func (v *Scrollable) toScrollable() *C.GtkScrollable { + if v == nil { + return nil + } + return v.native() +} + +// SetHAdjustment is a wrapper around gtk_scrollable_set_hadjustment(). +func (v *Scrollable) SetHAdjustment(adjustment *Adjustment) { + C.gtk_scrollable_set_hadjustment(v.native(), adjustment.native()) +} + +// GetHAdjustment is a wrapper around gtk_scrollable_get_hadjustment(). +func (v *Scrollable) GetHAdjustment() (*Adjustment, error) { + c := C.gtk_scrollable_get_hadjustment(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapAdjustment(glib.Take(unsafe.Pointer(c))), nil +} + +// SetVAdjustment is a wrapper around gtk_scrollable_set_vadjustment(). +func (v *Scrollable) SetVAdjustment(adjustment *Adjustment) { + C.gtk_scrollable_set_vadjustment(v.native(), adjustment.native()) +} + +// GetVAdjustment is a wrapper around gtk_scrollable_get_vadjustment(). +func (v *Scrollable) GetVAdjustment() (*Adjustment, error) { + c := C.gtk_scrollable_get_vadjustment(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapAdjustment(glib.Take(unsafe.Pointer(c))), nil +} + +/* + * GtkScrollbar + */ + +// Scrollbar is a representation of GTK's GtkScrollbar. +type Scrollbar struct { + Range +} + +// native returns a pointer to the underlying GtkScrollbar. +func (v *Scrollbar) native() *C.GtkScrollbar { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkScrollbar(p) +} + +func marshalScrollbar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapScrollbar(obj), nil +} + +func wrapScrollbar(obj *glib.Object) *Scrollbar { + if obj == nil { + return nil + } + + return &Scrollbar{Range{Widget{glib.InitiallyUnowned{obj}}}} +} + +// ScrollbarNew is a wrapper around gtk_scrollbar_new(). +func ScrollbarNew(orientation Orientation, adjustment *Adjustment) (*Scrollbar, error) { + c := C.gtk_scrollbar_new(C.GtkOrientation(orientation), adjustment.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapScrollbar(glib.Take(unsafe.Pointer(c))), nil +} + +/* + * GtkScrolledWindow + */ + +// ScrolledWindow is a representation of GTK's GtkScrolledWindow. +type ScrolledWindow struct { + Bin +} + +// native returns a pointer to the underlying GtkScrolledWindow. +func (v *ScrolledWindow) native() *C.GtkScrolledWindow { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkScrolledWindow(p) +} + +func marshalScrolledWindow(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapScrolledWindow(obj), nil +} + +func wrapScrolledWindow(obj *glib.Object) *ScrolledWindow { + if obj == nil { + return nil + } + + return &ScrolledWindow{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// ScrolledWindowNew() is a wrapper around gtk_scrolled_window_new(). +func ScrolledWindowNew(hadjustment, vadjustment *Adjustment) (*ScrolledWindow, error) { + c := C.gtk_scrolled_window_new(hadjustment.native(), + vadjustment.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapScrolledWindow(glib.Take(unsafe.Pointer(c))), nil +} + +// GetPolicy() is a wrapper around gtk_scrolled_window_get_policy(). +func (v *ScrolledWindow) GetPolicy() (hScrollbarPolicy, vScrollbarPolicy PolicyType) { + var hScrPol, vScrPol C.GtkPolicyType + C.gtk_scrolled_window_get_policy(v.native(), &hScrPol, &vScrPol) + hScrollbarPolicy, vScrollbarPolicy = PolicyType(hScrPol), PolicyType(vScrPol) + return +} + +// SetPolicy() is a wrapper around gtk_scrolled_window_set_policy(). +func (v *ScrolledWindow) SetPolicy(hScrollbarPolicy, vScrollbarPolicy PolicyType) { + C.gtk_scrolled_window_set_policy(v.native(), + C.GtkPolicyType(hScrollbarPolicy), + C.GtkPolicyType(vScrollbarPolicy)) +} + +// GetHAdjustment() is a wrapper around gtk_scrolled_window_get_hadjustment(). +func (v *ScrolledWindow) GetHAdjustment() *Adjustment { + c := C.gtk_scrolled_window_get_hadjustment(v.native()) + if c == nil { + return nil + } + return wrapAdjustment(glib.Take(unsafe.Pointer(c))) +} + +// SetHAdjustment is a wrapper around gtk_scrolled_window_set_hadjustment(). +func (v *ScrolledWindow) SetHAdjustment(adjustment *Adjustment) { + C.gtk_scrolled_window_set_hadjustment(v.native(), adjustment.native()) +} + +// GetVAdjustment() is a wrapper around gtk_scrolled_window_get_vadjustment(). +func (v *ScrolledWindow) GetVAdjustment() *Adjustment { + c := C.gtk_scrolled_window_get_vadjustment(v.native()) + if c == nil { + return nil + } + return wrapAdjustment(glib.Take(unsafe.Pointer(c))) +} + +// SetVAdjustment is a wrapper around gtk_scrolled_window_set_vadjustment(). +func (v *ScrolledWindow) SetVAdjustment(adjustment *Adjustment) { + C.gtk_scrolled_window_set_vadjustment(v.native(), adjustment.native()) +} + +// GetHScrollbar is a wrapper around gtk_scrolled_window_get_hscrollbar(). +func (v *ScrolledWindow) GetHScrollbar() *Scrollbar { + c := C.gtk_scrolled_window_get_hscrollbar(v.native()) + if c == nil { + return nil + } + return wrapScrollbar(glib.Take(unsafe.Pointer(c))) +} + +// GetVScrollbar is a wrapper around gtk_scrolled_window_get_vscrollbar(). +func (v *ScrolledWindow) GetVScrollbar() *Scrollbar { + c := C.gtk_scrolled_window_get_vscrollbar(v.native()) + if c == nil { + return nil + } + return wrapScrollbar(glib.Take(unsafe.Pointer(c))) +} + +// GetPlacement is a wrapper around gtk_scrolled_window_get_placement(). +func (v *ScrolledWindow) GetPlacement() CornerType { + c := C.gtk_scrolled_window_get_placement(v.native()) + return CornerType(c) +} + +// SetPlacement is a wrapper around gtk_scrolled_window_set_placement(). +func (v *ScrolledWindow) SetPlacement(windowPlacement CornerType) { + C.gtk_scrolled_window_set_placement(v.native(), C.GtkCornerType(windowPlacement)) +} + +// UnsetPlacement is a wrapper around gtk_scrolled_window_unset_placement(). +func (v *ScrolledWindow) UnsetPlacement() { + C.gtk_scrolled_window_unset_placement(v.native()) +} + +// GetShadowType is a wrapper around gtk_scrolled_window_get_shadow_type(). +func (v *ScrolledWindow) GetShadowType() ShadowType { + c := C.gtk_scrolled_window_get_shadow_type(v.native()) + return ShadowType(c) +} + +// SetShadowType is a wrapper around gtk_scrolled_window_set_shadow_type(). +func (v *ScrolledWindow) SetShadowType(t ShadowType) { + C.gtk_scrolled_window_set_shadow_type(v.native(), C.GtkShadowType(t)) +} + +// GetKineticScrolling is a wrapper around gtk_scrolled_window_get_kinetic_scrolling(). +func (v *ScrolledWindow) GetKineticScrolling() bool { + c := C.gtk_scrolled_window_get_kinetic_scrolling(v.native()) + return gobool(c) +} + +// SetKineticScrolling is a wrapper around gtk_scrolled_window_set_kinetic_scrolling(). +func (v *ScrolledWindow) SetKineticScrolling(kineticScrolling bool) { + C.gtk_scrolled_window_set_kinetic_scrolling(v.native(), gbool(kineticScrolling)) +} + +// GetCaptureButtonPress is a wrapper around gtk_scrolled_window_get_capture_button_press(). +func (v *ScrolledWindow) GetCaptureButtonPress() bool { + c := C.gtk_scrolled_window_get_capture_button_press(v.native()) + return gobool(c) +} + +// SetCaptureButtonPress is a wrapper around gtk_scrolled_window_set_capture_button_press(). +func (v *ScrolledWindow) SetCaptureButtonPress(captureButtonPress bool) { + C.gtk_scrolled_window_set_capture_button_press(v.native(), gbool(captureButtonPress)) +} + +// GetMinContentWidth is a wrapper around gtk_scrolled_window_get_min_content_width(). +func (v *ScrolledWindow) GetMinContentWidth() int { + c := C.gtk_scrolled_window_get_min_content_width(v.native()) + return int(c) +} + +// SetMinContentWidth is a wrapper around gtk_scrolled_window_set_min_content_width(). +func (v *ScrolledWindow) SetMinContentWidth(width int) { + C.gtk_scrolled_window_set_min_content_width(v.native(), C.gint(width)) +} + +// GetMinContentHeight is a wrapper around gtk_scrolled_window_get_min_content_height(). +func (v *ScrolledWindow) GetMinContentHeight() int { + c := C.gtk_scrolled_window_get_min_content_height(v.native()) + return int(c) +} + +// SetMinContentHeight is a wrapper around gtk_scrolled_window_set_min_content_height(). +func (v *ScrolledWindow) SetMinContentHeight(width int) { + C.gtk_scrolled_window_set_min_content_height(v.native(), C.gint(width)) +} + +/* + * GtkSearchEntry + */ + +// SearchEntry is a reprensentation of GTK's GtkSearchEntry. +type SearchEntry struct { + Entry +} + +// native returns a pointer to the underlying GtkSearchEntry. +func (v *SearchEntry) native() *C.GtkSearchEntry { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkSearchEntry(p) +} + +func marshalSearchEntry(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapSearchEntry(obj), nil +} + +func wrapSearchEntry(obj *glib.Object) *SearchEntry { + if obj == nil { + return nil + } + + e := wrapEditable(obj) + ce := wrapCellEditable(obj) + return &SearchEntry{Entry{Widget{glib.InitiallyUnowned{obj}}, *e, *ce}} +} + +// SearchEntryNew is a wrapper around gtk_search_entry_new(). +func SearchEntryNew() (*SearchEntry, error) { + c := C.gtk_search_entry_new() + if c == nil { + return nil, nilPtrErr + } + return wrapSearchEntry(glib.Take(unsafe.Pointer(c))), nil +} + +/* +* GtkSelectionData + */ +type SelectionData struct { + GtkSelectionData *C.GtkSelectionData +} + +func marshalSelectionData(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + return (*SelectionData)(unsafe.Pointer(c)), nil +} + +// native returns a pointer to the underlying GtkSelectionData. +func (v *SelectionData) native() *C.GtkSelectionData { + if v == nil { + return nil + } + + // I don't understand why we need this, but we do. + c := (*C.GValue)(unsafe.Pointer(v)) + p := (*C.GtkSelectionData)(unsafe.Pointer(c)) + return p +} + +// GetLength is a wrapper around gtk_selection_data_get_length(). +func (v *SelectionData) GetLength() int { + return int(C.gtk_selection_data_get_length(v.native())) +} + +// GetData is a wrapper around gtk_selection_data_get_data_with_length(). +// It returns a slice of the correct size with the copy of the selection's data. +func (v *SelectionData) GetData() []byte { + var length C.gint + c := C.gtk_selection_data_get_data_with_length(v.native(), &length) + + // Only set if length is valid. + if int(length) < 1 { + return nil + } + + var data []byte + sliceHeader := (*reflect.SliceHeader)(unsafe.Pointer(&data)) + sliceHeader.Len = int(length) + sliceHeader.Cap = int(length) + sliceHeader.Data = uintptr(unsafe.Pointer(c)) + + // Keep the SelectionData alive for as long as the byte slice is. + runtime.SetFinalizer(&data, func(*[]byte) { + runtime.KeepAlive(v) + }) + + return data +} + +// SetData is a wrapper around gtk_selection_data_set_data_with_length(). +func (v *SelectionData) SetData(atom gdk.Atom, data []byte) { + C.gtk_selection_data_set( + v.native(), + C.GdkAtom(unsafe.Pointer(atom)), + C.gint(8), (*C.guchar)(&data[0]), C.gint(len(data)), + ) +} + +// GetText is a wrapper around gtk_selection_data_get_text(). It returns a copy +// of the string from SelectionData and frees the C reference. +func (v *SelectionData) GetText() string { + charptr := C.gtk_selection_data_get_text(v.native()) + if charptr == nil { + return "" + } + + defer C.g_free(C.gpointer(charptr)) + + return ucharString(charptr) +} + +// SetText is a wrapper around gtk_selection_data_set_text(). +func (v *SelectionData) SetText(text string) bool { + textPtr := *(*[]byte)(unsafe.Pointer(&text)) + + return gobool(C.gtk_selection_data_set_text( + v.native(), + // https://play.golang.org/p/PmGaLDhRuEU + // This is probably safe since we expect Gdk to copy the string anyway. + (*C.gchar)(unsafe.Pointer(&textPtr[0])), C.int(len(text)), + )) +} + +// SetPixbuf is a wrapper around gtk_selection_data_set_pixbuf(). +func (v *SelectionData) SetPixbuf(pixbuf *gdk.Pixbuf) bool { + return gobool(C.gtk_selection_data_set_pixbuf( + v.native(), + (*C.GdkPixbuf)(unsafe.Pointer(pixbuf.Native())), + )) +} + +// GetPixbuf is a wrapper around gtk_selection_data_get_pixbuf(). It returns nil +// if the data is a recognized image type that could be converted to a new +// Pixbuf. +func (v *SelectionData) GetPixbuf() *gdk.Pixbuf { + c := C.gtk_selection_data_get_pixbuf(v.native()) + if c == nil { + return nil + } + + obj := &glib.Object{glib.ToGObject(unsafe.Pointer(c))} + p := &gdk.Pixbuf{obj} + runtime.SetFinalizer(p, func(_ interface{}) { obj.Unref() }) + + return p +} + +// SetURIs is a wrapper around gtk_selection_data_set_uris(). +func (v *SelectionData) SetURIs(uris []string) bool { + var clist = C.make_strings(C.int(len(uris))) + for i := range uris { + cstring := C.CString(uris[i]) + // This defer will only run once the function exits, not once the loop + // exits, so it's perfectly fine. + defer C.free(unsafe.Pointer(cstring)) + + C.set_string(clist, C.int(i), (*C.gchar)(cstring)) + } + + return gobool(C.gtk_selection_data_set_uris(v.native(), clist)) +} + +// GetURIs is a wrapper around gtk_selection_data_get_uris(). +func (v *SelectionData) GetURIs() []string { + uriPtrs := C.gtk_selection_data_get_uris(v.native()) + return toGoStringArray(uriPtrs) +} + +func (v *SelectionData) free() { + C.gtk_selection_data_free(v.native()) +} + +// DragSetIconPixbuf is used for the "drag-begin" event. It is a wrapper around +// gtk_drag_set_icon_pixbuf(). +func DragSetIconPixbuf(context *gdk.DragContext, pixbuf *gdk.Pixbuf, hotX, hotY int) { + ctx := unsafe.Pointer(context.Native()) + pix := unsafe.Pointer(pixbuf.Native()) + C.gtk_drag_set_icon_pixbuf((*C.GdkDragContext)(ctx), (*C.GdkPixbuf)(pix), C.gint(hotX), C.gint(hotY)) +} + +// DragSetIconWidget is a wrapper around gtk_drag_set_icon_widget(). +func DragSetIconWidget(context *gdk.DragContext, w IWidget, hotX, hotY int) { + ctx := unsafe.Pointer(context.Native()) + C.gtk_drag_set_icon_widget((*C.GdkDragContext)(ctx), w.toWidget(), C.gint(hotX), C.gint(hotY)) +} + +// DragSetIconSurface is a wrapper around gtk_drag_set_icon_surface(). +func DragSetIconSurface(context *gdk.DragContext, surface *cairo.Surface) { + ctx := unsafe.Pointer(context.Native()) + sur := unsafe.Pointer(surface.Native()) + C.gtk_drag_set_icon_surface((*C.GdkDragContext)(ctx), (*C.cairo_surface_t)(sur)) +} + +// DragSetIconName is a wrapper around gtk_drag_set_icon_name(). +func DragSetIconName(context *gdk.DragContext, iconName string, hotX, hotY int) { + ctx := unsafe.Pointer(context.Native()) + ico := (*C.gchar)(C.CString(iconName)) + defer C.free(unsafe.Pointer(ico)) + + C.gtk_drag_set_icon_name((*C.GdkDragContext)(ctx), ico, C.gint(hotX), C.gint(hotY)) +} + +// DragSetIconDefault is a wrapper around gtk_drag_set_icon_default(). +func DragSetIconDefault(context *gdk.DragContext) { + ctx := unsafe.Pointer(context.Native()) + C.gtk_drag_set_icon_default((*C.GdkDragContext)(ctx)) +} + +/* + * GtkSeparator + */ + +// Separator is a representation of GTK's GtkSeparator. +type Separator struct { + Widget +} + +// native returns a pointer to the underlying GtkSeperator. +func (v *Separator) native() *C.GtkSeparator { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkSeparator(p) +} + +func marshalSeparator(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapSeparator(obj), nil +} + +func wrapSeparator(obj *glib.Object) *Separator { + if obj == nil { + return nil + } + + return &Separator{Widget{glib.InitiallyUnowned{obj}}} +} + +// SeparatorNew is a wrapper around gtk_separator_new(). +func SeparatorNew(orientation Orientation) (*Separator, error) { + c := C.gtk_separator_new(C.GtkOrientation(orientation)) + if c == nil { + return nil, nilPtrErr + } + return wrapSeparator(glib.Take(unsafe.Pointer(c))), nil +} + +/* + * GtkSeparatorMenuItem + */ + +// SeparatorMenuItem is a representation of GTK's GtkSeparatorMenuItem. +type SeparatorMenuItem struct { + MenuItem +} + +// native returns a pointer to the underlying GtkSeparatorMenuItem. +func (v *SeparatorMenuItem) native() *C.GtkSeparatorMenuItem { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkSeparatorMenuItem(p) +} + +func marshalSeparatorMenuItem(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapSeparatorMenuItem(obj), nil +} + +func wrapSeparatorMenuItem(obj *glib.Object) *SeparatorMenuItem { + if obj == nil { + return nil + } + + return &SeparatorMenuItem{MenuItem{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}}} +} + +// SeparatorMenuItemNew is a wrapper around gtk_separator_menu_item_new(). +func SeparatorMenuItemNew() (*SeparatorMenuItem, error) { + c := C.gtk_separator_menu_item_new() + if c == nil { + return nil, nilPtrErr + } + return wrapSeparatorMenuItem(glib.Take(unsafe.Pointer(c))), nil +} + +/* + * GtkSeparatorToolItem + */ + +// SeparatorToolItem is a representation of GTK's GtkSeparatorToolItem. +type SeparatorToolItem struct { + ToolItem +} + +// native returns a pointer to the underlying GtkSeparatorToolItem. +func (v *SeparatorToolItem) native() *C.GtkSeparatorToolItem { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkSeparatorToolItem(p) +} + +func marshalSeparatorToolItem(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapSeparatorToolItem(obj), nil +} + +func wrapSeparatorToolItem(obj *glib.Object) *SeparatorToolItem { + if obj == nil { + return nil + } + + return &SeparatorToolItem{ToolItem{Bin{Container{Widget{ + glib.InitiallyUnowned{obj}}}}}} +} + +// SeparatorToolItemNew is a wrapper around gtk_separator_tool_item_new(). +func SeparatorToolItemNew() (*SeparatorToolItem, error) { + c := C.gtk_separator_tool_item_new() + if c == nil { + return nil, nilPtrErr + } + return wrapSeparatorToolItem(glib.Take(unsafe.Pointer(c))), nil +} + +// SetDraw is a wrapper around gtk_separator_tool_item_set_draw(). +func (v *SeparatorToolItem) SetDraw(draw bool) { + C.gtk_separator_tool_item_set_draw(v.native(), gbool(draw)) +} + +// GetDraw is a wrapper around gtk_separator_tool_item_get_draw(). +func (v *SeparatorToolItem) GetDraw() bool { + c := C.gtk_separator_tool_item_get_draw(v.native()) + return gobool(c) +} + +/* + * GtkSizeGroup + */ + +// SizeGroup is a representation of GTK's GtkSizeGroup +type SizeGroup struct { + *glib.Object +} + +// native() returns a pointer to the underlying GtkSizeGroup +func (v *SizeGroup) native() *C.GtkSizeGroup { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkSizeGroup(p) +} + +func marshalSizeGroup(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return &SizeGroup{obj}, nil +} + +func wrapSizeGroup(obj *glib.Object) *SizeGroup { + if obj == nil { + return nil + } + + return &SizeGroup{obj} +} + +// SizeGroupNew is a wrapper around gtk_size_group_new(). +func SizeGroupNew(mode SizeGroupMode) (*SizeGroup, error) { + c := C.gtk_size_group_new(C.GtkSizeGroupMode(mode)) + if c == nil { + return nil, nilPtrErr + } + return wrapSizeGroup(glib.Take(unsafe.Pointer(c))), nil +} + +func (v *SizeGroup) SetMode(mode SizeGroupMode) { + C.gtk_size_group_set_mode(v.native(), C.GtkSizeGroupMode(mode)) +} + +func (v *SizeGroup) GetMode() SizeGroupMode { + return SizeGroupMode(C.gtk_size_group_get_mode(v.native())) +} + +func (v *SizeGroup) AddWidget(widget IWidget) { + C.gtk_size_group_add_widget(v.native(), widget.toWidget()) +} + +func (v *SizeGroup) RemoveWidget(widget IWidget) { + C.gtk_size_group_remove_widget(v.native(), widget.toWidget()) +} + +func (v *SizeGroup) GetWidgets() *glib.SList { + c := C.gtk_size_group_get_widgets(v.native()) + if c == nil { + return nil + } + + // TODO: call DataWrapper on SList and wrap them to gtk.IWidget + // see (v *Container) GetFocusChain() + + return glib.WrapSList(uintptr(unsafe.Pointer(c))) +} + +/* + * GtkSpinButton + */ + +// SpinButton is a representation of GTK's GtkSpinButton. +type SpinButton struct { + Entry + Orientable +} + +// native returns a pointer to the underlying GtkSpinButton. +func (v *SpinButton) native() *C.GtkSpinButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkSpinButton(p) +} + +func marshalSpinButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapSpinButton(obj), nil +} + +func wrapSpinButton(obj *glib.Object) *SpinButton { + if obj == nil { + return nil + } + + e := wrapEditable(obj) + ce := wrapCellEditable(obj) + o := wrapOrientable(obj) + return &SpinButton{Entry{Widget{glib.InitiallyUnowned{obj}}, *e, *ce}, *o} +} + +// Configure is a wrapper around gtk_spin_button_configure(). +func (v *SpinButton) Configure(adjustment *Adjustment, climbRate float64, digits uint) { + C.gtk_spin_button_configure(v.native(), adjustment.native(), + C.gdouble(climbRate), C.guint(digits)) +} + +// SpinButtonNew is a wrapper around gtk_spin_button_new(). +func SpinButtonNew(adjustment *Adjustment, climbRate float64, digits uint) (*SpinButton, error) { + c := C.gtk_spin_button_new(adjustment.native(), + C.gdouble(climbRate), C.guint(digits)) + if c == nil { + return nil, nilPtrErr + } + return wrapSpinButton(glib.Take(unsafe.Pointer(c))), nil +} + +// SpinButtonNewWithRange is a wrapper around gtk_spin_button_new_with_range(). +func SpinButtonNewWithRange(min, max, step float64) (*SpinButton, error) { + c := C.gtk_spin_button_new_with_range(C.gdouble(min), C.gdouble(max), + C.gdouble(step)) + if c == nil { + return nil, nilPtrErr + } + return wrapSpinButton(glib.Take(unsafe.Pointer(c))), nil +} + +// SetAdjustment() is a wrapper around gtk_spin_button_set_adjustment(). +func (v *SpinButton) SetAdjustment(adjustment *Adjustment) { + C.gtk_spin_button_set_adjustment(v.native(), adjustment.native()) +} + +// GetAdjustment() is a wrapper around gtk_spin_button_get_adjustment +func (v *SpinButton) GetAdjustment() *Adjustment { + c := C.gtk_spin_button_get_adjustment(v.native()) + if c == nil { + return nil + } + return wrapAdjustment(glib.Take(unsafe.Pointer(c))) +} + +// SetDigits() is a wrapper around gtk_spin_button_set_digits(). +func (v *SpinButton) SetDigits(digits uint) { + C.gtk_spin_button_set_digits(v.native(), C.guint(digits)) +} + +// SetIncrements() is a wrapper around gtk_spin_button_set_increments(). +func (v *SpinButton) SetIncrements(step, page float64) { + C.gtk_spin_button_set_increments(v.native(), C.gdouble(step), C.gdouble(page)) +} + +// SetRange is a wrapper around gtk_spin_button_set_range(). +func (v *SpinButton) SetRange(min, max float64) { + C.gtk_spin_button_set_range(v.native(), C.gdouble(min), C.gdouble(max)) +} + +// SetValue() is a wrapper around gtk_spin_button_set_value(). +func (v *SpinButton) SetValue(value float64) { + C.gtk_spin_button_set_value(v.native(), C.gdouble(value)) +} + +// GetValue() is a wrapper around gtk_spin_button_get_value(). +func (v *SpinButton) GetValue() float64 { + c := C.gtk_spin_button_get_value(v.native()) + return float64(c) +} + +// GetValueAsInt is a wrapper around gtk_spin_button_get_value_as_int(). +func (v *SpinButton) GetValueAsInt() int { + c := C.gtk_spin_button_get_value_as_int(v.native()) + return int(c) +} + +// SetUpdatePolicy() is a wrapper around gtk_spin_button_set_update_policy(). +func (v *SpinButton) SetUpdatePolicy(policy SpinButtonUpdatePolicy) { + C.gtk_spin_button_set_update_policy( + v.native(), + C.GtkSpinButtonUpdatePolicy(policy)) +} + +// SetNumeric() is a wrapper around gtk_spin_button_set_numeric(). +func (v *SpinButton) SetNumeric(numeric bool) { + C.gtk_spin_button_set_numeric(v.native(), gbool(numeric)) +} + +// Spin() is a wrapper around gtk_spin_button_spin(). +func (v *SpinButton) Spin(direction SpinType, increment float64) { + C.gtk_spin_button_spin( + v.native(), + C.GtkSpinType(direction), + C.gdouble(increment)) +} + +// gtk_spin_button_set_wrap(). +// gtk_spin_button_set_snap_to_ticks(). + +// Update() is a wrapper around gtk_spin_button_update(). +func (v *SpinButton) Update() { + C.gtk_spin_button_update(v.native()) +} + +// GetDigits() is a wrapper around gtk_spin_button_get_digits(). +func (v *SpinButton) GetDigits() uint { + return uint(C.gtk_spin_button_get_digits(v.native())) +} + +// gtk_spin_button_get_increments(). +// gtk_spin_button_get_numeric(). +// gtk_spin_button_get_range(). +// gtk_spin_button_get_snap_to_ticks(). + +// GetUpdatePolicy() is a wrapper around gtk_spin_button_get_update_policy(). +func (v *SpinButton) GetUpdatePolicy() SpinButtonUpdatePolicy { + return SpinButtonUpdatePolicy( + C.gtk_spin_button_get_update_policy( + v.native())) +} + +// gtk_spin_button_get_wrap(). + +/* + * GtkSpinner + */ + +// Spinner is a representation of GTK's GtkSpinner. +type Spinner struct { + Widget +} + +// native returns a pointer to the underlying GtkSpinner. +func (v *Spinner) native() *C.GtkSpinner { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkSpinner(p) +} + +func marshalSpinner(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapSpinner(obj), nil +} + +func wrapSpinner(obj *glib.Object) *Spinner { + if obj == nil { + return nil + } + + return &Spinner{Widget{glib.InitiallyUnowned{obj}}} +} + +// SpinnerNew is a wrapper around gtk_spinner_new(). +func SpinnerNew() (*Spinner, error) { + c := C.gtk_spinner_new() + if c == nil { + return nil, nilPtrErr + } + return wrapSpinner(glib.Take(unsafe.Pointer(c))), nil +} + +// Start is a wrapper around gtk_spinner_start(). +func (v *Spinner) Start() { + C.gtk_spinner_start(v.native()) +} + +// Stop is a wrapper around gtk_spinner_stop(). +func (v *Spinner) Stop() { + C.gtk_spinner_stop(v.native()) +} + +/* + * GtkStatusbar + */ + +// Statusbar is a representation of GTK's GtkStatusbar +type Statusbar struct { + Box +} + +// native returns a pointer to the underlying GtkStatusbar +func (v *Statusbar) native() *C.GtkStatusbar { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkStatusbar(p) +} + +func marshalStatusbar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapStatusbar(obj), nil +} + +func wrapStatusbar(obj *glib.Object) *Statusbar { + if obj == nil { + return nil + } + + return &Statusbar{Box{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// StatusbarNew() is a wrapper around gtk_statusbar_new(). +func StatusbarNew() (*Statusbar, error) { + c := C.gtk_statusbar_new() + if c == nil { + return nil, nilPtrErr + } + return wrapStatusbar(glib.Take(unsafe.Pointer(c))), nil +} + +// GetContextId() is a wrapper around gtk_statusbar_get_context_id(). +func (v *Statusbar) GetContextId(contextDescription string) uint { + cstr := C.CString(contextDescription) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_statusbar_get_context_id(v.native(), (*C.gchar)(cstr)) + return uint(c) +} + +// Push() is a wrapper around gtk_statusbar_push(). +func (v *Statusbar) Push(contextID uint, text string) uint { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_statusbar_push(v.native(), C.guint(contextID), + (*C.gchar)(cstr)) + return uint(c) +} + +// Pop() is a wrapper around gtk_statusbar_pop(). +func (v *Statusbar) Pop(contextID uint) { + C.gtk_statusbar_pop(v.native(), C.guint(contextID)) +} + +// GetMessageArea() is a wrapper around gtk_statusbar_get_message_area(). +func (v *Statusbar) GetMessageArea() (*Box, error) { + c := C.gtk_statusbar_get_message_area(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return &Box{Container{Widget{glib.InitiallyUnowned{obj}}}}, nil +} + +// RemoveAll() is a wrapper around gtk_statusbar_remove_all() +func (v *Statusbar) RemoveAll(contextID uint) { + C.gtk_statusbar_remove_all(v.native(), C.guint(contextID)) +} + +/* + * GtkSwitch + */ + +// Switch is a representation of GTK's GtkSwitch. +type Switch struct { + Widget +} + +// native returns a pointer to the underlying GtkSwitch. +func (v *Switch) native() *C.GtkSwitch { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkSwitch(p) +} + +func marshalSwitch(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapSwitch(obj), nil +} + +func wrapSwitch(obj *glib.Object) *Switch { + if obj == nil { + return nil + } + + return &Switch{Widget{glib.InitiallyUnowned{obj}}} +} + +// SwitchNew is a wrapper around gtk_switch_new(). +func SwitchNew() (*Switch, error) { + c := C.gtk_switch_new() + if c == nil { + return nil, nilPtrErr + } + return wrapSwitch(glib.Take(unsafe.Pointer(c))), nil +} + +// GetActive is a wrapper around gtk_switch_get_active(). +func (v *Switch) GetActive() bool { + c := C.gtk_switch_get_active(v.native()) + return gobool(c) +} + +// SetActive is a wrapper around gtk_switch_set_active(). +func (v *Switch) SetActive(isActive bool) { + C.gtk_switch_set_active(v.native(), gbool(isActive)) +} + +/* + * GtkTargetEntry + */ + +// TargetEntry is a representation of GTK's GtkTargetEntry +type TargetEntry C.GtkTargetEntry + +func marshalTargetEntry(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + return (*TargetEntry)(unsafe.Pointer(c)), nil +} + +func (v *TargetEntry) native() *C.GtkTargetEntry { + return (*C.GtkTargetEntry)(unsafe.Pointer(v)) +} + +// TargetEntryNew is a wrapper around gtk_target_entry_new(). +func TargetEntryNew(target string, flags TargetFlags, info uint) (*TargetEntry, error) { + cstr := C.CString(target) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_target_entry_new((*C.gchar)(cstr), C.guint(flags), C.guint(info)) + if c == nil { + return nil, nilPtrErr + } + t := (*TargetEntry)(unsafe.Pointer(c)) + // causes setFinilizer error + // runtime.SetFinalizer(t, (*TargetEntry).free) + return t, nil +} + +func (v *TargetEntry) free() { + C.gtk_target_entry_free(v.native()) +} + +/* + * GtkTextTag + */ + +type TextTag struct { + *glib.Object +} + +// native returns a pointer to the underlying GObject as a GtkTextTag. +func (v *TextTag) native() *C.GtkTextTag { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTextTag(p) +} + +func marshalTextTag(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTextTag(obj), nil +} + +func wrapTextTag(obj *glib.Object) *TextTag { + if obj == nil { + return nil + } + + return &TextTag{obj} +} + +// TextTagNew is a wrapper around gtk_text_tag_new(). If name is empty, then the +// tag is anonymous. +func TextTagNew(name string) (*TextTag, error) { + var gchar *C.gchar + if name != "" { + gchar = (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(gchar)) + } + + c := C.gtk_text_tag_new(gchar) + if c == nil { + return nil, nilPtrErr + } + + return wrapTextTag(glib.Take(unsafe.Pointer(c))), nil +} + +// GetPriority() is a wrapper around gtk_text_tag_get_priority(). +func (v *TextTag) GetPriority() int { + return int(C.gtk_text_tag_get_priority(v.native())) +} + +// SetPriority() is a wrapper around gtk_text_tag_set_priority(). +func (v *TextTag) SetPriority(priority int) { + C.gtk_text_tag_set_priority(v.native(), C.gint(priority)) +} + +// Event() is a wrapper around gtk_text_tag_event(). +func (v *TextTag) Event(eventObject *glib.Object, event *gdk.Event, iter *TextIter) bool { + ok := C.gtk_text_tag_event(v.native(), + (*C.GObject)(unsafe.Pointer(eventObject.Native())), + (*C.GdkEvent)(unsafe.Pointer(event.Native())), + (*C.GtkTextIter)(iter), + ) + return gobool(ok) +} + +/* + * GtkTextTagTable + */ + +type TextTagTable struct { + *glib.Object +} + +// native returns a pointer to the underlying GObject as a GtkTextTagTable. +func (v *TextTagTable) native() *C.GtkTextTagTable { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTextTagTable(p) +} + +func marshalTextTagTable(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTextTagTable(obj), nil +} + +func wrapTextTagTable(obj *glib.Object) *TextTagTable { + if obj == nil { + return nil + } + + return &TextTagTable{obj} +} + +func TextTagTableNew() (*TextTagTable, error) { + c := C.gtk_text_tag_table_new() + if c == nil { + return nil, nilPtrErr + } + return wrapTextTagTable(glib.Take(unsafe.Pointer(c))), nil +} + +// Add() is a wrapper around gtk_text_tag_table_add(). +func (v *TextTagTable) Add(tag *TextTag) { + C.gtk_text_tag_table_add(v.native(), tag.native()) + //return gobool(c) // TODO version-separate +} + +// Lookup() is a wrapper around gtk_text_tag_table_lookup(). +func (v *TextTagTable) Lookup(name string) (*TextTag, error) { + cname := C.CString(name) + defer C.free(unsafe.Pointer(cname)) + c := C.gtk_text_tag_table_lookup(v.native(), (*C.gchar)(cname)) + if c == nil { + return nil, nilPtrErr + } + return wrapTextTag(glib.Take(unsafe.Pointer(c))), nil +} + +// Remove() is a wrapper around gtk_text_tag_table_remove(). +func (v *TextTagTable) Remove(tag *TextTag) { + C.gtk_text_tag_table_remove(v.native(), tag.native()) +} + +/* + * GtkTextBuffer + */ + +// TextBuffer is a representation of GTK's GtkTextBuffer. +type TextBuffer struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkTextBuffer. +func (v *TextBuffer) native() *C.GtkTextBuffer { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTextBuffer(p) +} + +func marshalTextBuffer(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTextBuffer(obj), nil +} + +func wrapTextBuffer(obj *glib.Object) *TextBuffer { + if obj == nil { + return nil + } + + return &TextBuffer{obj} +} + +// TextBufferNew() is a wrapper around gtk_text_buffer_new(). +func TextBufferNew(table *TextTagTable) (*TextBuffer, error) { + c := C.gtk_text_buffer_new(table.native()) + if c == nil { + return nil, nilPtrErr + } + + e := wrapTextBuffer(glib.Take(unsafe.Pointer(c))) + return e, nil +} + +// ApplyTag() is a wrapper around gtk_text_buffer_apply_tag(). +func (v *TextBuffer) ApplyTag(tag *TextTag, start, end *TextIter) { + C.gtk_text_buffer_apply_tag(v.native(), tag.native(), (*C.GtkTextIter)(start), (*C.GtkTextIter)(end)) +} + +// ApplyTagByName() is a wrapper around gtk_text_buffer_apply_tag_by_name(). +func (v *TextBuffer) ApplyTagByName(name string, start, end *TextIter) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_text_buffer_apply_tag_by_name(v.native(), (*C.gchar)(cstr), + (*C.GtkTextIter)(start), (*C.GtkTextIter)(end)) +} + +// SelectRange is a wrapper around gtk_text_buffer_select_range. +func (v *TextBuffer) SelectRange(start, end *TextIter) { + C.gtk_text_buffer_select_range(v.native(), (*C.GtkTextIter)(start), (*C.GtkTextIter)(end)) +} + +// CreateChildAnchor() is a wrapper around gtk_text_buffer_create_child_anchor(). +// Since it copies garbage from the stack into the padding bytes of iter, +// iter can't be reliably reused after this call unless GODEBUG=cgocheck=0. +func (v *TextBuffer) CreateChildAnchor(iter *TextIter) (*TextChildAnchor, error) { + c := C.gtk_text_buffer_create_child_anchor(v.native(), iter.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapTextChildAnchor(glib.Take(unsafe.Pointer(c))), nil +} + +// Delete() is a wrapper around gtk_text_buffer_delete(). +func (v *TextBuffer) Delete(start, end *TextIter) { + C.gtk_text_buffer_delete(v.native(), (*C.GtkTextIter)(start), (*C.GtkTextIter)(end)) +} + +func (v *TextBuffer) GetBounds() (start, end *TextIter) { + start, end = new(TextIter), new(TextIter) + C.gtk_text_buffer_get_bounds(v.native(), (*C.GtkTextIter)(start), (*C.GtkTextIter)(end)) + return +} + +// GetCharCount() is a wrapper around gtk_text_buffer_get_char_count(). +func (v *TextBuffer) GetCharCount() int { + return int(C.gtk_text_buffer_get_char_count(v.native())) +} + +// GetIterAtOffset() is a wrapper around gtk_text_buffer_get_iter_at_offset(). +func (v *TextBuffer) GetIterAtOffset(charOffset int) *TextIter { + var iter C.GtkTextIter + C.gtk_text_buffer_get_iter_at_offset(v.native(), &iter, C.gint(charOffset)) + return (*TextIter)(&iter) +} + +// GetIterAtLine() is a wrapper around gtk_text_buffer_get_iter_at_line(). +func (v *TextBuffer) GetIterAtLine(line int) *TextIter { + var iter C.GtkTextIter + C.gtk_text_buffer_get_iter_at_line(v.native(), &iter, C.gint(line)) + return (*TextIter)(&iter) +} + +// GetStartIter() is a wrapper around gtk_text_buffer_get_start_iter(). +func (v *TextBuffer) GetStartIter() *TextIter { + var iter C.GtkTextIter + C.gtk_text_buffer_get_start_iter(v.native(), &iter) + return (*TextIter)(&iter) +} + +// GetEndIter() is a wrapper around gtk_text_buffer_get_end_iter(). +func (v *TextBuffer) GetEndIter() *TextIter { + var iter C.GtkTextIter + C.gtk_text_buffer_get_end_iter(v.native(), &iter) + return (*TextIter)(&iter) +} + +// GetLineCount() is a wrapper around gtk_text_buffer_get_line_count(). +func (v *TextBuffer) GetLineCount() int { + return int(C.gtk_text_buffer_get_line_count(v.native())) +} + +// GetModified() is a wrapper around gtk_text_buffer_get_modified(). +func (v *TextBuffer) GetModified() bool { + return gobool(C.gtk_text_buffer_get_modified(v.native())) +} + +// GetTagTable() is a wrapper around gtk_text_buffer_get_tag_table(). +func (v *TextBuffer) GetTagTable() (*TextTagTable, error) { + c := C.gtk_text_buffer_get_tag_table(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapTextTagTable(obj), nil +} + +func (v *TextBuffer) GetText(start, end *TextIter, includeHiddenChars bool) (string, error) { + c := C.gtk_text_buffer_get_text( + v.native(), (*C.GtkTextIter)(start), (*C.GtkTextIter)(end), gbool(includeHiddenChars), + ) + if c == nil { + return "", nilPtrErr + } + gostr := goString(c) + C.g_free(C.gpointer(c)) + return gostr, nil +} + +// Insert() is a wrapper around gtk_text_buffer_insert(). +func (v *TextBuffer) Insert(iter *TextIter, text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_text_buffer_insert(v.native(), (*C.GtkTextIter)(iter), (*C.gchar)(cstr), C.gint(len(text))) +} + +// InsertPixbuf() is a wrapper around gtk_text_buffer_insert_pixbuf(). +func (v *TextBuffer) InsertPixbuf(iter *TextIter, pixbuf *gdk.Pixbuf) { + C.gtk_text_buffer_insert_pixbuf(v.native(), (*C.GtkTextIter)(iter), + (*C.GdkPixbuf)(unsafe.Pointer(pixbuf.Native()))) +} + +// InsertAtCursor() is a wrapper around gtk_text_buffer_insert_at_cursor(). +func (v *TextBuffer) InsertAtCursor(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_text_buffer_insert_at_cursor(v.native(), (*C.gchar)(cstr), C.gint(len(text))) +} + +// InsertWithTag() is a wrapper around gtk_text_buffer_insert_with_tags() that supports only one tag +// as cgo does not support functions with variable-argument lists (see https://github.com/golang/go/issues/975) +func (v *TextBuffer) InsertWithTag(iter *TextIter, text string, tag *TextTag) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C._gtk_text_buffer_insert_with_tag(v.native(), (*C.GtkTextIter)(iter), (*C.gchar)(cstr), C.gint(len(text)), tag.native()) +} + +// InsertWithTagByName() is a wrapper around gtk_text_buffer_insert_with_tags_by_name() that supports only one tag +// as cgo does not support functions with variable-argument lists (see https://github.com/golang/go/issues/975) +func (v *TextBuffer) InsertWithTagByName(iter *TextIter, text string, tagName string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + ctag := C.CString(tagName) + defer C.free(unsafe.Pointer(ctag)) + C._gtk_text_buffer_insert_with_tag_by_name(v.native(), (*C.GtkTextIter)(iter), (*C.gchar)(cstr), C.gint(len(text)), (*C.gchar)(ctag)) +} + +// RemoveTag() is a wrapper around gtk_text_buffer_remove_tag(). +func (v *TextBuffer) RemoveTag(tag *TextTag, start, end *TextIter) { + C.gtk_text_buffer_remove_tag(v.native(), tag.native(), (*C.GtkTextIter)(start), (*C.GtkTextIter)(end)) +} + +// RemoveAllTags() is a wrapper around gtk_text_buffer_remove_all_tags(). +func (v *TextBuffer) RemoveAllTags(start, end *TextIter) { + C.gtk_text_buffer_remove_all_tags(v.native(), (*C.GtkTextIter)(start), (*C.GtkTextIter)(end)) +} + +// SetModified() is a wrapper around gtk_text_buffer_set_modified(). +func (v *TextBuffer) SetModified(setting bool) { + C.gtk_text_buffer_set_modified(v.native(), gbool(setting)) +} + +func (v *TextBuffer) SetText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_text_buffer_set_text(v.native(), (*C.gchar)(cstr), + C.gint(len(text))) +} + +// GetIterAtMark() is a wrapper around gtk_text_buffer_get_iter_at_mark(). +func (v *TextBuffer) GetIterAtMark(mark *TextMark) *TextIter { + var iter C.GtkTextIter + C.gtk_text_buffer_get_iter_at_mark(v.native(), &iter, mark.native()) + return (*TextIter)(&iter) +} + +// CreateMark() is a wrapper around gtk_text_buffer_create_mark(). +func (v *TextBuffer) CreateMark(mark_name string, where *TextIter, left_gravity bool) *TextMark { + cstr := C.CString(mark_name) + defer C.free(unsafe.Pointer(cstr)) + ret := C.gtk_text_buffer_create_mark(v.native(), (*C.gchar)(cstr), (*C.GtkTextIter)(where), gbool(left_gravity)) + return wrapTextMark(glib.Take(unsafe.Pointer(ret))) +} + +// GetMark() is a wrapper around gtk_text_buffer_get_mark(). +func (v *TextBuffer) GetMark(mark_name string) *TextMark { + cstr := C.CString(mark_name) + defer C.free(unsafe.Pointer(cstr)) + ret := C.gtk_text_buffer_get_mark(v.native(), (*C.gchar)(cstr)) + return wrapTextMark(glib.Take(unsafe.Pointer(ret))) +} + +// DeleteMark() is a wrapper around gtk_text_buffer_delete_mark() +func (v *TextBuffer) DeleteMark(mark *TextMark) { + C.gtk_text_buffer_delete_mark(v.native(), mark.native()) +} + +// DeleteMarkByName() is a wrapper around gtk_text_buffer_delete_mark_by_name() +func (v *TextBuffer) DeleteMarkByName(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_text_buffer_delete_mark_by_name(v.native(), (*C.gchar)(cstr)) +} + +// PlaceCursor() is a wrapper around gtk_text_buffer_place_cursor() +func (v *TextBuffer) PlaceCursor(iter *TextIter) { + C.gtk_text_buffer_place_cursor(v.native(), (*C.GtkTextIter)(iter)) +} + +// GetHasSelection() is a variant solution around gtk_text_buffer_get_has_selection(). +func (v *TextBuffer) GetHasSelection() bool { + value, _ := v.GetProperty("has-selection") + return value.(bool) +} + +// DeleteSelection() is a wrapper around gtk_text_buffer_delete_selection(). +func (v *TextBuffer) DeleteSelection(interactive, defaultEditable bool) bool { + return gobool(C.gtk_text_buffer_delete_selection(v.native(), gbool(interactive), gbool(defaultEditable))) +} + +// GetSelectionBound() is a wrapper around gtk_text_buffer_get_selection_bound(). +func (v *TextBuffer) GetSelectionBound() *TextMark { + ret := C.gtk_text_buffer_get_selection_bound(v.native()) + return wrapTextMark(glib.Take(unsafe.Pointer(ret))) +} + +// GetSelectionBounds() is a wrapper around gtk_text_buffer_get_selection_bounds(). +func (v *TextBuffer) GetSelectionBounds() (start, end *TextIter, ok bool) { + start, end = new(TextIter), new(TextIter) + cbool := C.gtk_text_buffer_get_selection_bounds(v.native(), (*C.GtkTextIter)(start), (*C.GtkTextIter)(end)) + return start, end, gobool(cbool) +} + +// GetIterAtLineOffset() is a wrapper around gtk_text_buffer_get_iter_at_line_offset(). +func (v *TextBuffer) GetIterAtLineOffset(lineNumber, charOffset int) (iter *TextIter) { + iter = new(TextIter) + C.gtk_text_buffer_get_iter_at_line_offset(v.native(), (*C.GtkTextIter)(iter), (C.gint)(lineNumber), (C.gint)(charOffset)) + return +} + +// CreateTag() is a variant solution around gtk_text_buffer_create_tag(). +func (v *TextBuffer) CreateTag(name string, props map[string]interface{}) (tag *TextTag) { + var err error + var tagTable *TextTagTable + if tag, err = TextTagNew(name); err == nil { + if tagTable, err = v.GetTagTable(); err == nil { + tagTable.Add(tag) + for p, v := range props { + if err = tag.SetProperty(p, v); err != nil { + err = errors.New(fmt.Sprintf("%s, %v: %v\n", err.Error(), p, v)) + break + } + } + } + } + if err != nil { + fmt.Println(err.Error()) + } + return +} + +// RemoveTagByName() is a wrapper around gtk_text_buffer_remove_tag_by_name() +func (v *TextBuffer) RemoveTagByName(name string, start, end *TextIter) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_text_buffer_remove_tag_by_name(v.native(), (*C.gchar)(cstr), (*C.GtkTextIter)(start), (*C.GtkTextIter)(end)) +} + +// InsertMarkup() is a wrapper around gtk_text_buffer_register_serialize_tagset() +func (v *TextBuffer) RegisterSerializeTagset(tagsetName string) gdk.Atom { + cstr := C.CString(tagsetName) + if len(tagsetName) == 0 { + cstr = nil + } + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_text_buffer_register_serialize_tagset(v.native(), (*C.gchar)(cstr)) + return gdk.Atom(uintptr(unsafe.Pointer(c))) +} + +// RegisterDeserializeTagset() is a wrapper around gtk_text_buffer_register_deserialize_tagset() +func (v *TextBuffer) RegisterDeserializeTagset(tagsetName string) gdk.Atom { + cstr := C.CString(tagsetName) + if len(tagsetName) == 0 { + cstr = nil + } + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_text_buffer_register_deserialize_tagset(v.native(), (*C.gchar)(cstr)) + return gdk.Atom(uintptr(unsafe.Pointer(c))) +} + +// Serialize() is a wrapper around gtk_text_buffer_serialize() +func (v *TextBuffer) Serialize(contentBuffer *TextBuffer, format gdk.Atom, start, end *TextIter) string { + var length = new(C.gsize) + ptr := C.gtk_text_buffer_serialize(v.native(), contentBuffer.native(), C.GdkAtom(unsafe.Pointer(format)), + (*C.GtkTextIter)(start), (*C.GtkTextIter)(end), length) + return C.GoStringN((*C.char)(unsafe.Pointer(ptr)), (C.int)(*length)) +} + +// Deserialize() is a wrapper around gtk_text_buffer_deserialize() +func (v *TextBuffer) Deserialize(contentBuffer *TextBuffer, format gdk.Atom, iter *TextIter, data []byte) (ok bool, err error) { + var length = (C.gsize)(len(data)) + var cerr *C.GError = nil + cbool := C.gtk_text_buffer_deserialize(v.native(), contentBuffer.native(), C.GdkAtom(unsafe.Pointer(format)), + (*C.GtkTextIter)(iter), (*C.guint8)(unsafe.Pointer(&data[0])), length, &cerr) + if !gobool(cbool) { + defer C.g_error_free(cerr) + return false, errors.New(goString(cerr.message)) + } + return gobool(cbool), nil +} + +// GetInsert() is a wrapper around gtk_text_buffer_get_insert(). +func (v *TextBuffer) GetInsert() *TextMark { + ret := C.gtk_text_buffer_get_insert(v.native()) + return wrapTextMark(glib.Take(unsafe.Pointer(ret))) +} + +// CopyClipboard() is a wrapper around gtk_text_buffer_copy_clipboard(). +func (v *TextBuffer) CopyClipboard(clipboard *Clipboard) { + C.gtk_text_buffer_copy_clipboard(v.native(), clipboard.native()) +} + +// CutClipboard() is a wrapper around gtk_text_buffer_cut_clipboard(). +func (v *TextBuffer) CutClipboard(clipboard *Clipboard, defaultEditable bool) { + C.gtk_text_buffer_cut_clipboard(v.native(), clipboard.native(), gbool(defaultEditable)) +} + +// PasteClipboard() is a wrapper around gtk_text_buffer_paste_clipboard(). +func (v *TextBuffer) PasteClipboard(clipboard *Clipboard, overrideLocation *TextIter, defaultEditable bool) { + C.gtk_text_buffer_paste_clipboard(v.native(), clipboard.native(), (*C.GtkTextIter)(overrideLocation), gbool(defaultEditable)) +} + +// AddSelectionClipboard() is a wrapper around gtk_text_buffer_add_selection_clipboard(). +func (v *TextBuffer) AddSelectionClipboard(clipboard *Clipboard) { + C.gtk_text_buffer_add_selection_clipboard(v.native(), clipboard.native()) +} + +// RemoveSelectionClipboard() is a wrapper around gtk_text_buffer_remove_selection_clipboard(). +func (v *TextBuffer) RemoveSelectionClipboard(clipboard *Clipboard) { + C.gtk_text_buffer_remove_selection_clipboard(v.native(), clipboard.native()) +} + +// GetIterAtLineIndex() is a wrapper around gtk_text_buffer_get_iter_at_line_index(). +func (v *TextBuffer) GetIterAtLineIndex(lineNumber, charIndex int) (iter *TextIter) { + iter = new(TextIter) + C.gtk_text_buffer_get_iter_at_line_index(v.native(), (*C.GtkTextIter)(iter), (C.gint)(lineNumber), (C.gint)(charIndex)) + return +} + +// InsertInteractiveAtCursor() is a wrapper around gtk_text_buffer_insert_interactive_at_cursor(). +func (v *TextBuffer) InsertInteractiveAtCursor(text string, editable bool) bool { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + + return gobool(C.gtk_text_buffer_insert_interactive_at_cursor( + v.native(), + (*C.gchar)(cstr), + C.gint(len(text)), + gbool(editable))) +} + +// InsertInteractive() is a wrapper around gtk_text_buffer_insert_interactive(). +func (v *TextBuffer) InsertInteractive(iter *TextIter, text string, editable bool) bool { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + + return gobool(C.gtk_text_buffer_insert_interactive( + v.native(), + (*C.GtkTextIter)(iter), + (*C.gchar)(cstr), + C.gint(len(text)), + gbool(editable))) +} + +// InsertRangeInteractive() is a wrapper around gtk_text_buffer_insert_range_interactive(). +func (v *TextBuffer) InsertRangeInteractive(iter, start, end *TextIter, editable bool) bool { + + return gobool(C.gtk_text_buffer_insert_range_interactive( + v.native(), + (*C.GtkTextIter)(iter), + (*C.GtkTextIter)(start), + (*C.GtkTextIter)(end), + gbool(editable))) +} + +// InsertRange() is a wrapper around gtk_text_buffer_insert_range(). +func (v *TextBuffer) InsertRange(iter, start, end *TextIter) { + + C.gtk_text_buffer_insert_range( + v.native(), + (*C.GtkTextIter)(iter), + (*C.GtkTextIter)(start), + (*C.GtkTextIter)(end)) +} + +// DeleteInteractive() is a wrapper around gtk_text_buffer_delete_interactive(). +func (v *TextBuffer) DeleteInteractive(start, end *TextIter, editable bool) bool { + + return gobool(C.gtk_text_buffer_delete_interactive( + v.native(), + (*C.GtkTextIter)(start), + (*C.GtkTextIter)(end), + gbool(editable))) +} + +// BeginUserAction() is a wrapper around gtk_text_buffer_begin_user_action(). +func (v *TextBuffer) BeginUserAction() { + + C.gtk_text_buffer_begin_user_action(v.native()) +} + +// EndUserAction() is a wrapper around gtk_text_buffer_end_user_action(). +func (v *TextBuffer) EndUserAction() { + + C.gtk_text_buffer_end_user_action(v.native()) +} + +/* + * GtkToggleButton + */ + +// ToggleButton is a representation of GTK's GtkToggleButton. +type ToggleButton struct { + Button +} + +// native returns a pointer to the underlying GtkToggleButton. +func (v *ToggleButton) native() *C.GtkToggleButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkToggleButton(p) +} + +func marshalToggleButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapToggleButton(obj), nil +} + +func wrapToggleButton(obj *glib.Object) *ToggleButton { + if obj == nil { + return nil + } + + actionable := wrapActionable(obj) + return &ToggleButton{Button{Bin{Container{Widget{ + glib.InitiallyUnowned{obj}}}}, actionable}} +} + +// ToggleButtonNew is a wrapper around gtk_toggle_button_new(). +func ToggleButtonNew() (*ToggleButton, error) { + c := C.gtk_toggle_button_new() + if c == nil { + return nil, nilPtrErr + } + return wrapToggleButton(glib.Take(unsafe.Pointer(c))), nil +} + +// ToggleButtonNewWithLabel is a wrapper around +// gtk_toggle_button_new_with_label(). +func ToggleButtonNewWithLabel(label string) (*ToggleButton, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_toggle_button_new_with_label((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapToggleButton(glib.Take(unsafe.Pointer(c))), nil +} + +// ToggleButtonNewWithMnemonic is a wrapper around +// gtk_toggle_button_new_with_mnemonic(). +func ToggleButtonNewWithMnemonic(label string) (*ToggleButton, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_toggle_button_new_with_mnemonic((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapToggleButton(glib.Take(unsafe.Pointer(c))), nil +} + +// GetActive is a wrapper around gtk_toggle_button_get_active(). +func (v *ToggleButton) GetActive() bool { + c := C.gtk_toggle_button_get_active(v.native()) + return gobool(c) +} + +// SetActive is a wrapper around gtk_toggle_button_set_active(). +func (v *ToggleButton) SetActive(isActive bool) { + C.gtk_toggle_button_set_active(v.native(), gbool(isActive)) +} + +// GetMode is a wrapper around gtk_toggle_button_get_mode(). +func (v *ToggleButton) GetMode() bool { + c := C.gtk_toggle_button_get_mode(v.native()) + return gobool(c) +} + +// SetMode is a wrapper around gtk_toggle_button_set_mode(). +func (v *ToggleButton) SetMode(drawIndicator bool) { + C.gtk_toggle_button_set_mode(v.native(), gbool(drawIndicator)) +} + +// Toggled is a wrapper around gtk_toggle_button_toggled(). +func (v *ToggleButton) Toggled() { + C.gtk_toggle_button_toggled(v.native()) +} + +// GetInconsistent gtk_toggle_button_get_inconsistent(). +func (v *ToggleButton) GetInconsistent() bool { + c := C.gtk_toggle_button_get_inconsistent(v.native()) + return gobool(c) +} + +// SetInconsistent gtk_toggle_button_set_inconsistent(). +func (v *ToggleButton) SetInconsistent(setting bool) { + C.gtk_toggle_button_set_inconsistent(v.native(), gbool(setting)) +} + +/* + * GtkToolbar + */ + +// Toolbar is a representation of GTK's GtkToolbar. +type Toolbar struct { + Container +} + +// native returns a pointer to the underlying GtkToolbar. +func (v *Toolbar) native() *C.GtkToolbar { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkToolbar(p) +} + +func marshalToolbar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapToolbar(obj), nil +} + +func wrapToolbar(obj *glib.Object) *Toolbar { + if obj == nil { + return nil + } + + return &Toolbar{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// ToolbarNew is a wrapper around gtk_toolbar_new(). +func ToolbarNew() (*Toolbar, error) { + c := C.gtk_toolbar_new() + if c == nil { + return nil, nilPtrErr + } + return wrapToolbar(glib.Take(unsafe.Pointer(c))), nil +} + +// Insert is a wrapper around gtk_toolbar_insert(). +func (v *Toolbar) Insert(item IToolItem, pos int) { + C.gtk_toolbar_insert(v.native(), item.toToolItem(), C.gint(pos)) +} + +// GetItemIndex is a wrapper around gtk_toolbar_get_item_index(). +func (v *Toolbar) GetItemIndex(item IToolItem) int { + c := C.gtk_toolbar_get_item_index(v.native(), item.toToolItem()) + return int(c) +} + +// GetNItems is a wrapper around gtk_toolbar_get_n_items(). +func (v *Toolbar) GetNItems() int { + c := C.gtk_toolbar_get_n_items(v.native()) + return int(c) +} + +// GetNthItem is a wrapper around gtk_toolbar_get_nth_item(). +func (v *Toolbar) GetNthItem(n int) *ToolItem { + c := C.gtk_toolbar_get_nth_item(v.native(), C.gint(n)) + if c == nil { + return nil + } + return wrapToolItem(glib.Take(unsafe.Pointer(c))) +} + +// GetDropIndex is a wrapper around gtk_toolbar_get_drop_index(). +func (v *Toolbar) GetDropIndex(x, y int) int { + c := C.gtk_toolbar_get_drop_index(v.native(), C.gint(x), C.gint(y)) + return int(c) +} + +// SetDropHighlightItem is a wrapper around gtk_toolbar_set_drop_highlight_item(). +func (v *Toolbar) SetDropHighlightItem(toolItem IToolItem, index int) { + C.gtk_toolbar_set_drop_highlight_item(v.native(), + toolItem.toToolItem(), C.gint(index)) +} + +// SetShowArrow is a wrapper around gtk_toolbar_set_show_arrow(). +func (v *Toolbar) SetShowArrow(showArrow bool) { + C.gtk_toolbar_set_show_arrow(v.native(), gbool(showArrow)) +} + +// UnsetIconSize is a wrapper around gtk_toolbar_unset_icon_size(). +func (v *Toolbar) UnsetIconSize() { + C.gtk_toolbar_unset_icon_size(v.native()) +} + +// GetShowArrow is a wrapper around gtk_toolbar_get_show_arrow(). +func (v *Toolbar) GetShowArrow() bool { + c := C.gtk_toolbar_get_show_arrow(v.native()) + return gobool(c) +} + +// GetStyle is a wrapper around gtk_toolbar_get_style(). +func (v *Toolbar) GetStyle() ToolbarStyle { + c := C.gtk_toolbar_get_style(v.native()) + return ToolbarStyle(c) +} + +// GetIconSize is a wrapper around gtk_toolbar_get_icon_size(). +func (v *Toolbar) GetIconSize() IconSize { + c := C.gtk_toolbar_get_icon_size(v.native()) + return IconSize(c) +} + +// GetReliefStyle is a wrapper around gtk_toolbar_get_relief_style(). +func (v *Toolbar) GetReliefStyle() ReliefStyle { + c := C.gtk_toolbar_get_relief_style(v.native()) + return ReliefStyle(c) +} + +// SetStyle is a wrapper around gtk_toolbar_set_style(). +func (v *Toolbar) SetStyle(style ToolbarStyle) { + C.gtk_toolbar_set_style(v.native(), C.GtkToolbarStyle(style)) +} + +// SetIconSize is a wrapper around gtk_toolbar_set_icon_size(). +func (v *Toolbar) SetIconSize(iconSize IconSize) { + C.gtk_toolbar_set_icon_size(v.native(), C.GtkIconSize(iconSize)) +} + +// UnsetStyle is a wrapper around gtk_toolbar_unset_style(). +func (v *Toolbar) UnsetStyle() { + C.gtk_toolbar_unset_style(v.native()) +} + +/* + * GtkToolButton + */ + +// ToolButton is a representation of GTK's GtkToolButton. +type ToolButton struct { + ToolItem +} + +// native returns a pointer to the underlying GtkToolButton. +func (v *ToolButton) native() *C.GtkToolButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkToolButton(p) +} + +func marshalToolButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapToolButton(obj), nil +} + +func wrapToolButton(obj *glib.Object) *ToolButton { + if obj == nil { + return nil + } + + return &ToolButton{ToolItem{Bin{Container{Widget{ + glib.InitiallyUnowned{obj}}}}}} +} + +// ToolButtonNew is a wrapper around gtk_tool_button_new(). +func ToolButtonNew(iconWidget IWidget, label string) (*ToolButton, error) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + w := nullableWidget(iconWidget) + c := C.gtk_tool_button_new(w, (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapToolButton(glib.Take(unsafe.Pointer(c))), nil +} + +// SetLabel is a wrapper around gtk_tool_button_set_label(). +func (v *ToolButton) SetLabel(label string) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_tool_button_set_label(v.native(), (*C.gchar)(cstr)) +} + +// GetLabel is a wrapper around gtk_tool_button_get_label(). +func (v *ToolButton) GetLabel() string { + c := C.gtk_tool_button_get_label(v.native()) + return goString(c) +} + +// SetUseUnderline is a wrapper around gtk_tool_button_set_use_underline(). +func (v *ToolButton) SetGetUnderline(useUnderline bool) { + C.gtk_tool_button_set_use_underline(v.native(), gbool(useUnderline)) +} + +// GetUseUnderline is a wrapper around gtk_tool_button_get_use_underline(). +func (v *ToolButton) GetuseUnderline() bool { + c := C.gtk_tool_button_get_use_underline(v.native()) + return gobool(c) +} + +// SetIconName is a wrapper around gtk_tool_button_set_icon_name(). +func (v *ToolButton) SetIconName(iconName string) { + cstr := C.CString(iconName) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_tool_button_set_icon_name(v.native(), (*C.gchar)(cstr)) +} + +// GetIconName is a wrapper around gtk_tool_button_get_icon_name(). +func (v *ToolButton) GetIconName() string { + c := C.gtk_tool_button_get_icon_name(v.native()) + return goString(c) +} + +// SetIconWidget is a wrapper around gtk_tool_button_set_icon_widget(). +func (v *ToolButton) SetIconWidget(iconWidget IWidget) { + C.gtk_tool_button_set_icon_widget(v.native(), iconWidget.toWidget()) +} + +// GetIconWidget is a wrapper around gtk_tool_button_get_icon_widget(). +func (v *ToolButton) GetIconWidget() (IWidget, error) { + c := C.gtk_tool_button_get_icon_widget(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// SetLabelWidget is a wrapper around gtk_tool_button_set_label_widget(). +func (v *ToolButton) SetLabelWidget(labelWidget IWidget) { + C.gtk_tool_button_set_label_widget(v.native(), labelWidget.toWidget()) +} + +// GetLabelWidget is a wrapper around gtk_tool_button_get_label_widget(). +func (v *ToolButton) GetLabelWidget() (IWidget, error) { + c := C.gtk_tool_button_get_label_widget(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +/* + * GtkToggleToolButton + */ + +// ToggleToolButton is a representation of GTK's GtkToggleToolButton. +type ToggleToolButton struct { + ToolButton +} + +// native returns a pointer to the underlying GtkToggleToolButton. +func (v *ToggleToolButton) native() *C.GtkToggleToolButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkToggleToolButton(p) +} + +func marshalToggleToolButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapToggleToolButton(obj), nil +} + +func wrapToggleToolButton(obj *glib.Object) *ToggleToolButton { + if obj == nil { + return nil + } + + return &ToggleToolButton{ToolButton{ToolItem{Bin{Container{Widget{ + glib.InitiallyUnowned{obj}}}}}}} +} + +// ToggleToolButtonNew is a wrapper around gtk_toggle_tool_button_new(). +func ToggleToolButtonNew() (*ToggleToolButton, error) { + c := C.gtk_toggle_tool_button_new() + if c == nil { + return nil, nilPtrErr + } + return wrapToggleToolButton(glib.Take(unsafe.Pointer(c))), nil +} + +// GetActive is a wrapper around gtk_toggle_tool_button_get_active(). +func (v *ToggleToolButton) GetActive() bool { + c := C.gtk_toggle_tool_button_get_active(v.native()) + return gobool(c) +} + +// SetActive is a wrapper around gtk_toggle_tool_button_set_active(). +func (v *ToggleToolButton) SetActive(isActive bool) { + C.gtk_toggle_tool_button_set_active(v.native(), gbool(isActive)) +} + +/* + * GtkToolItem + */ + +// ToolItem is a representation of GTK's GtkToolItem. +type ToolItem struct { + Bin +} + +// IToolItem is an interface type implemented by all structs embedding +// a ToolItem. It is meant to be used as an argument type for wrapper +// functions that wrap around a C GTK function taking a GtkToolItem. +type IToolItem interface { + toToolItem() *C.GtkToolItem +} + +// native returns a pointer to the underlying GtkToolItem. +func (v *ToolItem) native() *C.GtkToolItem { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkToolItem(p) +} + +func (v *ToolItem) toToolItem() *C.GtkToolItem { + return v.native() +} + +func marshalToolItem(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapToolItem(obj), nil +} + +func wrapToolItem(obj *glib.Object) *ToolItem { + if obj == nil { + return nil + } + + return &ToolItem{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// ToolItemNew is a wrapper around gtk_tool_item_new(). +func ToolItemNew() (*ToolItem, error) { + c := C.gtk_tool_item_new() + if c == nil { + return nil, nilPtrErr + } + return wrapToolItem(glib.Take(unsafe.Pointer(c))), nil +} + +// SetHomogeneous is a wrapper around gtk_tool_item_set_homogeneous(). +func (v *ToolItem) SetHomogeneous(homogeneous bool) { + C.gtk_tool_item_set_homogeneous(v.native(), gbool(homogeneous)) +} + +// GetHomogeneous is a wrapper around gtk_tool_item_get_homogeneous(). +func (v *ToolItem) GetHomogeneous() bool { + c := C.gtk_tool_item_get_homogeneous(v.native()) + return gobool(c) +} + +// SetExpand is a wrapper around gtk_tool_item_set_expand(). +func (v *ToolItem) SetExpand(expand bool) { + C.gtk_tool_item_set_expand(v.native(), gbool(expand)) +} + +// GetExpand is a wrapper around gtk_tool_item_get_expand(). +func (v *ToolItem) GetExpand() bool { + c := C.gtk_tool_item_get_expand(v.native()) + return gobool(c) +} + +// SetTooltipText is a wrapper around gtk_tool_item_set_tooltip_text(). +func (v *ToolItem) SetTooltipText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_tool_item_set_tooltip_text(v.native(), (*C.gchar)(cstr)) +} + +// SetTooltipMarkup is a wrapper around gtk_tool_item_set_tooltip_markup(). +func (v *ToolItem) SetTooltipMarkup(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_tool_item_set_tooltip_markup(v.native(), (*C.gchar)(cstr)) +} + +// SetUseDragWindow is a wrapper around gtk_tool_item_set_use_drag_window(). +func (v *ToolItem) SetUseDragWindow(useDragWindow bool) { + C.gtk_tool_item_set_use_drag_window(v.native(), gbool(useDragWindow)) +} + +// GetUseDragWindow is a wrapper around gtk_tool_item_get_use_drag_window(). +func (v *ToolItem) GetUseDragWindow() bool { + c := C.gtk_tool_item_get_use_drag_window(v.native()) + return gobool(c) +} + +// SetVisibleHorizontal is a wrapper around gtk_tool_item_set_visible_horizontal(). +func (v *ToolItem) SetVisibleHorizontal(visibleHorizontal bool) { + C.gtk_tool_item_set_visible_horizontal(v.native(), + gbool(visibleHorizontal)) +} + +// GetVisibleHorizontal is a wrapper around gtk_tool_item_get_visible_horizontal(). +func (v *ToolItem) GetVisibleHorizontal() bool { + c := C.gtk_tool_item_get_visible_horizontal(v.native()) + return gobool(c) +} + +// SetVisibleVertical is a wrapper around gtk_tool_item_set_visible_vertical(). +func (v *ToolItem) SetVisibleVertical(visibleVertical bool) { + C.gtk_tool_item_set_visible_vertical(v.native(), gbool(visibleVertical)) +} + +// GetVisibleVertical is a wrapper around gtk_tool_item_get_visible_vertical(). +func (v *ToolItem) GetVisibleVertical() bool { + c := C.gtk_tool_item_get_visible_vertical(v.native()) + return gobool(c) +} + +// SetIsImportant is a wrapper around gtk_tool_item_set_is_important(). +func (v *ToolItem) SetIsImportant(isImportant bool) { + C.gtk_tool_item_set_is_important(v.native(), gbool(isImportant)) +} + +// GetIsImportant is a wrapper around gtk_tool_item_get_is_important(). +func (v *ToolItem) GetIsImportant() bool { + c := C.gtk_tool_item_get_is_important(v.native()) + return gobool(c) +} + +// TODO: gtk_tool_item_get_ellipsize_mode + +// GetIconSize is a wrapper around gtk_tool_item_get_icon_size(). +func (v *ToolItem) GetIconSize() IconSize { + c := C.gtk_tool_item_get_icon_size(v.native()) + return IconSize(c) +} + +// GetOrientation is a wrapper around gtk_tool_item_get_orientation(). +func (v *ToolItem) GetOrientation() Orientation { + c := C.gtk_tool_item_get_orientation(v.native()) + return Orientation(c) +} + +// GetToolbarStyle is a wrapper around gtk_tool_item_get_toolbar_style(). +func (v *ToolItem) GetToolbarStyle() ToolbarStyle { + c := C.gtk_tool_item_get_toolbar_style(v.native()) + return ToolbarStyle(c) +} + +// GetReliefStyle is a wrapper around gtk_tool_item_get_relief_style(). +func (v *ToolItem) GetReliefStyle() ReliefStyle { + c := C.gtk_tool_item_get_relief_style(v.native()) + return ReliefStyle(c) +} + +// GetTextAlignment is a wrapper around gtk_tool_item_get_text_alignment(). +func (v *ToolItem) GetTextAlignment() float32 { + c := C.gtk_tool_item_get_text_alignment(v.native()) + return float32(c) +} + +// GetTextOrientation is a wrapper around gtk_tool_item_get_text_orientation(). +func (v *ToolItem) GetTextOrientation() Orientation { + c := C.gtk_tool_item_get_text_orientation(v.native()) + return Orientation(c) +} + +// RetrieveProxyMenuItem is a wrapper around gtk_tool_item_retrieve_proxy_menu_item() +func (v *ToolItem) RetrieveProxyMenuItem() *MenuItem { + c := C.gtk_tool_item_retrieve_proxy_menu_item(v.native()) + if c == nil { + return nil + } + return wrapMenuItem(glib.Take(unsafe.Pointer(c))) +} + +// TODO: +// gtk_tool_item_get_proxy_menu_item(). + +// SetProxyMenuItem is a wrapper around gtk_tool_item_set_proxy_menu_item(). +func (v *ToolItem) SetProxyMenuItem(menuItemId string, menuItem IMenuItem) { + cstr := C.CString(menuItemId) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_tool_item_set_proxy_menu_item(v.native(), (*C.gchar)(cstr), + C.toGtkWidget(unsafe.Pointer(menuItem.toMenuItem()))) +} + +// RebuildMenu is a wrapper around gtk_tool_item_rebuild_menu(). +func (v *ToolItem) RebuildMenu() { + C.gtk_tool_item_rebuild_menu(v.native()) +} + +// ToolbarReconfigured is a wrapper around gtk_tool_item_toolbar_reconfigured(). +func (v *ToolItem) ToolbarReconfigured() { + C.gtk_tool_item_toolbar_reconfigured(v.native()) +} + +// TODO: gtk_tool_item_get_text_size_group + +/* + * GtkToolItemGroup + */ + +// TODO: +// gtk_tool_item_group_get_collapsed(). +// gtk_tool_item_group_get_drop_item(). +// gtk_tool_item_group_get_ellipsize(). +// gtk_tool_item_group_get_item_position(). +// gtk_tool_item_group_get_n_items(). +// gtk_tool_item_group_get_label(). +// gtk_tool_item_group_get_label_widget(). +// gtk_tool_item_group_get_nth_item(). +// gtk_tool_item_group_get_header_relief(). +// gtk_tool_item_group_insert(). +// gtk_tool_item_group_new(). +// gtk_tool_item_group_set_collapsed(). +// gtk_tool_item_group_set_ellipsize(). +// gtk_tool_item_group_set_item_position(). +// gtk_tool_item_group_set_label(). +// gtk_tool_item_group_set_label_widget(). +// gtk_tool_item_group_set_header_relief(). + +/* + * GtkToolPalette + */ + +// TODO: +// gtk_tool_palette_new(). +// gtk_tool_palette_get_exclusive(). +// gtk_tool_palette_set_exclusive(). +// gtk_tool_palette_get_expand(). +// gtk_tool_palette_set_expand(). +// gtk_tool_palette_get_group_position(). +// gtk_tool_palette_set_group_position(). +// gtk_tool_palette_get_icon_size(). +// gtk_tool_palette_set_icon_size(). +// gtk_tool_palette_unset_icon_size(). +// gtk_tool_palette_get_style(). +// gtk_tool_palette_set_style(). +// gtk_tool_palette_unset_style(). +// gtk_tool_palette_add_drag_dest(). +// gtk_tool_palette_get_drag_item(). +// gtk_tool_palette_get_drag_target_group(). +// gtk_tool_palette_get_drag_target_item(). +// gtk_tool_palette_get_drop_group(). +// gtk_tool_palette_get_drop_item(). +// gtk_tool_palette_set_drag_source(). +// GtkToolPaletteDragTargets + +/* + * GtkTreeIter + */ + +// TreeIter is a representation of GTK's GtkTreeIter. +type TreeIter struct { + GtkTreeIter C.GtkTreeIter +} + +// native returns a pointer to the underlying GtkTreeIter. +func (v *TreeIter) native() *C.GtkTreeIter { + if v == nil { + return nil + } + return &v.GtkTreeIter +} + +func marshalTreeIter(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + return (*TreeIter)(unsafe.Pointer(c)), nil +} + +func (v *TreeIter) free() { + C.gtk_tree_iter_free(v.native()) +} + +// Copy() is a wrapper around gtk_tree_iter_copy(). +// +// Caution: when this method is used together with selection.GetSelectedRows(), +// it might cause random crash issue. See issue #590 and #610. +func (v *TreeIter) Copy() (*TreeIter, error) { + c := C.gtk_tree_iter_copy(v.native()) + if c == nil { + return nil, nilPtrErr + } + t := &TreeIter{*c} + runtime.SetFinalizer(t, (*TreeIter).free) + return t, nil +} + +/* + * GtkTreeModel + */ + +// TreeModel is a representation of GTK's GtkTreeModel GInterface. +type TreeModel struct { + *glib.Object +} + +// ITreeModel is an interface type implemented by all structs +// embedding a TreeModel. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkTreeModel. +type ITreeModel interface { + toTreeModel() *C.GtkTreeModel + ToTreeModel() *TreeModel +} + +// native returns a pointer to the underlying GObject as a GtkTreeModel. +func (v *TreeModel) native() *C.GtkTreeModel { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTreeModel(p) +} + +func (v *TreeModel) toTreeModel() *C.GtkTreeModel { + if v == nil { + return nil + } + return v.native() +} + +func marshalTreeModel(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTreeModel(obj), nil +} + +func wrapTreeModel(obj *glib.Object) *TreeModel { + if obj == nil { + return nil + } + + return &TreeModel{obj} +} + +// ToTreeModel is a helper getter, e.g.: it returns *gtk.TreeStore/ListStore as a *gtk.TreeModel. +// In other cases, where you have a gtk.ITreeModel, use the type assertion. +func (v *TreeModel) ToTreeModel() *TreeModel { + return v +} + +// GetFlags() is a wrapper around gtk_tree_model_get_flags(). +func (v *TreeModel) GetFlags() TreeModelFlags { + c := C.gtk_tree_model_get_flags(v.native()) + return TreeModelFlags(c) +} + +// GetNColumns() is a wrapper around gtk_tree_model_get_n_columns(). +func (v *TreeModel) GetNColumns() int { + c := C.gtk_tree_model_get_n_columns(v.native()) + return int(c) +} + +// GetColumnType() is a wrapper around gtk_tree_model_get_column_type(). +func (v *TreeModel) GetColumnType(index int) glib.Type { + c := C.gtk_tree_model_get_column_type(v.native(), C.gint(index)) + return glib.Type(c) +} + +// GetIter() is a wrapper around gtk_tree_model_get_iter(). +func (v *TreeModel) GetIter(path *TreePath) (*TreeIter, error) { + var iter C.GtkTreeIter + c := C.gtk_tree_model_get_iter(v.native(), &iter, path.native()) + if !gobool(c) { + return nil, errors.New("Unable to set iterator") + } + t := &TreeIter{iter} + return t, nil +} + +// GetIterFromString() is a wrapper around +// gtk_tree_model_get_iter_from_string(). +func (v *TreeModel) GetIterFromString(path string) (*TreeIter, error) { + var iter C.GtkTreeIter + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_tree_model_get_iter_from_string(v.native(), &iter, + (*C.gchar)(cstr)) + if !gobool(c) { + return nil, errors.New("Unable to set iterator") + } + t := &TreeIter{iter} + return t, nil +} + +// GetIterFirst() is a wrapper around gtk_tree_model_get_iter_first(). +func (v *TreeModel) GetIterFirst() (*TreeIter, bool) { + var iter C.GtkTreeIter + c := C.gtk_tree_model_get_iter_first(v.native(), &iter) + if !gobool(c) { + return nil, false + } + t := &TreeIter{iter} + return t, true +} + +// GetPath() is a wrapper around gtk_tree_model_get_path(). +func (v *TreeModel) GetPath(iter *TreeIter) (*TreePath, error) { + c := C.gtk_tree_model_get_path(v.native(), iter.native()) + if c == nil { + return nil, nilPtrErr + } + p := &TreePath{c} + runtime.SetFinalizer(p, (*TreePath).free) + return p, nil +} + +// GetStringFromIter() is a wrapper around gtk_tree_model_get_string_from_iter(). +func (v *TreeModel) GetStringFromIter(iter *TreeIter) string { + c := C.gtk_tree_model_get_string_from_iter(v.native(), iter.native()) + s := goString(c) + defer C.g_free((C.gpointer)(c)) + return s +} + +// GetValue() is a wrapper around gtk_tree_model_get_value(). +func (v *TreeModel) GetValue(iter *TreeIter, column int) (*glib.Value, error) { + val, err := glib.ValueAlloc() + if err != nil { + return nil, err + } + C.gtk_tree_model_get_value( + v.native(), + iter.native(), + C.gint(column), + (*C.GValue)(unsafe.Pointer(val.Native()))) + return val, nil +} + +// IterHasChild() is a wrapper around gtk_tree_model_iter_has_child(). +func (v *TreeModel) IterHasChild(iter *TreeIter) bool { + c := C.gtk_tree_model_iter_has_child(v.native(), iter.native()) + return gobool(c) +} + +// IterNext() is a wrapper around gtk_tree_model_iter_next(). +func (v *TreeModel) IterNext(iter *TreeIter) bool { + c := C.gtk_tree_model_iter_next(v.native(), iter.native()) + return gobool(c) +} + +// IterPrevious is a wrapper around gtk_tree_model_iter_previous(). +func (v *TreeModel) IterPrevious(iter *TreeIter) bool { + c := C.gtk_tree_model_iter_previous(v.native(), iter.native()) + return gobool(c) +} + +// IterParent is a wrapper around gtk_tree_model_iter_parent(). +func (v *TreeModel) IterParent(iter, child *TreeIter) bool { + c := C.gtk_tree_model_iter_parent(v.native(), iter.native(), child.native()) + return gobool(c) +} + +// IterNthChild is a wrapper around gtk_tree_model_iter_nth_child(). +func (v *TreeModel) IterNthChild(iter *TreeIter, parent *TreeIter, n int) bool { + c := C.gtk_tree_model_iter_nth_child(v.native(), iter.native(), parent.native(), C.gint(n)) + return gobool(c) +} + +// IterChildren is a wrapper around gtk_tree_model_iter_children(). +func (v *TreeModel) IterChildren(iter, child *TreeIter) bool { + var cIter, cChild *C.GtkTreeIter + if iter != nil { + cIter = iter.native() + } + cChild = child.native() + c := C.gtk_tree_model_iter_children(v.native(), cChild, cIter) + return gobool(c) +} + +// IterNChildren is a wrapper around gtk_tree_model_iter_n_children(). +func (v *TreeModel) IterNChildren(iter *TreeIter) int { + var cIter *C.GtkTreeIter + if iter != nil { + cIter = iter.native() + } + c := C.gtk_tree_model_iter_n_children(v.native(), cIter) + return int(c) +} + +// FilterNew is a wrapper around gtk_tree_model_filter_new(). +func (v *TreeModel) FilterNew(root *TreePath) (*TreeModelFilter, error) { + c := C.gtk_tree_model_filter_new(v.native(), root.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapTreeModelFilter(obj), nil +} + +// TreeModelForeachFunc defines the function prototype for the foreach function (f arg) for +// (* TreeModel).ForEach +type TreeModelForeachFunc func(model *TreeModel, path *TreePath, iter *TreeIter) bool + +// ForEach() is a wrapper around gtk_tree_model_foreach () +func (v *TreeModel) ForEach(f TreeModelForeachFunc) { + id := callback.Assign(f) + defer callback.Delete(id) + + C._gtk_tree_model_foreach(v.toTreeModel(), C.gpointer(id)) +} + +/* + * GtkTreeModelFilter + */ + +// TreeModelFilter is a representation of GTK's GtkTreeModelFilter. +type TreeModelFilter struct { + *glib.Object + + // Interfaces + TreeModel +} + +func (v *TreeModelFilter) native() *C.GtkTreeModelFilter { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTreeModelFilter(p) +} + +func (v *TreeModelFilter) toTreeModelFilter() *C.GtkTreeModelFilter { + if v == nil { + return nil + } + return v.native() +} + +func marshalTreeModelFilter(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTreeModelFilter(obj), nil +} + +func wrapTreeModelFilter(obj *glib.Object) *TreeModelFilter { + if obj == nil { + return nil + } + + tm := wrapTreeModel(obj) + return &TreeModelFilter{obj, *tm} +} + +// SetVisibleColumn is a wrapper around gtk_tree_model_filter_set_visible_column(). +func (v *TreeModelFilter) SetVisibleColumn(column int) { + C.gtk_tree_model_filter_set_visible_column(v.native(), C.gint(column)) +} + +// ConvertChildPathToPath is a wrapper around gtk_tree_model_filter_convert_child_path_to_path(). +func (v *TreeModelFilter) ConvertChildPathToPath(childPath *TreePath) *TreePath { + path := C.gtk_tree_model_filter_convert_child_path_to_path(v.native(), childPath.native()) + if path == nil { + return nil + } + p := &TreePath{path} + runtime.SetFinalizer(p, (*TreePath).free) + return p +} + +// ConvertChildIterToIter is a wrapper around gtk_tree_model_filter_convert_child_iter_to_iter(). +func (v *TreeModelFilter) ConvertChildIterToIter(childIter *TreeIter) (*TreeIter, bool) { + var iter C.GtkTreeIter + ok := gobool(C.gtk_tree_model_filter_convert_child_iter_to_iter(v.native(), &iter, childIter.native())) + t := &TreeIter{iter} + return t, ok +} + +// ConvertIterToChildIter is a wrapper around gtk_tree_model_filter_convert_child_iter_to_iter(). +func (v *TreeModelFilter) ConvertIterToChildIter(filterIter *TreeIter) *TreeIter { + var iter C.GtkTreeIter + C.gtk_tree_model_filter_convert_iter_to_child_iter(v.native(), &iter, filterIter.native()) + t := &TreeIter{iter} + return t +} + +// ConvertPathToChildPath is a wrapper around gtk_tree_model_filter_convert_path_to_child_path(). +func (v *TreeModelFilter) ConvertPathToChildPath(filterPath *TreePath) *TreePath { + path := C.gtk_tree_model_filter_convert_path_to_child_path(v.native(), filterPath.native()) + if path == nil { + return nil + } + p := &TreePath{path} + runtime.SetFinalizer(p, (*TreePath).free) + return p +} + +// Refilter is a wrapper around gtk_tree_model_filter_refilter(). +func (v *TreeModelFilter) Refilter() { + C.gtk_tree_model_filter_refilter(v.native()) +} + +// TreeModelFilterVisibleFunc defines the function prototype for the filter visibility function (f arg) +// to TreeModelFilter.SetVisibleFunc. +type TreeModelFilterVisibleFunc func(model *TreeModel, iter *TreeIter) bool + +// SetVisibleFunc is a wrapper around gtk_tree_model_filter_set_visible_func(). +func (v *TreeModelFilter) SetVisibleFunc(f TreeModelFilterVisibleFunc) { + C._gtk_tree_model_filter_set_visible_func(v.native(), C.gpointer(callback.Assign(f))) +} + +// Down() is a wrapper around gtk_tree_path_down() +func (v *TreePath) Down() { + C.gtk_tree_path_down(v.native()) +} + +// IsAncestor() is a wrapper around gtk_tree_path_is_ancestor() +func (v *TreePath) IsAncestor(descendant *TreePath) bool { + return gobool(C.gtk_tree_path_is_ancestor(v.native(), descendant.native())) +} + +// IsDescendant() is a wrapper around gtk_tree_path_is_descendant() +func (v *TreePath) IsDescendant(ancestor *TreePath) bool { + return gobool(C.gtk_tree_path_is_descendant(v.native(), ancestor.native())) +} + +/* + * GtkTreePath + */ + +// TreePath is a representation of GTK's GtkTreePath. +type TreePath struct { + GtkTreePath *C.GtkTreePath +} + +// Return a TreePath from the GList +func TreePathFromList(list *glib.List) *TreePath { + if list == nil { + return nil + } + return &TreePath{(*C.GtkTreePath)(list.Data().(unsafe.Pointer))} +} + +// native returns a pointer to the underlying GtkTreePath. +func (v *TreePath) native() *C.GtkTreePath { + if v == nil { + return nil + } + return v.GtkTreePath +} + +func marshalTreePath(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + return &TreePath{(*C.GtkTreePath)(unsafe.Pointer(c))}, nil +} + +func (v *TreePath) free() { + C.gtk_tree_path_free(v.native()) +} + +// GetIndices is a wrapper around gtk_tree_path_get_indices_with_depth +func (v *TreePath) GetIndices() []int { + var depth C.gint + var goindices []int + var ginthelp C.gint + indices := uintptr(unsafe.Pointer(C.gtk_tree_path_get_indices_with_depth(v.native(), &depth))) + size := unsafe.Sizeof(ginthelp) + for i := 0; i < int(depth); i++ { + goind := int(*((*C.gint)(unsafe.Pointer(indices)))) + goindices = append(goindices, goind) + indices += size + } + return goindices +} + +// String is a wrapper around gtk_tree_path_to_string(). +func (v *TreePath) String() string { + c := C.gtk_tree_path_to_string(v.native()) + return goString(c) +} + +// TreePathNewFromString is a wrapper around gtk_tree_path_new_from_string(). +func TreePathNewFromString(path string) (*TreePath, error) { + cstr := C.CString(path) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_tree_path_new_from_string((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + t := &TreePath{c} + runtime.SetFinalizer(t, (*TreePath).free) + return t, nil +} + +// Next() is a wrapper around gtk_tree_path_next() +func (v *TreePath) Next() { + C.gtk_tree_path_next(v.native()) +} + +// Prev() is a wrapper around gtk_tree_path_prev() +func (v *TreePath) Prev() bool { + return gobool(C.gtk_tree_path_prev(v.native())) +} + +// Up() is a wrapper around gtk_tree_path_up() +func (v *TreePath) Up() bool { + return gobool(C.gtk_tree_path_up(v.native())) +} + +// TreePathNewFirst() is a wrapper around gtk_tree_path_new_first(). +func TreePathNewFirst() (*TreePath, error) { + c := C.gtk_tree_path_new_first() + if c == nil { + return nil, nilPtrErr + } + t := &TreePath{c} + runtime.SetFinalizer(t, (*TreePath).free) + return t, nil +} + +// AppendIndex() is a wrapper around gtk_tree_path_append_index(). +func (v *TreePath) AppendIndex(index int) { + C.gtk_tree_path_append_index(v.native(), C.gint(index)) +} + +// PrependIndex() is a wrapper around gtk_tree_path_prepend_index(). +func (v *TreePath) PrependIndex(index int) { + C.gtk_tree_path_prepend_index(v.native(), C.gint(index)) +} + +// GetDepth() is a wrapper around gtk_tree_path_get_depth(). +func (v *TreePath) GetDepth() int { + return int(C.gtk_tree_path_get_depth(v.native())) +} + +// Copy() is a wrapper around gtk_tree_path_copy(). +func (v *TreePath) Copy() (*TreePath, error) { + c := C.gtk_tree_path_copy(v.native()) + if c == nil { + return nil, nilPtrErr + } + t := &TreePath{c} + runtime.SetFinalizer(t, (*TreePath).free) + return t, nil +} + +// Compare() is a wrapper around gtk_tree_path_compare(). +func (v *TreePath) Compare(b *TreePath) int { + return int(C.gtk_tree_path_compare(v.native(), b.native())) +} + +/* + * GtkTreeSelection + */ + +// TreeSelection is a representation of GTK's GtkTreeSelection. +type TreeSelection struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkTreeSelection. +func (v *TreeSelection) native() *C.GtkTreeSelection { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTreeSelection(p) +} + +func marshalTreeSelection(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTreeSelection(obj), nil +} + +func wrapTreeSelection(obj *glib.Object) *TreeSelection { + if obj == nil { + return nil + } + + return &TreeSelection{obj} +} + +// GetSelected() is a wrapper around gtk_tree_selection_get_selected(). +func (v *TreeSelection) GetSelected() (model ITreeModel, iter *TreeIter, ok bool) { + var cmodel *C.GtkTreeModel + var citer C.GtkTreeIter + c := C.gtk_tree_selection_get_selected(v.native(), + &cmodel, &citer) + model = wrapTreeModel(glib.Take(unsafe.Pointer(cmodel))) + iter = &TreeIter{citer} + ok = gobool(c) + return +} + +// SelectPath is a wrapper around gtk_tree_selection_select_path(). +func (v *TreeSelection) SelectPath(path *TreePath) { + C.gtk_tree_selection_select_path(v.native(), path.native()) +} + +// UnselectPath is a wrapper around gtk_tree_selection_unselect_path(). +func (v *TreeSelection) UnselectPath(path *TreePath) { + C.gtk_tree_selection_unselect_path(v.native(), path.native()) +} + +// GetSelectedRows is a wrapper around gtk_tree_selection_get_selected_rows(). +// All the elements of returned list are wrapped into (*gtk.TreePath) values. +// +// Please note that a runtime finalizer is only set on the head of the linked +// list, and must be kept live while accessing any item in the list, or the +// Go garbage collector will free the whole list. +func (v *TreeSelection) GetSelectedRows(model ITreeModel) *glib.List { + var pcmodel **C.GtkTreeModel + if model != nil { + cmodel := model.toTreeModel() + pcmodel = &cmodel + } + + clist := C.gtk_tree_selection_get_selected_rows(v.native(), pcmodel) + if clist == nil { + return nil + } + + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return &TreePath{(*C.GtkTreePath)(ptr)} + }) + runtime.SetFinalizer(glist, func(glist *glib.List) { + glist.FreeFull(func(item interface{}) { + path := item.(*TreePath) + C.gtk_tree_path_free(path.GtkTreePath) + }) + }) + + return glist +} + +// CountSelectedRows() is a wrapper around gtk_tree_selection_count_selected_rows(). +func (v *TreeSelection) CountSelectedRows() int { + return int(C.gtk_tree_selection_count_selected_rows(v.native())) +} + +// SelectIter is a wrapper around gtk_tree_selection_select_iter(). +func (v *TreeSelection) SelectIter(iter *TreeIter) { + C.gtk_tree_selection_select_iter(v.native(), iter.native()) +} + +// SetMode() is a wrapper around gtk_tree_selection_set_mode(). +func (v *TreeSelection) SetMode(m SelectionMode) { + C.gtk_tree_selection_set_mode(v.native(), C.GtkSelectionMode(m)) +} + +// GetMode() is a wrapper around gtk_tree_selection_get_mode(). +func (v *TreeSelection) GetMode() SelectionMode { + return SelectionMode(C.gtk_tree_selection_get_mode(v.native())) +} + +// SelectAll() is a wrapper around gtk_tree_selection_select_all() +func (v *TreeSelection) SelectAll() { + C.gtk_tree_selection_select_all(v.native()) +} + +// UnelectAll() is a wrapper around gtk_tree_selection_unselect_all() +func (v *TreeSelection) UnselectAll() { + C.gtk_tree_selection_unselect_all(v.native()) +} + +// UnselectIter() is a wrapper around gtk_tree_selection_unselect_iter(). +func (v *TreeSelection) UnselectIter(iter *TreeIter) { + C.gtk_tree_selection_unselect_iter(v.native(), iter.native()) +} + +// IterIsSelected() is a wrapper around gtk_tree_selection_iter_is_selected(). +func (v *TreeSelection) IterIsSelected(iter *TreeIter) bool { + return gobool(C.gtk_tree_selection_iter_is_selected(v.native(), iter.native())) +} + +// SelectRange() is a wrapper around gtk_tree_selection_select_range(). +func (v *TreeSelection) SelectRange(start, end *TreePath) { + C.gtk_tree_selection_select_range(v.native(), start.native(), end.native()) +} + +// UnselectRange() is a wrapper around gtk_tree_selection_unselect_range(). +func (v *TreeSelection) UnselectRange(start, end *TreePath) { + C.gtk_tree_selection_unselect_range(v.native(), start.native(), end.native()) +} + +// PathIsSelected() is a wrapper around gtk_tree_selection_path_is_selected(). +func (v *TreeSelection) PathIsSelected(path *TreePath) bool { + return gobool(C.gtk_tree_selection_path_is_selected(v.native(), path.native())) +} + +// TreeSelectionForeachFunc defines the function prototype for the selected_foreach function (f arg) for +// (* TreeSelection).SelectedForEach +type TreeSelectionForeachFunc func(model *TreeModel, path *TreePath, iter *TreeIter) + +// SelectedForEach() is a wrapper around gtk_tree_selection_selected_foreach() +func (v *TreeSelection) SelectedForEach(f TreeSelectionForeachFunc) { + id := callback.Assign(f) + defer callback.Delete(id) + + C._gtk_tree_selection_selected_foreach(v.native(), C.gpointer(id)) +} + +// TreeSelectionFunc defines the function prototype for the gtk_tree_selection_set_select_function +// function (f arg) for (* TreeSelection).SetSelectFunction +type TreeSelectionFunc func(selection *TreeSelection, model *TreeModel, path *TreePath, selected bool) bool + +// SetSelectFunction() is a wrapper around gtk_tree_selection_set_select_function() +func (v *TreeSelection) SetSelectFunction(f TreeSelectionFunc) { + C._gtk_tree_selection_set_select_function(v.native(), C.gpointer(callback.Assign(f))) +} + +/* + * GtkTreeRowReference + */ + +// TreeRowReference is a representation of GTK's GtkTreeRowReference. +type TreeRowReference struct { + GtkTreeRowReference *C.GtkTreeRowReference +} + +func (v *TreeRowReference) native() *C.GtkTreeRowReference { + if v == nil { + return nil + } + return v.GtkTreeRowReference +} + +func (v *TreeRowReference) free() { + C.gtk_tree_row_reference_free(v.native()) +} + +// TreeRowReferenceNew is a wrapper around gtk_tree_row_reference_new(). +func TreeRowReferenceNew(model *TreeModel, path *TreePath) (*TreeRowReference, error) { + c := C.gtk_tree_row_reference_new(model.native(), path.native()) + if c == nil { + return nil, nilPtrErr + } + r := &TreeRowReference{c} + runtime.SetFinalizer(r, (*TreeRowReference).free) + return r, nil +} + +// GetPath is a wrapper around gtk_tree_row_reference_get_path. +func (v *TreeRowReference) GetPath() *TreePath { + c := C.gtk_tree_row_reference_get_path(v.native()) + if c == nil { + return nil + } + t := &TreePath{c} + runtime.SetFinalizer(t, (*TreePath).free) + return t +} + +// GetModel is a wrapper around gtk_tree_row_reference_get_path. +func (v *TreeRowReference) GetModel() (ITreeModel, error) { + c := C.gtk_tree_row_reference_get_model(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castTreeModel(c) +} + +// Valid is a wrapper around gtk_tree_row_reference_valid. +func (v *TreeRowReference) Valid() bool { + c := C.gtk_tree_row_reference_valid(v.native()) + return gobool(c) +} + +/* + * GtkTreeSortable + */ + +// TreeSortable is a representation of GTK's GtkTreeSortable +type TreeSortable struct { + *glib.Object +} + +// ITreeSortable is an interface type implemented by all structs +// embedding a TreeSortable. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkTreeSortable. +type ITreeSortable interface { + toTreeSortable() *C.GtkTreeSortable +} + +// native returns a pointer to the underlying GtkTreeSortable +func (v *TreeSortable) native() *C.GtkTreeSortable { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTreeSortable(p) +} + +func (v *TreeSortable) toTreeSortable() *C.GtkTreeSortable { + if v == nil { + return nil + } + return v.native() +} + +func marshalTreeSortable(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTreeSortable(obj), nil +} + +func wrapTreeSortable(obj *glib.Object) *TreeSortable { + if obj == nil { + return nil + } + + return &TreeSortable{obj} +} + +// TreeIterCompareFunc is a representation of GtkTreeIterCompareFunc. +// It defines the function prototype for the sort function (f arg) for (* TreeSortable).SetSortFunc +type TreeIterCompareFunc func(model *TreeModel, a, b *TreeIter) int + +// GetSortColumnId() is a wrapper around gtk_tree_sortable_get_sort_column_id(). +func (v *TreeSortable) GetSortColumnId() (int, SortType, bool) { + var column C.gint + var order C.GtkSortType + ok := gobool(C.gtk_tree_sortable_get_sort_column_id(v.native(), &column, &order)) + return int(column), SortType(order), ok +} + +// SetSortColumnId() is a wrapper around gtk_tree_sortable_set_sort_column_id(). +func (v *TreeSortable) SetSortColumnId(column int, order SortType) { + C.gtk_tree_sortable_set_sort_column_id(v.native(), C.gint(column), C.GtkSortType(order)) +} + +// SetSortFunc() is a wrapper around gtk_tree_sortable_set_sort_func(). +func (v *TreeSortable) SetSortFunc(sortColumn int, f TreeIterCompareFunc) { + C._gtk_tree_sortable_set_sort_func(v.native(), C.gint(sortColumn), C.gpointer(callback.Assign(f))) +} + +// SetDefaultSortFunc() is a wrapper around gtk_tree_sortable_set_default_sort_func(). +func (v *TreeSortable) SetDefaultSortFunc(f TreeIterCompareFunc) { + C._gtk_tree_sortable_set_default_sort_func(v.native(), C.gpointer(callback.Assign(f))) +} + +func (v *TreeSortable) HasDefaultSortFunc() bool { + return gobool(C.gtk_tree_sortable_has_default_sort_func(v.native())) +} + +/* + * GtkTreeModelSort + */ + +// TreeModelSort is a representation of GTK's GtkTreeModelSort +type TreeModelSort struct { + *glib.Object + + // Interfaces + TreeModel + TreeSortable +} + +// native returns a pointer to the underlying GtkTreeModelSort +func (v *TreeModelSort) native() *C.GtkTreeModelSort { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTreeModelSort(p) +} + +func marshalTreeModelSort(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTreeModelSort(obj), nil +} + +func wrapTreeModelSort(obj *glib.Object) *TreeModelSort { + if obj == nil { + return nil + } + + tm := wrapTreeModel(obj) + ts := wrapTreeSortable(obj) + return &TreeModelSort{obj, *tm, *ts} +} + +func (v *TreeModelSort) toTreeModel() *C.GtkTreeModel { + if v == nil { + return nil + } + return C.toGtkTreeModel(unsafe.Pointer(v.GObject)) +} + +func (v *TreeModelSort) toTreeSortable() *C.GtkTreeSortable { + if v == nil { + return nil + } + return C.toGtkTreeSortable(unsafe.Pointer(v.GObject)) +} + +// TreeModelSortNew is a wrapper around gtk_tree_model_sort_new_with_model(): +func TreeModelSortNew(model ITreeModel) (*TreeModelSort, error) { + var mptr *C.GtkTreeModel + if model != nil { + mptr = model.toTreeModel() + } + c := C.gtk_tree_model_sort_new_with_model(mptr) + if c == nil { + return nil, nilPtrErr + } + + tms := wrapTreeModelSort(glib.Take(unsafe.Pointer(c))) + return tms, nil +} + +// GetModel is a wrapper around gtk_tree_model_sort_get_model() +func (v *TreeModelSort) GetModel() (ITreeModel, error) { + c := C.gtk_tree_model_sort_get_model(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castTreeModel(c) +} + +// ConvertChildPathToPath is a wrapper around gtk_tree_model_sort_convert_child_path_to_path(). +func (v *TreeModelSort) ConvertChildPathToPath(childPath *TreePath) *TreePath { + path := C.gtk_tree_model_sort_convert_child_path_to_path(v.native(), childPath.native()) + if path == nil { + return nil + } + p := &TreePath{path} + runtime.SetFinalizer(p, (*TreePath).free) + return p +} + +// ConvertChildIterToIter is a wrapper around gtk_tree_model_sort_convert_child_iter_to_iter(). +func (v *TreeModelSort) ConvertChildIterToIter(childIter *TreeIter) (*TreeIter, bool) { + var iter C.GtkTreeIter + ok := gobool(C.gtk_tree_model_sort_convert_child_iter_to_iter(v.native(), &iter, childIter.native())) + t := &TreeIter{iter} + return t, ok +} + +// ConvertPathToChildPath is a wrapper around gtk_tree_model_sort_convert_path_to_child_path(). +func (v *TreeModelSort) ConvertPathToChildPath(sortPath *TreePath) *TreePath { + path := C.gtk_tree_model_sort_convert_path_to_child_path(v.native(), sortPath.native()) + if path == nil { + return nil + } + p := &TreePath{path} + runtime.SetFinalizer(p, (*TreePath).free) + return p +} + +// ConvertIterToChildIter is a wrapper around gtk_tree_model_sort_convert_iter_to_child_iter(). +func (v *TreeModelSort) ConvertIterToChildIter(sortIter *TreeIter) *TreeIter { + var iter C.GtkTreeIter + C.gtk_tree_model_sort_convert_iter_to_child_iter(v.native(), &iter, sortIter.native()) + t := &TreeIter{iter} + return t +} + +// ResetDefaultSortFunc is a wrapper around gtk_tree_model_sort_reset_default_sort_func(). +func (v *TreeModelSort) ResetDefaultSortFunc() { + C.gtk_tree_model_sort_reset_default_sort_func(v.native()) +} + +// ClearCache is a wrapper around gtk_tree_model_sort_clear_cache(). +func (v *TreeModelSort) ClearCache() { + C.gtk_tree_model_sort_clear_cache(v.native()) +} + +// IterIsValid is a wrapper around gtk_tree_model_sort_iter_is_valid(). +func (v *TreeModelSort) IterIsValid(iter *TreeIter) bool { + return gobool(C.gtk_tree_model_sort_iter_is_valid(v.native(), iter.native())) +} + +/* + * GtkTreeStore + */ + +// TreeStore is a representation of GTK's GtkTreeStore. +type TreeStore struct { + *glib.Object + + // Interfaces + TreeModel + TreeSortable +} + +// native returns a pointer to the underlying GtkTreeStore. +func (v *TreeStore) native() *C.GtkTreeStore { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTreeStore(p) +} + +func marshalTreeStore(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTreeStore(obj), nil +} + +func wrapTreeStore(obj *glib.Object) *TreeStore { + if obj == nil { + return nil + } + + tm := wrapTreeModel(obj) + ts := wrapTreeSortable(obj) + return &TreeStore{obj, *tm, *ts} +} + +func (v *TreeStore) toTreeModel() *C.GtkTreeModel { + if v == nil { + return nil + } + return C.toGtkTreeModel(unsafe.Pointer(v.GObject)) +} + +func (v *TreeStore) toTreeSortable() *C.GtkTreeSortable { + if v == nil { + return nil + } + return C.toGtkTreeSortable(unsafe.Pointer(v.GObject)) +} + +// TreeStoreNew is a wrapper around gtk_tree_store_newv(). +func TreeStoreNew(types ...glib.Type) (*TreeStore, error) { + gtypes := C.alloc_types(C.int(len(types))) + for n, val := range types { + C.set_type(gtypes, C.int(n), C.GType(val)) + } + defer C.g_free(C.gpointer(gtypes)) + c := C.gtk_tree_store_newv(C.gint(len(types)), gtypes) + if c == nil { + return nil, nilPtrErr + } + + ts := wrapTreeStore(glib.Take(unsafe.Pointer(c))) + return ts, nil +} + +// Append is a wrapper around gtk_tree_store_append(). +func (v *TreeStore) Append(parent *TreeIter) *TreeIter { + var ti C.GtkTreeIter + var cParent *C.GtkTreeIter + if parent != nil { + cParent = parent.native() + } + C.gtk_tree_store_append(v.native(), &ti, cParent) + iter := &TreeIter{ti} + return iter +} + +// Prepend is a wrapper around gtk_tree_store_prepend(). +func (v *TreeStore) Prepend(parent *TreeIter) *TreeIter { + var ti C.GtkTreeIter + var cParent *C.GtkTreeIter + if parent != nil { + cParent = parent.native() + } + C.gtk_tree_store_prepend(v.native(), &ti, cParent) + iter := &TreeIter{ti} + return iter +} + +// Insert is a wrapper around gtk_tree_store_insert +func (v *TreeStore) Insert(parent *TreeIter, position int) *TreeIter { + var ti C.GtkTreeIter + var cParent *C.GtkTreeIter + if parent != nil { + cParent = parent.native() + } + C.gtk_tree_store_insert(v.native(), &ti, cParent, C.gint(position)) + iter := &TreeIter{ti} + return iter +} + +// SetValue is a wrapper around gtk_tree_store_set_value() +func (v *TreeStore) SetValue(iter *TreeIter, column int, value interface{}) error { + switch value.(type) { + case *gdk.Pixbuf: + pix := value.(*gdk.Pixbuf) + C._gtk_tree_store_set(v.native(), iter.native(), C.gint(column), unsafe.Pointer(pix.Native())) + + default: + gv, err := glib.GValue(value) + if err != nil { + return err + } + C.gtk_tree_store_set_value(v.native(), iter.native(), + C.gint(column), + (*C.GValue)(C.gpointer(gv.Native()))) + } + return nil +} + +// Remove is a wrapper around gtk_tree_store_remove(). +func (v *TreeStore) Remove(iter *TreeIter) bool { + var ti *C.GtkTreeIter + if iter != nil { + ti = iter.native() + } + return 0 != C.gtk_tree_store_remove(v.native(), ti) +} + +// Clear is a wrapper around gtk_tree_store_clear(). +func (v *TreeStore) Clear() { + C.gtk_tree_store_clear(v.native()) +} + +// InsertBefore() is a wrapper around gtk_tree_store_insert_before(). +func (v *TreeStore) InsertBefore(parent, sibling *TreeIter) *TreeIter { + var ti C.GtkTreeIter + C.gtk_tree_store_insert_before(v.native(), &ti, parent.native(), sibling.native()) + iter := &TreeIter{ti} + return iter +} + +// InsertAfter() is a wrapper around gtk_tree_store_insert_after(). +func (v *TreeStore) InsertAfter(parent, sibling *TreeIter) *TreeIter { + var ti C.GtkTreeIter + C.gtk_tree_store_insert_after(v.native(), &ti, parent.native(), sibling.native()) + iter := &TreeIter{ti} + return iter +} + +// InsertWithValues() is a wrapper around gtk_tree_store_insert_with_valuesv(). +func (v *TreeStore) InsertWithValues(iter, parent *TreeIter, position int, inColumns []int, inValues []interface{}) error { + length := len(inColumns) + if len(inValues) < length { + length = len(inValues) + } + + cColumns := make([]C.gint, 0, length) + cValues := make([]C.GValue, 0, length) + + for i := 0; i < length; i++ { + + value := inValues[i] + var gvalue *C.GValue + + switch value.(type) { + case *gdk.Pixbuf: + pix := value.(*gdk.Pixbuf) + + if pix == nil { + continue + } + + gvalue = (*C.GValue)(unsafe.Pointer(pix.Native())) + + default: + gv, err := glib.GValue(value) + if err != nil { + return err + } + gvalue = (*C.GValue)(C.gpointer(gv.Native())) + } + + cColumns = append(cColumns, C.gint(inColumns[i])) + cValues = append(cValues, *gvalue) + } + + var cColumnsPointer *C.gint + if len(cColumns) > 0 { + cColumnsPointer = &cColumns[0] + } + var cValuesPointer *C.GValue + if len(cValues) > 0 { + cValuesPointer = &cValues[0] + } + + C.gtk_tree_store_insert_with_valuesv(v.native(), iter.native(), parent.native(), C.gint(position), cColumnsPointer, cValuesPointer, C.gint(len(cColumns))) + + return nil +} + +// MoveBefore is a wrapper around gtk_tree_store_move_before(). +func (v *TreeStore) MoveBefore(iter, position *TreeIter) { + C.gtk_tree_store_move_before(v.native(), iter.native(), + position.native()) +} + +// MoveAfter is a wrapper around gtk_tree_store_move_after(). +func (v *TreeStore) MoveAfter(iter, position *TreeIter) { + C.gtk_tree_store_move_after(v.native(), iter.native(), + position.native()) +} + +// Swap is a wrapper around gtk_tree_store_swap(). +func (v *TreeStore) Swap(a, b *TreeIter) { + C.gtk_tree_store_swap(v.native(), a.native(), b.native()) +} + +// SetColumnTypes is a wrapper around gtk_tree_store_set_column_types(). +// The size of glib.Type must match the number of columns +func (v *TreeStore) SetColumnTypes(types ...glib.Type) { + gtypes := C.alloc_types(C.int(len(types))) + for n, val := range types { + C.set_type(gtypes, C.int(n), C.GType(val)) + } + defer C.g_free(C.gpointer(gtypes)) + C.gtk_tree_store_set_column_types(v.native(), C.gint(len(types)), gtypes) +} + +/* + * GtkViewport + */ + +// Viewport is a representation of GTK's GtkViewport GInterface. +type Viewport struct { + Bin + + // Interfaces + Scrollable +} + +// IViewport is an interface type implemented by all structs +// embedding a Viewport. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkViewport. +type IViewport interface { + toViewport() *C.GtkViewport +} + +// native() returns a pointer to the underlying GObject as a GtkViewport. +func (v *Viewport) native() *C.GtkViewport { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkViewport(p) +} + +func wrapViewport(obj *glib.Object) *Viewport { + if obj == nil { + return nil + } + + b := wrapBin(obj) + s := wrapScrollable(obj) + return &Viewport{ + Bin: *b, + Scrollable: *s, + } +} + +func (v *Viewport) toViewport() *C.GtkViewport { + if v == nil { + return nil + } + return v.native() +} + +// ViewportNew() is a wrapper around gtk_viewport_new(). +func ViewportNew(hadjustment, vadjustment *Adjustment) (*Viewport, error) { + c := C.gtk_viewport_new(hadjustment.native(), vadjustment.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapViewport(glib.Take(unsafe.Pointer(c))), nil +} + +// SetShadowType is a wrapper around gtk_viewport_set_shadow_type(). +func (v *Viewport) SetShadowType(shadowType ShadowType) { + C.gtk_viewport_set_shadow_type(v.native(), C.GtkShadowType(shadowType)) +} + +// GetShadowType is a wrapper around gtk_viewport_get_shadow_type(). +func (v *Viewport) GetShadowType() ShadowType { + c := C.gtk_viewport_get_shadow_type(v.native()) + return ShadowType(c) +} + +// GetBinWindow is a wrapper around gtk_viewport_get_bin_window(). +func (v *Viewport) GetBinWindow() *gdk.Window { + c := C.gtk_viewport_get_bin_window(v.native()) + if c == nil { + return nil + } + return &gdk.Window{glib.Take(unsafe.Pointer(c))} +} + +// GetViewWindow is a wrapper around gtk_viewport_get_view_window(). +func (v *Viewport) GetViewWindow() *gdk.Window { + c := C.gtk_viewport_get_view_window(v.native()) + if c == nil { + return nil + } + return &gdk.Window{glib.Take(unsafe.Pointer(c))} +} + +/* + * GtkVolumeButton + */ + +// VolumeButton is a representation of GTK's GtkVolumeButton. +type VolumeButton struct { + ScaleButton +} + +// native() returns a pointer to the underlying GtkVolumeButton. +func (v *VolumeButton) native() *C.GtkVolumeButton { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkVolumeButton(p) +} + +func marshalVolumeButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapVolumeButton(obj), nil +} + +func wrapVolumeButton(obj *glib.Object) *VolumeButton { + if obj == nil { + return nil + } + + actionable := wrapActionable(obj) + return &VolumeButton{ScaleButton{Button{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}, actionable}}} +} + +// VolumeButtonNew is a wrapper around gtk_volume_button_new(). +func VolumeButtonNew() (*VolumeButton, error) { + c := C.gtk_volume_button_new() + if c == nil { + return nil, nilPtrErr + } + return wrapVolumeButton(glib.Take(unsafe.Pointer(c))), nil +} + +type WrapFn interface{} + +var WrapMap = map[string]WrapFn{ + "GtkAccelGroup": wrapAccelGroup, + "GtkAccelMao": wrapAccelMap, + "GtkAdjustment": wrapAdjustment, + "GtkApplicationWindow": wrapApplicationWindow, + "GtkAssistant": wrapAssistant, + "GtkBin": wrapBin, + "GtkBox": wrapBox, + "GtkButton": wrapButton, + "GtkCalendar": wrapCalendar, + "GtkCellLayout": wrapCellLayout, + "GtkCellEditable": wrapCellEditable, + "GtkCellRenderer": wrapCellRenderer, + "GtkCellRendererSpinner": wrapCellRendererSpinner, + "GtkCellRendererPixbuf": wrapCellRendererPixbuf, + "GtkCellRendererText": wrapCellRendererText, + "GtkCellRendererProgress": wrapCellRendererProgress, + "GtkCellRendererToggle": wrapCellRendererToggle, + "GtkCellRendererCombo": wrapCellRendererCombo, + "GtkCellRendererAccel": wrapCellRendererAccel, + "GtkCellRendererSpin": wrapCellRendererSpin, + "GtkCheckButton": wrapCheckButton, + "GtkCheckMenuItem": wrapCheckMenuItem, + "GtkClipboard": wrapClipboard, + "GtkColorButton": wrapColorButton, + "GtkContainer": wrapContainer, + "GtkDialog": wrapDialog, + "GtkDrawingArea": wrapDrawingArea, + "GtkEditable": wrapEditable, + "GtkEntry": wrapEntry, + "GtkEntryBuffer": wrapEntryBuffer, + "GtkEntryCompletion": wrapEntryCompletion, + "GtkEventBox": wrapEventBox, + "GtkExpander": wrapExpander, + "GtkFrame": wrapFrame, + "GtkFileChooser": wrapFileChooser, + "GtkFileChooserButton": wrapFileChooserButton, + "GtkFileChooserDialog": wrapFileChooserDialog, + "GtkFileChooserWidget": wrapFileChooserWidget, + "GtkGrid": wrapGrid, + "GtkIconView": wrapIconView, + "GtkImage": wrapImage, + "GtkLabel": wrapLabel, + "GtkLayout": wrapLayout, + "GtkLinkButton": wrapLinkButton, + "GtkListStore": wrapListStore, + "GtkMenu": wrapMenu, + "GtkMenuBar": wrapMenuBar, + "GtkMenuButton": wrapMenuButton, + "GtkMenuItem": wrapMenuItem, + "GtkMenuShell": wrapMenuShell, + "GtkMessageDialog": wrapMessageDialog, + "GtkNotebook": wrapNotebook, + "GtkOffscreenWindow": wrapOffscreenWindow, + "GtkOrientable": wrapOrientable, + "GtkOverlay": wrapOverlay, + "GtkPaned": wrapPaned, + "GtkProgressBar": wrapProgressBar, + "GtkRadioButton": wrapRadioButton, + "GtkRadioMenuItem": wrapRadioMenuItem, + "GtkRange": wrapRange, + "GtkRecentChooser": wrapRecentChooser, + "GtkRecentChooserMenu": wrapRecentChooserMenu, + "GtkRecentFilter": wrapRecentFilter, + "GtkRecentManager": wrapRecentManager, + "GtkScaleButton": wrapScaleButton, + "GtkScale": wrapScale, + "GtkScrollable": wrapScrollable, + "GtkScrollbar": wrapScrollbar, + "GtkScrolledWindow": wrapScrolledWindow, + "GtkSearchEntry": wrapSearchEntry, + "GtkSeparator": wrapSeparator, + "GtkSeparatorMenuItem": wrapSeparatorMenuItem, + "GtkSeparatorToolItem": wrapSeparatorToolItem, + "GtkSpinButton": wrapSpinButton, + "GtkSpinner": wrapSpinner, + "GtkStatusbar": wrapStatusbar, + "GtkSwitch": wrapSwitch, + "GtkTextBuffer": wrapTextBuffer, + "GtkTextChildAnchor": wrapTextChildAnchor, + "GtkTextTag": wrapTextTag, + "GtkTextTagTable": wrapTextTagTable, + "GtkTextView": wrapTextView, + "GtkToggleButton": wrapToggleButton, + "GtkToolbar": wrapToolbar, + "GtkToolButton": wrapToolButton, + "GtkToggleToolButton": wrapToggleToolButton, + "GtkToolItem": wrapToolItem, + "GtkTreeModel": wrapTreeModel, + "GtkTreeModelFilter": wrapTreeModelFilter, + "GtkTreeModelSort": wrapTreeModelSort, + "GtkTreeSelection": wrapTreeSelection, + "GtkTreeStore": wrapTreeStore, + "GtkTreeView": wrapTreeView, + "GtkTreeViewColumn": wrapTreeViewColumn, + "GtkViewport": wrapViewport, + "GtkVolumeButton": wrapVolumeButton, + "GtkWidget": wrapWidget, + "GtkWindow": wrapWindow, +} + +// castInternal casts the given object to the appropriate Go struct, but returns it as interface for later type assertions. +// The className is the results of C.object_get_class_name(c) called on the native object. +// The obj is the result of glib.Take(unsafe.Pointer(c)), used as a parameter for the wrapper functions. +func castInternal(className string, obj *glib.Object) (interface{}, error) { + fn, ok := WrapMap[className] + if !ok { + return nil, errors.New("unrecognized class name '" + className + "'") + } + + // Check that the wrapper function is actually a function + rf := reflect.ValueOf(fn) + if rf.Type().Kind() != reflect.Func { + return nil, errors.New("wraper is not a function") + } + + // Call the wraper function with the *glib.Object as first parameter + // e.g. "wrapWindow(obj)" + v := reflect.ValueOf(obj) + rv := rf.Call([]reflect.Value{v}) + + // At most/max 1 return value + if len(rv) != 1 { + return nil, errors.New("wrapper did not return") + } + + // Needs to be a pointer of some sort + if k := rv[0].Kind(); k != reflect.Ptr { + return nil, fmt.Errorf("wrong return type %s", k) + } + + // Only get an interface value, type check will be done in more specific functions + return rv[0].Interface(), nil +} + +// cast takes a native GObject and casts it to the appropriate Go struct. +//TODO change all wrapFns to return an IObject +//^- not sure about this TODO. This may make some usages of the wrapper functions quite verbose, no? +func cast(c *C.GObject) (glib.IObject, error) { + ptr := unsafe.Pointer(c) + var ( + className = goString(C.object_get_class_name(C.toGObject(ptr))) + obj = glib.Take(ptr) + ) + + intf, err := castInternal(className, obj) + if err != nil { + return nil, err + } + + ret, ok := intf.(glib.IObject) + if !ok { + return nil, errors.New("did not return an IObject") + } + + return ret, nil +} + +// castWidget takes a native GtkWidget and casts it to the appropriate Go struct. +func castWidget(c *C.GtkWidget) (IWidget, error) { + ptr := unsafe.Pointer(c) + var ( + className = goString(C.object_get_class_name(C.toGObject(ptr))) + obj = glib.Take(ptr) + ) + + intf, err := castInternal(className, obj) + if err != nil { + return nil, err + } + + ret, ok := intf.(IWidget) + if !ok { + return nil, fmt.Errorf("expected value of type IWidget, got %T", intf) + } + + return ret, nil +} + +// castCellRenderer takes a native GtkCellRenderer and casts it to the appropriate Go struct. +func castCellRenderer(c *C.GtkCellRenderer) (ICellRenderer, error) { + ptr := unsafe.Pointer(c) + var ( + className = goString(C.object_get_class_name(C.toGObject(ptr))) + obj = glib.Take(ptr) + ) + + intf, err := castInternal(className, obj) + if err != nil { + return nil, err + } + + ret, ok := intf.(ICellRenderer) + if !ok { + return nil, fmt.Errorf("expected value of type ICellRenderer, got %T", intf) + } + + return ret, nil +} + +// castTreeModel takes a native GtkCellTreeModel and casts it to the appropriate Go struct. +func castTreeModel(c *C.GtkTreeModel) (ITreeModel, error) { + ptr := unsafe.Pointer(c) + var ( + className = goString(C.object_get_class_name(C.toGObject(ptr))) + obj = glib.Take(ptr) + ) + + intf, err := castInternal(className, obj) + if err != nil { + return nil, err + } + + ret, ok := intf.(ITreeModel) + if !ok { + return nil, fmt.Errorf("expected value of type ITreeModel, got %T", intf) + } + + return ret, nil +} + +// castCellEditable takes a native GtkCellEditable and casts it to the appropriate Go struct. +func castCellEditable(c *C.GtkCellEditable) (ICellEditable, error) { + ptr := unsafe.Pointer(c) + var ( + className = goString(C.object_get_class_name(C.toGObject(ptr))) + obj = glib.Take(ptr) + ) + + intf, err := castInternal(className, obj) + if err != nil { + return nil, err + } + + ret, ok := intf.(ICellEditable) + if !ok { + return nil, fmt.Errorf("expected value of type ICellEditable, got %T", intf) + } + + return ret, nil +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk.go.h b/vendor/github.com/gotk3/gotk3/gtk/gtk.go.h new file mode 100644 index 0000000..9e11052 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk.go.h @@ -0,0 +1,651 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#pragma once + +#include +#include +#include + +// gotk3_callbackDelete satisfies the GDestroyNotify type. +extern void gotk3_callbackDelete(gpointer callback_id); + +static GtkAboutDialog *toGtkAboutDialog(void *p) { + return (GTK_ABOUT_DIALOG(p)); +} + +static GtkAppChooser *toGtkAppChooser(void *p) { return (GTK_APP_CHOOSER(p)); } + +static GtkAppChooserButton *toGtkAppChooserButton(void *p) { + return (GTK_APP_CHOOSER_BUTTON(p)); +} + +static GtkAppChooserDialog *toGtkAppChooserDialog(void *p) { + return (GTK_APP_CHOOSER_DIALOG(p)); +} + +static GtkAppChooserWidget *toGtkAppChooserWidget(void *p) { + return (GTK_APP_CHOOSER_WIDGET(p)); +} + +static GtkApplication *toGtkApplication(void *p) { + return (GTK_APPLICATION(p)); +} + +static GtkApplicationWindow *toGtkApplicationWindow(void *p) { + return (GTK_APPLICATION_WINDOW(p)); +} + +static GtkAssistant *toGtkAssistant(void *p) { return (GTK_ASSISTANT(p)); } + +static GtkCalendar *toGtkCalendar(void *p) { return (GTK_CALENDAR(p)); } + +static GtkColorChooserDialog *toGtkColorChooserDialog(void *p) { + return (GTK_COLOR_CHOOSER_DIALOG(p)); +} + +static GtkDrawingArea *toGtkDrawingArea(void *p) { + return (GTK_DRAWING_AREA(p)); +} + +static GtkCellRendererSpinner *toGtkCellRendererSpinner(void *p) { + return (GTK_CELL_RENDERER_SPINNER(p)); +} + +static GtkEventBox *toGtkEventBox(void *p) { return (GTK_EVENT_BOX(p)); } + +static GtkGrid *toGtkGrid(void *p) { return (GTK_GRID(p)); } + +static GtkWidget *toGtkWidget(void *p) { return (GTK_WIDGET(p)); } + +static GtkContainer *toGtkContainer(void *p) { return (GTK_CONTAINER(p)); } + +static GtkOverlay *toGtkOverlay(void *p) { return (GTK_OVERLAY(p)); } + +static GtkPageSetup *toGtkPageSetup(void *p) { return (GTK_PAGE_SETUP(p)); } + +static GtkPaned *toGtkPaned(void *p) { return (GTK_PANED(p)); } + +static GtkPrintContext *toGtkPrintContext(void *p) { + return (GTK_PRINT_CONTEXT(p)); +} + +static GtkPrintOperation *toGtkPrintOperation(void *p) { + return (GTK_PRINT_OPERATION(p)); +} + +static GtkPrintOperationPreview *toGtkPrintOperationPreview(void *p) { + return (GTK_PRINT_OPERATION_PREVIEW(p)); +} + +static GtkPrintSettings *toGtkPrintSettings(void *p) { + return (GTK_PRINT_SETTINGS(p)); +} + +static GtkProgressBar *toGtkProgressBar(void *p) { + return (GTK_PROGRESS_BAR(p)); +} + +static GtkLevelBar *toGtkLevelBar(void *p) { return (GTK_LEVEL_BAR(p)); } + +static GtkBin *toGtkBin(void *p) { return (GTK_BIN(p)); } + +static GtkWindow *toGtkWindow(void *p) { return (GTK_WINDOW(p)); } + +static GtkWindowGroup *toGtkWindowGroup(void *p) { + return (GTK_WINDOW_GROUP(p)); +} + +static GtkBox *toGtkBox(void *p) { return (GTK_BOX(p)); } + +static GtkStatusbar *toGtkStatusbar(void *p) { return (GTK_STATUSBAR(p)); } + +static GtkLabel *toGtkLabel(void *p) { return (GTK_LABEL(p)); } + +static GtkNotebook *toGtkNotebook(void *p) { return (GTK_NOTEBOOK(p)); } + +static GtkEntry *toGtkEntry(void *p) { return (GTK_ENTRY(p)); } + +static GtkEntryBuffer *toGtkEntryBuffer(void *p) { + return (GTK_ENTRY_BUFFER(p)); +} + +static GtkEntryCompletion *toGtkEntryCompletion(void *p) { + return (GTK_ENTRY_COMPLETION(p)); +} + +static GtkAdjustment *toGtkAdjustment(void *p) { return (GTK_ADJUSTMENT(p)); } + +static GtkAccelGroup *toGtkAccelGroup(void *p) { return (GTK_ACCEL_GROUP(p)); } + +static GtkAccelMap *toGtkAccelMap(void *p) { return (GTK_ACCEL_MAP(p)); } + +static GtkTextTag *toGtkTextTag(void *p) { return (GTK_TEXT_TAG(p)); } + +static GtkIconView *toGtkIconView(void *p) { return (GTK_ICON_VIEW(p)); } + +static GtkImage *toGtkImage(void *p) { return (GTK_IMAGE(p)); } + +static GtkButtonBox *toGtkButtonBox(void *p) { return (GTK_BUTTON_BOX(p)); } + +static GtkButton *toGtkButton(void *p) { return (GTK_BUTTON(p)); } + +static GtkScaleButton *toGtkScaleButton(void *p) { + return (GTK_SCALE_BUTTON(p)); +} + +static GtkColorButton *toGtkColorButton(void *p) { + return (GTK_COLOR_BUTTON(p)); +} + +static GtkViewport *toGtkViewport(void *p) { return (GTK_VIEWPORT(p)); } + +static GtkVolumeButton *toGtkVolumeButton(void *p) { + return (GTK_VOLUME_BUTTON(p)); +} + +static GtkScrollable *toGtkScrollable(void *p) { return (GTK_SCROLLABLE(p)); } + +static GtkScrolledWindow *toGtkScrolledWindow(void *p) { + return (GTK_SCROLLED_WINDOW(p)); +} + +static GtkMenuItem *toGtkMenuItem(void *p) { return (GTK_MENU_ITEM(p)); } + +static GtkMenu *toGtkMenu(void *p) { return (GTK_MENU(p)); } + +static GtkMenuShell *toGtkMenuShell(void *p) { return (GTK_MENU_SHELL(p)); } + +static GtkMenuBar *toGtkMenuBar(void *p) { return (GTK_MENU_BAR(p)); } + +static GtkSizeGroup *toGtkSizeGroup(void *p) { return (GTK_SIZE_GROUP(p)); } + +static GtkSpinButton *toGtkSpinButton(void *p) { return (GTK_SPIN_BUTTON(p)); } + +static GtkSpinner *toGtkSpinner(void *p) { return (GTK_SPINNER(p)); } + +static GtkComboBox *toGtkComboBox(void *p) { return (GTK_COMBO_BOX(p)); } + +static GtkComboBoxText *toGtkComboBoxText(void *p) { + return (GTK_COMBO_BOX_TEXT(p)); +} + +static GtkLinkButton *toGtkLinkButton(void *p) { return (GTK_LINK_BUTTON(p)); } + +static GtkLockButton *toGtkLockButton(void *p) { return (GTK_LOCK_BUTTON(p)); } + +static GtkLayout *toGtkLayout(void *p) { return (GTK_LAYOUT(p)); } + +static GtkTreeModelSort *toGtkTreeModelSortable(void *p) { + return (GTK_TREE_MODEL_SORT(p)); +} + +static GtkListStore *toGtkListStore(void *p) { return (GTK_LIST_STORE(p)); } + +static GtkSwitch *toGtkSwitch(void *p) { return (GTK_SWITCH(p)); } + +static GtkTextView *toGtkTextView(void *p) { return (GTK_TEXT_VIEW(p)); } + +static GtkTextMark *toGtkTextMark(void *p) { return (GTK_TEXT_MARK(p)); } + +static GtkTextTagTable *toGtkTextTagTable(void *p) { + return (GTK_TEXT_TAG_TABLE(p)); +} + +static GtkTextBuffer *toGtkTextBuffer(void *p) { return (GTK_TEXT_BUFFER(p)); } + +static GtkTreeModel *toGtkTreeModel(void *p) { return (GTK_TREE_MODEL(p)); } + +static GtkTreeModelFilter *toGtkTreeModelFilter(void *p) { + return (GTK_TREE_MODEL_FILTER(p)); +} + +static GtkCellRenderer *toGtkCellRenderer(void *p) { + return (GTK_CELL_RENDERER(p)); +} + +static GtkCellEditable *toGtkCellEditable(void *p) { + return (GTK_CELL_EDITABLE(p)); +} + +static GtkCellRendererPixbuf *toGtkCellRendererPixbuf(void *p) { + return (GTK_CELL_RENDERER_PIXBUF(p)); +} + +static GtkCellRendererProgress *toGtkCellRendererProgress(void *p) { + return (GTK_CELL_RENDERER_PROGRESS(p)); +} + +static GtkCellRendererText *toGtkCellRendererText(void *p) { + return (GTK_CELL_RENDERER_TEXT(p)); +} + +static GtkCellRendererToggle *toGtkCellRendererToggle(void *p) { + return (GTK_CELL_RENDERER_TOGGLE(p)); +} + +static GtkCellRendererCombo *toGtkCellRendererCombo(void *p) { + return (GTK_CELL_RENDERER_COMBO(p)); +} + +static GtkCellRendererAccel *toGtkCellRendererAccel(void *p) { + return (GTK_CELL_RENDERER_ACCEL(p)); +} + +static GtkCellRendererSpin *toGtkCellRendererSpin(void *p) { + return (GTK_CELL_RENDERER_SPIN(p)); +} + +static GtkCellLayout *toGtkCellLayout(void *p) { return (GTK_CELL_LAYOUT(p)); } + +static GtkCellArea *toGtkCellArea(void *p) { return (GTK_CELL_AREA(p)); } + +static GtkCellAreaContext *toGtkCellAreaContext(void *p) { + return (GTK_CELL_AREA_CONTEXT(p)); +} + +static GtkCellAreaBox *toGtkCellAreaBox(void *p) { + return (GTK_CELL_AREA_BOX(p)); +} + +static GtkOrientable *toGtkOrientable(void *p) { return (GTK_ORIENTABLE(p)); } + +static GtkTreeStore *toGtkTreeStore(void *p) { return (GTK_TREE_STORE(p)); } + +static GtkTreeView *toGtkTreeView(void *p) { return (GTK_TREE_VIEW(p)); } + +static GtkTreeViewColumn *toGtkTreeViewColumn(void *p) { + return (GTK_TREE_VIEW_COLUMN(p)); +} + +static GtkTreeSelection *toGtkTreeSelection(void *p) { + return (GTK_TREE_SELECTION(p)); +} + +static GtkTreeModelSort *toGtkTreeModelSort(void *p) { + return (GTK_TREE_MODEL_SORT(p)); +} + +static GtkTreeSortable *toGtkTreeSortable(void *p) { + return (GTK_TREE_SORTABLE(p)); +} + +static GtkClipboard *toGtkClipboard(void *p) { return (GTK_CLIPBOARD(p)); } + +static GtkDialog *toGtkDialog(void *p) { return (GTK_DIALOG(p)); } + +static GtkMessageDialog *toGtkMessageDialog(void *p) { + return (GTK_MESSAGE_DIALOG(p)); +} + +static GtkBuilder *toGtkBuilder(void *p) { return (GTK_BUILDER(p)); } + +static GtkSeparatorMenuItem *toGtkSeparatorMenuItem(void *p) { + return (GTK_SEPARATOR_MENU_ITEM(p)); +} + +static GtkCheckButton *toGtkCheckButton(void *p) { + return (GTK_CHECK_BUTTON(p)); +} + +static GtkToggleButton *toGtkToggleButton(void *p) { + return (GTK_TOGGLE_BUTTON(p)); +} + +static GtkFontButton *toGtkFontButton(void *p) { return (GTK_FONT_BUTTON(p)); } + +static GtkFrame *toGtkFrame(void *p) { return (GTK_FRAME(p)); } + +static GtkAspectFrame *toGtkAspectFrame(void *p) { + return (GTK_ASPECT_FRAME(p)); +} + +static GtkSeparator *toGtkSeparator(void *p) { return (GTK_SEPARATOR(p)); } + +static GtkScale *toGtkScale(void *p) { return (GTK_SCALE(p)); } + +static GtkScrollbar *toGtkScrollbar(void *p) { return (GTK_SCROLLBAR(p)); } + +static GtkRange *toGtkRange(void *p) { return (GTK_RANGE(p)); } + +static GtkSearchEntry *toGtkSearchEntry(void *p) { + return (GTK_SEARCH_ENTRY(p)); +} + +static GtkOffscreenWindow *toGtkOffscreenWindow(void *p) { + return (GTK_OFFSCREEN_WINDOW(p)); +} + +static GtkExpander *toGtkExpander(void *p) { return (GTK_EXPANDER(p)); } + +static GtkFileChooser *toGtkFileChooser(void *p) { + return (GTK_FILE_CHOOSER(p)); +} + +static GtkFileChooserButton *toGtkFileChooserButton(void *p) { + return (GTK_FILE_CHOOSER_BUTTON(p)); +} + +static GtkFileChooserDialog *toGtkFileChooserDialog(void *p) { + return (GTK_FILE_CHOOSER_DIALOG(p)); +} + +static GtkFileChooserWidget *toGtkFileChooserWidget(void *p) { + return (GTK_FILE_CHOOSER_WIDGET(p)); +} + +static GtkFileFilter *toGtkFileFilter(void *p) { return (GTK_FILE_FILTER(p)); } + +static GtkMenuButton *toGtkMenuButton(void *p) { return (GTK_MENU_BUTTON(p)); } + +static GtkRadioButton *toGtkRadioButton(void *p) { + return (GTK_RADIO_BUTTON(p)); +} + +static GtkRecentChooser *toGtkRecentChooser(void *p) { + return (GTK_RECENT_CHOOSER(p)); +} + +static GtkRecentChooserMenu *toGtkRecentChooserMenu(void *p) { + return (GTK_RECENT_CHOOSER_MENU(p)); +} + +static GtkColorChooser *toGtkColorChooser(void *p) { + return (GTK_COLOR_CHOOSER(p)); +} + +static GtkFontChooser *toGtkFontChooser(void *p) { + return (GTK_FONT_CHOOSER(p)); +} + +static GtkRecentFilter *toGtkRecentFilter(void *p) { + return (GTK_RECENT_FILTER(p)); +} + +static GtkRecentManager *toGtkRecentManager(void *p) { + return (GTK_RECENT_MANAGER(p)); +} + +static GtkCheckMenuItem *toGtkCheckMenuItem(void *p) { + return (GTK_CHECK_MENU_ITEM(p)); +} + +static GtkRadioMenuItem *toGtkRadioMenuItem(void *p) { + return (GTK_RADIO_MENU_ITEM(p)); +} + +static GtkToolItem *toGtkToolItem(void *p) { return (GTK_TOOL_ITEM(p)); } + +static GtkToolbar *toGtkToolbar(void *p) { return (GTK_TOOLBAR(p)); } + +static GtkTooltip *toGtkTooltip(void *p) { return (GTK_TOOLTIP(p)); } + +static GtkEditable *toGtkEditable(void *p) { return (GTK_EDITABLE(p)); } + +static GtkToolButton *toGtkToolButton(void *p) { return (GTK_TOOL_BUTTON(p)); } + +static GtkToggleToolButton *toGtkToggleToolButton(void *p) { + return (GTK_TOGGLE_TOOL_BUTTON(p)); +} + +static GtkSeparatorToolItem *toGtkSeparatorToolItem(void *p) { + return (GTK_SEPARATOR_TOOL_ITEM(p)); +} + +static GtkCssProvider *toGtkCssProvider(void *p) { + return (GTK_CSS_PROVIDER(p)); +} + +static GtkStyleContext *toGtkStyleContext(void *p) { + return (GTK_STYLE_CONTEXT(p)); +} + +static GtkStyleProvider *toGtkStyleProvider(void *p) { + return (GTK_STYLE_PROVIDER(p)); +} + +static GtkInfoBar *toGtkInfoBar(void *p) { return (GTK_INFO_BAR(p)); } + +static GMenuModel *toGMenuModel(void *p) { return (G_MENU_MODEL(p)); } + +static GActionGroup *toGActionGroup(void *p) { return (G_ACTION_GROUP(p)); } + +static GdkPixbuf *toGdkPixbuf(void *p) { return (GDK_PIXBUF(p)); } + +static GdkScreen *toGdkScreen(void *p) { return (GDK_SCREEN(p)); } + +static GdkDevice *toGdkDevice(void *p) { return (GDK_DEVICE(p)); } + +static GObject *toGObject(void *p) { return (G_OBJECT(p)); } + +static GType *alloc_types(int n) { return ((GType *)g_new0(GType, n)); } + +static void set_type(GType *types, int n, GType t) { types[n] = t; } + +// _gtk_test_init is a wrapper to use gtk_test_init directly from go. +// The variadic part on gtk_test_init is not used at the moment, according to +// the documentation. +static void _gtk_test_init(int *argcp, char ***argvp) { + gtk_test_init(argcp, argvp); +} + +static GtkTreeViewColumn *_gtk_tree_view_column_new_with_attributes_one( + const gchar *title, GtkCellRenderer *renderer, const gchar *attribute, + gint column) { + GtkTreeViewColumn *tvc; + + tvc = gtk_tree_view_column_new_with_attributes(title, renderer, attribute, + column, NULL); + return (tvc); +} + +static void _gtk_list_store_set(GtkListStore *list_store, GtkTreeIter *iter, + gint column, void *value) { + gtk_list_store_set(list_store, iter, column, value, -1); +} + +static void _gtk_tree_store_set(GtkTreeStore *store, GtkTreeIter *iter, + gint column, void *value) { + gtk_tree_store_set(store, iter, column, value, -1); +} + +extern gboolean substring_match_equal_func(GtkTreeModel *model, gint column, + gchar *key, GtkTreeIter *iter, + gpointer data); + +static GtkWidget *_gtk_message_dialog_new(GtkWindow *parent, + GtkDialogFlags flags, + GtkMessageType type, + GtkButtonsType buttons, char *msg) { + GtkWidget *w; + + w = gtk_message_dialog_new(parent, flags, type, buttons, "%s", msg); + return (w); +} + +static GtkWidget *_gtk_message_dialog_new_with_markup(GtkWindow *parent, + GtkDialogFlags flags, + GtkMessageType type, + GtkButtonsType buttons, + char *msg) { + GtkWidget *w; + + w = gtk_message_dialog_new_with_markup(parent, flags, type, buttons, "%s", + msg); + return (w); +} + +static void +_gtk_message_dialog_format_secondary_text(GtkMessageDialog *message_dialog, + const gchar *msg) { + gtk_message_dialog_format_secondary_text(message_dialog, "%s", msg); +} + +static void +_gtk_message_dialog_format_secondary_markup(GtkMessageDialog *message_dialog, + const gchar *msg) { + gtk_message_dialog_format_secondary_markup(message_dialog, "%s", msg); +} + +static const gchar *object_get_class_name(GObject *object) { + return G_OBJECT_CLASS_NAME(G_OBJECT_GET_CLASS(object)); +} + +static GtkWidget *gtk_file_chooser_dialog_new_1(const gchar *title, + GtkWindow *parent, + GtkFileChooserAction action, + const gchar *first_button_text, + int first_button_id) { + return gtk_file_chooser_dialog_new(title, parent, action, first_button_text, + first_button_id, NULL); +} + +static GtkWidget *gtk_file_chooser_dialog_new_2( + const gchar *title, GtkWindow *parent, GtkFileChooserAction action, + const gchar *first_button_text, int first_button_id, + const gchar *second_button_text, int second_button_id) { + return gtk_file_chooser_dialog_new(title, parent, action, first_button_text, + first_button_id, second_button_text, + second_button_id, NULL); +} + +static void _gtk_widget_hide_on_delete(GtkWidget *w) { + g_signal_connect(GTK_WIDGET(w), "delete-event", + G_CALLBACK(gtk_widget_hide_on_delete), NULL); +} + +static inline gchar **make_strings(int count) { + return (gchar **)malloc(sizeof(gchar *) * count); +} + +static inline void destroy_strings(gchar **strings) { free(strings); } + +static inline gchar *get_string(gchar **strings, int n) { return strings[n]; } + +static inline void set_string(gchar **strings, int n, gchar *str) { + strings[n] = str; +} + +extern void goBuilderConnect(GtkBuilder *builder, GObject *object, + gchar *signal_name, gchar *handler_name, + GObject *connect_object, GConnectFlags flags, + gpointer user_data); + +static inline void _gtk_builder_connect_signals_full(GtkBuilder *builder) { + gtk_builder_connect_signals_full( + builder, (GtkBuilderConnectFunc)(goBuilderConnect), NULL); +} + +extern gboolean goTreeViewSearchEqualFunc(GtkTreeModel *model, gint column, + gchar *key, GtkTreeIter *iter, + gpointer data); + +static inline void _gtk_tree_view_set_search_equal_func(GtkTreeView *tree_view, + gpointer user_data) { + gtk_tree_view_set_search_equal_func( + tree_view, (GtkTreeViewSearchEqualFunc)(goTreeViewSearchEqualFunc), + user_data, (GDestroyNotify)(gotk3_callbackDelete)); +} + +extern gboolean goTreeModelFilterVisibleFunc(GtkTreeModel *model, + GtkTreeIter *iter, gpointer data); + +static inline void +_gtk_tree_model_filter_set_visible_func(GtkTreeModelFilter *filter, + gpointer user_data) { + gtk_tree_model_filter_set_visible_func( + filter, (GtkTreeModelFilterVisibleFunc)(goTreeModelFilterVisibleFunc), + user_data, (GDestroyNotify)(gotk3_callbackDelete)); +} + +static inline void _gtk_text_buffer_insert_with_tag_by_name( + GtkTextBuffer *buffer, GtkTextIter *iter, const gchar *text, gint len, + const gchar *first_tag_name) { + gtk_text_buffer_insert_with_tags_by_name(buffer, iter, text, len, + first_tag_name, NULL); +} + +static inline void _gtk_text_buffer_insert_with_tag(GtkTextBuffer *buffer, + GtkTextIter *iter, + const gchar *text, gint len, + GtkTextTag *tag) { + gtk_text_buffer_insert_with_tags(buffer, iter, text, len, tag, NULL); +} + +extern gint goTreeSortableSortFunc(GtkTreeModel *model, GtkTreeIter *a, + GtkTreeIter *b, gpointer data); + +static inline void _gtk_tree_sortable_set_sort_func(GtkTreeSortable *sortable, + gint sort_column_id, + gpointer user_data) { + gtk_tree_sortable_set_sort_func( + sortable, sort_column_id, + (GtkTreeIterCompareFunc)(goTreeSortableSortFunc), user_data, NULL); +} + +static inline void +_gtk_tree_sortable_set_default_sort_func(GtkTreeSortable *sortable, + gpointer user_data) { + gtk_tree_sortable_set_default_sort_func( + sortable, (GtkTreeIterCompareFunc)(goTreeSortableSortFunc), user_data, + (GDestroyNotify)(gotk3_callbackDelete)); +} + +static GtkWidget *_gtk_dialog_new_with_buttons(const gchar *title, + GtkWindow *parent, + GtkDialogFlags flags, + const gchar *first_button_text) { + GtkWidget *w; + + w = gtk_dialog_new_with_buttons(title, parent, flags, first_button_text, + NULL); + return (w); +} + +extern gint goTreeModelForeachFunc(GtkTreeModel *model, GtkTreePath *path, + GtkTreeIter *iter, gpointer data); + +static inline void _gtk_tree_model_foreach(GtkTreeModel *model, + gpointer user_data) { + gtk_tree_model_foreach( + model, (GtkTreeModelForeachFunc)(goTreeModelForeachFunc), user_data); +} + +extern void goTreeSelectionForeachFunc(GtkTreeModel *model, GtkTreePath *path, + GtkTreeIter *iter, gpointer data); + +static inline void +_gtk_tree_selection_selected_foreach(GtkTreeSelection *selection, + gpointer user_data) { + gtk_tree_selection_selected_foreach( + selection, (GtkTreeSelectionForeachFunc)(goTreeSelectionForeachFunc), + user_data); +} + +extern gboolean goTreeSelectionFunc(GtkTreeSelection *selection, + GtkTreeModel *model, GtkTreePath *path, + gboolean selected, gpointer data); + +static inline void +_gtk_tree_selection_set_select_function(GtkTreeSelection *selection, + gpointer user_data) { + gtk_tree_selection_set_select_function( + + selection, (GtkTreeSelectionFunc)(goTreeSelectionFunc), user_data, + (GDestroyNotify)(gotk3_callbackDelete)); +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_10.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_10.go new file mode 100644 index 0000000..c9b47e7 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_10.go @@ -0,0 +1,336 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// This file includes wrapers for symbols deprecated beginning with GTK 3.10, +// and should only be included in a build targeted intended to target GTK +// 3.8 or earlier. To target an earlier build build, use the build tag +// gtk_MAJOR_MINOR. For example, to target GTK 3.8, run +// 'go build -tags gtk_3_8'. +// +build gtk_3_6 gtk_3_8 gtk_deprecated + +package gtk + +// #include +// #include +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// ButtonNewFromStock is a wrapper around gtk_button_new_from_stock(). +func ButtonNewFromStock(stock Stock) (*Button, error) { + cstr := C.CString(string(stock)) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_button_new_from_stock((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapButton(glib.Take(unsafe.Pointer(c))), nil +} + +// SetUseStock is a wrapper around gtk_button_set_use_stock(). +func (v *Button) SetUseStock(useStock bool) { + C.gtk_button_set_use_stock(v.native(), gbool(useStock)) +} + +// GetUseStock is a wrapper around gtk_button_get_use_stock(). +func (v *Button) GetUseStock() bool { + c := C.gtk_button_get_use_stock(v.native()) + return gobool(c) +} + +// GetIconStock is a wrapper around gtk_entry_get_icon_stock(). +func (v *Entry) GetIconStock(iconPos EntryIconPosition) (string, error) { + c := C.gtk_entry_get_icon_stock(v.native(), + C.GtkEntryIconPosition(iconPos)) + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +// SetIconFromStock is a wrapper around gtk_entry_set_icon_from_stock(). +func (v *Entry) SetIconFromStock(iconPos EntryIconPosition, stockID string) { + cstr := C.CString(stockID) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_entry_set_icon_from_stock(v.native(), + C.GtkEntryIconPosition(iconPos), (*C.gchar)(cstr)) +} + +/* + * GtkImage + */ + +// TODO: + +/* +// gtk_image_get_icon_set(). +func (v *Image) GetIconSet() { +} +*/ + +// gtk_image_get_stock(). + +/* +// gtk_image_new_from_icon_set(). +func ImageNewFromIconSet() { +} +*/ + +// ImageNewFromStock is a wrapper around gtk_image_new_from_stock(). +func ImageNewFromStock(stock Stock, size IconSize) (*Image, error) { + cstr := C.CString(string(stock)) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_image_new_from_stock((*C.gchar)(cstr), C.GtkIconSize(size)) + if c == nil { + return nil, nilPtrErr + } + return wrapImage(glib.Take(unsafe.Pointer(c))), nil +} + +// SetFromStock is a wrapper around gtk_image_set_from_stock(). +func (v *Image) SetFromStock(stock Stock, size IconSize) { + cstr := C.CString(string(stock)) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_image_set_from_stock(v.native(), (*C.gchar)(cstr), + C.GtkIconSize(size)) +} + +// TODO: +/* +// gtk_image_set_from_icon_set(). +func (v *Image) SetFromIconSet() { +} +*/ + +// StatusIconNewFromStock is a wrapper around gtk_status_icon_new_from_stock(). +// Deprecated since 3.10, use StatusIconNewFromIconName (gtk_status_icon_new_from_icon_name) instead. +func StatusIconNewFromStock(stockId string) (*StatusIcon, error) { + cstr := C.CString(stockId) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_status_icon_new_from_file((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapStatusIcon(obj), nil +} + +// SetFromStock is a wrapper around gtk_status_icon_set_from_stock() +// Deprecated since 3.10, use SetFromIconName (gtk_status_icon_set_from_icon_name) instead. +func (v *StatusIcon) SetFromStock(stockID string) { + cstr := C.CString(stockID) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_status_icon_set_from_stock(v.native(), (*C.gchar)(cstr)) +} + +// GetStock is a wrapper around gtk_status_icon_get_stock() +// Deprecated since 3.10, use GetIconName (gtk_status_icon_get_icon_name) instead +func (v *StatusIcon) GetStock() string { + c := C.gtk_status_icon_get_stock(v.native()) + if c == nil { + return "" + } + return C.GoString((*C.char)(c)) +} + +// Stock is a special type that does not have an equivalent type in +// GTK. It is the type used as a parameter anytime an identifier for +// stock icons are needed. A Stock must be type converted to string when +// function parameters may take a Stock, but when other string values are +// valid as well. +type Stock string + +const ( + STOCK_ABOUT Stock = C.GTK_STOCK_ABOUT + STOCK_ADD Stock = C.GTK_STOCK_ADD + STOCK_APPLY Stock = C.GTK_STOCK_APPLY + STOCK_BOLD Stock = C.GTK_STOCK_BOLD + STOCK_CANCEL Stock = C.GTK_STOCK_CANCEL + STOCK_CAPS_LOCK_WARNING Stock = C.GTK_STOCK_CAPS_LOCK_WARNING + STOCK_CDROM Stock = C.GTK_STOCK_CDROM + STOCK_CLEAR Stock = C.GTK_STOCK_CLEAR + STOCK_CLOSE Stock = C.GTK_STOCK_CLOSE + STOCK_COLOR_PICKER Stock = C.GTK_STOCK_COLOR_PICKER + STOCK_CONNECT Stock = C.GTK_STOCK_CONNECT + STOCK_CONVERT Stock = C.GTK_STOCK_CONVERT + STOCK_COPY Stock = C.GTK_STOCK_COPY + STOCK_CUT Stock = C.GTK_STOCK_CUT + STOCK_DELETE Stock = C.GTK_STOCK_DELETE + STOCK_DIALOG_AUTHENTICATION Stock = C.GTK_STOCK_DIALOG_AUTHENTICATION + STOCK_DIALOG_INFO Stock = C.GTK_STOCK_DIALOG_INFO + STOCK_DIALOG_WARNING Stock = C.GTK_STOCK_DIALOG_WARNING + STOCK_DIALOG_ERROR Stock = C.GTK_STOCK_DIALOG_ERROR + STOCK_DIALOG_QUESTION Stock = C.GTK_STOCK_DIALOG_QUESTION + STOCK_DIRECTORY Stock = C.GTK_STOCK_DIRECTORY + STOCK_DISCARD Stock = C.GTK_STOCK_DISCARD + STOCK_DISCONNECT Stock = C.GTK_STOCK_DISCONNECT + STOCK_DND Stock = C.GTK_STOCK_DND + STOCK_DND_MULTIPLE Stock = C.GTK_STOCK_DND_MULTIPLE + STOCK_EDIT Stock = C.GTK_STOCK_EDIT + STOCK_EXECUTE Stock = C.GTK_STOCK_EXECUTE + STOCK_FILE Stock = C.GTK_STOCK_FILE + STOCK_FIND Stock = C.GTK_STOCK_FIND + STOCK_FIND_AND_REPLACE Stock = C.GTK_STOCK_FIND_AND_REPLACE + STOCK_FLOPPY Stock = C.GTK_STOCK_FLOPPY + STOCK_FULLSCREEN Stock = C.GTK_STOCK_FULLSCREEN + STOCK_GOTO_BOTTOM Stock = C.GTK_STOCK_GOTO_BOTTOM + STOCK_GOTO_FIRST Stock = C.GTK_STOCK_GOTO_FIRST + STOCK_GOTO_LAST Stock = C.GTK_STOCK_GOTO_LAST + STOCK_GOTO_TOP Stock = C.GTK_STOCK_GOTO_TOP + STOCK_GO_BACK Stock = C.GTK_STOCK_GO_BACK + STOCK_GO_DOWN Stock = C.GTK_STOCK_GO_DOWN + STOCK_GO_FORWARD Stock = C.GTK_STOCK_GO_FORWARD + STOCK_GO_UP Stock = C.GTK_STOCK_GO_UP + STOCK_HARDDISK Stock = C.GTK_STOCK_HARDDISK + STOCK_HELP Stock = C.GTK_STOCK_HELP + STOCK_HOME Stock = C.GTK_STOCK_HOME + STOCK_INDEX Stock = C.GTK_STOCK_INDEX + STOCK_INDENT Stock = C.GTK_STOCK_INDENT + STOCK_INFO Stock = C.GTK_STOCK_INFO + STOCK_ITALIC Stock = C.GTK_STOCK_ITALIC + STOCK_JUMP_TO Stock = C.GTK_STOCK_JUMP_TO + STOCK_JUSTIFY_CENTER Stock = C.GTK_STOCK_JUSTIFY_CENTER + STOCK_JUSTIFY_FILL Stock = C.GTK_STOCK_JUSTIFY_FILL + STOCK_JUSTIFY_LEFT Stock = C.GTK_STOCK_JUSTIFY_LEFT + STOCK_JUSTIFY_RIGHT Stock = C.GTK_STOCK_JUSTIFY_RIGHT + STOCK_LEAVE_FULLSCREEN Stock = C.GTK_STOCK_LEAVE_FULLSCREEN + STOCK_MISSING_IMAGE Stock = C.GTK_STOCK_MISSING_IMAGE + STOCK_MEDIA_FORWARD Stock = C.GTK_STOCK_MEDIA_FORWARD + STOCK_MEDIA_NEXT Stock = C.GTK_STOCK_MEDIA_NEXT + STOCK_MEDIA_PAUSE Stock = C.GTK_STOCK_MEDIA_PAUSE + STOCK_MEDIA_PLAY Stock = C.GTK_STOCK_MEDIA_PLAY + STOCK_MEDIA_PREVIOUS Stock = C.GTK_STOCK_MEDIA_PREVIOUS + STOCK_MEDIA_RECORD Stock = C.GTK_STOCK_MEDIA_RECORD + STOCK_MEDIA_REWIND Stock = C.GTK_STOCK_MEDIA_REWIND + STOCK_MEDIA_STOP Stock = C.GTK_STOCK_MEDIA_STOP + STOCK_NETWORK Stock = C.GTK_STOCK_NETWORK + STOCK_NEW Stock = C.GTK_STOCK_NEW + STOCK_NO Stock = C.GTK_STOCK_NO + STOCK_OK Stock = C.GTK_STOCK_OK + STOCK_OPEN Stock = C.GTK_STOCK_OPEN + STOCK_ORIENTATION_PORTRAIT Stock = C.GTK_STOCK_ORIENTATION_PORTRAIT + STOCK_ORIENTATION_LANDSCAPE Stock = C.GTK_STOCK_ORIENTATION_LANDSCAPE + STOCK_ORIENTATION_REVERSE_LANDSCAPE Stock = C.GTK_STOCK_ORIENTATION_REVERSE_LANDSCAPE + STOCK_ORIENTATION_REVERSE_PORTRAIT Stock = C.GTK_STOCK_ORIENTATION_REVERSE_PORTRAIT + STOCK_PAGE_SETUP Stock = C.GTK_STOCK_PAGE_SETUP + STOCK_PASTE Stock = C.GTK_STOCK_PASTE + STOCK_PREFERENCES Stock = C.GTK_STOCK_PREFERENCES + STOCK_PRINT Stock = C.GTK_STOCK_PRINT + STOCK_PRINT_ERROR Stock = C.GTK_STOCK_PRINT_ERROR + STOCK_PRINT_PAUSED Stock = C.GTK_STOCK_PRINT_PAUSED + STOCK_PRINT_PREVIEW Stock = C.GTK_STOCK_PRINT_PREVIEW + STOCK_PRINT_REPORT Stock = C.GTK_STOCK_PRINT_REPORT + STOCK_PRINT_WARNING Stock = C.GTK_STOCK_PRINT_WARNING + STOCK_PROPERTIES Stock = C.GTK_STOCK_PROPERTIES + STOCK_QUIT Stock = C.GTK_STOCK_QUIT + STOCK_REDO Stock = C.GTK_STOCK_REDO + STOCK_REFRESH Stock = C.GTK_STOCK_REFRESH + STOCK_REMOVE Stock = C.GTK_STOCK_REMOVE + STOCK_REVERT_TO_SAVED Stock = C.GTK_STOCK_REVERT_TO_SAVED + STOCK_SAVE Stock = C.GTK_STOCK_SAVE + STOCK_SAVE_AS Stock = C.GTK_STOCK_SAVE_AS + STOCK_SELECT_ALL Stock = C.GTK_STOCK_SELECT_ALL + STOCK_SELECT_COLOR Stock = C.GTK_STOCK_SELECT_COLOR + STOCK_SELECT_FONT Stock = C.GTK_STOCK_SELECT_FONT + STOCK_SORT_ASCENDING Stock = C.GTK_STOCK_SORT_ASCENDING + STOCK_SORT_DESCENDING Stock = C.GTK_STOCK_SORT_DESCENDING + STOCK_SPELL_CHECK Stock = C.GTK_STOCK_SPELL_CHECK + STOCK_STOP Stock = C.GTK_STOCK_STOP + STOCK_STRIKETHROUGH Stock = C.GTK_STOCK_STRIKETHROUGH + STOCK_UNDELETE Stock = C.GTK_STOCK_UNDELETE + STOCK_UNDERLINE Stock = C.GTK_STOCK_UNDERLINE + STOCK_UNDO Stock = C.GTK_STOCK_UNDO + STOCK_UNINDENT Stock = C.GTK_STOCK_UNINDENT + STOCK_YES Stock = C.GTK_STOCK_YES + STOCK_ZOOM_100 Stock = C.GTK_STOCK_ZOOM_100 + STOCK_ZOOM_FIT Stock = C.GTK_STOCK_ZOOM_FIT + STOCK_ZOOM_IN Stock = C.GTK_STOCK_ZOOM_IN + STOCK_ZOOM_OUT Stock = C.GTK_STOCK_ZOOM_OUT +) + +// ReshowWithInitialSize is a wrapper around +// gtk_window_reshow_with_initial_size(). +func (v *Window) ReshowWithInitialSize() { + C.gtk_window_reshow_with_initial_size(v.native()) +} + +/* + * GtkWidget + */ + +// TODO: +// gtk_widget_render_icon_pixbuf(). +// gtk_widget_pop_composite_child(). +// gtk_widget_push_composite_child(). +// gtk_widget_set_composite_name(). + +/* + * GtkContainer + */ + +// TODO: +// gtk_container_resize_children(). + +/* + * GtkImageMenuItem + */ + +// TODO: +// gtk_image_menu_item_set_image(). +// gtk_image_menu_item_get_image(). +// gtk_image_menu_item_new(). +// gtk_image_menu_item_new_from_stock(). +// gtk_image_menu_item_new_with_label(). +// gtk_image_menu_item_new_with_mnemonic(). +// gtk_image_menu_item_get_use_stock(). +// gtk_image_menu_item_set_use_stock(). +// gtk_image_menu_item_get_always_show_image(). +// gtk_image_menu_item_set_always_show_image(). +// gtk_image_menu_item_set_accel_group(). + +/* + * GtkToolButton + */ + +// TODO: +// gtk_tool_button_new_from_stock(). +// gtk_tool_button_set_stock_id(). +// gtk_tool_button_get_stock_id(). + +/* + * GtkDialog + */ + +// TODO: + +/* +// gtk_dialog_set_alternative_button_order(). +func SetAlternativeButtonOrder(ids ...ResponseType) { +} +*/ + +/* +// gtk_alternative_dialog_button_order(). +func (v *gdk.Screen) AlternativeDialogButtonOrder() bool { + c := C.gtk_alternative_dialog_button_order(v.native()) + return gobool(c) +} +*/ + +// gtk_dialog_set_alternative_button_order_from_array diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_12.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_12.go new file mode 100644 index 0000000..293febc --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_12.go @@ -0,0 +1,95 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// This file includes wrapers for symbols deprecated beginning with GTK 3.12, +// and should only be included in a build targeted intended to target GTK +// 3.10 or earlier. To target an earlier build build, use the build tag +// gtk_MAJOR_MINOR. For example, to target GTK 3.8, run +// 'go build -tags gtk_3_8'. +// +build gtk_3_6 gtk_3_8 gtk_3_10 gtk_deprecated + +package gtk + +// #include +import "C" + +/* + * GtkDialog + */ + +// GetActionArea() is a wrapper around gtk_dialog_get_action_area(). +func (v *Dialog) GetActionArea() (IWidget, error) { + c := C.gtk_dialog_get_action_area(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castWidget(c) +} + +/* + * GtkMessageDialog + */ + +// GetImage is a wrapper around gtk_message_dialog_get_image(). +func (v *MessageDialog) GetImage() (IWidget, error) { + c := C.gtk_message_dialog_get_image(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castWidget(c) +} + +// SetImage is a wrapper around gtk_message_dialog_set_image(). +func (v *MessageDialog) SetImage(image IWidget) { + C.gtk_message_dialog_set_image(v.native(), image.toWidget()) +} + +/* + * GtkWidget + */ + +// GetMarginLeft is a wrapper around gtk_widget_get_margin_left(). +func (v *Widget) GetMarginLeft() int { + c := C.gtk_widget_get_margin_left(v.native()) + return int(c) +} + +// SetMarginLeft is a wrapper around gtk_widget_set_margin_left(). +func (v *Widget) SetMarginLeft(margin int) { + C.gtk_widget_set_margin_left(v.native(), C.gint(margin)) +} + +// GetMarginRight is a wrapper around gtk_widget_get_margin_right(). +func (v *Widget) GetMarginRight() int { + c := C.gtk_widget_get_margin_right(v.native()) + return int(c) +} + +// SetMarginRight is a wrapper around gtk_widget_set_margin_right(). +func (v *Widget) SetMarginRight(margin int) { + C.gtk_widget_set_margin_right(v.native(), C.gint(margin)) +} + +// TODO: +// gtk_widget_get_root_window(). + +/* + * GtkContainer + */ + +// TODO: +// gtk_container_get_resize_mode(). +// gtk_container_set_resize_mode(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_14.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_14.go new file mode 100644 index 0000000..9984f7e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_14.go @@ -0,0 +1,508 @@ +// +build gtk_3_6 gtk_3_8 gtk_3_10 gtk_3_12 gtk_deprecated + +package gtk + +// #include +// #include +// #include "gtk_deprecated_since_3_14.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_alignment_get_type()), marshalAlignment}, + {glib.Type(C.gtk_arrow_get_type()), marshalArrow}, + {glib.Type(C.gtk_misc_get_type()), marshalMisc}, + {glib.Type(C.gtk_status_icon_get_type()), marshalStatusIcon}, + } + glib.RegisterGValueMarshalers(tm) + + //Contribute to casting + for k, v := range map[string]WrapFn{ + "GtkAlignment": wrapAlignment, + "GtkArrow": wrapArrow, + "GtkMisc": wrapMisc, + "GtkStatusIcon": wrapStatusIcon, + } { + WrapMap[k] = v + } +} + +/* + * deprecated since version 3.14 and should not be used in newly-written code + */ + +/* + * GtkTreeView + */ + +// TODO: +// gtk_tree_view_set_rules_hint(). +// gtk_tree_view_get_rules_hint(). + +/* + * GtkWindow + */ + +// SetHasResizeGrip is a wrapper around gtk_window_set_has_resize_grip(). +func (v *Window) SetHasResizeGrip(setting bool) { + C.gtk_window_set_has_resize_grip(v.native(), gbool(setting)) +} + +// GetHasResizeGrip is a wrapper around gtk_window_get_has_resize_grip(). +func (v *Window) GetHasResizeGrip() bool { + c := C.gtk_window_get_has_resize_grip(v.native()) + return gobool(c) +} + +// ResizeGripIsVisible is a wrapper around gtk_window_resize_grip_is_visible(). +func (v *Window) ResizeGripIsVisible() bool { + c := C.gtk_window_resize_grip_is_visible(v.native()) + return gobool(c) +} + +// GetResizeGripArea is a wrapper around gtk_window_get_resize_grip_area(). +func (v *Window) GetResizeGripArea() (*gdk.Rectangle, bool) { + var cRect *C.GdkRectangle + wasRetrieved := C.gtk_window_get_resize_grip_area(v.native(), cRect) + rect := gdk.WrapRectangle(uintptr(unsafe.Pointer(cRect))) + return rect, gobool(wasRetrieved) +} + +/* + * GtkWidget + */ + +// Reparent() is a wrapper around gtk_widget_reparent(). +func (v *Widget) Reparent(newParent IWidget) { + C.gtk_widget_reparent(v.native(), newParent.toWidget()) +} + +// SetDoubleBuffered is a wrapper around gtk_widget_set_double_buffered(). +func (v *Widget) SetDoubleBuffered(doubleBuffered bool) { + C.gtk_widget_set_double_buffered(v.native(), gbool(doubleBuffered)) +} + +// GetDoubleBuffered is a wrapper around gtk_widget_get_double_buffered(). +func (v *Widget) GetDoubleBuffered() bool { + c := C.gtk_widget_get_double_buffered(v.native()) + return gobool(c) +} + +// TODO: +// gtk_widget_region_intersect(). + +// GetPadding is a wrapper around gtk_alignment_get_padding(). +func (v *Alignment) GetPadding() (top, bottom, left, right uint) { + var ctop, cbottom, cleft, cright C.guint + C.gtk_alignment_get_padding(v.native(), &ctop, &cbottom, &cleft, + &cright) + return uint(ctop), uint(cbottom), uint(cleft), uint(cright) +} + +// SetPadding is a wrapper around gtk_alignment_set_padding(). +func (v *Alignment) SetPadding(top, bottom, left, right uint) { + C.gtk_alignment_set_padding(v.native(), C.guint(top), C.guint(bottom), + C.guint(left), C.guint(right)) +} + +// AlignmentNew is a wrapper around gtk_alignment_new(). +func AlignmentNew(xalign, yalign, xscale, yscale float32) (*Alignment, error) { + c := C.gtk_alignment_new(C.gfloat(xalign), C.gfloat(yalign), C.gfloat(xscale), + C.gfloat(yscale)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapAlignment(obj), nil +} + +// Set is a wrapper around gtk_alignment_set(). +func (v *Alignment) Set(xalign, yalign, xscale, yscale float32) { + C.gtk_alignment_set(v.native(), C.gfloat(xalign), C.gfloat(yalign), + C.gfloat(xscale), C.gfloat(yscale)) +} + +/* + * GtkArrow + */ + +// Arrow is a representation of GTK's GtkArrow. +type Arrow struct { + Misc +} + +// ArrowNew is a wrapper around gtk_arrow_new(). +func ArrowNew(arrowType ArrowType, shadowType ShadowType) (*Arrow, error) { + c := C.gtk_arrow_new(C.GtkArrowType(arrowType), + C.GtkShadowType(shadowType)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapArrow(obj), nil +} + +// Set is a wrapper around gtk_arrow_set(). +func (v *Arrow) Set(arrowType ArrowType, shadowType ShadowType) { + C.gtk_arrow_set(v.native(), C.GtkArrowType(arrowType), C.GtkShadowType(shadowType)) +} + +// SetAlignment() is a wrapper around gtk_button_set_alignment(). +func (v *Button) SetAlignment(xalign, yalign float32) { + C.gtk_button_set_alignment(v.native(), (C.gfloat)(xalign), + (C.gfloat)(yalign)) +} + +// GetAlignment() is a wrapper around gtk_button_get_alignment(). +func (v *Button) GetAlignment() (xalign, yalign float32) { + var x, y C.gfloat + C.gtk_button_get_alignment(v.native(), &x, &y) + return float32(x), float32(y) +} + +// SetReallocateRedraws is a wrapper around gtk_container_set_reallocate_redraws(). +func (v *Container) SetReallocateRedraws(needsRedraws bool) { + C.gtk_container_set_reallocate_redraws(v.native(), gbool(needsRedraws)) +} + +// GetAlignment is a wrapper around gtk_misc_get_alignment(). +func (v *Misc) GetAlignment() (xAlign, yAlign float32) { + var x, y C.gfloat + C.gtk_misc_get_alignment(v.native(), &x, &y) + return float32(x), float32(y) +} + +// SetAlignment is a wrapper around gtk_misc_set_alignment(). +func (v *Misc) SetAlignment(xAlign, yAlign float32) { + C.gtk_misc_set_alignment(v.native(), C.gfloat(xAlign), C.gfloat(yAlign)) +} + +// GetPadding is a wrapper around gtk_misc_get_padding(). +func (v *Misc) GetPadding() (xpad, ypad int) { + var x, y C.gint + C.gtk_misc_get_padding(v.native(), &x, &y) + return int(x), int(y) +} + +// SetPadding is a wrapper around gtk_misc_set_padding(). +func (v *Misc) SetPadding(xPad, yPad int) { + C.gtk_misc_set_padding(v.native(), C.gint(xPad), C.gint(yPad)) +} + +/* + * GtkArrow + * deprecated since version 3.14 + */ +// native returns a pointer to the underlying GtkButton. +func (v *Arrow) native() *C.GtkArrow { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkArrow(p) +} + +func marshalArrow(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapArrow(obj), nil +} + +func wrapArrow(obj *glib.Object) *Arrow { + if obj == nil { + return nil + } + + return &Arrow{Misc{Widget{glib.InitiallyUnowned{obj}}}} +} + +/* + * GtkAlignment + * deprecated since version 3.14 + */ + +type Alignment struct { + Bin +} + +// native returns a pointer to the underlying GtkAlignment. +func (v *Alignment) native() *C.GtkAlignment { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkAlignment(p) +} + +func marshalAlignment(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapAlignment(obj), nil +} + +func wrapAlignment(obj *glib.Object) *Alignment { + if obj == nil { + return nil + } + + return &Alignment{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +/* + * GtkStatusIcon + * deprecated since version 3.14 + */ + +// StatusIcon is a representation of GTK's GtkStatusIcon. +// Deprecated since 3.14 in favor of notifications +// (no replacement, see https://stackoverflow.com/questions/41917903/gtk-3-statusicon-replacement) +type StatusIcon struct { + *glib.Object +} + +func marshalStatusIcon(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapStatusIcon(obj), nil +} + +func wrapStatusIcon(obj *glib.Object) *StatusIcon { + if obj == nil { + return nil + } + + return &StatusIcon{obj} +} + +func (v *StatusIcon) native() *C.GtkStatusIcon { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkStatusIcon(p) +} + +// TODO: GtkStatusIcon * gtk_status_icon_new_from_gicon (GIcon *icon); +// TODO: void gtk_status_icon_set_from_gicon (GtkStatusIcon *status_icon, GIcon *icon); + +// TODO: GIcon * gtk_status_icon_get_gicon (GtkStatusIcon *status_icon); + +// TODO: void gtk_status_icon_set_screen (GtkStatusIcon *status_icon, GdkScreen *screen); +// TODO: GdkScreen * gtk_status_icon_get_screen (GtkStatusIcon *status_icon); + +// TODO: GdkPixbuf * gtk_status_icon_get_pixbuf (GtkStatusIcon *status_icon); + +// TODO: void gtk_status_icon_position_menu (GtkMenu *menu, gint *x, gint *y, gboolean *push_in, gpointer user_data); +// TODO: gboolean gtk_status_icon_get_geometry (GtkStatusIcon *status_icon, GdkScreen **screen, GdkRectangle *area, GtkOrientation *orientation); + +// StatusIconNew is a wrapper around gtk_status_icon_new() +func StatusIconNew() (*StatusIcon, error) { + c := C.gtk_status_icon_new() + if c == nil { + return nil, nilPtrErr + } + return wrapStatusIcon(glib.Take(unsafe.Pointer(c))), nil +} + +// StatusIconNewFromFile is a wrapper around gtk_status_icon_new_from_file() +func StatusIconNewFromFile(filename string) (*StatusIcon, error) { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_status_icon_new_from_file((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapStatusIcon(glib.Take(unsafe.Pointer(c))), nil +} + +// StatusIconNewFromIconName is a wrapper around gtk_status_icon_new_from_icon_name() +func StatusIconNewFromIconName(iconName string) (*StatusIcon, error) { + cstr := C.CString(iconName) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_status_icon_new_from_icon_name((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return wrapStatusIcon(glib.Take(unsafe.Pointer(c))), nil +} + +// StatusIconNewFromPixbuf is a wrapper around gtk_status_icon_new_from_pixbuf(). +func StatusIconNewFromPixbuf(pixbuf *gdk.Pixbuf) (*StatusIcon, error) { + c := C.gtk_status_icon_new_from_pixbuf(C.toGdkPixbuf(unsafe.Pointer(pixbuf.Native()))) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapStatusIcon(obj), nil +} + +// SetFromFile is a wrapper around gtk_status_icon_set_from_file() +func (v *StatusIcon) SetFromFile(filename string) { + cstr := C.CString(filename) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_status_icon_set_from_file(v.native(), (*C.gchar)(cstr)) +} + +// SetFromIconName is a wrapper around gtk_status_icon_set_from_icon_name() +func (v *StatusIcon) SetFromIconName(iconName string) { + cstr := C.CString(iconName) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_status_icon_set_from_icon_name(v.native(), (*C.gchar)(cstr)) +} + +// SetFromPixbuf is a wrapper around gtk_status_icon_set_from_pixbuf() +func (v *StatusIcon) SetFromPixbuf(pixbuf *gdk.Pixbuf) { + C.gtk_status_icon_set_from_pixbuf(v.native(), C.toGdkPixbuf(unsafe.Pointer(pixbuf.Native()))) +} + +// GetStorageType is a wrapper around gtk_status_icon_get_storage_type() +func (v *StatusIcon) GetStorageType() ImageType { + return (ImageType)(C.gtk_status_icon_get_storage_type(v.native())) +} + +// SetTooltipText is a wrapper around gtk_status_icon_set_tooltip_text() +func (v *StatusIcon) SetTooltipText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_status_icon_set_tooltip_text(v.native(), (*C.gchar)(cstr)) +} + +// GetTooltipText is a wrapper around gtk_status_icon_get_tooltip_text() +func (v *StatusIcon) GetTooltipText() string { + c := C.gtk_status_icon_get_tooltip_text(v.native()) + if c == nil { + return "" + } + return C.GoString((*C.char)(c)) +} + +// SetTooltipMarkup is a wrapper around gtk_status_icon_set_tooltip_markup() +func (v *StatusIcon) SetTooltipMarkup(markup string) { + cstr := C.CString(markup) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_status_icon_set_tooltip_markup(v.native(), (*C.gchar)(cstr)) +} + +// GetTooltipMarkup is a wrapper around gtk_status_icon_get_tooltip_markup() +func (v *StatusIcon) GetTooltipMarkup() string { + c := C.gtk_status_icon_get_tooltip_markup(v.native()) + if c == nil { + return "" + } + return C.GoString((*C.char)(c)) +} + +// SetHasTooltip is a wrapper around gtk_status_icon_set_has_tooltip() +func (v *StatusIcon) SetHasTooltip(hasTooltip bool) { + C.gtk_status_icon_set_has_tooltip(v.native(), gbool(hasTooltip)) +} + +// GetTitle is a wrapper around gtk_status_icon_get_title() +func (v *StatusIcon) GetTitle() string { + c := C.gtk_status_icon_get_title(v.native()) + if c == nil { + return "" + } + return C.GoString((*C.char)(c)) +} + +// SetName is a wrapper around gtk_status_icon_set_name() +func (v *StatusIcon) SetName(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_status_icon_set_name(v.native(), (*C.gchar)(cstr)) +} + +// SetVisible is a wrapper around gtk_status_icon_set_visible() +func (v *StatusIcon) SetVisible(visible bool) { + C.gtk_status_icon_set_visible(v.native(), gbool(visible)) +} + +// GetVisible is a wrapper around gtk_status_icon_get_visible() +func (v *StatusIcon) GetVisible() bool { + return gobool(C.gtk_status_icon_get_visible(v.native())) +} + +// IsEmbedded is a wrapper around gtk_status_icon_is_embedded() +func (v *StatusIcon) IsEmbedded() bool { + return gobool(C.gtk_status_icon_is_embedded(v.native())) +} + +// GetX11WindowID is a wrapper around gtk_status_icon_get_x11_window_id() +func (v *StatusIcon) GetX11WindowID() uint32 { + return uint32(C.gtk_status_icon_get_x11_window_id(v.native())) +} + +// GetHasTooltip is a wrapper around gtk_status_icon_get_has_tooltip() +func (v *StatusIcon) GetHasTooltip() bool { + return gobool(C.gtk_status_icon_get_has_tooltip(v.native())) +} + +// SetTitle is a wrapper around gtk_status_icon_set_title() +func (v *StatusIcon) SetTitle(title string) { + cstr := C.CString(title) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_status_icon_set_title(v.native(), (*C.gchar)(cstr)) +} + +// GetIconName is a wrapper around gtk_status_icon_get_icon_name() +func (v *StatusIcon) GetIconName() string { + c := C.gtk_status_icon_get_icon_name(v.native()) + if c == nil { + return "" + } + return C.GoString((*C.char)(c)) +} + +// GetSize is a wrapper around gtk_status_icon_get_size() +func (v *StatusIcon) GetSize() int { + return int(C.gtk_status_icon_get_size(v.native())) +} + +// PopupAtStatusIcon() is a wrapper around gtk_menu_popup() specific to usage with GtkStatusIcon. +// gomenu_popup() is defined in menu.go.h, this is a workaround to pass gtk_status_icon_position_menu as the GtkMenuPositionFunc. +func (v *Menu) PopupAtStatusIcon(statusIcon *StatusIcon, button gdk.Button, activateTime uint32) { + C.gotk_menu_popup_at_status_icon(v.native(), statusIcon.native(), C.guint(button), C.guint32(activateTime)) +} + +/* + * GtkMisc + */ + +// Misc is a representation of GTK's GtkMisc. +type Misc struct { + Widget +} + +// native returns a pointer to the underlying GtkMisc. +func (v *Misc) native() *C.GtkMisc { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkMisc(p) +} + +func marshalMisc(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapMisc(obj), nil +} + +func wrapMisc(obj *glib.Object) *Misc { + if obj == nil { + return nil + } + + return &Misc{Widget{glib.InitiallyUnowned{obj}}} +} + +/* + * End deprecated since version 3.14 + */ diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_14.go.h b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_14.go.h new file mode 100644 index 0000000..f5ad487 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_14.go.h @@ -0,0 +1,28 @@ + +/* + * deprecated since version 3.14 + */ + +// Wrapper for gtk_menu_popup to allow calling gtk_status_icon_position_menu as +// callback from go code Used in func (v *Menu) PopupAtStatusIcon +static void gotk_menu_popup_at_status_icon(GtkMenu *menu, + GtkStatusIcon *status_icon, + guint button, + guint32 activate_time) { + gtk_menu_popup(menu, NULL, NULL, gtk_status_icon_position_menu, status_icon, + button, activate_time); +} + +static GtkAlignment *toGtkAlignment(void *p) { return (GTK_ALIGNMENT(p)); } + +static GtkArrow *toGtkArrow(void *p) { return (GTK_ARROW(p)); } + +static GtkMisc *toGtkMisc(void *p) { return (GTK_MISC(p)); } + +static GtkStatusIcon *toGtkStatusIcon(void *p) { return (GTK_STATUS_ICON(p)); } + +static GdkPixbuf *toGdkPixbuf(void *p) { return (GDK_PIXBUF(p)); } + +/* + * End deprecated since version 3.14 + */ diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_16.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_16.go new file mode 100644 index 0000000..ef51cf1 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_16.go @@ -0,0 +1,55 @@ +//+build gtk_3_6 gtk_3_8 gtk_3_10 gtk_3_12 gtk_3_14 gtk_deprecated + +package gtk + +// #include +// #include +// #include +import "C" + +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" +) + +// OverrideColor is a wrapper around gtk_widget_override_color(). +func (v *Widget) OverrideColor(state StateFlags, color *gdk.RGBA) { + var cColor *C.GdkRGBA + if color != nil { + cColor = (*C.GdkRGBA)(unsafe.Pointer(color.Native())) + } + C.gtk_widget_override_color(v.native(), C.GtkStateFlags(state), cColor) +} + +// OverrideBackgroundColor is a wrapper around gtk_widget_override_background_color(). +func (v *Widget) OverrideBackgroundColor(state StateFlags, color *gdk.RGBA) { + var cColor *C.GdkRGBA + if color != nil { + cColor = (*C.GdkRGBA)(unsafe.Pointer(color.Native())) + } + C.gtk_widget_override_background_color(v.native(), C.GtkStateFlags(state), cColor) +} + +// SetColor is a convenience func to override the background color of the given button. +func (v *Button) SetColor(color string) { + rgba := C.GdkRGBA{} + C.gdk_rgba_parse(&rgba, (*C.gchar)(C.CString(color))) + C.gtk_widget_override_background_color(v.toWidget(), C.GTK_STATE_FLAG_NORMAL, &rgba) +} + +// OverrideFont is a wrapper around gtk_widget_override_font(). +func (v *Widget) OverrideFont(description string) { + cstr := C.CString(description) + defer C.free(unsafe.Pointer(cstr)) + c := C.pango_font_description_from_string(cstr) + C.gtk_widget_override_font(v.native(), c) +} + +// TODO: +// gtk_widget_override_symbolic_color(). +// gtk_widget_override_cursor(). + +func (v *Label) SetFont(font string) { + v.OverrideFont(font) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_18.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_18.go new file mode 100644 index 0000000..06f9ec5 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_18.go @@ -0,0 +1,11 @@ +//+build gtk_3_6 gtk_3_8 gtk_3_10 gtk_3_12 gtk_3_14 gtk_3_16 gtk_deprecated + +package gtk + +/* + * GtkPlacesSidebar + */ + +// TODO: +// gtk_places_sidebar_get_show_connect_to_server(). +// gtk_places_sidebar_set_show_connect_to_server(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_20.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_20.go new file mode 100644 index 0000000..3edf2f0 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_20.go @@ -0,0 +1,86 @@ +//+build gtk_3_6 gtk_3_8 gtk_3_10 gtk_3_12 gtk_3_14 gtk_3_16 gtk_3_18 gtk_deprecated + +package gtk + +// #include +// #include +import "C" +import ( + "unsafe" +) + +/* + * GtkRange + */ + +// TODO: +// gtk_range_get_min_slider_size(). +// gtk_range_set_min_slider_size(). + +/* + * GtkToolbar + */ + +// TODO: +// GtkToolbarSpaceStyle + +/* + * GtkFileChooserButton + */ + +// GetFocusOnClick is a wrapper around gtk_file_chooser_button_get_focus_on_click(). +func (v *FileChooserButton) GetFocusOnClick() bool { + return gobool(C.gtk_file_chooser_button_get_focus_on_click(v.native())) +} + +// SetFocusOnClick is a wrapper around gtk_file_chooser_button_set_focus_on_click(). +func (v *FileChooserButton) SetFocusOnClick(grabFocus bool) { + C.gtk_file_chooser_button_set_focus_on_click(v.native(), gbool(grabFocus)) +} + +/* + * GtkButton + */ + +// GetFocusOnClick is a wrapper around gtk_button_get_focus_on_click(). +func (v *Button) GetFocusOnClick() bool { + c := C.gtk_button_get_focus_on_click(v.native()) + return gobool(c) +} + +// SetFocusOnClick is a wrapper around gtk_button_set_focus_on_click(). +func (v *Button) SetFocusOnClick(focusOnClick bool) { + C.gtk_button_set_focus_on_click(v.native(), gbool(focusOnClick)) +} + +/* + * GtkTextIter + */ + +// BeginsTag is a wrapper around gtk_text_iter_begins_tag(). +func (v *TextIter) BeginsTag(v1 *TextTag) bool { + return gobool(C.gtk_text_iter_begins_tag(v.native(), v1.native())) +} + +/* + * GtkWindow + */ + +// ParseGeometry is a wrapper around gtk_window_parse_geometry(). +func (v *Window) ParseGeometry(geometry string) bool { + cstr := C.CString(geometry) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_window_parse_geometry(v.native(), (*C.gchar)(cstr)) + return gobool(c) +} + +// ResizeToGeometry is a wrapper around gtk_window_resize_to_geometry(). +func (v *Window) ResizeToGeometry(width, height int) { + C.gtk_window_resize_to_geometry(v.native(), C.gint(width), C.gint(height)) +} + +// SetDefaultGeometry is a wrapper around gtk_window_set_default_geometry(). +func (v *Window) SetDefaultGeometry(width, height int) { + C.gtk_window_set_default_geometry(v.native(), C.gint(width), + C.gint(height)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_22.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_22.go new file mode 100644 index 0000000..7f658b7 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_22.go @@ -0,0 +1,67 @@ +//+build gtk_3_6 gtk_3_8 gtk_3_10 gtk_3_12 gtk_3_14 gtk_3_16 gtk_3_18 gtk_3_20 gtk_deprecated + +package gtk + +// #include +// #include +import "C" + +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" +) + +/* + * GtkWidget + */ + +// TODO: +// gtk_widget_send_expose(). +// gtk_widget_is_composited(). + +// PopupAtMouse() is a wrapper for gtk_menu_popup(), without the option for a custom positioning function. +func (v *Menu) PopupAtMouseCursor(parentMenuShell IMenu, parentMenuItem IMenuItem, button gdk.Button, activateTime uint32) { + wshell := nullableWidget(parentMenuShell) + witem := nullableWidget(parentMenuItem) + + C.gtk_menu_popup(v.native(), + wshell, + witem, + nil, + nil, + C.guint(button), + C.guint32(activateTime)) +} + +func (v *SizeGroup) GetIgnoreHidden() bool { + c := C.gtk_size_group_get_ignore_hidden(v.native()) + return gobool(c) +} + +// SetWMClass is a wrapper around gtk_window_set_wmclass(). +func (v *Window) SetWMClass(name, class string) { + cName := C.CString(name) + defer C.free(unsafe.Pointer(cName)) + cClass := C.CString(class) + defer C.free(unsafe.Pointer(cClass)) + C.gtk_window_set_wmclass(v.native(), (*C.gchar)(cName), (*C.gchar)(cClass)) +} + +func (v *SizeGroup) SetIgnoreHidden(ignoreHidden bool) { + C.gtk_size_group_set_ignore_hidden(v.native(), gbool(ignoreHidden)) +} + +// GetFontName is a wrapper around gtk_font_button_get_font_name(). +func (v *FontButton) GetFontName() string { + c := C.gtk_font_button_get_font_name(v.native()) + return goString(c) +} + +// SetFontName is a wrapper around gtk_font_button_set_font_name(). +func (v *FontButton) SetFontName(fontname string) bool { + cstr := C.CString(fontname) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_font_button_set_font_name(v.native(), (*C.gchar)(cstr)) + return gobool(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_24.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_24.go new file mode 100644 index 0000000..14541ed --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_24.go @@ -0,0 +1,66 @@ +//+build gtk_3_6 gtk_3_8 gtk_3_10 gtk_3_12 gtk_3_14 gtk_3_16 gtk_3_18 gtk_3_20 gtk_3_22 gtk_deprecated + +package gtk + +// #include +// #include +import "C" +import ( + "fmt" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +// GetFocusChain is a wrapper around gtk_container_get_focus_chain(). +func (v *Container) GetFocusChain() ([]IWidget, bool, error) { + var cwlist *C.GList + c := C.gtk_container_get_focus_chain(v.native(), &cwlist) + + if cwlist == nil { + return nil, gobool(c), nil + } + + var widgets []IWidget + wlist := glib.WrapList(uintptr(unsafe.Pointer(cwlist))) + for ; wlist.Data() != nil; wlist = wlist.Next() { + w, ok := wlist.Data().(*Widget) + if !ok { + return nil, gobool(c), fmt.Errorf("element is not of type *Widget, got %T", w) + } + widget, err := castWidget(w.toWidget()) + if err != nil { + return nil, gobool(c), err + } + widgets = append(widgets, widget) + } + return widgets, gobool(c), nil +} + +/* + * GtkContainer + */ + +// SetFocusChain is a wrapper around gtk_container_set_focus_chain(). +func (v *Container) SetFocusChain(focusableWidgets []IWidget) { + var list *glib.List + for _, w := range focusableWidgets { + data := uintptr(unsafe.Pointer(w.toWidget())) + list = list.Append(data) + } + glist := (*C.GList)(unsafe.Pointer(list)) + C.gtk_container_set_focus_chain(v.native(), glist) +} + +// TODO: +// gtk_container_unset_focus_chain + +// CssProviderGetDefault is a wrapper around gtk_css_provider_get_default(). +func CssProviderGetDefault() (*CssProvider, error) { + c := C.gtk_css_provider_get_default() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapCssProvider(obj), nil +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_8.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_8.go new file mode 100644 index 0000000..815521d --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_deprecated_since_3_8.go @@ -0,0 +1,41 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// This file includes wrapers for symbols deprecated beginning with GTK 3.8, +// and should only be included in a build targeted intended to target GTK +// 3.6 or earlier. To target an earlier build build, use the build tag +// gtk_MAJOR_MINOR. For example, to target GTK 3.6, run +// 'go build -tags gtk_3_6'. +// +build gtk_3_6 gtk_deprecated + +package gtk + +// #include +// #include +import "C" + +// SetOpacity is a wrapper around gtk_window_set_opacity() +// Deprecated since 3.8, replaced by SetOpacity on Widget (gtk_widget_set_opacity) +func (v *Window) SetOpacity(opacity float64) { + C.gtk_window_set_opacity(v.native(), C.gdouble(opacity)) +} + +// GetOpacity is a wrapper around gtk_window_get_opacity() +// Deprecated since 3.8, replaced by GetOpacity on Widget (gtk_widget_get_opacity) +func (v *Window) GetOpacity() float64 { + c := C.gtk_window_get_opacity(v.native()) + return float64(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_export.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_export.go new file mode 100644 index 0000000..6c0153a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_export.go @@ -0,0 +1,109 @@ +package gtk + +/* + #include +*/ +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/internal/callback" +) + +//export goBuilderConnect +func goBuilderConnect( + builder *C.GtkBuilder, + object *C.GObject, + signal_name *C.gchar, + handler_name *C.gchar, + connect_object *C.GObject, + flags C.GConnectFlags, + user_data C.gpointer) { + + builderSignals.Lock() + signals, ok := builderSignals.m[builder] + builderSignals.Unlock() + + if !ok { + panic("no signal mapping defined for this GtkBuilder") + } + + h := C.GoString((*C.char)(handler_name)) + s := C.GoString((*C.char)(signal_name)) + + handler, ok := signals[h] + if !ok { + return + } + + if object == nil { + panic("unexpected nil object from builder") + } + + //TODO: figure out a better way to get a glib.Object from a *C.GObject + gobj := glib.Object{glib.ToGObject(unsafe.Pointer(object))} + gobj.Connect(s, handler) +} + +//export goTreeViewSearchEqualFunc +func goTreeViewSearchEqualFunc(model *C.GtkTreeModel, column C.gint, key *C.gchar, iter *C.GtkTreeIter, data C.gpointer) C.gboolean { + fn := callback.Get(uintptr(data)).(TreeViewSearchEqualFunc) + return gbool(fn( + wrapTreeModel(glib.Take(unsafe.Pointer(model))), + int(column), + C.GoString(key), + &TreeIter{(C.GtkTreeIter)(*iter)}, + )) +} + +//export goTreeModelFilterVisibleFunc +func goTreeModelFilterVisibleFunc(model *C.GtkTreeModel, iter *C.GtkTreeIter, data C.gpointer) C.gboolean { + goIter := &TreeIter{(C.GtkTreeIter)(*iter)} + fn := callback.Get(uintptr(data)).(TreeModelFilterVisibleFunc) + return gbool(fn( + wrapTreeModel(glib.Take(unsafe.Pointer(model))), + goIter, + )) +} + +//export goTreeSortableSortFunc +func goTreeSortableSortFunc(model *C.GtkTreeModel, a, b *C.GtkTreeIter, data C.gpointer) C.gint { + fn := callback.Get(uintptr(data)).(TreeIterCompareFunc) + return C.gint(fn( + wrapTreeModel(glib.Take(unsafe.Pointer(model))), + &TreeIter{(C.GtkTreeIter)(*a)}, + &TreeIter{(C.GtkTreeIter)(*b)}, + )) +} + +//export goTreeModelForeachFunc +func goTreeModelForeachFunc(model *C.GtkTreeModel, path *C.GtkTreePath, iter *C.GtkTreeIter, data C.gpointer) C.gboolean { + fn := callback.Get(uintptr(data)).(TreeModelForeachFunc) + return gbool(fn( + wrapTreeModel(glib.Take(unsafe.Pointer(model))), + &TreePath{(*C.GtkTreePath)(path)}, + &TreeIter{(C.GtkTreeIter)(*iter)}, + )) +} + +//export goTreeSelectionForeachFunc +func goTreeSelectionForeachFunc(model *C.GtkTreeModel, path *C.GtkTreePath, iter *C.GtkTreeIter, data C.gpointer) { + fn := callback.Get(uintptr(data)).(TreeSelectionForeachFunc) + fn( + wrapTreeModel(glib.Take(unsafe.Pointer(model))), + &TreePath{(*C.GtkTreePath)(path)}, + &TreeIter{(C.GtkTreeIter)(*iter)}, + ) +} + +//export goTreeSelectionFunc +func goTreeSelectionFunc(selection *C.GtkTreeSelection, model *C.GtkTreeModel, path *C.GtkTreePath, selected C.gboolean, data C.gpointer) C.gboolean { + fn := callback.Get(uintptr(data)).(TreeSelectionFunc) + return gbool(fn( + wrapTreeSelection(glib.Take(unsafe.Pointer(selection))), + wrapTreeModel(glib.Take(unsafe.Pointer(model))), + &TreePath{(*C.GtkTreePath)(path)}, + gobool(selected), + )) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_10.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_10.go new file mode 100644 index 0000000..59b72e4 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_10.go @@ -0,0 +1,36 @@ +// +build !gtk_3_6,!gtk_3_8 + +package gtk + +// #include +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/internal/callback" +) + +//export goListBoxFilterFuncs +func goListBoxFilterFuncs(row *C.GtkListBoxRow, userData C.gpointer) C.gboolean { + fn := callback.Get(uintptr(userData)).(ListBoxFilterFunc) + return gbool(fn(wrapListBoxRow(glib.Take(unsafe.Pointer(row))))) +} + +//export goListBoxHeaderFuncs +func goListBoxHeaderFuncs(row *C.GtkListBoxRow, before *C.GtkListBoxRow, userData C.gpointer) { + fn := callback.Get(uintptr(userData)).(ListBoxHeaderFunc) + fn( + wrapListBoxRow(glib.Take(unsafe.Pointer(row))), + wrapListBoxRow(glib.Take(unsafe.Pointer(before))), + ) +} + +//export goListBoxSortFuncs +func goListBoxSortFuncs(row1 *C.GtkListBoxRow, row2 *C.GtkListBoxRow, userData C.gpointer) C.gint { + fn := callback.Get(uintptr(userData)).(ListBoxSortFunc) + return C.gint(fn( + wrapListBoxRow(glib.Take(unsafe.Pointer(row1))), + wrapListBoxRow(glib.Take(unsafe.Pointer(row2))), + )) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_14.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_14.go new file mode 100644 index 0000000..60a9788 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_14.go @@ -0,0 +1,19 @@ +// Same copyright and license as the rest of the files in this project +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12 + +package gtk + +// #include +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/internal/callback" +) + +//export goListBoxForEachFuncs +func goListBoxForEachFuncs(box *C.GtkListBox, row *C.GtkListBoxRow, userData C.gpointer) { + fn := callback.Get(uintptr(userData)).(ListBoxForeachFunc) + fn(wrapListBox(glib.Take(unsafe.Pointer(box))), wrapListBoxRow(glib.Take(unsafe.Pointer(row)))) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_16.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_16.go new file mode 100644 index 0000000..e1c0480 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_export_since_3_16.go @@ -0,0 +1,14 @@ +// Same copyright and license as the rest of the files in this project +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14 + +package gtk + +// #include +import "C" +import "github.com/gotk3/gotk3/internal/callback" + +//export goListBoxCreateWidgetFuncs +func goListBoxCreateWidgetFuncs(item, userData C.gpointer) { + fn := callback.Get(uintptr(userData)).(ListBoxCreateWidgetFunc) + fn(uintptr(item)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_10.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_10.go new file mode 100644 index 0000000..dae8a75 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_10.go @@ -0,0 +1,918 @@ +// Same copyright and license as the rest of the files in this project +// This file contains accelerator related functions and structures + +// +build !gtk_3_6,!gtk_3_8 +// not use this: go build -tags gtk_3_8'. Otherwise, if no build tags are used, GTK 3.10 + +package gtk + +// #include +// #include +// #include "gtk_since_3_10.go.h" +import "C" +import ( + "errors" + "unsafe" + + "github.com/gotk3/gotk3/cairo" + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/internal/callback" + "github.com/gotk3/gotk3/pango" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.gtk_revealer_transition_type_get_type()), marshalRevealerTransitionType}, + {glib.Type(C.gtk_stack_transition_type_get_type()), marshalStackTransitionType}, + + // Objects/Interfaces + {glib.Type(C.gtk_header_bar_get_type()), marshalHeaderBar}, + {glib.Type(C.gtk_list_box_get_type()), marshalListBox}, + {glib.Type(C.gtk_list_box_row_get_type()), marshalListBoxRow}, + {glib.Type(C.gtk_revealer_get_type()), marshalRevealer}, + {glib.Type(C.gtk_search_bar_get_type()), marshalSearchBar}, + {glib.Type(C.gtk_stack_get_type()), marshalStack}, + {glib.Type(C.gtk_stack_switcher_get_type()), marshalStackSwitcher}, + } + glib.RegisterGValueMarshalers(tm) + + //Contribute to casting + for k, v := range map[string]WrapFn{ + "GtkHeaderBar": wrapHeaderBar, + "GtkListBox": wrapListBox, + "GtkListBoxRow": wrapListBoxRow, + "GtkRevealer": wrapRevealer, + "GtkSearchBar": wrapSearchBar, + "GtkStack": wrapStack, + } { + WrapMap[k] = v + } +} + +/* + * Constants + */ + +const ( + ALIGN_BASELINE Align = C.GTK_ALIGN_BASELINE +) + +// ImageType +const ( + IMAGE_SURFACE ImageType = C.GTK_IMAGE_SURFACE +) + +// RevealerTransitionType is a representation of GTK's GtkRevealerTransitionType. +type RevealerTransitionType int + +const ( + REVEALER_TRANSITION_TYPE_NONE RevealerTransitionType = C.GTK_REVEALER_TRANSITION_TYPE_NONE + REVEALER_TRANSITION_TYPE_CROSSFADE RevealerTransitionType = C.GTK_REVEALER_TRANSITION_TYPE_CROSSFADE + REVEALER_TRANSITION_TYPE_SLIDE_RIGHT RevealerTransitionType = C.GTK_REVEALER_TRANSITION_TYPE_SLIDE_RIGHT + REVEALER_TRANSITION_TYPE_SLIDE_LEFT RevealerTransitionType = C.GTK_REVEALER_TRANSITION_TYPE_SLIDE_LEFT + REVEALER_TRANSITION_TYPE_SLIDE_UP RevealerTransitionType = C.GTK_REVEALER_TRANSITION_TYPE_SLIDE_UP + REVEALER_TRANSITION_TYPE_SLIDE_DOWN RevealerTransitionType = C.GTK_REVEALER_TRANSITION_TYPE_SLIDE_DOWN +) + +func marshalRevealerTransitionType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return RevealerTransitionType(c), nil +} + +// StackTransitionType is a representation of GTK's GtkStackTransitionType. +type StackTransitionType int + +const ( + STACK_TRANSITION_TYPE_NONE StackTransitionType = C.GTK_STACK_TRANSITION_TYPE_NONE + STACK_TRANSITION_TYPE_CROSSFADE StackTransitionType = C.GTK_STACK_TRANSITION_TYPE_CROSSFADE + STACK_TRANSITION_TYPE_SLIDE_RIGHT StackTransitionType = C.GTK_STACK_TRANSITION_TYPE_SLIDE_RIGHT + STACK_TRANSITION_TYPE_SLIDE_LEFT StackTransitionType = C.GTK_STACK_TRANSITION_TYPE_SLIDE_LEFT + STACK_TRANSITION_TYPE_SLIDE_UP StackTransitionType = C.GTK_STACK_TRANSITION_TYPE_SLIDE_UP + STACK_TRANSITION_TYPE_SLIDE_DOWN StackTransitionType = C.GTK_STACK_TRANSITION_TYPE_SLIDE_DOWN + STACK_TRANSITION_TYPE_SLIDE_LEFT_RIGHT StackTransitionType = C.GTK_STACK_TRANSITION_TYPE_SLIDE_LEFT_RIGHT + STACK_TRANSITION_TYPE_SLIDE_UP_DOWN StackTransitionType = C.GTK_STACK_TRANSITION_TYPE_SLIDE_UP_DOWN +) + +func marshalStackTransitionType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return StackTransitionType(c), nil +} + +/* + * GtkWidget + */ + +// TODO: +// gtk_widget_get_composite_name(). + +/* + * GtkImage + */ + +// ImageNewFromSurface is a wrapper around gtk_image_new_from_surface(). +func ImageNewFromSurface(surface *cairo.Surface) (*Image, error) { + c := C.gtk_image_new_from_surface((*C.cairo_surface_t)(surface.GetCSurface())) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapImage(obj), nil +} + +// SetFromSurface is a wrapper around gtk_image_set_from_surface(). +func (v *Image) SetFromSurface(surface *cairo.Surface) { + csurface := (*C.cairo_surface_t)(surface.GetCSurface()) + C.gtk_image_set_from_surface(v.native(), csurface) +} + +/* + * GtkIconTheme + */ + +// HasIcon is a wrapper around gtk_icon_theme_load_icon_for_scale(). +func (v *IconTheme) LoadIconForScale(iconName string, size, scale int, flags IconLookupFlags) (*gdk.Pixbuf, error) { + cstr := C.CString(iconName) + defer C.free(unsafe.Pointer(cstr)) + + var err *C.GError = nil + c := C.gtk_icon_theme_load_icon_for_scale(v.Theme, (*C.gchar)(cstr), C.gint(size), C.gint(scale), C.GtkIconLookupFlags(flags), &err) + if c == nil { + defer C.g_error_free(err) + return nil, errors.New(goString(err.message)) + } + return &gdk.Pixbuf{glib.Take(unsafe.Pointer(c))}, nil +} + +/* + * GtkEntry + */ + +// GetTabs is a wrapper around gtk_entry_get_tabs(). +func (v *Entry) GetTabs() (*pango.TabArray, error) { + c := C.gtk_entry_get_tabs(v.native()) + if c == nil { + return nil, nilPtrErr + } + return pango.WrapTabArray(uintptr(unsafe.Pointer(c))), nil +} + +// SetTabs is a wrapper around gtk_entry_set_tabs(). +func (v *Entry) SetTabs(tabs *pango.TabArray) { + C.gtk_entry_set_tabs(v.native(), (*C.PangoTabArray)(unsafe.Pointer(tabs.Native()))) +} + +/* + * GtkButton + */ + +// ButtonNewFromIconName is a wrapper around gtk_button_new_from_icon_name(). +func ButtonNewFromIconName(iconName string, size IconSize) (*Button, error) { + cstr := C.CString(iconName) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_button_new_from_icon_name((*C.gchar)(cstr), + C.GtkIconSize(size)) + if c == nil { + return nil, nilPtrErr + } + return wrapButton(glib.Take(unsafe.Pointer(c))), nil +} + +/* + * GtkBox + */ + +// TODO: +// gtk_box_get_baseline_position(). +// gtk_box_set_baseline_position(). + +/* + * GtkGrid + */ + +// RemoveRow is a wrapper around gtk_grid_remove_row(). +func (v *Grid) RemoveRow(position int) { + C.gtk_grid_remove_row(v.native(), C.gint(position)) +} + +// RemoveColumn is a wrapper around gtk_grid_remove_column(). +func (v *Grid) RemoveColumn(position int) { + C.gtk_grid_remove_column(v.native(), C.gint(position)) +} + +// TODO: +// gtk_grid_get_baseline_row(). +// gtk_grid_set_baseline_row(). +// gtk_grid_get_row_baseline_position(). +// gtk_grid_set_row_baseline_position(). + +/* + * GtkHeaderBar + */ + +// HeaderBar is a representation of GtkHeaderBar +type HeaderBar struct { + Container +} + +// native returns a pointer to the underlying GtkHeaderBar. +func (v *HeaderBar) native() *C.GtkHeaderBar { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkHeaderBar(p) +} + +func marshalHeaderBar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapHeaderBar(obj), nil +} + +func wrapHeaderBar(obj *glib.Object) *HeaderBar { + if obj == nil { + return nil + } + + return &HeaderBar{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// HeaderBarNew is a wrapper around gtk_header_bar_new(). +func HeaderBarNew() (*HeaderBar, error) { + c := C.gtk_header_bar_new() + if c == nil { + return nil, nilPtrErr + } + return wrapHeaderBar(glib.Take(unsafe.Pointer(c))), nil +} + +// SetTitle is a wrapper around gtk_header_bar_set_title(). +func (v *HeaderBar) SetTitle(title string) { + cstr := C.CString(title) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_header_bar_set_title(v.native(), (*C.gchar)(cstr)) +} + +// GetTitle is a wrapper around gtk_header_bar_get_title(). +func (v *HeaderBar) GetTitle() string { + cstr := C.gtk_header_bar_get_title(v.native()) + return C.GoString((*C.char)(cstr)) +} + +// SetSubtitle is a wrapper around gtk_header_bar_set_subtitle(). +func (v *HeaderBar) SetSubtitle(subtitle string) { + cstr := C.CString(subtitle) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_header_bar_set_subtitle(v.native(), (*C.gchar)(cstr)) +} + +// GetSubtitle is a wrapper around gtk_header_bar_get_subtitle(). +func (v *HeaderBar) GetSubtitle() string { + cstr := C.gtk_header_bar_get_subtitle(v.native()) + return C.GoString((*C.char)(cstr)) +} + +// SetCustomTitle is a wrapper around gtk_header_bar_set_custom_title(). +func (v *HeaderBar) SetCustomTitle(titleWidget IWidget) { + C.gtk_header_bar_set_custom_title(v.native(), titleWidget.toWidget()) +} + +// GetCustomTitle is a wrapper around gtk_header_bar_get_custom_title(). +func (v *HeaderBar) GetCustomTitle() (IWidget, error) { + c := C.gtk_header_bar_get_custom_title(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// PackStart is a wrapper around gtk_header_bar_pack_start(). +func (v *HeaderBar) PackStart(child IWidget) { + C.gtk_header_bar_pack_start(v.native(), child.toWidget()) +} + +// PackEnd is a wrapper around gtk_header_bar_pack_end(). +func (v *HeaderBar) PackEnd(child IWidget) { + C.gtk_header_bar_pack_end(v.native(), child.toWidget()) +} + +// SetShowCloseButton is a wrapper around gtk_header_bar_set_show_close_button(). +func (v *HeaderBar) SetShowCloseButton(setting bool) { + C.gtk_header_bar_set_show_close_button(v.native(), gbool(setting)) +} + +// GetShowCloseButton is a wrapper around gtk_header_bar_get_show_close_button(). +func (v *HeaderBar) GetShowCloseButton() bool { + c := C.gtk_header_bar_get_show_close_button(v.native()) + return gobool(c) +} + +/* + * GtkLabel + */ + +// GetLines is a wrapper around gtk_label_get_lines(). +func (v *Label) GetLines() int { + c := C.gtk_label_get_lines(v.native()) + return int(c) +} + +// SetLines is a wrapper around gtk_label_set_lines(). +func (v *Label) SetLines(lines int) { + C.gtk_label_set_lines(v.native(), C.gint(lines)) +} + +/* + * GtkListBox + */ + +// ListBox is a representation of GTK's GtkListBox. +type ListBox struct { + Container +} + +// native returns a pointer to the underlying GtkListBox. +func (v *ListBox) native() *C.GtkListBox { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkListBox(p) +} + +func marshalListBox(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapListBox(obj), nil +} + +func wrapListBox(obj *glib.Object) *ListBox { + if obj == nil { + return nil + } + + return &ListBox{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// ListBoxNew is a wrapper around gtk_list_box_new(). +func ListBoxNew() (*ListBox, error) { + c := C.gtk_list_box_new() + if c == nil { + return nil, nilPtrErr + } + return wrapListBox(glib.Take(unsafe.Pointer(c))), nil +} + +// Prepend is a wrapper around gtk_list_box_prepend(). +func (v *ListBox) Prepend(child IWidget) { + C.gtk_list_box_prepend(v.native(), child.toWidget()) +} + +// Insert is a wrapper around gtk_list_box_insert(). +func (v *ListBox) Insert(child IWidget, position int) { + C.gtk_list_box_insert(v.native(), child.toWidget(), C.gint(position)) +} + +// SelectRow is a wrapper around gtk_list_box_select_row(). +func (v *ListBox) SelectRow(row *ListBoxRow) { + C.gtk_list_box_select_row(v.native(), row.native()) +} + +// GetSelectedRow is a wrapper around gtk_list_box_get_selected_row(). +func (v *ListBox) GetSelectedRow() *ListBoxRow { + c := C.gtk_list_box_get_selected_row(v.native()) + if c == nil { + return nil + } + return wrapListBoxRow(glib.Take(unsafe.Pointer(c))) +} + +// SetSelectionMode is a wrapper around gtk_list_box_set_selection_mode(). +func (v *ListBox) SetSelectionMode(mode SelectionMode) { + C.gtk_list_box_set_selection_mode(v.native(), C.GtkSelectionMode(mode)) +} + +// GetSelectionMode is a wrapper around gtk_list_box_get_selection_mode() +func (v *ListBox) GetSelectionMode() SelectionMode { + c := C.gtk_list_box_get_selection_mode(v.native()) + return SelectionMode(c) +} + +// SetActivateOnSingleClick is a wrapper around gtk_list_box_set_activate_on_single_click(). +func (v *ListBox) SetActivateOnSingleClick(single bool) { + C.gtk_list_box_set_activate_on_single_click(v.native(), gbool(single)) +} + +// GetActivateOnSingleClick is a wrapper around gtk_list_box_get_activate_on_single_click(). +func (v *ListBox) GetActivateOnSingleClick() bool { + c := C.gtk_list_box_get_activate_on_single_click(v.native()) + return gobool(c) +} + +// GetAdjustment is a wrapper around gtk_list_box_get_adjustment(). +func (v *ListBox) GetAdjustment() *Adjustment { + c := C.gtk_list_box_get_adjustment(v.native()) + obj := glib.Take(unsafe.Pointer(c)) + return &Adjustment{glib.InitiallyUnowned{obj}} +} + +// SetAdjustment is a wrapper around gtk_list_box_set_adjustment(). +func (v *ListBox) SetAdjustment(adjustment *Adjustment) { + C.gtk_list_box_set_adjustment(v.native(), adjustment.native()) +} + +// SetPlaceholder is a wrapper around gtk_list_box_set_placeholder(). +func (v *ListBox) SetPlaceholder(placeholder IWidget) { + C.gtk_list_box_set_placeholder(v.native(), placeholder.toWidget()) +} + +// GetRowAtIndex is a wrapper around gtk_list_box_get_row_at_index(). +func (v *ListBox) GetRowAtIndex(index int) *ListBoxRow { + c := C.gtk_list_box_get_row_at_index(v.native(), C.gint(index)) + if c == nil { + return nil + } + return wrapListBoxRow(glib.Take(unsafe.Pointer(c))) +} + +// GetRowAtY is a wrapper around gtk_list_box_get_row_at_y(). +func (v *ListBox) GetRowAtY(y int) *ListBoxRow { + c := C.gtk_list_box_get_row_at_y(v.native(), C.gint(y)) + if c == nil { + return nil + } + return wrapListBoxRow(glib.Take(unsafe.Pointer(c))) +} + +// InvalidateFilter is a wrapper around gtk_list_box_invalidate_filter(). +func (v *ListBox) InvalidateFilter() { + C.gtk_list_box_invalidate_filter(v.native()) +} + +// InvalidateHeaders is a wrapper around gtk_list_box_invalidate_headers(). +func (v *ListBox) InvalidateHeaders() { + C.gtk_list_box_invalidate_headers(v.native()) +} + +// InvalidateSort is a wrapper around gtk_list_box_invalidate_sort(). +func (v *ListBox) InvalidateSort() { + C.gtk_list_box_invalidate_sort(v.native()) +} + +// ListBoxFilterFunc is a representation of GtkListBoxFilterFunc +type ListBoxFilterFunc func(row *ListBoxRow) bool + +// SetFilterFunc is a wrapper around gtk_list_box_set_filter_func +func (v *ListBox) SetFilterFunc(fn ListBoxFilterFunc) { + C._gtk_list_box_set_filter_func(v.native(), C.gpointer(callback.Assign(fn))) +} + +// ListBoxHeaderFunc is a representation of GtkListBoxUpdateHeaderFunc +type ListBoxHeaderFunc func(row *ListBoxRow, before *ListBoxRow) + +// SetHeaderFunc is a wrapper around gtk_list_box_set_header_func +func (v *ListBox) SetHeaderFunc(fn ListBoxHeaderFunc) { + C._gtk_list_box_set_header_func(v.native(), C.gpointer(callback.Assign(fn))) +} + +// ListBoxSortFunc is a representation of GtkListBoxSortFunc +type ListBoxSortFunc func(row1 *ListBoxRow, row2 *ListBoxRow) int + +// SetSortFunc is a wrapper around gtk_list_box_set_sort_func +func (v *ListBox) SetSortFunc(fn ListBoxSortFunc) { + C._gtk_list_box_set_sort_func(v.native(), C.gpointer(callback.Assign(fn))) +} + +// DragHighlightRow is a wrapper around gtk_list_box_drag_highlight_row() +func (v *ListBox) DragHighlightRow(row *ListBoxRow) { + C.gtk_list_box_drag_highlight_row(v.native(), row.native()) +} + +// DragUnhighlightRow is a wrapper around gtk_list_box_drag_unhighlight_row(). +func (v *ListBox) DragUnhighlightRow() { + C.gtk_list_box_drag_unhighlight_row(v.native()) +} + +/* + * GtkListBoxRow + */ + +// ListBoxRow is a representation of GTK's GtkListBoxRow. +type ListBoxRow struct { + Bin +} + +// native returns a pointer to the underlying GtkListBoxRow. +func (v *ListBoxRow) native() *C.GtkListBoxRow { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkListBoxRow(p) +} + +func marshalListBoxRow(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapListBoxRow(obj), nil +} + +func wrapListBoxRow(obj *glib.Object) *ListBoxRow { + if obj == nil { + return nil + } + + return &ListBoxRow{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// ListBoxRowNew is a wrapper around gtk_list_box_row_new(). +func ListBoxRowNew() (*ListBoxRow, error) { + c := C.gtk_list_box_row_new() + if c == nil { + return nil, nilPtrErr + } + return wrapListBoxRow(glib.Take(unsafe.Pointer(c))), nil +} + +// Changed is a wrapper around gtk_list_box_row_changed(). +func (v *ListBoxRow) Changed() { + C.gtk_list_box_row_changed(v.native()) +} + +// GetHeader is a wrapper around gtk_list_box_row_get_header(). +func (v *ListBoxRow) GetHeader() (IWidget, error) { + c := C.gtk_list_box_row_get_header(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// SetHeader is a wrapper around gtk_list_box_row_set_header(). +func (v *ListBoxRow) SetHeader(header IWidget) { + if header == nil { + C.gtk_list_box_row_set_header(v.native(), nil) + return + } + C.gtk_list_box_row_set_header(v.native(), header.toWidget()) +} + +// GetIndex is a wrapper around gtk_list_box_row_get_index() +func (v *ListBoxRow) GetIndex() int { + c := C.gtk_list_box_row_get_index(v.native()) + return int(c) +} + +/* + * GtkPlacesSidebar + */ + +// TODO: +// gtk_places_sidebar_new(). +// gtk_places_sidebar_set_open_flags(). +// gtk_places_sidebar_get_open_flags(). +// gtk_places_sidebar_set_location(). +// gtk_places_sidebar_get_location(). +// gtk_places_sidebar_set_show_desktop(). +// gtk_places_sidebar_get_show_desktop(). +// gtk_places_sidebar_add_shortcut(). +// gtk_places_sidebar_remove_shortcut(). +// gtk_places_sidebar_list_shortcuts(). +// gtk_places_sidebar_get_nth_bookmark(). +// enum GtkPlacesOpenFlags + +/* + * GtkRevealer + */ + +// Revealer is a representation of GTK's GtkRevealer +type Revealer struct { + Bin +} + +// native returns a pointer to the underlying GtkRevealer. +func (v *Revealer) native() *C.GtkRevealer { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkRevealer(p) +} + +func marshalRevealer(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapRevealer(obj), nil +} + +func wrapRevealer(obj *glib.Object) *Revealer { + if obj == nil { + return nil + } + + return &Revealer{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// RevealerNew is a wrapper around gtk_revealer_new() +func RevealerNew() (*Revealer, error) { + c := C.gtk_revealer_new() + if c == nil { + return nil, nilPtrErr + } + return wrapRevealer(glib.Take(unsafe.Pointer(c))), nil +} + +// GetRevealChild is a wrapper around gtk_revealer_get_reveal_child(). +func (v *Revealer) GetRevealChild() bool { + c := C.gtk_revealer_get_reveal_child(v.native()) + return gobool(c) +} + +// SetRevealChild is a wrapper around gtk_revealer_set_reveal_child(). +func (v *Revealer) SetRevealChild(revealChild bool) { + C.gtk_revealer_set_reveal_child(v.native(), gbool(revealChild)) +} + +// GetChildRevealed is a wrapper around gtk_revealer_get_child_revealed(). +func (v *Revealer) GetChildRevealed() bool { + c := C.gtk_revealer_get_child_revealed(v.native()) + return gobool(c) +} + +// GetTransitionDuration is a wrapper around gtk_revealer_get_transition_duration() +func (v *Revealer) GetTransitionDuration() uint { + c := C.gtk_revealer_get_transition_duration(v.native()) + return uint(c) +} + +// SetTransitionDuration is a wrapper around gtk_revealer_set_transition_duration(). +func (v *Revealer) SetTransitionDuration(duration uint) { + C.gtk_revealer_set_transition_duration(v.native(), C.guint(duration)) +} + +// GetTransitionType is a wrapper around gtk_revealer_get_transition_type() +func (v *Revealer) GetTransitionType() RevealerTransitionType { + c := C.gtk_revealer_get_transition_type(v.native()) + return RevealerTransitionType(c) +} + +// SetTransitionType is a wrapper around gtk_revealer_set_transition_type() +func (v *Revealer) SetTransitionType(transition RevealerTransitionType) { + t := C.GtkRevealerTransitionType(transition) + C.gtk_revealer_set_transition_type(v.native(), t) +} + +/* + * GtkSearchBar + */ + +// SearchBar is a representation of GTK's GtkSearchBar. +type SearchBar struct { + Bin +} + +// native returns a pointer to the underlying GtkSearchBar. +func (v *SearchBar) native() *C.GtkSearchBar { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkSearchBar(p) +} + +func marshalSearchBar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapSearchBar(obj), nil +} + +func wrapSearchBar(obj *glib.Object) *SearchBar { + if obj == nil { + return nil + } + + return &SearchBar{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// SearchBarNew is a wrapper around gtk_search_bar_new() +func SearchBarNew() (*SearchBar, error) { + c := C.gtk_search_bar_new() + if c == nil { + return nil, nilPtrErr + } + return wrapSearchBar(glib.Take(unsafe.Pointer(c))), nil +} + +// ConnectEntry is a wrapper around gtk_search_bar_connect_entry(). +func (v *SearchBar) ConnectEntry(entry IEntry) { + C.gtk_search_bar_connect_entry(v.native(), entry.toEntry()) +} + +// GetSearchMode is a wrapper around gtk_search_bar_get_search_mode(). +func (v *SearchBar) GetSearchMode() bool { + c := C.gtk_search_bar_get_search_mode(v.native()) + return gobool(c) +} + +// SetSearchMode is a wrapper around gtk_search_bar_set_search_mode(). +func (v *SearchBar) SetSearchMode(searchMode bool) { + C.gtk_search_bar_set_search_mode(v.native(), gbool(searchMode)) +} + +// GetShowCloseButton is a wrapper arounb gtk_search_bar_get_show_close_button(). +func (v *SearchBar) GetShowCloseButton() bool { + c := C.gtk_search_bar_get_show_close_button(v.native()) + return gobool(c) +} + +// SetShowCloseButton is a wrapper around gtk_search_bar_set_show_close_button() +func (v *SearchBar) SetShowCloseButton(visible bool) { + C.gtk_search_bar_set_show_close_button(v.native(), gbool(visible)) +} + +// HandleEvent is a wrapper around gtk_search_bar_handle_event() +func (v *SearchBar) HandleEvent(event *gdk.Event) { + e := (*C.GdkEvent)(unsafe.Pointer(event.Native())) + C.gtk_search_bar_handle_event(v.native(), e) +} + +/* + * GtkStack + */ + +// Stack is a representation of GTK's GtkStack. +type Stack struct { + Container +} + +// native returns a pointer to the underlying GtkStack. +func (v *Stack) native() *C.GtkStack { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkStack(p) +} + +func marshalStack(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapStack(obj), nil +} + +func wrapStack(obj *glib.Object) *Stack { + if obj == nil { + return nil + } + + return &Stack{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// StackNew is a wrapper around gtk_stack_new(). +func StackNew() (*Stack, error) { + c := C.gtk_stack_new() + if c == nil { + return nil, nilPtrErr + } + return wrapStack(glib.Take(unsafe.Pointer(c))), nil +} + +// AddNamed is a wrapper around gtk_stack_add_named(). +func (v *Stack) AddNamed(child IWidget, name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_stack_add_named(v.native(), child.toWidget(), (*C.gchar)(cstr)) +} + +// AddTitled is a wrapper around gtk_stack_add_titled(). +func (v *Stack) AddTitled(child IWidget, name, title string) { + cName := C.CString(name) + defer C.free(unsafe.Pointer(cName)) + cTitle := C.CString(title) + defer C.free(unsafe.Pointer(cTitle)) + C.gtk_stack_add_titled(v.native(), child.toWidget(), (*C.gchar)(cName), + (*C.gchar)(cTitle)) +} + +// SetVisibleChild is a wrapper around gtk_stack_set_visible_child(). +func (v *Stack) SetVisibleChild(child IWidget) { + C.gtk_stack_set_visible_child(v.native(), child.toWidget()) +} + +// GetVisibleChild is a wrapper around gtk_stack_get_visible_child(). +func (v *Stack) GetVisibleChild() (IWidget, error) { + c := C.gtk_stack_get_visible_child(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// SetVisibleChildName is a wrapper around gtk_stack_set_visible_child_name(). +func (v *Stack) SetVisibleChildName(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_stack_set_visible_child_name(v.native(), (*C.gchar)(cstr)) +} + +// GetVisibleChildName is a wrapper around gtk_stack_get_visible_child_name(). +func (v *Stack) GetVisibleChildName() string { + c := C.gtk_stack_get_visible_child_name(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetVisibleChildFull is a wrapper around gtk_stack_set_visible_child_full(). +func (v *Stack) SetVisibleChildFull(name string, transaction StackTransitionType) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_stack_set_visible_child_full(v.native(), (*C.gchar)(cstr), + C.GtkStackTransitionType(transaction)) +} + +// SetHomogeneous is a wrapper around gtk_stack_set_homogeneous(). +func (v *Stack) SetHomogeneous(homogeneous bool) { + C.gtk_stack_set_homogeneous(v.native(), gbool(homogeneous)) +} + +// GetHomogeneous is a wrapper around gtk_stack_get_homogeneous(). +func (v *Stack) GetHomogeneous() bool { + c := C.gtk_stack_get_homogeneous(v.native()) + return gobool(c) +} + +// SetTransitionDuration is a wrapper around gtk_stack_set_transition_duration(). +func (v *Stack) SetTransitionDuration(duration uint) { + C.gtk_stack_set_transition_duration(v.native(), C.guint(duration)) +} + +// GetTransitionDuration is a wrapper around gtk_stack_get_transition_duration(). +func (v *Stack) GetTransitionDuration() uint { + c := C.gtk_stack_get_transition_duration(v.native()) + return uint(c) +} + +// SetTransitionType is a wrapper around gtk_stack_set_transition_type(). +func (v *Stack) SetTransitionType(transition StackTransitionType) { + C.gtk_stack_set_transition_type(v.native(), C.GtkStackTransitionType(transition)) +} + +// GetTransitionType is a wrapper around gtk_stack_get_transition_type(). +func (v *Stack) GetTransitionType() StackTransitionType { + c := C.gtk_stack_get_transition_type(v.native()) + return StackTransitionType(c) +} + +/* + * GtkBuilder + */ + +// BuilderNewFromFile is a wrapper around gtk_builder_new_from_file(). +func BuilderNewFromFile(filePath string) (*Builder, error) { + cstr := C.CString(filePath) + defer C.free(unsafe.Pointer(cstr)) + + c := C.gtk_builder_new_from_file((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + + obj := glib.Take(unsafe.Pointer(c)) + return &Builder{obj}, nil +} + +// BuilderNewFromResource is a wrapper around gtk_builder_new_from_resource(). +func BuilderNewFromResource(resourcePath string) (*Builder, error) { + cstr := C.CString(resourcePath) + defer C.free(unsafe.Pointer(cstr)) + + c := C.gtk_builder_new_from_resource((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + + obj := glib.Take(unsafe.Pointer(c)) + return &Builder{obj}, nil +} + +// BuilderNewFromString is a wrapper around gtk_builder_new_from_string(). +func BuilderNewFromString(resource string) (*Builder, error) { + cstr := C.CString(resource) + defer C.free(unsafe.Pointer(cstr)) + + c := C.gtk_builder_new_from_string((*C.gchar)(cstr), C.gssize(len(resource))) + if c == nil { + return nil, nilPtrErr + } + + obj := glib.Take(unsafe.Pointer(c)) + return &Builder{obj}, nil +} + +// TODO: +// gtk_builder_add_callback_symbol +// gtk_builder_add_callback_symbols +// gtk_builder_lookup_callback_symbol +// gtk_builder_set_application +// gtk_builder_get_application diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_10.go.h b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_10.go.h new file mode 100644 index 0000000..4d30466 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_10.go.h @@ -0,0 +1,64 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include "gtk.go.h" // for gotk3_callbackDelete +#include + +static GtkHeaderBar *toGtkHeaderBar(void *p) { return (GTK_HEADER_BAR(p)); } + +static GtkListBox *toGtkListBox(void *p) { return (GTK_LIST_BOX(p)); } + +static GtkListBoxRow *toGtkListBoxRow(void *p) { return (GTK_LIST_BOX_ROW(p)); } + +static GtkRevealer *toGtkRevealer(void *p) { return (GTK_REVEALER(p)); } + +static GtkSearchBar *toGtkSearchBar(void *p) { return (GTK_SEARCH_BAR(p)); } + +static GtkStack *toGtkStack(void *p) { return (GTK_STACK(p)); } + +static GtkStackSwitcher *toGtkStackSwitcher(void *p) { + return (GTK_STACK_SWITCHER(p)); +} + +extern gboolean goListBoxFilterFuncs(GtkListBoxRow *row, gpointer user_data); + +static inline void _gtk_list_box_set_filter_func(GtkListBox *box, + gpointer user_data) { + gtk_list_box_set_filter_func(box, + (GtkListBoxFilterFunc)(goListBoxFilterFuncs), + user_data, (GDestroyNotify)(gotk3_callbackDelete)); +} + +extern void goListBoxHeaderFuncs(GtkListBoxRow *row, GtkListBoxRow *before, + gpointer user_data); + +static inline void _gtk_list_box_set_header_func(GtkListBox *box, + gpointer user_data) { + gtk_list_box_set_header_func( + box, (GtkListBoxUpdateHeaderFunc)(goListBoxHeaderFuncs), user_data, + (GDestroyNotify)(gotk3_callbackDelete)); +} + +extern gint goListBoxSortFuncs(GtkListBoxRow *row1, GtkListBoxRow *row2, + gpointer user_data); + +static inline void _gtk_list_box_set_sort_func(GtkListBox *box, + gpointer user_data) { + gtk_list_box_set_sort_func(box, (GtkListBoxSortFunc)(goListBoxSortFuncs), + user_data, (GDestroyNotify)(gotk3_callbackDelete)); +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_12.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_12.go new file mode 100644 index 0000000..ad13a24 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_12.go @@ -0,0 +1,574 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// Wrapper for GtkPopover originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10 +// not use this: go build -tags gtk_3_8'. Otherwise, if no build tags are used, GTK 3.10 + +package gtk + +// #include +// #include +// #include "gtk_since_3_12.go.h" +import "C" + +import ( + "errors" + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +/* + * Constants + */ + +const ( + DIALOG_USE_HEADER_BAR DialogFlags = C.GTK_DIALOG_USE_HEADER_BAR +) + +const ( + STATE_FLAG_LINK StateFlags = C.GTK_STATE_FLAG_LINK + STATE_FLAG_VISITED StateFlags = C.GTK_STATE_FLAG_VISITED +) + +const ( + BUTTONBOX_EXPAND ButtonBoxStyle = C.GTK_BUTTONBOX_EXPAND +) + +func init() { + tm := []glib.TypeMarshaler{ + // Objects/Interfaces + {glib.Type(C.gtk_flow_box_get_type()), marshalFlowBox}, + {glib.Type(C.gtk_flow_box_child_get_type()), marshalFlowBoxChild}, + {glib.Type(C.gtk_popover_get_type()), marshalPopover}, + } + glib.RegisterGValueMarshalers(tm) + + //Contribute to casting + for k, v := range map[string]WrapFn{ + "GtkFlowBox": wrapFlowBox, + "GtkFlowBoxChild": wrapFlowBoxChild, + "GtkPopover": wrapPopover, + } { + WrapMap[k] = v + } +} + +// GetLocaleDirection is a wrapper around gtk_get_locale_direction(). +func GetLocaleDirection() TextDirection { + c := C.gtk_get_locale_direction() + return TextDirection(c) +} + +/* + * GtkStack + */ + +const ( + STACK_TRANSITION_TYPE_OVER_UP StackTransitionType = C.GTK_STACK_TRANSITION_TYPE_OVER_UP + STACK_TRANSITION_TYPE_OVER_DOWN = C.GTK_STACK_TRANSITION_TYPE_OVER_DOWN + STACK_TRANSITION_TYPE_OVER_LEFT = C.GTK_STACK_TRANSITION_TYPE_OVER_LEFT + STACK_TRANSITION_TYPE_OVER_RIGHT = C.GTK_STACK_TRANSITION_TYPE_OVER_RIGHT + STACK_TRANSITION_TYPE_UNDER_UP = C.GTK_STACK_TRANSITION_TYPE_UNDER_UP + STACK_TRANSITION_TYPE_UNDER_DOWN = C.GTK_STACK_TRANSITION_TYPE_UNDER_DOWN + STACK_TRANSITION_TYPE_UNDER_LEFT = C.GTK_STACK_TRANSITION_TYPE_UNDER_LEFT + STACK_TRANSITION_TYPE_UNDER_RIGHT = C.GTK_STACK_TRANSITION_TYPE_UNDER_RIGHT + STACK_TRANSITION_TYPE_OVER_UP_DOWN = C.GTK_STACK_TRANSITION_TYPE_OVER_UP_DOWN +) + +/* + * Dialog + */ + +// GetHeaderBar is a wrapper around gtk_dialog_get_header_bar(). +func (v *Dialog) GetHeaderBar() (IWidget, error) { + c := C.gtk_dialog_get_header_bar(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +/* + * Entry + */ + +// SetMaxWidthChars is a wrapper around gtk_entry_set_max_width_chars(). +func (v *Entry) SetMaxWidthChars(nChars int) { + C.gtk_entry_set_max_width_chars(v.native(), C.gint(nChars)) +} + +// GetMaxWidthChars is a wrapper around gtk_entry_get_max_width_chars(). +func (v *Entry) GetMaxWidthChars() int { + c := C.gtk_entry_get_max_width_chars(v.native()) + return int(c) +} + +/* + * HeaderBar + */ + +// GetDecorationLayout is a wrapper around gtk_header_bar_get_decoration_layout(). +func (v *HeaderBar) GetDecorationLayout() string { + c := C.gtk_header_bar_get_decoration_layout(v.native()) + return C.GoString((*C.char)(c)) +} + +// SetDecorationLayout is a wrapper around gtk_header_bar_set_decoration_layout(). +func (v *HeaderBar) SetDecorationLayout(layout string) { + cstr := C.CString(layout) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_header_bar_set_decoration_layout(v.native(), (*C.gchar)(cstr)) +} + +// GetHasSubtitle is a wrapper around gtk_header_bar_get_has_subtitle(). +func (v *HeaderBar) GetHasSubtitle() bool { + c := C.gtk_header_bar_get_has_subtitle(v.native()) + return gobool(c) +} + +// SetHasSubtitle is a wrapper around gtk_header_bar_set_has_subtitle(). +func (v *HeaderBar) SetHasSubtitle(setting bool) { + C.gtk_header_bar_set_has_subtitle(v.native(), gbool(setting)) +} + +/* + * MenuButton + */ + +// SetPopover is a wrapper around gtk_menu_button_set_popover(). +func (v *MenuButton) SetPopover(popover *Popover) { + C.gtk_menu_button_set_popover(v.native(), popover.toWidget()) +} + +// GetPopover is a wrapper around gtk_menu_button_get_popover(). +func (v *MenuButton) GetPopover() *Popover { + c := C.gtk_menu_button_get_popover(v.native()) + if c == nil { + return nil + } + return wrapPopover(glib.Take(unsafe.Pointer(c))) +} + +// GetUsePopover is a wrapper around gtk_menu_button_get_use_popover(). +func (v *MenuButton) GetUsePopover() bool { + c := C.gtk_menu_button_get_use_popover(v.native()) + return gobool(c) +} + +// SetUsePopover is a wrapper around gtk_menu_button_set_use_popover(). +func (v *MenuButton) SetUsePopover(setting bool) { + C.gtk_menu_button_set_use_popover(v.native(), gbool(setting)) +} + +/* + * FlowBox + */ + +// FlowBox is a representation of GtkFlowBox +type FlowBox struct { + Container +} + +func (fb *FlowBox) native() *C.GtkFlowBox { + if fb == nil || fb.GObject == nil { + return nil + } + p := unsafe.Pointer(fb.GObject) + return C.toGtkFlowBox(p) +} + +func marshalFlowBox(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapFlowBox(obj), nil +} + +func wrapFlowBox(obj *glib.Object) *FlowBox { + if obj == nil { + return nil + } + + return &FlowBox{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// FlowBoxNew is a wrapper around gtk_flow_box_new() +func FlowBoxNew() (*FlowBox, error) { + c := C.gtk_flow_box_new() + if c == nil { + return nil, nilPtrErr + } + return wrapFlowBox(glib.Take(unsafe.Pointer(c))), nil +} + +// Insert is a wrapper around gtk_flow_box_insert() +func (fb *FlowBox) Insert(widget IWidget, position int) { + C.gtk_flow_box_insert(fb.native(), widget.toWidget(), C.gint(position)) +} + +// GetChildAtIndex is a wrapper around gtk_flow_box_get_child_at_index() +func (fb *FlowBox) GetChildAtIndex(idx int) *FlowBoxChild { + c := C.gtk_flow_box_get_child_at_index(fb.native(), C.gint(idx)) + if c == nil { + return nil + } + return wrapFlowBoxChild(glib.Take(unsafe.Pointer(c))) +} + +// TODO 3.22.6 gtk_flow_box_get_child_at_pos() + +// SetHAdjustment is a wrapper around gtk_flow_box_set_hadjustment() +func (fb *FlowBox) SetHAdjustment(adjustment *Adjustment) { + C.gtk_flow_box_set_hadjustment(fb.native(), adjustment.native()) +} + +// SetVAdjustment is a wrapper around gtk_flow_box_set_vadjustment() +func (fb *FlowBox) SetVAdjustment(adjustment *Adjustment) { + C.gtk_flow_box_set_vadjustment(fb.native(), adjustment.native()) +} + +// SetHomogeneous is a wrapper around gtk_flow_box_set_homogeneous() +func (fb *FlowBox) SetHomogeneous(homogeneous bool) { + C.gtk_flow_box_set_homogeneous(fb.native(), gbool(homogeneous)) +} + +// GetHomogeneous is a wrapper around gtk_flow_box_get_homogeneous() +func (fb *FlowBox) GetHomogeneous() bool { + c := C.gtk_flow_box_get_homogeneous(fb.native()) + return gobool(c) +} + +// SetRowSpacing is a wrapper around gtk_flow_box_set_row_spacing() +func (fb *FlowBox) SetRowSpacing(spacing uint) { + C.gtk_flow_box_set_row_spacing(fb.native(), C.guint(spacing)) +} + +// GetRowSpacing is a wrapper around gtk_flow_box_get_row_spacing() +func (fb *FlowBox) GetRowSpacing() uint { + c := C.gtk_flow_box_get_row_spacing(fb.native()) + return uint(c) +} + +// SetColumnSpacing is a wrapper around gtk_flow_box_set_column_spacing() +func (fb *FlowBox) SetColumnSpacing(spacing uint) { + C.gtk_flow_box_set_column_spacing(fb.native(), C.guint(spacing)) +} + +// GetColumnSpacing is a wrapper around gtk_flow_box_get_column_spacing() +func (fb *FlowBox) GetColumnSpacing() uint { + c := C.gtk_flow_box_get_column_spacing(fb.native()) + return uint(c) +} + +// SetMinChildrenPerLine is a wrapper around gtk_flow_box_set_min_children_per_line() +func (fb *FlowBox) SetMinChildrenPerLine(n_children uint) { + C.gtk_flow_box_set_min_children_per_line(fb.native(), C.guint(n_children)) +} + +// GetMinChildrenPerLine is a wrapper around gtk_flow_box_get_min_children_per_line() +func (fb *FlowBox) GetMinChildrenPerLine() uint { + c := C.gtk_flow_box_get_min_children_per_line(fb.native()) + return uint(c) +} + +// SetMaxChildrenPerLine is a wrapper around gtk_flow_box_set_max_children_per_line() +func (fb *FlowBox) SetMaxChildrenPerLine(n_children uint) { + C.gtk_flow_box_set_max_children_per_line(fb.native(), C.guint(n_children)) +} + +// GetMaxChildrenPerLine is a wrapper around gtk_flow_box_get_max_children_per_line() +func (fb *FlowBox) GetMaxChildrenPerLine() uint { + c := C.gtk_flow_box_get_max_children_per_line(fb.native()) + return uint(c) +} + +// SetActivateOnSingleClick is a wrapper around gtk_flow_box_set_activate_on_single_click() +func (fb *FlowBox) SetActivateOnSingleClick(single bool) { + C.gtk_flow_box_set_activate_on_single_click(fb.native(), gbool(single)) +} + +// GetActivateOnSingleClick gtk_flow_box_get_activate_on_single_click() +func (fb *FlowBox) GetActivateOnSingleClick() bool { + c := C.gtk_flow_box_get_activate_on_single_click(fb.native()) + return gobool(c) +} + +// TODO: gtk_flow_box_selected_foreach() + +// GetSelectedChildren is a wrapper around gtk_flow_box_get_selected_children() +func (fb *FlowBox) GetSelectedChildren() (rv []*FlowBoxChild) { + c := C.gtk_flow_box_get_selected_children(fb.native()) + if c == nil { + return + } + list := glib.WrapList(uintptr(unsafe.Pointer(c))) + for l := list; l != nil; l = l.Next() { + o := wrapFlowBoxChild(glib.Take(l.Data().(unsafe.Pointer))) + rv = append(rv, o) + } + // We got a transfer container, so we must free the list. + list.Free() + + return +} + +// SelectChild is a wrapper around gtk_flow_box_select_child() +func (fb *FlowBox) SelectChild(child *FlowBoxChild) { + C.gtk_flow_box_select_child(fb.native(), child.native()) +} + +// UnselectChild is a wrapper around gtk_flow_box_unselect_child() +func (fb *FlowBox) UnselectChild(child *FlowBoxChild) { + C.gtk_flow_box_unselect_child(fb.native(), child.native()) +} + +// SelectAll is a wrapper around gtk_flow_box_select_all() +func (fb *FlowBox) SelectAll() { + C.gtk_flow_box_select_all(fb.native()) +} + +// UnselectAll is a wrapper around gtk_flow_box_unselect_all() +func (fb *FlowBox) UnselectAll() { + C.gtk_flow_box_unselect_all(fb.native()) +} + +// SetSelectionMode is a wrapper around gtk_flow_box_set_selection_mode() +func (fb *FlowBox) SetSelectionMode(mode SelectionMode) { + C.gtk_flow_box_set_selection_mode(fb.native(), C.GtkSelectionMode(mode)) +} + +// GetSelectionMode is a wrapper around gtk_flow_box_get_selection_mode() +func (fb *FlowBox) GetSelectionMode() SelectionMode { + c := C.gtk_flow_box_get_selection_mode(fb.native()) + return SelectionMode(c) +} + +// TODO gtk_flow_box_set_filter_func() +// TODO gtk_flow_box_invalidate_filter() +// TODO gtk_flow_box_set_sort_func() +// TODO gtk_flow_box_invalidate_sort() +// TODO 3.18 gtk_flow_box_bind_model() + +/* + * FlowBoxChild + */ + +// FlowBoxChild is a representation of GtkFlowBoxChild +type FlowBoxChild struct { + Bin +} + +func (fbc *FlowBoxChild) native() *C.GtkFlowBoxChild { + if fbc == nil || fbc.GObject == nil { + return nil + } + p := unsafe.Pointer(fbc.GObject) + return C.toGtkFlowBoxChild(p) +} + +func marshalFlowBoxChild(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapFlowBoxChild(obj), nil +} + +func wrapFlowBoxChild(obj *glib.Object) *FlowBoxChild { + if obj == nil { + return nil + } + + return &FlowBoxChild{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// FlowBoxChildNew is a wrapper around gtk_flow_box_child_new() +func FlowBoxChildNew() (*FlowBoxChild, error) { + c := C.gtk_flow_box_child_new() + if c == nil { + return nil, nilPtrErr + } + return wrapFlowBoxChild(glib.Take(unsafe.Pointer(c))), nil +} + +// GetIndex is a wrapper around gtk_flow_box_child_get_index() +func (fbc *FlowBoxChild) GetIndex() int { + c := C.gtk_flow_box_child_get_index(fbc.native()) + return int(c) +} + +// IsSelected is a wrapper around gtk_flow_box_child_is_selected() +func (fbc *FlowBoxChild) IsSelected() bool { + c := C.gtk_flow_box_child_is_selected(fbc.native()) + return gobool(c) +} + +// Changed is a wrapper around gtk_flow_box_child_changed() +func (fbc *FlowBoxChild) Changed() { + C.gtk_flow_box_child_changed(fbc.native()) +} + +/* + * GtkPlacesSidebar + */ + +// TODO: +// gtk_places_sidebar_get_local_only(). +// gtk_places_sidebar_set_local_only(). + +/* + * GtkPopover + */ + +// Popover is a representation of GTK's GtkPopover. +type Popover struct { + Bin +} + +func (v *Popover) native() *C.GtkPopover { + if v == nil || v.GObject == nil { + return nil + } + + p := unsafe.Pointer(v.GObject) + return C.toGtkPopover(p) +} + +func marshalPopover(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapPopover(glib.Take(unsafe.Pointer(c))), nil +} + +func wrapPopover(obj *glib.Object) *Popover { + if obj == nil { + return nil + } + + return &Popover{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// PopoverNew is a wrapper around gtk_popover_new(). +func PopoverNew(relative IWidget) (*Popover, error) { + //Takes relative to widget + var c *C.struct__GtkWidget + if relative == nil { + c = C.gtk_popover_new(nil) + } else { + c = C.gtk_popover_new(relative.toWidget()) + } + if c == nil { + return nil, nilPtrErr + } + return wrapPopover(glib.Take(unsafe.Pointer(c))), nil +} + +// PopoverNewFromModel is a wrapper around gtk_popover_new_from_model(). +func PopoverNewFromModel(relative IWidget, model *glib.MenuModel) (*Popover, error) { + //Takes relative to widget + var c *C.struct__GtkWidget + + mptr := C.toGMenuModel(unsafe.Pointer(model.Native())) + + if relative == nil { + c = C.gtk_popover_new_from_model(nil, mptr) + } else { + c = C.gtk_popover_new_from_model(relative.toWidget(), mptr) + } + if c == nil { + return nil, nilPtrErr + } + return wrapPopover(glib.Take(unsafe.Pointer(c))), nil +} + +// BindModel is a wrapper around gtk_popover_bind_model(). +func (v *Popover) BindModel(menuModel *glib.MenuModel, actionNamespace string) { + cstr := C.CString(actionNamespace) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_popover_bind_model(v.native(), C.toGMenuModel(unsafe.Pointer(menuModel.Native())), (*C.gchar)(cstr)) +} + +// SetRelativeTo is a wrapper around gtk_popover_set_relative_to(). +func (v *Popover) SetRelativeTo(relative IWidget) { + C.gtk_popover_set_relative_to(v.native(), relative.toWidget()) +} + +// GetRelativeTo is a wrapper around gtk_popover_get_relative_to(). +func (v *Popover) GetRelativeTo() (IWidget, error) { + c := C.gtk_popover_get_relative_to(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// SetPointingTo is a wrapper around gtk_popover_set_pointing_to(). +func (v *Popover) SetPointingTo(rect gdk.Rectangle) { + C.gtk_popover_set_pointing_to(v.native(), nativeGdkRectangle(rect)) +} + +// GetPointingTo is a wrapper around gtk_popover_get_pointing_to(). +func (v *Popover) GetPointingTo() (*gdk.Rectangle, bool) { + var cRect *C.GdkRectangle + isSet := C.gtk_popover_get_pointing_to(v.native(), cRect) + rect := gdk.WrapRectangle(uintptr(unsafe.Pointer(cRect))) + return rect, gobool(isSet) +} + +// SetPosition is a wrapper around gtk_popover_set_position(). +func (v *Popover) SetPosition(position PositionType) { + C.gtk_popover_set_position(v.native(), C.GtkPositionType(position)) +} + +// GetPosition is a wrapper around gtk_popover_get_position(). +func (v *Popover) GetPosition() PositionType { + c := C.gtk_popover_get_position(v.native()) + return PositionType(c) +} + +// SetModal is a wrapper around gtk_popover_set_modal(). +func (v *Popover) SetModal(modal bool) { + C.gtk_popover_set_modal(v.native(), gbool(modal)) +} + +// GetModal is a wrapper around gtk_popover_get_modal(). +func (v *Popover) GetModal() bool { + return gobool(C.gtk_popover_get_modal(v.native())) +} + +/* + * TreePath + */ + +// TreePathNewFromIndicesv is a wrapper around gtk_tree_path_new_from_indicesv(). +func TreePathNewFromIndicesv(indices []int) (*TreePath, error) { + if len(indices) == 0 { + return nil, errors.New("no indice") + } + + var cIndices []C.gint + for i := 0; i < len(indices); i++ { + cIndices = append(cIndices, C.gint(indices[i])) + } + + var cIndicesPointer *C.gint = &cIndices[0] + c := C.gtk_tree_path_new_from_indicesv(cIndicesPointer, C.gsize(len(indices))) + if c == nil { + return nil, nilPtrErr + } + t := &TreePath{c} + runtime.SetFinalizer(t, (*TreePath).free) + return t, nil +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_12.go.h b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_12.go.h new file mode 100644 index 0000000..24c2f18 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_12.go.h @@ -0,0 +1,27 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +static GtkFlowBox *toGtkFlowBox(void *p) { return (GTK_FLOW_BOX(p)); } + +static GtkFlowBoxChild *toGtkFlowBoxChild(void *p) { + return (GTK_FLOW_BOX_CHILD(p)); +} + +static GMenuModel *toGMenuModel(void *p) { return (G_MENU_MODEL(p)); } + +static GtkPopover *toGtkPopover(void *p) { return (GTK_POPOVER(p)); } diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_14.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_14.go new file mode 100644 index 0000000..865a1ef --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_14.go @@ -0,0 +1,134 @@ +// Same copyright and license as the rest of the files in this project +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12 + +package gtk + +// #include +// #include +// #include "gtk_since_3_14.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/internal/callback" + "github.com/gotk3/gotk3/glib" +) + +/* + * Constants + */ + +const ( + STATE_FLAG_CHECKED StateFlags = C.GTK_STATE_FLAG_CHECKED +) + +// IconLookupFlags is a representation of GTK's GtkIconLookupFlags. +const ( + ICON_LOOKUP_FORCE_REGULAR IconLookupFlags = C.GTK_ICON_LOOKUP_FORCE_REGULAR + ICON_LOOKUP_FORCE_SYMBOLIC = C.GTK_ICON_LOOKUP_FORCE_SYMBOLIC + ICON_LOOKUP_DIR_LTR = C.GTK_ICON_LOOKUP_DIR_LTR + ICON_LOOKUP_DIR_RTL = C.GTK_ICON_LOOKUP_DIR_RTL +) + +/* + * GtkStack + */ + +const ( + STACK_TRANSITION_TYPE_OVER_DOWN_UP StackTransitionType = C.GTK_STACK_TRANSITION_TYPE_OVER_DOWN_UP + STACK_TRANSITION_TYPE_OVER_LEFT_RIGHT = C.GTK_STACK_TRANSITION_TYPE_OVER_LEFT_RIGHT + STACK_TRANSITION_TYPE_OVER_RIGHT_LEFT = C.GTK_STACK_TRANSITION_TYPE_OVER_RIGHT_LEFT +) + +/* + * GtkListBox + */ + +// UnselectRow is a wrapper around gtk_list_box_unselect_row(). +func (v *ListBox) UnselectRow(row *ListBoxRow) { + C.gtk_list_box_unselect_row(v.native(), row.native()) +} + +// SelectAll is a wrapper around gtk_list_box_select_all(). +func (v *ListBox) SelectAll() { + C.gtk_list_box_select_all(v.native()) +} + +// UnselectAll is a wrapper around gtk_list_box_unselect_all(). +func (v *ListBox) UnselectAll() { + C.gtk_list_box_unselect_all(v.native()) +} + +// ListBoxForeachFunc is a representation of GtkListBoxForeachFunc +type ListBoxForeachFunc func(box *ListBox, row *ListBoxRow) int + +// SelectedForeach is a wrapper around gtk_list_box_selected_foreach(). +func (v *ListBox) SelectedForeach(fn ListBoxForeachFunc) { + id := callback.Assign(fn) + defer callback.Delete(id) + + C._gtk_list_box_selected_foreach(v.native(), C.gpointer(id)) +} + +// GetSelectedRows is a wrapper around gtk_list_box_get_selected_rows(). +func (v *ListBox) GetSelectedRows() *glib.List { + clist := C.gtk_list_box_get_selected_rows(v.native()) + if clist == nil { + return nil + } + + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return wrapListBoxRow(glib.Take(ptr)) + }) + + return glist +} + +/* + * GtkListBoxRow + */ + +// IsSelected is a wrapper around gtk_list_box_row_is_selected(). +func (v *ListBoxRow) IsSelected() bool { + c := C.gtk_list_box_row_is_selected(v.native()) + return gobool(c) +} + +// SetActivatable is a wrapper around gtk_list_box_row_set_activatable(). +func (v *ListBoxRow) SetActivatable(activatable bool) { + C.gtk_list_box_row_set_activatable(v.native(), gbool(activatable)) +} + +// GetActivatable is a wrapper around gtk_list_box_row_get_activatable(). +func (v *ListBoxRow) GetActivatable() bool { + c := C.gtk_list_box_row_get_activatable(v.native()) + return gobool(c) +} + +// SetSelectable is a wrapper around gtk_list_box_row_set_selectable(). +func (v *ListBoxRow) SetSelectable(selectable bool) { + C.gtk_list_box_row_set_selectable(v.native(), gbool(selectable)) +} + +// GetSelectable is a wrapper around gtk_list_box_row_get_selectable(). +func (v *ListBoxRow) GetSelectable() bool { + c := C.gtk_list_box_row_get_selectable(v.native()) + return gobool(c) +} + +/* + * GtkPlacesSidebar + */ + +// TODO: +// gtk_places_sidebar_get_show_enter_location(). +// gtk_places_sidebar_set_show_enter_location(). + +/* + * GtkSwitch + */ + +// TODO: +// gtk_switch_set_state(). +// gtk_switch_get_state(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_14.go.h b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_14.go.h new file mode 100644 index 0000000..9cf2054 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_14.go.h @@ -0,0 +1,10 @@ +// Same copyright and license as the rest of the files in this project + +extern void goListBoxForEachFuncs(GtkListBox *box, GtkListBoxRow *row, + gpointer user_data); + +static inline void _gtk_list_box_selected_foreach(GtkListBox *box, + gpointer user_data) { + gtk_list_box_selected_foreach( + box, (GtkListBoxForeachFunc)(goListBoxForEachFuncs), user_data); +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16.go new file mode 100644 index 0000000..98f807c --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16.go @@ -0,0 +1,371 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14 + +// See: https://developer.gnome.org/gtk3/3.16/api-index-3-16.html + +package gtk + +// #include +// #include "gtk_since_3_16.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +const ( + POLICY_EXTERNAL PolicyType = C.GTK_POLICY_EXTERNAL +) + +func init() { + tm := []glib.TypeMarshaler{ + + // Objects/Interfaces + {glib.Type(C.gtk_button_role_get_type()), marshalButtonRole}, + {glib.Type(C.gtk_popover_menu_get_type()), marshalPopoverMenu}, + {glib.Type(C.gtk_model_button_get_type()), marshalModelButton}, + {glib.Type(C.gtk_stack_sidebar_get_type()), marshalStackSidebar}, + {glib.Type(C.gtk_text_extend_selection_get_type()), marshalTextExtendSelection}, + } + glib.RegisterGValueMarshalers(tm) + + //Contribute to casting + for k, v := range map[string]WrapFn{ + "GtkPopoverMenu": wrapPopoverMenu, + "GtkModelButton": wrapModelButton, + "GtkStackSidebar": wrapStackSidebar, + } { + WrapMap[k] = v + } +} + +/* + * Constants + */ + +// ButtonRole is a representation of GTK's GtkButtonRole. +type ButtonRole int + +const ( + BUTTON_ROLE_NORMAL ButtonRole = C.GTK_BUTTON_ROLE_NORMAL + BUTTON_ROLE_CHECK ButtonRole = C.GTK_BUTTON_ROLE_CHECK + BUTTON_ROLE_RADIO ButtonRole = C.GTK_BUTTON_ROLE_RADIO +) + +func marshalButtonRole(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return ButtonRole(c), nil +} + +/* + * TextView + */ + +// TextExtendSelection is a representation of GTK's GtkTextExtendSelection. +type TextExtendSelection int + +const ( + TEXT_EXTEND_SELECTION_WORD TextExtendSelection = C.GTK_TEXT_EXTEND_SELECTION_WORD + TEXT_EXTEND_SELECTION_LINE TextExtendSelection = C.GTK_TEXT_EXTEND_SELECTION_LINE +) + +func marshalTextExtendSelection(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return TextExtendSelection(c), nil +} + +/* + * GtkStack + */ + +// SetHHomogeneous is a wrapper around gtk_stack_set_hhomogeneous(). +func (v *Stack) SetHHomogeneous(hhomogeneous bool) { + C.gtk_stack_set_hhomogeneous(v.native(), gbool(hhomogeneous)) +} + +// GetHHomogeneous is a wrapper around gtk_stack_get_hhomogeneous(). +func (v *Stack) GetHHomogeneous() bool { + return gobool(C.gtk_stack_get_hhomogeneous(v.native())) +} + +// SetVHomogeneous is a wrapper around gtk_stack_set_vhomogeneous(). +func (v *Stack) SetVHomogeneous(vhomogeneous bool) { + C.gtk_stack_set_vhomogeneous(v.native(), gbool(vhomogeneous)) +} + +// GetVHomogeneous is a wrapper around gtk_stack_get_vhomogeneous(). +func (v *Stack) GetVHomogeneous() bool { + return gobool(C.gtk_stack_get_vhomogeneous(v.native())) +} + +/* + * GtkNotebook + */ + +// DetachTab is a wrapper around gtk_notebook_detach_tab(). +func (v *Notebook) DetachTab(child IWidget) { + C.gtk_notebook_detach_tab(v.native(), child.toWidget()) +} + +/* + * GtkListBox + */ + +// ListBoxCreateWidgetFunc is a representation of GtkListBoxCreateWidgetFunc. +type ListBoxCreateWidgetFunc func(item interface{}) int + +/* + * GtkScrolledWindow + */ + +// SetOverlayScrolling is a wrapper around gtk_scrolled_window_set_overlay_scrolling(). +func (v *ScrolledWindow) SetOverlayScrolling(scrolling bool) { + C.gtk_scrolled_window_set_overlay_scrolling(v.native(), gbool(scrolling)) +} + +// GetOverlayScrolling is a wrapper around gtk_scrolled_window_get_overlay_scrolling(). +func (v *ScrolledWindow) GetOverlayScrolling() bool { + return gobool(C.gtk_scrolled_window_get_overlay_scrolling(v.native())) +} + +/* + * GtkPaned + */ + +// SetWideHandle is a wrapper around gtk_paned_set_wide_handle(). +func (v *Paned) SetWideHandle(wide bool) { + C.gtk_paned_set_wide_handle(v.native(), gbool(wide)) +} + +// GetWideHandle is a wrapper around gtk_paned_get_wide_handle(). +func (v *Paned) GetWideHandle() bool { + return gobool(C.gtk_paned_get_wide_handle(v.native())) +} + +/* + * GtkLabel + */ + +// GetXAlign is a wrapper around gtk_label_get_xalign(). +func (v *Label) GetXAlign() float64 { + c := C.gtk_label_get_xalign(v.native()) + return float64(c) +} + +// GetYAlign is a wrapper around gtk_label_get_yalign(). +func (v *Label) GetYAlign() float64 { + c := C.gtk_label_get_yalign(v.native()) + return float64(c) +} + +// SetXAlign is a wrapper around gtk_label_set_xalign(). +func (v *Label) SetXAlign(n float64) { + C.gtk_label_set_xalign(v.native(), C.gfloat(n)) +} + +// SetYAlign is a wrapper around gtk_label_set_yalign(). +func (v *Label) SetYAlign(n float64) { + C.gtk_label_set_yalign(v.native(), C.gfloat(n)) +} + +/* +* GtkModelButton + */ + +// ModelButton is a representation of GTK's GtkModelButton. +type ModelButton struct { + Button +} + +func (v *ModelButton) native() *C.GtkModelButton { + if v == nil || v.GObject == nil { + return nil + } + + p := unsafe.Pointer(v.GObject) + return C.toGtkModelButton(p) +} + +func marshalModelButton(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapModelButton(glib.Take(unsafe.Pointer(c))), nil +} + +func wrapModelButton(obj *glib.Object) *ModelButton { + if obj == nil { + return nil + } + + actionable := wrapActionable(obj) + return &ModelButton{Button{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}, actionable}} +} + +// ModelButtonNew is a wrapper around gtk_model_button_new +func ModelButtonNew() (*ModelButton, error) { + c := C.gtk_model_button_new() + if c == nil { + return nil, nilPtrErr + } + return wrapModelButton(glib.Take(unsafe.Pointer(c))), nil +} + +/* + * GtkPopoverMenu + */ + +// PopoverMenu is a representation of GTK's GtkPopoverMenu. +type PopoverMenu struct { + Popover +} + +func (v *PopoverMenu) native() *C.GtkPopoverMenu { + if v == nil || v.GObject == nil { + return nil + } + + p := unsafe.Pointer(v.GObject) + return C.toGtkPopoverMenu(p) +} + +func marshalPopoverMenu(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapPopoverMenu(glib.Take(unsafe.Pointer(c))), nil +} + +func wrapPopoverMenu(obj *glib.Object) *PopoverMenu { + if obj == nil { + return nil + } + + return &PopoverMenu{Popover{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}}} +} + +// PopoverMenuNew is a wrapper around gtk_popover_menu_new +func PopoverMenuNew() (*PopoverMenu, error) { + c := C.gtk_popover_menu_new() + if c == nil { + return nil, nilPtrErr + } + return wrapPopoverMenu(glib.Take(unsafe.Pointer(c))), nil +} + +// OpenSubmenu is a wrapper around gtk_popover_menu_open_submenu +func (v *PopoverMenu) OpenSubmenu(name string) { + cstr1 := (*C.gchar)(C.CString(name)) + defer C.free(unsafe.Pointer(cstr1)) + + C.gtk_popover_menu_open_submenu(v.native(), cstr1) +} + +/* + * GtkStackSidebar + */ + +// StackSidebar is a representation of GTK's GtkStackSidebar. +type StackSidebar struct { + Bin +} + +// native returns a pointer to the underlying GtkStack. +func (v *StackSidebar) native() *C.GtkStackSidebar { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkStackSidebar(p) +} + +func marshalStackSidebar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapStackSidebar(obj), nil +} + +func wrapStackSidebar(obj *glib.Object) *StackSidebar { + if obj == nil { + return nil + } + + return &StackSidebar{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// StackSidebarNew is a wrapper around gtk_stack_sidebar_new(). +func StackSidebarNew() (*StackSidebar, error) { + c := C.gtk_stack_sidebar_new() + if c == nil { + return nil, nilPtrErr + } + return wrapStackSidebar(glib.Take(unsafe.Pointer(c))), nil +} + +// SetStack is a wrapper around gtk_stack_sidebar_set_stack(). +func (v *StackSidebar) SetStack(stack *Stack) { + C.gtk_stack_sidebar_set_stack(v.native(), stack.native()) +} + +// GetStack is a wrapper around gtk_stack_sidebar_get_stack(). +func (v *StackSidebar) GetStack() *Stack { + c := C.gtk_stack_sidebar_get_stack(v.native()) + if c == nil { + return nil + } + return wrapStack(glib.Take(unsafe.Pointer(c))) +} + +/* + * GtkEntry + */ + +// GrabFocusWithoutSelecting is a wrapper for gtk_entry_grab_focus_without_selecting() +func (v *Entry) GrabFocusWithoutSelecting() { + C.gtk_entry_grab_focus_without_selecting(v.native()) +} + +/* + * GtkSearchEntry + */ + +// HandleEvent is a wrapper around gtk_search_entry_handle_event(). +func (v *SearchEntry) HandleEvent(event *gdk.Event) { + e := (*C.GdkEvent)(unsafe.Pointer(event.Native())) + C.gtk_search_entry_handle_event(v.native(), e) +} + +/* + * GtkTextBuffer + */ + +// InsertMarkup is a wrapper around gtk_text_buffer_insert_markup() +func (v *TextBuffer) InsertMarkup(start *TextIter, text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_text_buffer_insert_markup(v.native(), (*C.GtkTextIter)(start), (*C.gchar)(cstr), C.gint(len(text))) +} + +/* + * CssProvider + */ + +// LoadFromResource is a wrapper around gtk_css_provider_load_from_resource(). +// +// See: https://developer.gnome.org/gtk3/stable/GtkCssProvider.html#gtk-css-provider-load-from-resource +func (v *CssProvider) LoadFromResource(path string) { + cpath := C.CString(path) + defer C.free(unsafe.Pointer(cpath)) + C.gtk_css_provider_load_from_resource(v.native(), (*C.gchar)(cpath)) +} + +/* + * GtkTextView + */ + +// SetMonospace is a wrapper around gtk_text_view_set_monospace() +func (v *TextView) SetMonospace(monospace bool) { + C.gtk_text_view_set_monospace(v.native(), gbool(monospace)) +} + +// GetMonospace is a wrapper around gtk_text_view_get_monospace() +func (v *TextView) GetMonospace() bool { + return gobool(C.gtk_text_view_get_monospace(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16.go.h b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16.go.h new file mode 100644 index 0000000..379ade5 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16.go.h @@ -0,0 +1,47 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#pragma once + +#include "gtk.go.h" +#include // for gotk3_callbackDelete + +static GListModel *toGListModel(void *p) { return (G_LIST_MODEL(p)); } + +static GtkModelButton *toGtkModelButton(void *mb) { + return (GTK_MODEL_BUTTON(mb)); +} + +static GtkPopoverMenu *toGtkPopoverMenu(void *p) { + return (GTK_POPOVER_MENU(p)); +} + +static GtkStackSidebar *toGtkStackSidebar(void *p) { + return (GTK_STACK_SIDEBAR(p)); +} + +static GtkGLArea *toGtkGLArea(void *p) { return (GTK_GL_AREA(p)); } + +extern void goListBoxCreateWidgetFuncs(gpointer item, gpointer user_data); + +static inline void _gtk_list_box_bind_model(GtkListBox *box, GListModel *model, + gpointer user_data) { + gtk_list_box_bind_model( + box, model, (GtkListBoxCreateWidgetFunc)(goListBoxCreateWidgetFuncs), + user_data, (GDestroyNotify)(gotk3_callbackDelete)); +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16_deprecated_since_3_20.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16_deprecated_since_3_20.go new file mode 100644 index 0000000..0f8350e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16_deprecated_since_3_20.go @@ -0,0 +1,22 @@ +// Same copyright and license as the rest of the files in this project. +// This file is normally only compiled for GTK 3.16 and 3.18. +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,gtk_deprecated gtk_3_16 gtk_3_18 + +package gtk + +// #include +import "C" + +/* + * GtkPopover + */ + +// SetTransitionsEnabled is a wrapper gtk_popover_set_transitions_enabled(). +func (v *Popover) SetTransitionsEnabled(transitionsEnabled bool) { + C.gtk_popover_set_transitions_enabled(v.native(), gbool(transitionsEnabled)) +} + +// GetTransitionsEnabled is a wrapper gtk_popover_get_transitions_enabled(). +func (v *Popover) GetTransitionsEnabled() bool { + return gobool(C.gtk_popover_get_transitions_enabled(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16_glib_2_44.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16_glib_2_44.go new file mode 100644 index 0000000..3b5c237 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_16_glib_2_44.go @@ -0,0 +1,25 @@ +// Same copyright and license as the rest of the files in this project +// The code in this file is only for GTK+ version 3.16+, as well as Glib version 2.44+ + +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!glib_2_40,!glib_2_42 + +package gtk + +// #include +// #include "gtk_since_3_16.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/internal/callback" + "github.com/gotk3/gotk3/glib" +) + +// BindModel is a wrapper around gtk_list_box_bind_model(). +func (v *ListBox) BindModel(listModel *glib.ListModel, createWidgetFunc ListBoxCreateWidgetFunc) { + C._gtk_list_box_bind_model( + v.native(), + C.toGListModel(unsafe.Pointer(listModel.Native())), + C.gpointer(callback.Assign(createWidgetFunc)), + ) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_18.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_18.go new file mode 100644 index 0000000..108ecdb --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_18.go @@ -0,0 +1,103 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16 + +// See: https://developer.gnome.org/gtk3/3.18/api-index-3-18.html + +// For gtk_overlay_reorder_overlay(): +// See: https://git.gnome.org/browse/gtk+/tree/gtk/gtkoverlay.h?h=gtk-3-18 + +package gtk + +// #include +import "C" + +/* + * GtkStack + */ + +// TODO: +// gtk_stack_get_interpolate_size(). +// gtk_stack_set_interpolate_size(). + +/* + * GtkRadioMenuItem + */ + +// JoinGroup is a wrapper around gtk_radio_menu_item_join_group(). +func (v *RadioMenuItem) JoinGroup(group_source *RadioMenuItem) { + C.gtk_radio_menu_item_join_group(v.native(), group_source.native()) +} + +/* + * GtkOverlay + */ + +// ReorderOverlay() is a wrapper around gtk_overlay_reorder_overlay(). +func (v *Overlay) ReorderOverlay(child IWidget, position int) { + C.gtk_overlay_reorder_overlay(v.native(), child.toWidget(), C.int(position)) +} + +// GetOverlayPassThrough() is a wrapper around gtk_overlay_get_overlay_pass_through(). +func (v *Overlay) GetOverlayPassThrough(widget IWidget) bool { + c := C.gtk_overlay_get_overlay_pass_through(v.native(), widget.toWidget()) + return gobool(c) +} + +// SetOverlayPassThrough() is a wrapper around gtk_overlay_set_overlay_pass_through(). +func (v *Overlay) SetOverlayPassThrough(widget IWidget, passThrough bool) { + C.gtk_overlay_set_overlay_pass_through(v.native(), widget.toWidget(), gbool(passThrough)) +} + +/* + * GtkPlacesSidebar + */ + +// TODO: +// gtk_places_sidebar_set_show_recent(). +// gtk_places_sidebar_get_show_recent(). +// gtk_places_sidebar_get_show_trash(). +// gtk_places_sidebar_set_show_trash(). +// gtk_places_sidebar_get_show_other_locations(). +// gtk_places_sidebar_set_show_other_locations(). +// gtk_places_sidebar_set_drop_targets_visible(). + +/* + * GtkPopover + */ + +// SetDefaultWidget is a wrapper around gtk_popover_set_default_widget(). +func (p *Popover) SetDefaultWidget(widget IWidget) { + C.gtk_popover_set_default_widget(p.native(), widget.toWidget()) +} + +// GetDefaultWidget is a wrapper around gtk_popover_get_default_widget(). +func (p *Popover) GetDefaultWidget() (IWidget, error) { + w := C.gtk_popover_get_default_widget(p.native()) + if w == nil { + return nil, nil + } + return castWidget(w) +} + +/* + * GtkTextView + */ + +// SetTopMargin is a wrapper around gtk_text_view_set_top_margin(). +func (v *TextView) SetTopMargin(topMargin int) { + C.gtk_text_view_set_top_margin(v.native(), C.gint(topMargin)) +} + +// GetTopMargin is a wrapper around gtk_text_view_get_top_margin(). +func (v *TextView) GetTopMargin() int { + return int(C.gtk_text_view_get_top_margin(v.native())) +} + +// SetBottomMargin is a wrapper around gtk_text_view_set_bottom_margin(). +func (v *TextView) SetBottomMargin(bottomMargin int) { + C.gtk_text_view_set_bottom_margin(v.native(), C.gint(bottomMargin)) +} + +// GetBottomMargin is a wrapper around gtk_text_view_get_bottom_margin(). +func (v *TextView) GetBottomMargin() int { + return int(C.gtk_text_view_get_bottom_margin(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_20.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_20.go new file mode 100644 index 0000000..0a5a33a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_20.go @@ -0,0 +1,283 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16,!gtk_3_18 + +// See: https://developer.gnome.org/gtk3/3.20/api-index-3-20.html + +package gtk + +// #include +// #include "gtk_since_3_20.go.h" +import "C" + +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.gtk_popover_constraint_get_type()), marshalPopoverConstraint}, + } + glib.RegisterGValueMarshalers(tm) +} + +/* + * Constants + */ + +// PopoverConstraint is a representation of GTK's GtkPopoverConstraint. +type PopoverConstraint int + +const ( + POPOVER_CONSTRAINT_NONE PopoverConstraint = C.GTK_POPOVER_CONSTRAINT_NONE + POPOVER_CONSTRAINT_WINDOW PopoverConstraint = C.GTK_POPOVER_CONSTRAINT_WINDOW +) + +func marshalPopoverConstraint(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PopoverConstraint(c), nil +} + +const ( + STATE_FLAG_DROP_ACTIVE StateFlags = C.GTK_STATE_FLAG_DROP_ACTIVE +) + +/* + * GtkNativeDialog + */ + +// NativeDialog is a representation of GTK's GtkNativeDialog. +type NativeDialog struct { + glib.InitiallyUnowned +} + +// native returns a pointer to the underlying GObject as a GtkNativeDialog. +func (v *NativeDialog) native() *C.GtkNativeDialog { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkNativeDialog(p) +} + +func wrapNativeDialog(obj *glib.Object) *NativeDialog { + if obj == nil { + return nil + } + + return &NativeDialog{glib.InitiallyUnowned{obj}} +} + +// Run() is a wrapper around gtk_native_dialog_run(). +func (v *NativeDialog) Run() int { + c := C.gtk_native_dialog_run(v.native()) + return int(c) +} + +// Destroy() is a wrapper around gtk_native_dialog_destroy(). +func (v *NativeDialog) Destroy() { + C.gtk_native_dialog_destroy(v.native()) +} + +// SetModal is a wrapper around gtk_native_dialog_set_modal(). +func (v *NativeDialog) SetModal(modal bool) { + C.gtk_native_dialog_set_modal(v.native(), gbool(modal)) +} + +// GetModal is a wrapper around gtk_native_dialog_get_modal(). +func (v *NativeDialog) GetModal() bool { + c := C.gtk_native_dialog_get_modal(v.native()) + return gobool(c) +} + +// SetTitle is a wrapper around gtk_native_dialog_set_title(). +func (v *NativeDialog) SetTitle(title string) { + cstr := C.CString(title) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_native_dialog_set_title(v.native(), (*C.char)(cstr)) +} + +// GetTitle is a wrapper around gtk_native_dialog_get_title(). +func (v *NativeDialog) GetTitle() (string, error) { + return stringReturn((*C.gchar)(C.gtk_native_dialog_get_title(v.native()))) +} + +// SetTransientFor is a wrapper around gtk_native_dialog_set_transient_for(). +func (v *NativeDialog) SetTransientFor(parent IWindow) { + var pw *C.GtkWindow = nil + if parent != nil { + pw = parent.toWindow() + } + C.gtk_native_dialog_set_transient_for(v.native(), pw) +} + +// GetTransientFor is a wrapper around gtk_native_dialog_get_transient_for(). +func (v *NativeDialog) GetTransientFor() (*Window, error) { + c := C.gtk_native_dialog_get_transient_for(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapWindow(glib.Take(unsafe.Pointer(c))), nil +} + +// GetVisible() is a wrapper around gtk_native_dialog_get_visible(). +func (v *NativeDialog) GetVisible() bool { + c := C.gtk_native_dialog_get_visible(v.native()) + return gobool(c) +} + +// Show() is a wrapper around gtk_native_dialog_show(). +func (v *NativeDialog) Show() { + C.gtk_native_dialog_show(v.native()) +} + +// Hide() is a wrapper around gtk_native_dialog_hide(). +func (v *NativeDialog) Hide() { + C.gtk_native_dialog_hide(v.native()) +} + +/* + * GtkFileChooserNative + */ + +// FileChooserNativeDialog is a representation of GTK's GtkFileChooserNative. +type FileChooserNativeDialog struct { + NativeDialog + + // Interfaces + FileChooser +} + +// native returns a pointer to the underlying GObject as a GtkNativeDialog. +func (v *FileChooserNativeDialog) native() *C.GtkFileChooserNative { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkFileChooserNative(p) +} + +func wrapFileChooserNativeDialog(obj *glib.Object) *FileChooserNativeDialog { + if obj == nil { + return nil + } + + fc := wrapFileChooser(obj) + return &FileChooserNativeDialog{NativeDialog{glib.InitiallyUnowned{obj}}, *fc} +} + +// FileChooserNativeDialogNew is a wrapper around gtk_file_chooser_native_new(). +func FileChooserNativeDialogNew(title string, parent IWindow, action FileChooserAction, + accept_label string, cancel_label string) (*FileChooserNativeDialog, error) { + + c_title := C.CString(title) + defer C.free(unsafe.Pointer(c_title)) + + c_accept_label := C.CString(accept_label) + defer C.free(unsafe.Pointer(c_accept_label)) + + c_cancel_label := C.CString(cancel_label) + defer C.free(unsafe.Pointer(c_cancel_label)) + + var w *C.GtkWindow = nil + if parent != nil { + w = parent.toWindow() + } + + c := C.gtk_file_chooser_native_new( + (*C.gchar)(c_title), w, C.GtkFileChooserAction(action), + (*C.gchar)(c_accept_label), (*C.gchar)(c_cancel_label)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapFileChooserNativeDialog(obj), nil +} + +/* + * FileChooserNative + */ +func OpenFileChooserNative(title string, parent IWindow) *string { + c_title := C.CString(title) + + var native *C.GtkFileChooserNative + + var w *C.GtkWindow = nil + if parent != nil { + w = parent.toWindow() + } + + native = C.gtk_file_chooser_native_new((*C.gchar)(c_title), + w, + C.GtkFileChooserAction(FILE_CHOOSER_ACTION_OPEN), + (*C.gchar)(C.CString("_Open")), + (*C.gchar)(C.CString("_Cancel"))) + + p := unsafe.Pointer(unsafe.Pointer(native)) + dlg := C.toGtkNativeDialog(p) + res := C.gtk_native_dialog_run(dlg) + + if res == C.GTK_RESPONSE_ACCEPT { + c := C.gtk_file_chooser_get_filename(C.toGtkFileChooser(p)) + s := goString(c) + defer C.g_free((C.gpointer)(c)) + + return &s + } + + return nil +} + +// SetAcceptLabel is a wrapper around gtk_file_chooser_native_set_accept_label(). +func (v *FileChooserNativeDialog) SetAcceptLabel(accept_label string) { + cstr := C.CString(accept_label) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_file_chooser_native_set_accept_label(v.native(), (*C.char)(cstr)) +} + +// GetAcceptLabel is a wrapper around gtk_file_chooser_native_get_accept_label(). +func (v *FileChooserNativeDialog) GetAcceptLabel() (string, error) { + return stringReturn((*C.gchar)(C.gtk_file_chooser_native_get_accept_label(v.native()))) +} + +// SetCancelLabel is a wrapper around gtk_file_chooser_native_set_cancel_label(). +func (v *FileChooserNativeDialog) SetCancelLabel(cancel_label string) { + cstr := C.CString(cancel_label) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_file_chooser_native_set_cancel_label(v.native(), (*C.char)(cstr)) +} + +// GetCancelLabel is a wrapper around gtk_file_chooser_native_get_cancel_label(). +func (v *FileChooserNativeDialog) GetCancelLabel() (string, error) { + return stringReturn((*C.gchar)(C.gtk_file_chooser_native_get_cancel_label(v.native()))) +} + +/* + * GtkTextView + */ + +// TODO: +// gtk_text_view_reset_cursor_blink(). + +/* + * GtkExpander + */ + +// TODO: +// gtk_expander_set_spacing(). +// gtk_expander_get_spacing(). + +/* + * GtkPopover + */ + +// SetConstrainTo is a wrapper gtk_popover_set_constrain_to(). +func (v *Popover) SetConstrainTo(constrain PopoverConstraint) { + C.gtk_popover_set_constrain_to(v.native(), C.GtkPopoverConstraint(constrain)) +} + +// GetConstrainTo is a wrapper gtk_popover_get_constrain_to(). +func (v *Popover) GetConstrainTo() PopoverConstraint { + return PopoverConstraint(C.gtk_popover_get_constrain_to(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_20.go.h b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_20.go.h new file mode 100644 index 0000000..940c4a8 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_20.go.h @@ -0,0 +1,33 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#pragma once + +#include + +static GtkFileChooser *toGtkFileChooser(void *p) { + return (GTK_FILE_CHOOSER(p)); +} + +static GtkFileChooserNative *toGtkFileChooserNative(void *p) { + return (GTK_FILE_CHOOSER_NATIVE(p)); +} + +static GtkNativeDialog *toGtkNativeDialog(void *p) { + return (GTK_NATIVE_DIALOG(p)); +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_22.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_22.go new file mode 100644 index 0000000..ff1e3bf --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_22.go @@ -0,0 +1,66 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16,!gtk_3_18,!gtk_3_20 + +// See: https://developer.gnome.org/gtk3/3.22/api-index-3-22.html + +package gtk + +// #include +import "C" + +// Popup is a wrapper around gtk_popover_popup(). +func (v *Popover) Popup() { + C.gtk_popover_popup(v.native()) +} + +// Popdown is a wrapper around gtk_popover_popdown(). +func (v *Popover) Popdown() { + C.gtk_popover_popdown(v.native()) +} + +/* + * GtkScrolledWindow + */ + +// GetMaxContentWidth is a wrapper around gtk_scrolled_window_get_max_content_width(). +func (v *ScrolledWindow) GetMaxContentWidth() int { + c := C.gtk_scrolled_window_get_max_content_width(v.native()) + return int(c) +} + +// SetMaxContentWidth is a wrapper around gtk_scrolled_window_set_max_content_width(). +func (v *ScrolledWindow) SetMaxContentWidth(width int) { + C.gtk_scrolled_window_set_max_content_width(v.native(), C.gint(width)) +} + +// GetMaxContentHeight is a wrapper around gtk_scrolled_window_get_max_content_height(). +func (v *ScrolledWindow) GetMaxContentHeight() int { + c := C.gtk_scrolled_window_get_max_content_height(v.native()) + return int(c) +} + +// SetMaxContentHeight is a wrapper around gtk_scrolled_window_set_max_content_height(). +func (v *ScrolledWindow) SetMaxContentHeight(width int) { + C.gtk_scrolled_window_set_max_content_height(v.native(), C.gint(width)) +} + +// GetPropagateNaturalWidth is a wrapper around gtk_scrolled_window_get_propagate_natural_width(). +func (v *ScrolledWindow) GetPropagateNaturalWidth() bool { + c := C.gtk_scrolled_window_get_propagate_natural_width(v.native()) + return gobool(c) +} + +// SetPropagateNaturalWidth is a wrapper around gtk_scrolled_window_set_propagate_natural_width(). +func (v *ScrolledWindow) SetPropagateNaturalWidth(propagate bool) { + C.gtk_scrolled_window_set_propagate_natural_width(v.native(), gbool(propagate)) +} + +// GetPropagateNaturalHeight is a wrapper around gtk_scrolled_window_get_propagate_natural_height(). +func (v *ScrolledWindow) GetPropagateNaturalHeight() bool { + c := C.gtk_scrolled_window_get_propagate_natural_height(v.native()) + return gobool(c) +} + +// SetPropagateNaturalHeight is a wrapper around gtk_scrolled_window_set_propagate_natural_height(). +func (v *ScrolledWindow) SetPropagateNaturalHeight(propagate bool) { + C.gtk_scrolled_window_set_propagate_natural_height(v.native(), gbool(propagate)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_24.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_24.go new file mode 100644 index 0000000..97968fb --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_24.go @@ -0,0 +1,14 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16,!gtk_3_18,!gtk_3_20,!gtk_3_22 + +package gtk + +// #include +import "C" + +/* + * GtkInputPurpose + */ + +const ( + INPUT_PURPOSE_TERMINAL InputPurpose = C.GTK_INPUT_PURPOSE_TERMINAL +) diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_8.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_8.go new file mode 100644 index 0000000..21ffa40 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_since_3_8.go @@ -0,0 +1,36 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// This file includes wrapers for symbols included since GTK 3.8, and +// and should not be included in a build intended to target any older GTK +// versions. To target an older build, such as 3.8, use +// 'go build -tags gtk_3_8'. Otherwise, if no build tags are used, GTK 3.18 +// is assumed and this file is built. +// +build !gtk_3_6 + +package gtk + +// #include +import "C" + +/* + * Constants + */ + +const ( + STATE_FLAG_DIR_LTR StateFlags = C.GTK_STATE_FLAG_DIR_LTR + STATE_FLAG_DIR_RTL StateFlags = C.GTK_STATE_FLAG_DIR_RTL +) diff --git a/vendor/github.com/gotk3/gotk3/gtk/gtk_test.go b/vendor/github.com/gotk3/gotk3/gtk/gtk_test.go new file mode 100644 index 0000000..147107e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/gtk_test.go @@ -0,0 +1,875 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package gtk + +import ( + "fmt" + "log" + "testing" + "time" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +func init() { + Init(nil) +} + +// TestBoolConvs tests the conversion between Go bools and gboolean +// types. +func TestBoolConvs(t *testing.T) { + if err := testBoolConvs(); err != nil { + t.Error(err) + } +} + +// TestBox tests creating and adding widgets to a Box +func TestBox(t *testing.T) { + vbox, err := BoxNew(ORIENTATION_VERTICAL, 0) + if err != nil { + t.Error("Unable to create box") + } + + vbox.Set("homogeneous", true) + if vbox.GetHomogeneous() != true { + t.Error("Could not set or get Box homogeneous property") + } + + vbox.SetHomogeneous(false) + if vbox.GetHomogeneous() != false { + t.Error("Could not set or get Box homogeneous property") + } + + vbox.Set("spacing", 1) + if vbox.GetSpacing() != 1 { + t.Error("Could not set or get Box spacing") + } + + vbox.SetSpacing(2) + if vbox.GetSpacing() != 2 { + t.Error("Could not set or get Box spacing") + } + + // add a child to start and end + start, err := LabelNew("Start") + if err != nil { + t.Error("Unable to create label") + } + + end, err := LabelNew("End") + if err != nil { + t.Error("Unable to create label") + } + + vbox.PackStart(start, true, true, 3) + vbox.PackEnd(end, true, true, 3) +} +func TestTextBuffer_WhenSetText_ExpectGetTextReturnsSame(t *testing.T) { + buffer, err := TextBufferNew(nil) + if err != nil { + t.Error("Unable to create text buffer") + } + expected := "Hello, World!" + buffer.SetText(expected) + + start, end := buffer.GetBounds() + + actual, err := buffer.GetText(start, end, true) + if err != nil { + t.Error("Unable to get text from buffer") + } + + if actual != expected { + t.Errorf("Expected '%s'; Got '%s'", expected, actual) + } +} + +func testTextViewEditable(set bool) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + exp := set + tv.SetEditable(exp) + act := tv.GetEditable() + if exp != act { + return fmt.Errorf("Expected GetEditable(): %v; Got: %v", exp, act) + } + return nil +} + +func TestTextView_WhenSetEditableFalse_ExpectGetEditableReturnsFalse(t *testing.T) { + if err := testTextViewEditable(false); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetEditableTrue_ExpectGetEditableReturnsTrue(t *testing.T) { + if err := testTextViewEditable(true); err != nil { + t.Error(err) + } +} + +func testTextViewWrapMode(set WrapMode) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + exp := set + tv.SetWrapMode(set) + act := tv.GetWrapMode() + if act != exp { + return fmt.Errorf("Expected GetWrapMode(): %v; Got: %v", exp, act) + } + return nil +} + +func TestTextView_WhenSetWrapModeNone_ExpectGetWrapModeReturnsNone(t *testing.T) { + if err := testTextViewWrapMode(WRAP_NONE); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetWrapModeWord_ExpectGetWrapModeReturnsWord(t *testing.T) { + if err := testTextViewWrapMode(WRAP_WORD); err != nil { + t.Error(err) + } +} + +func testTextViewCursorVisible(set bool) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + exp := set + tv.SetCursorVisible(set) + act := tv.GetCursorVisible() + if act != exp { + return fmt.Errorf("Expected GetCursorVisible(): %v; Got: %v", exp, act) + } + return nil +} + +func TestTextView_WhenSetCursorVisibleFalse_ExpectGetCursorVisibleReturnsFalse(t *testing.T) { + if err := testTextViewCursorVisible(false); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetCursorVisibleTrue_ExpectGetCursorVisibleReturnsTrue(t *testing.T) { + if err := testTextViewCursorVisible(true); err != nil { + t.Error(err) + } +} + +func testTextViewOverwrite(set bool) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + exp := set + tv.SetOverwrite(set) + act := tv.GetOverwrite() + if act != exp { + return fmt.Errorf("Expected GetOverwrite(): %v; Got: %v", exp, act) + } + return nil +} + +func TestTextView_WhenSetOverwriteFalse_ExpectGetOverwriteReturnsFalse(t *testing.T) { + if err := testTextViewOverwrite(false); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetOverwriteTrue_ExpectGetOverwriteReturnsTrue(t *testing.T) { + if err := testTextViewOverwrite(true); err != nil { + t.Error(err) + } +} + +func testTextViewJustification(justify Justification) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + exp := justify + tv.SetJustification(justify) + act := tv.GetJustification() + if act != exp { + return fmt.Errorf("Expected GetJustification(): %v; Got: %v", exp, act) + } + return nil +} + +func TestTextView_WhenSetJustificationLeft_ExpectGetJustificationReturnsLeft(t *testing.T) { + if err := testTextViewJustification(JUSTIFY_LEFT); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetJustificationRight_ExpectGetJustificationReturnsRight(t *testing.T) { + if err := testTextViewJustification(JUSTIFY_RIGHT); err != nil { + t.Error(err) + } +} + +func testTextViewAcceptsTab(set bool) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + exp := set + tv.SetAcceptsTab(set) + if act := tv.GetAcceptsTab(); act != exp { + return fmt.Errorf("Expected GetAcceptsTab(): %v; Got: %v", exp, act) + } + return nil +} + +func TestTextView_WhenSetAcceptsTabFalse_ExpectGetAcceptsTabReturnsFalse(t *testing.T) { + if err := testTextViewAcceptsTab(false); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetAcceptsTabTrue_ExpectGetAcceptsTabReturnsTrue(t *testing.T) { + if err := testTextViewAcceptsTab(true); err != nil { + t.Error(err) + } +} + +func testIntProperty(val int, set func(int), get func() int) error { + set(val) + if exp, act := val, get(); act != exp { + return fmt.Errorf("Expected: %d; got: %d", exp, act) + } + return nil +} + +func testTextViewPixelsAboveLines(px int) error { + tv, err := TextViewNew() + if err != nil { + return err + } + return testIntProperty(px, (*tv).SetPixelsAboveLines, (*tv).GetPixelsAboveLines) +} + +func TestTextView_WhenSetPixelsAboveLines10_ExpectGetPixelsAboveLinesReturns10(t *testing.T) { + if err := testTextViewPixelsAboveLines(10); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetPixelsAboveLines11_ExpectGetPixelsAboveLinesReturns11(t *testing.T) { + if err := testTextViewPixelsAboveLines(11); err != nil { + t.Error(err) + } +} + +func testTextViewPixelsBelowLines(px int) error { + tv, err := TextViewNew() + if err != nil { + return err + } + return testIntProperty(px, (*tv).SetPixelsBelowLines, (*tv).GetPixelsBelowLines) +} + +func TestTextView_WhenSetPixelsBelowLines10_ExpectGetPixelsAboveLinesReturns10(t *testing.T) { + if err := testTextViewPixelsBelowLines(10); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetPixelsBelowLines11_ExpectGetPixelsBelowLinesReturns11(t *testing.T) { + if err := testTextViewPixelsBelowLines(11); err != nil { + t.Error(err) + } +} + +func testTextViewPixelsInsideWrap(px int) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + return testIntProperty(px, (*tv).SetPixelsInsideWrap, (*tv).GetPixelsInsideWrap) +} + +func TestTextView_WhenSetPixelsInsideWrap10_ExpectGetPixelsInsideWrapReturns11(t *testing.T) { + if err := testTextViewPixelsInsideWrap(10); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetPixelsInsideWrap11_ExpectGetPixelsInsideWrapReturns11(t *testing.T) { + if err := testTextViewPixelsInsideWrap(11); err != nil { + t.Error(err) + } +} + +func testTextViewLeftMargin(margin int) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + return testIntProperty(margin, (*tv).SetLeftMargin, (*tv).GetLeftMargin) +} + +func TestTextView_WhenSetLeftMargin11_ExpectGetLeftMarginReturns11(t *testing.T) { + if err := testTextViewLeftMargin(11); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetLeftMargin10_ExpectGetLeftMarginReturns10(t *testing.T) { + if err := testTextViewLeftMargin(10); err != nil { + t.Error(err) + } +} + +func testTextViewRightMargin(margin int) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + return testIntProperty(margin, (*tv).SetRightMargin, (*tv).GetRightMargin) +} + +func TestTextView_WhenSetRightMargin10_ExpectGetRightMarginReturns10(t *testing.T) { + if err := testTextViewRightMargin(10); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetRightMargin11_ExpectGetRightMarginReturns11(t *testing.T) { + if err := testTextViewRightMargin(11); err != nil { + t.Error(err) + } +} + +func testTextViewIndent(indent int) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + return testIntProperty(indent, (*tv).SetIndent, (*tv).GetIndent) +} + +func TestTextView_WhenSetIndent10_ExpectGetIndentReturns10(t *testing.T) { + if err := testTextViewIndent(10); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetIndent11_ExpectGetIndentReturns11(t *testing.T) { + if err := testTextViewIndent(11); err != nil { + t.Error(err) + } +} + +func testTextViewInputHints(hint InputHints) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + tv.SetInputHints(hint) + if exp, act := hint, tv.GetInputHints(); act != exp { + return fmt.Errorf("Expected %v; Got %v", exp, act) + } + return nil +} + +func TestTextView_WhenSetInputHintsNone_ExpectGetInputHintsReturnsNone(t *testing.T) { + if err := testTextViewInputHints(INPUT_HINT_NONE); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetInputHintsSpellCheck_ExpectGetInputHintsReturnsSpellCheck(t *testing.T) { + if err := testTextViewInputHints(INPUT_HINT_SPELLCHECK); err != nil { + t.Error(err) + } +} + +func testTextViewInputPurpose(purpose InputPurpose) error { + tv, err := TextViewNew() + if err != nil { + return err + } + + tv.SetInputPurpose(purpose) + if exp, act := purpose, tv.GetInputPurpose(); act != exp { + return fmt.Errorf("Expected %v; Got %v", exp, act) + } + return nil +} + +func TestTextView_WhenSetInputPurposeURL_ExpectGetInputPurposeReturnsURL(t *testing.T) { + if err := testTextViewInputPurpose(INPUT_PURPOSE_URL); err != nil { + t.Error(err) + } +} + +func TestTextView_WhenSetInputPurposeALPHA_ExpectGetInputPurposeReturnsALPHA(t *testing.T) { + if err := testTextViewInputPurpose(INPUT_PURPOSE_ALPHA); err != nil { + t.Error(err) + } +} + +func testCellRendererToggleSetRadio(set bool) error { + renderer, err := CellRendererToggleNew() + if err != nil { + return err + } + + renderer.SetRadio(set) + if exp, act := set, renderer.GetRadio(); act != exp { + return fmt.Errorf("Expected GetRadio(): %v; Got: %v", exp, act) + } + return nil +} + +func TestCellRendererToggle_WhenSetRadioFalse_ExpectGetRadioReturnsFalse(t *testing.T) { + if err := testCellRendererToggleSetRadio(false); err != nil { + t.Error(err) + } +} + +func TestCellRendererToggle_WhenSetRadioTrue_ExpectGetRadioReturnsTrue(t *testing.T) { + if err := testCellRendererToggleSetRadio(true); err != nil { + t.Error(err) + } +} + +func testCellRendererToggleSetActive(set bool) error { + renderer, err := CellRendererToggleNew() + if err != nil { + return err + } + + renderer.SetActive(set) + if exp, act := set, renderer.GetActive(); act != exp { + return fmt.Errorf("Expected GetActive(): %v; Got: %v", exp, act) + } + return nil +} + +func TestCellRendererToggle_WhenSetActiveFalse_ExpectGetActiveReturnsFalse(t *testing.T) { + if err := testCellRendererToggleSetActive(false); err != nil { + t.Error(err) + } +} + +func TestCellRendererToggle_WhenSetActiveTrue_ExpectGetActiveReturnsTrue(t *testing.T) { + if err := testCellRendererToggleSetActive(true); err != nil { + t.Error(err) + } +} + +func testCellRendererToggleSetActivatable(set bool) error { + renderer, err := CellRendererToggleNew() + if err != nil { + return err + } + + renderer.SetActivatable(set) + if exp, act := set, renderer.GetActivatable(); act != exp { + return fmt.Errorf("Expected GetActivatable(): %v; Got: %v", exp, act) + } + return nil +} + +func TestCellRendererToggle_WhenSetActivatableFalse_ExpectGetActivatableReturnsFalse(t *testing.T) { + if err := testCellRendererToggleSetActivatable(false); err != nil { + t.Error(err) + } +} + +func TestCellRendererToggle_WhenSetActivatableTrue_ExpectGetActivatableReturnsTrue(t *testing.T) { + if err := testCellRendererToggleSetActivatable(true); err != nil { + t.Error(err) + } +} + +func TestCellRendererAccel_AccelModeMarshaling(t *testing.T) { + // CellRendererAccel has no getters/setters, everything is handled via properties, so marshaling has to work + renderer, err := CellRendererAccelNew() + if err != nil { + t.Error(err) + } + + err = renderer.SetProperty("accel-mode", CELL_RENDERER_ACCEL_MODE_OTHER) + if err != nil { + t.Error(err) + } + + value, err := renderer.GetProperty("accel-mode") + if err != nil { + t.Error(err) + } + + if CELL_RENDERER_ACCEL_MODE_OTHER != value { + t.Errorf("Expected %v, got %v", CELL_RENDERER_ACCEL_MODE_OTHER, value) + } +} + +func TestCellRendererAccel_ModifierTypeMarshaling(t *testing.T) { + // CellRendererAccel has no getters/setters, everything is handled via properties, so marshaling has to work + renderer, err := CellRendererAccelNew() + if err != nil { + t.Error(err) + } + + err = renderer.SetProperty("accel-mods", gdk.META_MASK) + if err != nil { + t.Error(err) + } + + value, err := renderer.GetProperty("accel-mods") + if err != nil { + t.Error(err) + } + + if gdk.META_MASK != value.(gdk.ModifierType) { + t.Errorf("Expected %v, got %v", gdk.META_MASK, value.(gdk.ModifierType)) + } +} + +func setupListStore() *ListStore { + ls, err := ListStoreNew(glib.TYPE_STRING) + if err != nil { + log.Fatal("Unexpected err:", err) + } + return ls +} + +func getLastIter(ls *ListStore) (*TreeIter, bool) { + iter, listIsntEmpty := ls.GetIterFirst() + if !listIsntEmpty { + return iter, listIsntEmpty + } + + for { + temp := *iter + last := &temp + if !ls.IterNext(iter) { + return last, true + } + } + + panic("Shouldn't get here") +} + +// TestListStoreRemoveLastInvalidIterator tests that when a ListStore stores +// one item and it is removed, the iterator becomes invalid. +func TestListStoreRemoveLastInvalidIterator(t *testing.T) { + ls := setupListStore() + + iter := ls.Append() + + if iterValid := ls.Remove(iter); iterValid { + t.Fatal("Remove() returned true (iter valid); expected false (iter invalid)") + } +} + +func TestListStoreInsertBefore(t *testing.T) { + ls := setupListStore() + + // Given 1 iter is already in the liststore + initialIter := ls.Append() + + // When another iter is inserted before it + newIter := ls.InsertBefore(initialIter) + + // Expect the newly-inserted iter is first iter in list + firstIter, listIsntEmpty := ls.GetIterFirst() + if !listIsntEmpty { + t.Fatal("Unexpected: liststore is empty") + } + + if *firstIter != *newIter { + t.Fatal("Expected the new iter added to front of list") + } +} + +// When 'sibling' parameter is nil, the new iter should be appended to the liststore +func TestListStoreInsertBefore_WhenNilSibling(t *testing.T) { + ls := setupListStore() + + // Given 2 iters in liststore + ls.Append() + ls.Append() + + // When 'sibling' parameter of InsertBefore() is nil... + newIter := ls.InsertBefore(nil) + + // Then expect newly-inserted iter is the first iter in list + lastIter, listIsntEmpty := getLastIter(ls) + if !listIsntEmpty { + t.Fatal("Unexpected: liststore is empty") + } + + if *lastIter != *newIter { + t.Fatal("Expected the new iter added to end of list") + } +} + +func TestListStoreInsertAfter(t *testing.T) { + ls := setupListStore() + + // Given 1 iter in liststore + sibling := ls.Append() + + // When InsertAfter(sibling) + newIter := ls.InsertAfter(sibling) + + // Then expect newly-inserted iter is the last iter in list + lastIter, listIsntEmpty := getLastIter(ls) + if !listIsntEmpty { + t.Fatal("Unexpected: liststore is empty") + } + + if *lastIter != *newIter { + t.Fatal("Expected the new iter added to end of list") + } +} + +// When 'sibling' parameter is nil, the new iter should be prepended to the liststore +func TestListStoreInsertAfter_WhenNilSibling(t *testing.T) { + ls := setupListStore() + + // Given 2 iters in liststore + ls.Append() + ls.Append() + + // When InsertAfter(nil) + newIter := ls.InsertAfter(nil) + + // Then expect newly-inserted iter is the first iter in the list + first, listIsntEmpty := ls.GetIterFirst() + if !listIsntEmpty { + t.Fatal("Unexpected: liststore is empty") + } + + if *first != *newIter { + t.Fatal("Expected the new iter was prepended to liststore") + } +} + +// Test storing and fetching a non-empty string value in a ListStore +func TestListStoreGetValue_NonEmptyString(t *testing.T) { + ls := setupListStore() + + // Add a string + err := ls.InsertWithValues(nil, -1, []int{0}, []interface{}{"foo"}) + if err != nil { + t.Fatal("Failed to insert row", err) + } + + // Fetch the first iter + first, listIsntEmpty := ls.GetIterFirst() + if !listIsntEmpty { + t.Fatal("Unexpected: liststore is empty") + } + + // Obtain a value + v, err := ls.GetValue(first, 0) + if err != nil { + t.Fatal("Failed GetValue()", err) + } + + s, err := v.GetString() + if err != nil { + t.Fatal("Failed GetString()", err) + } + + if s != "foo" { + t.Errorf("Expected 'foo'; Got %v", s) + } +} + +// Test storing and fetching an empty string value in a ListStore +func TestListStoreGetValue_EmptyString(t *testing.T) { + ls := setupListStore() + + // Add a string + err := ls.InsertWithValues(nil, -1, []int{0}, []interface{}{""}) + if err != nil { + t.Fatal("Failed to insert row", err) + } + + // Fetch the first iter + first, listIsntEmpty := ls.GetIterFirst() + if !listIsntEmpty { + t.Fatal("Unexpected: liststore is empty") + } + + // Obtain a value + v, err := ls.GetValue(first, 0) + if err != nil { + t.Fatal("Failed GetValue()", err) + } + + s, err := v.GetString() + if err != nil { + t.Fatal("Failed GetString()", err) + } + + if s != "" { + t.Errorf("Expected an empty string; Got %v", s) + } +} + +// Test storing and fetching a missing string value in a ListStore +func TestListStoreGetValue_MissingString(t *testing.T) { + ls := setupListStore() + + // Add a string + err := ls.InsertWithValues(nil, -1, nil, nil) + if err != nil { + t.Fatal("Failed to insert row", err) + } + + // Fetch the first iter + first, listIsntEmpty := ls.GetIterFirst() + if !listIsntEmpty { + t.Fatal("Unexpected: liststore is empty") + } + + // Obtain a value + v, err := ls.GetValue(first, 0) + if err != nil { + t.Fatal("Failed GetValue()", err) + } + + _, err = v.GetString() + if err == nil { + t.Fatal("Unexpected success: error expected from GetString()", err) + } +} + +func TestBuilder(t *testing.T) { + builder, err := BuilderNew() + if err != nil { + t.Error("Unable to create builder") + } + + str := ` + + + + + 10 + + + 20 + + + gtk-ok + TRUE + + + + + + + + + +` + + err = builder.AddFromString(str) + if err != nil { + t.Error("Unable to add from string") + } + + widget, err := builder.GetObject("ok_button") + if err != nil { + t.Error("Unable to get widget from string") + } + + button, ok := widget.(*Button) + if !ok { + t.Error("Unable to cast to gtk.Button") + } + + l, err := button.GetLabel() + if err != nil { + t.Error("Unable to get button label") + } + + if l != "gtk-ok" { + t.Errorf("Label has the wrong value: %q", l) + } + + done := make(chan bool) + + builder.ConnectSignals(map[string]interface{}{ + "ok_button_clicked": func() { + done <- true + }, + }) + + go button.Emit("clicked") + + select { + case <-done: + case <-time.After(1 * time.Second): + t.Error("Failed to call callback") + } +} + +func TestTextTagEvent(t *testing.T) { + textTag, err := TextTagNew("mytexttag") + if err != nil { + t.Error("could not create text tag") + } + + evk := gdk.EventKeyNew() + + var iter TextIter + ok := textTag.Event(textTag.Object, evk.Event, &iter) + + if ok { + t.Error("event should not have been handled") + } + + textTag.Connect("event", func() bool { + return true + }) + + ok = textTag.Event(textTag.Object, evk.Event, &iter) + + if !ok { + t.Error("event should have been handled") + } + +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/icon_view.go b/vendor/github.com/gotk3/gotk3/gtk/icon_view.go new file mode 100644 index 0000000..3508c1f --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/icon_view.go @@ -0,0 +1,481 @@ +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +/* + * GtkIconView + */ + +// IconView is a representation of GTK's GtkIconView. +type IconView struct { + Container +} + +// native returns a pointer to the underlying GtkIconView. +func (v *IconView) native() *C.GtkIconView { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkIconView(p) +} + +func marshalIconView(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapIconView(obj), nil +} + +func wrapIconView(obj *glib.Object) *IconView { + if obj == nil { + return nil + } + + return &IconView{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// IconViewNew is a wrapper around gtk_icon_view_new(). +func IconViewNew() (*IconView, error) { + c := C.gtk_icon_view_new() + if c == nil { + return nil, nilPtrErr + } + + return wrapIconView(glib.Take(unsafe.Pointer(c))), nil +} + +// TODO: +// gtk_icon_view_new_with_area(). + +// IconViewNewWithModel is a wrapper around gtk_icon_view_new_with_model(). +func IconViewNewWithModel(model ITreeModel) (*IconView, error) { + c := C.gtk_icon_view_new_with_model(model.toTreeModel()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapIconView(obj), nil +} + +// SetModel is a wrapper around gtk_icon_view_set_model(). +func (v *IconView) SetModel(model ITreeModel) { + var mptr *C.GtkTreeModel + if model != nil { + mptr = model.toTreeModel() + } + C.gtk_icon_view_set_model(v.native(), mptr) +} + +// GetModel is a wrapper around gtk_icon_view_get_model(). +func (v *IconView) GetModel() (ITreeModel, error) { + c := C.gtk_icon_view_get_model(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castTreeModel(c) +} + +// SetTextColumn is a wrapper around gtk_icon_view_set_text_column(). +func (v *IconView) SetTextColumn(column int) { + C.gtk_icon_view_set_text_column(v.native(), C.gint(column)) +} + +// GetTextColumn is a wrapper around gtk_icon_view_get_text_column(). +func (v *IconView) GetTextColumn() int { + return int(C.gtk_icon_view_get_text_column(v.native())) +} + +// SetMarkupColumn is a wrapper around gtk_icon_view_set_markup_column(). +func (v *IconView) SetMarkupColumn(column int) { + C.gtk_icon_view_set_markup_column(v.native(), C.gint(column)) +} + +// GetMarkupColumn is a wrapper around gtk_icon_view_get_markup_column(). +func (v *IconView) GetMarkupColumn() int { + return int(C.gtk_icon_view_get_markup_column(v.native())) +} + +// SetPixbufColumn is a wrapper around gtk_icon_view_set_pixbuf_column(). +func (v *IconView) SetPixbufColumn(column int) { + C.gtk_icon_view_set_pixbuf_column(v.native(), C.gint(column)) +} + +// GetPixbufColumn is a wrapper around gtk_icon_view_get_pixbuf_column(). +func (v *IconView) GetPixbufColumn() int { + return int(C.gtk_icon_view_get_pixbuf_column(v.native())) +} + +// GetPathAtPos is a wrapper around gtk_icon_view_get_path_at_pos(). +func (v *IconView) GetPathAtPos(x, y int) *TreePath { + var ( + cpath *C.GtkTreePath + path *TreePath + ) + + cpath = C.gtk_icon_view_get_path_at_pos(v.native(), C.gint(x), C.gint(y)) + + if cpath != nil { + path = &TreePath{cpath} + runtime.SetFinalizer(path, (*TreePath).free) + } + + return path +} + +// GetItemAtPos is a wrapper around gtk_icon_view_get_item_at_pos(). +func (v *IconView) GetItemAtPos(x, y int) (*TreePath, *CellRenderer) { + var ( + cpath *C.GtkTreePath + ccell *C.GtkCellRenderer + path *TreePath + cell *CellRenderer + ) + + C.gtk_icon_view_get_item_at_pos(v.native(), C.gint(x), C.gint(y), &cpath, &ccell) + + if cpath != nil { + path = &TreePath{cpath} + runtime.SetFinalizer(path, (*TreePath).free) + } + + if ccell != nil { + cell = wrapCellRenderer(glib.Take(unsafe.Pointer(ccell))) + } + + return path, cell +} + +// ConvertWidgetToBinWindowCoords is a wrapper around gtk_icon_view_convert_widget_to_bin_window_coords(). +func (v *IconView) ConvertWidgetToBinWindowCoords(x, y int) (int, int) { + var bx, by C.gint + + C.gtk_icon_view_convert_widget_to_bin_window_coords(v.native(), C.gint(x), C.gint(y), &bx, &by) + + return int(bx), int(by) +} + +// SetCursor is a wrapper around gtk_icon_view_set_cursor(). +func (v *IconView) SetCursor(path *TreePath, cell *CellRenderer, startEditing bool) { + C.gtk_icon_view_set_cursor(v.native(), path.native(), cell.native(), gbool(startEditing)) +} + +// GetCursor is a wrapper around gtk_icon_view_get_cursor(). +func (v *IconView) GetCursor() (*TreePath, *CellRenderer) { + var ( + cpath *C.GtkTreePath + ccell *C.GtkCellRenderer + path *TreePath + cell *CellRenderer + ) + + C.gtk_icon_view_get_cursor(v.native(), &cpath, &ccell) + + if cpath != nil { + path = &TreePath{cpath} + runtime.SetFinalizer(path, (*TreePath).free) + } + + if ccell != nil { + cell = wrapCellRenderer(glib.Take(unsafe.Pointer(ccell))) + } + + return path, cell +} + +// TODO: +// gtk_icon_view_selected_foreach(). +// func (v *IconView) SelectedForeach() {} + +// SetSelectionMode is a wrapper around gtk_icon_view_set_selection_mode(). +func (v *IconView) SetSelectionMode(mode SelectionMode) { + C.gtk_icon_view_set_selection_mode(v.native(), C.GtkSelectionMode(mode)) +} + +// GetSelectionMode is a wrapper around gtk_icon_view_get_selection_mode(). +func (v *IconView) GetSelectionMode() SelectionMode { + return SelectionMode(C.gtk_icon_view_get_selection_mode(v.native())) +} + +// SetItemOrientation is a wrapper around gtk_icon_view_set_item_orientation(). +func (v *IconView) SetItemOrientation(orientation Orientation) { + C.gtk_icon_view_set_item_orientation(v.native(), C.GtkOrientation(orientation)) +} + +// GetItemOrientation is a wrapper around gtk_icon_view_get_item_orientation(). +func (v *IconView) GetItemOrientation() Orientation { + return Orientation(C.gtk_icon_view_get_item_orientation(v.native())) +} + +// SetColumns is a wrapper around gtk_icon_view_set_columns(). +func (v *IconView) SetColumns(columns int) { + C.gtk_icon_view_set_columns(v.native(), C.gint(columns)) +} + +// GetColumns is a wrapper around gtk_icon_view_get_columns(). +func (v *IconView) GetColumns() int { + return int(C.gtk_icon_view_get_columns(v.native())) +} + +// SetItemWidth is a wrapper around gtk_icon_view_set_item_width(). +func (v *IconView) SetItemWidth(width int) { + C.gtk_icon_view_set_item_width(v.native(), C.gint(width)) +} + +// GetItemWidth is a wrapper around gtk_icon_view_get_item_width(). +func (v *IconView) GetItemWidth() int { + return int(C.gtk_icon_view_get_item_width(v.native())) +} + +// SetSpacing is a wrapper around gtk_icon_view_set_spacing(). +func (v *IconView) SetSpacing(spacing int) { + C.gtk_icon_view_set_spacing(v.native(), C.gint(spacing)) +} + +// GetSpacing is a wrapper around gtk_icon_view_get_spacing(). +func (v *IconView) GetSpacing() int { + return int(C.gtk_icon_view_get_spacing(v.native())) +} + +// SetRowSpacing is a wrapper around gtk_icon_view_set_row_spacing(). +func (v *IconView) SetRowSpacing(rowSpacing int) { + C.gtk_icon_view_set_row_spacing(v.native(), C.gint(rowSpacing)) +} + +// GetRowSpacing is a wrapper around gtk_icon_view_get_row_spacing(). +func (v *IconView) GetRowSpacing() int { + return int(C.gtk_icon_view_get_row_spacing(v.native())) +} + +// SetColumnSpacing is a wrapper around gtk_icon_view_set_column_spacing(). +func (v *IconView) SetColumnSpacing(columnSpacing int) { + C.gtk_icon_view_set_column_spacing(v.native(), C.gint(columnSpacing)) +} + +// GetColumnSpacing is a wrapper around gtk_icon_view_get_column_spacing(). +func (v *IconView) GetColumnSpacing() int { + return int(C.gtk_icon_view_get_column_spacing(v.native())) +} + +// SetMargin is a wrapper around gtk_icon_view_set_margin(). +func (v *IconView) SetMargin(margin int) { + C.gtk_icon_view_set_margin(v.native(), C.gint(margin)) +} + +// GetMargin is a wrapper around gtk_icon_view_get_margin(). +func (v *IconView) GetMargin() int { + return int(C.gtk_icon_view_get_margin(v.native())) +} + +// SetItemPadding is a wrapper around gtk_icon_view_set_item_padding(). +func (v *IconView) SetItemPadding(itemPadding int) { + C.gtk_icon_view_set_item_padding(v.native(), C.gint(itemPadding)) +} + +// GetItemPadding is a wrapper around gtk_icon_view_get_item_padding(). +func (v *IconView) GetItemPadding() int { + return int(C.gtk_icon_view_get_item_padding(v.native())) +} + +// SetActivateOnSingleClick is a wrapper around gtk_icon_view_set_activate_on_single_click(). +func (v *IconView) SetActivateOnSingleClick(single bool) { + C.gtk_icon_view_set_activate_on_single_click(v.native(), gbool(single)) +} + +// GetActivateOnSingleClick is a wrapper around gtk_icon_view_get_activate_on_single_click(). +func (v *IconView) GetActivateOnSingleClick() bool { + return gobool(C.gtk_icon_view_get_activate_on_single_click(v.native())) +} + +// GetCellRect is a wrapper around gtk_icon_view_get_cell_rect(). +func (v *IconView) GetCellRect(path *TreePath, cell *CellRenderer) *gdk.Rectangle { + var crect C.GdkRectangle + + C.gtk_icon_view_get_cell_rect(v.native(), path.native(), cell.native(), &crect) + + return gdk.WrapRectangle(uintptr(unsafe.Pointer(&crect))) +} + +// SelectPath is a wrapper around gtk_icon_view_select_path(). +func (v *IconView) SelectPath(path *TreePath) { + C.gtk_icon_view_select_path(v.native(), path.native()) +} + +// UnselectPath is a wrapper around gtk_icon_view_unselect_path(). +func (v *IconView) UnselectPath(path *TreePath) { + C.gtk_icon_view_unselect_path(v.native(), path.native()) +} + +// PathIsSelected is a wrapper around gtk_icon_view_path_is_selected(). +func (v *IconView) PathIsSelected(path *TreePath) bool { + return gobool(C.gtk_icon_view_path_is_selected(v.native(), path.native())) +} + +// GetSelectedItems is a wrapper around gtk_icon_view_get_selected_items(). +func (v *IconView) GetSelectedItems() *glib.List { + clist := C.gtk_icon_view_get_selected_items(v.native()) + if clist == nil { + return nil + } + + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return &TreePath{(*C.GtkTreePath)(ptr)} + }) + runtime.SetFinalizer(glist, func(glist *glib.List) { + glist.FreeFull(func(item interface{}) { + path := item.(*TreePath) + C.gtk_tree_path_free(path.GtkTreePath) + }) + }) + + return glist +} + +// SelectAll is a wrapper around gtk_icon_view_select_all(). +func (v *IconView) SelectAll() { + C.gtk_icon_view_select_all(v.native()) +} + +// UnselectAll is a wrapper around gtk_icon_view_unselect_all(). +func (v *IconView) UnselectAll() { + C.gtk_icon_view_unselect_all(v.native()) +} + +// ItemActivated is a wrapper around gtk_icon_view_item_activated(). +func (v *IconView) ItemActivated(path *TreePath) { + C.gtk_icon_view_item_activated(v.native(), path.native()) +} + +// ScrollToPath is a wrapper around gtk_icon_view_scroll_to_path(). +func (v *IconView) ScrollToPath(path *TreePath, useAlign bool, rowAlign, colAlign float64) { + C.gtk_icon_view_scroll_to_path(v.native(), path.native(), gbool(useAlign), + C.gfloat(rowAlign), C.gfloat(colAlign)) +} + +// GetVisibleRange is a wrapper around gtk_icon_view_get_visible_range(). +func (v *IconView) GetVisibleRange() (*TreePath, *TreePath) { + var ( + cpathStart, cpathEnd *C.GtkTreePath + pathStart, pathEnd *TreePath + ) + + C.gtk_icon_view_get_visible_range(v.native(), &cpathStart, &cpathEnd) + + if cpathStart != nil { + pathStart = &TreePath{cpathStart} + runtime.SetFinalizer(pathStart, (*TreePath).free) + } + + if cpathEnd != nil { + pathEnd = &TreePath{cpathEnd} + runtime.SetFinalizer(pathEnd, (*TreePath).free) + } + + return pathStart, pathEnd +} + +// SetTooltipItem is a wrapper around gtk_icon_view_set_tooltip_item(). +func (v *IconView) SetTooltipItem(tooltip *Tooltip, path *TreePath) { + C.gtk_icon_view_set_tooltip_item(v.native(), tooltip.native(), path.native()) +} + +// SetTooltipCell is a wrapper around gtk_icon_view_set_tooltip_cell(). +func (v *IconView) SetTooltipCell(tooltip *Tooltip, path *TreePath, cell *CellRenderer) { + C.gtk_icon_view_set_tooltip_cell(v.native(), tooltip.native(), path.native(), cell.native()) +} + +// GetTooltipContext is a wrapper around gtk_icon_view_get_tooltip_context(). +func (v *IconView) GetTooltipContext(x, y int, keyboardTip bool) (*TreeModel, *TreePath, *TreeIter) { + var ( + cmodel *C.GtkTreeModel + cpath *C.GtkTreePath + citer *C.GtkTreeIter + model *TreeModel + path *TreePath + iter *TreeIter + ) + + px := C.gint(x) + py := C.gint(y) + if !gobool(C.gtk_icon_view_get_tooltip_context(v.native(), + &px, + &py, + gbool(keyboardTip), + &cmodel, + &cpath, + citer, + )) { + return nil, nil, nil + } + + if cmodel != nil { + model = wrapTreeModel(glib.Take(unsafe.Pointer(cmodel))) + } + + if cpath != nil { + path = &TreePath{cpath} + runtime.SetFinalizer(path, (*TreePath).free) + } + + if citer != nil { + iter = &TreeIter{*citer} + runtime.SetFinalizer(iter, (*TreeIter).free) + } + + return model, path, iter +} + +// SetTooltipColumn is a wrapper around gtk_icon_view_set_tooltip_column(). +func (v *IconView) SetTooltipColumn(column int) { + C.gtk_icon_view_set_tooltip_column(v.native(), C.gint(column)) +} + +// GetTooltipColumn is a wrapper around gtk_icon_view_get_tooltip_column(). +func (v *IconView) GetTooltipColumn() int { + return int(C.gtk_icon_view_get_tooltip_column(v.native())) +} + +// GetItemRow is a wrapper around gtk_icon_view_get_item_row(). +func (v *IconView) GetItemRow(path *TreePath) int { + return int(C.gtk_icon_view_get_item_row(v.native(), path.native())) +} + +// TODO: +// gtk_icon_view_get_item_column(). +// gtk_icon_view_enable_model_drag_source(). +// func (v *IconView) EnableModelDragSource() {} +// gtk_icon_view_enable_model_drag_dest(). +// func (v *IconView) EnableModelDragDest() {} +// gtk_icon_view_unset_model_drag_source(). +// func (v *IconView) UnsetModelDragSource() {} +// gtk_icon_view_unset_model_drag_dest(). +// func (v *IconView) UnsetModelDragDest() {} + +// SetReorderable is a wrapper around gtk_icon_view_set_reorderable(). +func (v *IconView) SetReorderable(reorderable bool) { + C.gtk_icon_view_set_reorderable(v.native(), gbool(reorderable)) +} + +// GetReorderable is a wrapper around gtk_icon_view_get_reorderable(). +func (v *IconView) GetReorderable() bool { + return gobool(C.gtk_icon_view_get_reorderable(v.native())) +} + +// TODO: +// gtk_icon_view_set_drag_dest_item(). +// func (v *IconView) SetDragDestItem() {} +// gtk_icon_view_get_drag_dest_item(). +// func (v *IconView) GetDragDestItem() {} +// gtk_icon_view_get_dest_item_at_pos(). +// func (v *IconView) GetDestItemAtPos() {} +// gtk_icon_view_create_drag_icon(). +// func (v *IconView) CreateDragIcon() {} diff --git a/vendor/github.com/gotk3/gotk3/gtk/info_bar.go b/vendor/github.com/gotk3/gotk3/gtk/info_bar.go new file mode 100644 index 0000000..82a12a3 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/info_bar.go @@ -0,0 +1,133 @@ +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_info_bar_get_type()), marshalInfoBar}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkInfoBar"] = wrapInfoBar +} + +type InfoBar struct { + Box +} + +func (v *InfoBar) native() *C.GtkInfoBar { + if v == nil || v.GObject == nil { + return nil + } + + p := unsafe.Pointer(v.GObject) + return C.toGtkInfoBar(p) +} + +func marshalInfoBar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapInfoBar(glib.Take(unsafe.Pointer(c))), nil +} + +func wrapInfoBar(obj *glib.Object) *InfoBar { + if obj == nil { + return nil + } + + return &InfoBar{Box{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// InfoBarNew is a wrapper around gtk_info_bar_new(). +func InfoBarNew() (*InfoBar, error) { + c := C.gtk_info_bar_new() + if c == nil { + return nil, nilPtrErr + } + + return wrapInfoBar(glib.Take(unsafe.Pointer(c))), nil +} + +// TODO: +// gtk_info_bar_new_with_buttons(). + +// AddActionWidget is a wrapper around gtk_info_bar_add_action_widget(). +func (v *InfoBar) AddActionWidget(w IWidget, responseId ResponseType) { + C.gtk_info_bar_add_action_widget(v.native(), w.toWidget(), C.gint(responseId)) +} + +// AddButton is a wrapper around gtk_info_bar_add_button(). +func (v *InfoBar) AddButton(buttonText string, responseId ResponseType) { + cstr := C.CString(buttonText) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_info_bar_add_button(v.native(), (*C.gchar)(cstr), C.gint(responseId)) +} + +// TODO: +// gtk_info_bar_add_buttons(). + +// SetResponseSensitive is a wrapper around gtk_info_bar_set_response_sensitive(). +func (v *InfoBar) SetResponseSensitive(responseId ResponseType, setting bool) { + C.gtk_info_bar_set_response_sensitive(v.native(), C.gint(responseId), gbool(setting)) +} + +// SetDefaultResponse is a wrapper around gtk_info_bar_set_default_response(). +func (v *InfoBar) SetDefaultResponse(responseId ResponseType) { + C.gtk_info_bar_set_default_response(v.native(), C.gint(responseId)) +} + +// TODO: +// gtk_info_bar_response(). + +// SetMessageType is a wrapper around gtk_info_bar_set_message_type(). +func (v *InfoBar) SetMessageType(messageType MessageType) { + C.gtk_info_bar_set_message_type(v.native(), C.GtkMessageType(messageType)) +} + +// GetMessageType is a wrapper around gtk_info_bar_get_message_type(). +func (v *InfoBar) GetMessageType() MessageType { + messageType := C.gtk_info_bar_get_message_type(v.native()) + return MessageType(messageType) +} + +// GetActionArea is a wrapper around gtk_info_bar_get_action_area(). +func (v *InfoBar) GetActionArea() (IWidget, error) { + c := C.gtk_info_bar_get_action_area(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castWidget(c) +} + +// GetContentArea is a wrapper around gtk_info_bar_get_content_area(). +func (v *InfoBar) GetContentArea() (*Box, error) { + c := C.gtk_info_bar_get_content_area(v.native()) + if c == nil { + return nil, nilPtrErr + } + + return wrapBox(glib.Take(unsafe.Pointer(c))), nil +} + +// GetShowCloseButton is a wrapper around gtk_info_bar_get_show_close_button(). +func (v *InfoBar) GetShowCloseButton() bool { + b := C.gtk_info_bar_get_show_close_button(v.native()) + return gobool(b) +} + +// SetShowCloseButton is a wrapper around gtk_info_bar_set_show_close_button(). +func (v *InfoBar) SetShowCloseButton(setting bool) { + C.gtk_info_bar_set_show_close_button(v.native(), gbool(setting)) +} + +// TODO: for GTK+ 3.22.29 +// gtk_info_bar_get_revealed(). +// gtk_info_bar_set_revealed(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/label.go b/vendor/github.com/gotk3/gotk3/gtk/label.go new file mode 100644 index 0000000..c8a0846 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/label.go @@ -0,0 +1,299 @@ +// Same copyright and license as the rest of the files in this project +// This file contains style related functions and structures + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/pango" + + "github.com/gotk3/gotk3/glib" +) + +/* + * GtkLabel + */ + +// Label is a representation of GTK's GtkLabel. +type Label struct { + Widget +} + +// native returns a pointer to the underlying GtkLabel. +func (v *Label) native() *C.GtkLabel { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkLabel(p) +} + +func marshalLabel(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapLabel(obj), nil +} + +func wrapLabel(obj *glib.Object) *Label { + if obj == nil { + return nil + } + + return &Label{Widget{glib.InitiallyUnowned{obj}}} +} + +// WidgetToLabel is a convience func that casts the given *Widget into a *Label. +func WidgetToLabel(widget *Widget) (*Label, error) { + obj := glib.Take(unsafe.Pointer(widget.GObject)) + return wrapLabel(obj), nil +} + +// LabelNew is a wrapper around gtk_label_new(). +func LabelNew(str string) (*Label, error) { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_label_new((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapLabel(obj), nil +} + +// SetText is a wrapper around gtk_label_set_text(). +func (v *Label) SetText(str string) { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_label_set_text(v.native(), (*C.gchar)(cstr)) +} + +// TODO: +// gtk_label_set_text_with_mnemonic(). +// gtk_label_get_attributes(). +func (v *Label) SetAttributes(attributes *pango.AttrList) { + C.gtk_label_set_attributes(v.native(), (*C.PangoAttrList)(unsafe.Pointer(attributes.Native()))) +} + +// SetMarkup is a wrapper around gtk_label_set_markup(). +func (v *Label) SetMarkup(str string) { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_label_set_markup(v.native(), (*C.gchar)(cstr)) +} + +// SetMarkupWithMnemonic is a wrapper around +// gtk_label_set_markup_with_mnemonic(). +func (v *Label) SetMarkupWithMnemonic(str string) { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_label_set_markup_with_mnemonic(v.native(), (*C.gchar)(cstr)) +} + +// SetPattern is a wrapper around gtk_label_set_pattern(). +func (v *Label) SetPattern(patern string) { + cstr := C.CString(patern) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_label_set_pattern(v.native(), (*C.gchar)(cstr)) +} + +// SetJustify is a wrapper around gtk_label_set_justify(). +func (v *Label) SetJustify(jtype Justification) { + C.gtk_label_set_justify(v.native(), C.GtkJustification(jtype)) +} + +// SetEllipsize is a wrapper around gtk_label_set_ellipsize(). +func (v *Label) SetEllipsize(mode pango.EllipsizeMode) { + C.gtk_label_set_ellipsize(v.native(), C.PangoEllipsizeMode(mode)) +} + +// GetWidthChars is a wrapper around gtk_label_get_width_chars(). +func (v *Label) GetWidthChars() int { + c := C.gtk_label_get_width_chars(v.native()) + return int(c) +} + +// SetWidthChars is a wrapper around gtk_label_set_width_chars(). +func (v *Label) SetWidthChars(nChars int) { + C.gtk_label_set_width_chars(v.native(), C.gint(nChars)) +} + +// GetMaxWidthChars is a wrapper around gtk_label_get_max_width_chars(). +func (v *Label) GetMaxWidthChars() int { + c := C.gtk_label_get_max_width_chars(v.native()) + return int(c) +} + +// SetMaxWidthChars is a wrapper around gtk_label_set_max_width_chars(). +func (v *Label) SetMaxWidthChars(nChars int) { + C.gtk_label_set_max_width_chars(v.native(), C.gint(nChars)) +} + +// GetLineWrap is a wrapper around gtk_label_get_line_wrap(). +func (v *Label) GetLineWrap() bool { + c := C.gtk_label_get_line_wrap(v.native()) + return gobool(c) +} + +// SetLineWrap is a wrapper around gtk_label_set_line_wrap(). +func (v *Label) SetLineWrap(wrap bool) { + C.gtk_label_set_line_wrap(v.native(), gbool(wrap)) +} + +// SetLineWrapMode is a wrapper around gtk_label_set_line_wrap_mode(). +func (v *Label) SetLineWrapMode(wrapMode pango.WrapMode) { + C.gtk_label_set_line_wrap_mode(v.native(), C.PangoWrapMode(wrapMode)) +} + +// TODO: +// gtk_label_get_line_wrap_mode(). +// gtk_label_get_layout_offsets(). +// gtk_label_get_layout(). +// gtk_label_get_mnemonic_widget(). + +// GetSelectable is a wrapper around gtk_label_get_selectable(). +func (v *Label) GetSelectable() bool { + c := C.gtk_label_get_selectable(v.native()) + return gobool(c) +} + +// GetText is a wrapper around gtk_label_get_text(). +func (v *Label) GetText() (string, error) { + c := C.gtk_label_get_text(v.native()) + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +// GetJustify is a wrapper around gtk_label_get_justify(). +func (v *Label) GetJustify() Justification { + c := C.gtk_label_get_justify(v.native()) + return Justification(c) +} + +// GetEllipsize is a wrapper around gtk_label_get_ellipsize(). +func (v *Label) GetEllipsize() pango.EllipsizeMode { + c := C.gtk_label_get_ellipsize(v.native()) + return pango.EllipsizeMode(c) +} + +// GetCurrentUri is a wrapper around gtk_label_get_current_uri(). +func (v *Label) GetCurrentUri() string { + c := C.gtk_label_get_current_uri(v.native()) + return C.GoString((*C.char)(c)) +} + +// GetTrackVisitedLinks is a wrapper around gtk_label_get_track_visited_links(). +func (v *Label) GetTrackVisitedLinks() bool { + c := C.gtk_label_get_track_visited_links(v.native()) + return gobool(c) +} + +// SetTrackVisitedLinks is a wrapper around gtk_label_set_track_visited_links(). +func (v *Label) SetTrackVisitedLinks(trackLinks bool) { + C.gtk_label_set_track_visited_links(v.native(), gbool(trackLinks)) +} + +// GetAngle is a wrapper around gtk_label_get_angle(). +func (v *Label) GetAngle() float64 { + c := C.gtk_label_get_angle(v.native()) + return float64(c) +} + +// SetAngle is a wrapper around gtk_label_set_angle(). +func (v *Label) SetAngle(angle float64) { + C.gtk_label_set_angle(v.native(), C.gdouble(angle)) +} + +// GetSelectionBounds is a wrapper around gtk_label_get_selection_bounds(). +func (v *Label) GetSelectionBounds() (start, end int, nonEmpty bool) { + var cstart, cend C.gint + c := C.gtk_label_get_selection_bounds(v.native(), &cstart, &cend) + return int(cstart), int(cend), gobool(c) +} + +// GetSingleLineMode is a wrapper around gtk_label_get_single_line_mode(). +func (v *Label) GetSingleLineMode() bool { + c := C.gtk_label_get_single_line_mode(v.native()) + return gobool(c) +} + +// SetSingleLineMode is a wrapper around gtk_label_set_single_line_mode(). +func (v *Label) SetSingleLineMode(mode bool) { + C.gtk_label_set_single_line_mode(v.native(), gbool(mode)) +} + +// GetUseMarkup is a wrapper around gtk_label_get_use_markup(). +func (v *Label) GetUseMarkup() bool { + c := C.gtk_label_get_use_markup(v.native()) + return gobool(c) +} + +// SetUseMarkup is a wrapper around gtk_label_set_use_markup(). +func (v *Label) SetUseMarkup(use bool) { + C.gtk_label_set_use_markup(v.native(), gbool(use)) +} + +// GetUseUnderline is a wrapper around gtk_label_get_use_underline(). +func (v *Label) GetUseUnderline() bool { + c := C.gtk_label_get_use_underline(v.native()) + return gobool(c) +} + +// SetUseUnderline is a wrapper around gtk_label_set_use_underline(). +func (v *Label) SetUseUnderline(use bool) { + C.gtk_label_set_use_underline(v.native(), gbool(use)) +} + +// LabelNewWithMnemonic is a wrapper around gtk_label_new_with_mnemonic(). +func LabelNewWithMnemonic(str string) (*Label, error) { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_label_new_with_mnemonic((*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapLabel(obj), nil +} + +// SelectRegion is a wrapper around gtk_label_select_region(). +func (v *Label) SelectRegion(startOffset, endOffset int) { + C.gtk_label_select_region(v.native(), C.gint(startOffset), + C.gint(endOffset)) +} + +// SetSelectable is a wrapper around gtk_label_set_selectable(). +func (v *Label) SetSelectable(setting bool) { + C.gtk_label_set_selectable(v.native(), gbool(setting)) +} + +// SetLabel is a wrapper around gtk_label_set_label(). +func (v *Label) SetLabel(str string) { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_label_set_label(v.native(), (*C.gchar)(cstr)) +} + +// GetLabel is a wrapper around gtk_label_get_label(). +func (v *Label) GetLabel() string { + c := C.gtk_label_get_label(v.native()) + if c == nil { + return "" + } + return C.GoString((*C.char)(c)) +} + +// GetMnemonicKeyval is a wrapper around gtk_label_get_mnemonic_keyval(). +func (v *Label) GetMnemonicKeyval() uint { + return uint(C.gtk_label_get_mnemonic_keyval(v.native())) +} + +// SetMnemonicWidget is a wrapper around gtk_label_set_mnemonic_widget(). +func (v *Label) SetMnemonicWidget(widget IWidget) { + C.gtk_label_set_mnemonic_widget(v.native(), widget.toWidget()) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/level_bar.go b/vendor/github.com/gotk3/gotk3/gtk/level_bar.go new file mode 100644 index 0000000..1e35bf9 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/level_bar.go @@ -0,0 +1,158 @@ +// Supports building with gtk 3.6+ + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_level_bar_mode_get_type()), marshalLevelBarMode}, + + {glib.Type(C.gtk_level_bar_get_type()), marshalLevelBar}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkLevelBar"] = wrapLevelBar +} + +// LevelBarMode is a representation of GTK's GtkLevelBarMode. +type LevelBarMode int + +const ( + LEVEL_BAR_MODE_CONTINUOUS LevelBarMode = C.GTK_LEVEL_BAR_MODE_CONTINUOUS + LEVEL_BAR_MODE_DISCRETE LevelBarMode = C.GTK_LEVEL_BAR_MODE_DISCRETE +) + +// stock offset macro values of GtkLevelBar +const ( + LEVEL_BAR_OFFSET_LOW string = C.GTK_LEVEL_BAR_OFFSET_LOW + LEVEL_BAR_OFFSET_HIGH string = C.GTK_LEVEL_BAR_OFFSET_HIGH +) + +func marshalLevelBarMode(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return LevelBarMode(c), nil +} + +/* + * GtkLevelBar + */ + +type LevelBar struct { + Widget +} + +// native returns a pointer to the underlying GtkLevelBar. +func (v *LevelBar) native() *C.GtkLevelBar { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkLevelBar(p) +} + +func marshalLevelBar(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapLevelBar(obj), nil +} + +func wrapLevelBar(obj *glib.Object) *LevelBar { + if obj == nil { + return nil + } + + return &LevelBar{Widget{glib.InitiallyUnowned{obj}}} +} + +// LevelBarNew is a wrapper around gtk_level_bar_new(). +func LevelBarNew() (*LevelBar, error) { + c := C.gtk_level_bar_new() + if c == nil { + return nil, nilPtrErr + } + return wrapLevelBar(glib.Take(unsafe.Pointer(c))), nil +} + +// LevelBarNewForInterval is a wrapper around gtk_level_bar_new_for_interval(). +func LevelBarNewForInterval(min_value, max_value float64) (*LevelBar, error) { + c := C.gtk_level_bar_new_for_interval(C.gdouble(min_value), C.gdouble(max_value)) + if c == nil { + return nil, nilPtrErr + } + return wrapLevelBar(glib.Take(unsafe.Pointer(c))), nil +} + +// SetMode is a wrapper around gtk_level_bar_set_mode(). +func (v *LevelBar) SetMode(m LevelBarMode) { + C.gtk_level_bar_set_mode(v.native(), C.GtkLevelBarMode(m)) +} + +// GetMode is a wrapper around gtk_level_bar_get_mode(). +func (v *LevelBar) GetMode() LevelBarMode { + return LevelBarMode(C.gtk_level_bar_get_mode(v.native())) +} + +// SetValue is a wrapper around gtk_level_bar_set_value(). +func (v *LevelBar) SetValue(value float64) { + C.gtk_level_bar_set_value(v.native(), C.gdouble(value)) +} + +// GetValue is a wrapper around gtk_level_bar_get_value(). +func (v *LevelBar) GetValue() float64 { + c := C.gtk_level_bar_get_value(v.native()) + return float64(c) +} + +// SetMinValue is a wrapper around gtk_level_bar_set_min_value(). +func (v *LevelBar) SetMinValue(value float64) { + C.gtk_level_bar_set_min_value(v.native(), C.gdouble(value)) +} + +// GetMinValue is a wrapper around gtk_level_bar_get_min_value(). +func (v *LevelBar) GetMinValue() float64 { + c := C.gtk_level_bar_get_min_value(v.native()) + return float64(c) +} + +// SetMaxValue is a wrapper around gtk_level_bar_set_max_value(). +func (v *LevelBar) SetMaxValue(value float64) { + C.gtk_level_bar_set_max_value(v.native(), C.gdouble(value)) +} + +// GetMaxValue is a wrapper around gtk_level_bar_get_max_value(). +func (v *LevelBar) GetMaxValue() float64 { + c := C.gtk_level_bar_get_max_value(v.native()) + return float64(c) +} + +// AddOffsetValue is a wrapper around gtk_level_bar_add_offset_value(). +func (v *LevelBar) AddOffsetValue(name string, value float64) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_level_bar_add_offset_value(v.native(), (*C.gchar)(cstr), C.gdouble(value)) +} + +// RemoveOffsetValue is a wrapper around gtk_level_bar_remove_offset_value(). +func (v *LevelBar) RemoveOffsetValue(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_level_bar_remove_offset_value(v.native(), (*C.gchar)(cstr)) +} + +// GetOffsetValue is a wrapper around gtk_level_bar_get_offset_value(). +func (v *LevelBar) GetOffsetValue(name string) (float64, bool) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + var value C.gdouble + c := C.gtk_level_bar_get_offset_value(v.native(), (*C.gchar)(cstr), &value) + return float64(value), gobool(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/level_bar_since_3_20.go b/vendor/github.com/gotk3/gotk3/gtk/level_bar_since_3_20.go new file mode 100644 index 0000000..c70ff2d --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/level_bar_since_3_20.go @@ -0,0 +1,15 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16,!gtk_3_18 + +package gtk + +// #include +// #include "gtk.go.h" +import "C" + +/* + * Constants + */ + +const ( + LEVEL_BAR_OFFSET_FULL string = C.GTK_LEVEL_BAR_OFFSET_FULL +) diff --git a/vendor/github.com/gotk3/gotk3/gtk/level_bar_since_3_8.go b/vendor/github.com/gotk3/gotk3/gtk/level_bar_since_3_8.go new file mode 100644 index 0000000..8df8f29 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/level_bar_since_3_8.go @@ -0,0 +1,18 @@ +// +build !gtk_3_6 + +package gtk + +// #include +// #include "gtk.go.h" +import "C" + +// SetInverted() is a wrapper around gtk_level_bar_set_inverted(). +func (v *LevelBar) SetInverted(inverted bool) { + C.gtk_level_bar_set_inverted(v.native(), gbool(inverted)) +} + +// GetInverted() is a wrapper around gtk_level_bar_get_inverted(). +func (v *LevelBar) GetInverted() bool { + c := C.gtk_level_bar_get_inverted(v.native()) + return gobool(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/menu.go b/vendor/github.com/gotk3/gotk3/gtk/menu.go new file mode 100644 index 0000000..43d5e3e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/menu.go @@ -0,0 +1,172 @@ +// Same copyright and license as the rest of the files in this project +// This file contains accelerator related functions and structures + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" + + "github.com/gotk3/gotk3/glib" +) + +/* + * GtkMenu + */ + +// Menu is a representation of GTK's GtkMenu. +type Menu struct { + MenuShell +} + +// IMenu is an interface type implemented by all structs embedding +// a Menu. It is meant to be used as an argument type for wrapper +// functions that wrap around a C GTK function taking a +// GtkMenu. +type IMenu interface { + toMenu() *C.GtkMenu + toWidget() *C.GtkWidget +} + +// native() returns a pointer to the underlying GtkMenu. +func (v *Menu) native() *C.GtkMenu { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkMenu(p) +} + +func (v *Menu) toMenu() *C.GtkMenu { + if v == nil { + return nil + } + return v.native() +} + +func marshalMenu(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapMenu(obj), nil +} + +func wrapMenu(obj *glib.Object) *Menu { + if obj == nil { + return nil + } + + return &Menu{MenuShell{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// MenuNew() is a wrapper around gtk_menu_new(). +func MenuNew() (*Menu, error) { + c := C.gtk_menu_new() + if c == nil { + return nil, nilPtrErr + } + return wrapMenu(glib.Take(unsafe.Pointer(c))), nil +} + +// GtkMenuNewFromModel is a wrapper around gtk_menu_new_from_model(). +func GtkMenuNewFromModel(model *glib.MenuModel) (*Menu, error) { + c := C.gtk_menu_new_from_model(C.toGMenuModel(unsafe.Pointer(model.Native()))) + if c == nil { + return nil, nilPtrErr + } + return wrapMenu(glib.Take(unsafe.Pointer(c))), nil +} + +// SetScreen is a wrapper around gtk_menu_set_screen(). +func (v *Menu) SetScreen(screen *gdk.Screen) { + C.gtk_menu_set_screen(v.native(), (*C.GdkScreen)(unsafe.Pointer(screen.Native()))) +} + +// Attach is a wrapper around gtk_menu_attach(). +func (v *Menu) Attach(child IWidget, l, r, t, b uint) { + C.gtk_menu_attach( + v.native(), + child.toWidget(), + C.guint(l), + C.guint(r), + C.guint(t), + C.guint(b)) +} + +// SetMonitor() is a wrapper around gtk_menu_set_monitor(). +func (v *Menu) SetMonitor(monitor_num int) { + C.gtk_menu_set_monitor(v.native(), C.gint(monitor_num)) +} + +// GetMonitor() is a wrapper around gtk_menu_get_monitor(). +func (v *Menu) GetMonitor() int { + return int(C.gtk_menu_get_monitor(v.native())) +} + +// ReorderChild() is a wrapper around gtk_menu_reorder_child(). +func (v *Menu) ReorderChild(child IWidget, position int) { + C.gtk_menu_reorder_child(v.native(), child.toWidget(), C.gint(position)) +} + +// SetReserveToggleSize() is a wrapper around gtk_menu_set_reserve_toggle_size(). +func (v *Menu) SetReserveToggleSize(reserve bool) { + C.gtk_menu_set_reserve_toggle_size(v.native(), gbool(reserve)) +} + +// GetReserveToggleSize() is a wrapper around gtk_menu_get_reserve_toggle_size(). +func (v *Menu) GetReserveToggleSize() bool { + return gobool(C.gtk_menu_get_reserve_toggle_size(v.native())) +} + +// Popdown() is a wrapper around gtk_menu_popdown(). +func (v *Menu) Popdown() { + C.gtk_menu_popdown(v.native()) +} + +// TODO +/* +gtk_menu_reposition () require 'GtkMenuPositionFunc' (according to its position function.) +*/ + +// GetActive() is a wrapper around gtk_menu_get_active(). +func (v *Menu) GetActive() (*Menu, error) { + c := C.gtk_menu_get_active(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapMenu(glib.Take(unsafe.Pointer(c))), nil +} + +// SetActive() is a wrapper around gtk_menu_set_active(). +func (v *Menu) SetActive(index uint) { + C.gtk_menu_set_active(v.native(), C.guint(index)) +} + +// TODO +/* +void +gtk_menu_attach_to_widget (GtkMenu *menu, + GtkWidget *attach_widget, + GtkMenuDetachFunc detacher); + +void +gtk_menu_detach (GtkMenu *menu); +*/ + +// GetAttachWidget() is a wrapper around gtk_menu_get_attach_widget(). +func (v *Menu) GetAttachWidget() (IWidget, error) { + c := C.gtk_menu_get_attach_widget(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castWidget(c) +} + +// TODO +/* +GList * +gtk_menu_get_for_attach_widget (GtkWidget *widget); +*/ diff --git a/vendor/github.com/gotk3/gotk3/gtk/menu_before_3_22.go b/vendor/github.com/gotk3/gotk3/gtk/menu_before_3_22.go new file mode 100644 index 0000000..5f138a0 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/menu_before_3_22.go @@ -0,0 +1,19 @@ +// +build gtk_3_6 gtk_3_8 gtk_3_10 gtk_3_12 gtk_3_14 gtk_3_16 gtk_3_18 gtk_3_20 + +package gtk + +// #include +// #include +import "C" +import "github.com/gotk3/gotk3/gdk" + +// PopupAtPointer() is a wrapper for gtk_menu_popup_at_pointer(), on older versions it uses PopupAtMouseCursor +func (v *Menu) PopupAtPointer(_ *gdk.Event) { + C.gtk_menu_popup(v.native(), + nil, + nil, + nil, + nil, + C.guint(0), + C.gtk_get_current_event_time()) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/menu_shell.go b/vendor/github.com/gotk3/gotk3/gtk/menu_shell.go new file mode 100644 index 0000000..9595a09 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/menu_shell.go @@ -0,0 +1,157 @@ +// Same copyright and license as the rest of the files in this project +// This file contains accelerator related functions and structures + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_menu_direction_type_get_type()), marshalMenuDirectionType}, + } + + glib.RegisterGValueMarshalers(tm) +} + +// MenuDirectionType is a representation of GTK's GtkMenuDirectionType. +type MenuDirectionType int + +const ( + MENU_DIR_PARENT MenuDirectionType = C.GTK_MENU_DIR_PARENT + MENU_DIR_CHILD MenuDirectionType = C.GTK_MENU_DIR_CHILD + MENU_DIR_NEXT MenuDirectionType = C.GTK_MENU_DIR_NEXT + MENU_DIR_PREV MenuDirectionType = C.GTK_MENU_DIR_PREV +) + +func marshalMenuDirectionType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return MenuDirectionType(c), nil +} + +/* + * GtkMenuShell + */ + +// MenuShell is a representation of GTK's GtkMenuShell. +type MenuShell struct { + Container +} + +// native returns a pointer to the underlying GtkMenuShell. +func (v *MenuShell) native() *C.GtkMenuShell { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkMenuShell(p) +} + +func marshalMenuShell(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapMenuShell(obj), nil +} + +func wrapMenuShell(obj *glib.Object) *MenuShell { + if obj == nil { + return nil + } + + return &MenuShell{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// Append is a wrapper around gtk_menu_shell_append(). +func (v *MenuShell) Append(child IMenuItem) { + C.gtk_menu_shell_append(v.native(), child.toWidget()) +} + +// Prepend is a wrapper around gtk_menu_shell_prepend(). +func (v *MenuShell) Prepend(child IMenuItem) { + C.gtk_menu_shell_prepend(v.native(), child.toWidget()) +} + +// Insert is a wrapper around gtk_menu_shell_insert(). +func (v *MenuShell) Insert(child IMenuItem, position int) { + C.gtk_menu_shell_insert(v.native(), child.toWidget(), C.gint(position)) +} + +// Deactivate is a wrapper around gtk_menu_shell_deactivate(). +func (v *MenuShell) Deactivate() { + C.gtk_menu_shell_deactivate(v.native()) +} + +// SelectItem is a wrapper around gtk_menu_shell_select_item(). +func (v *MenuShell) SelectItem(child IMenuItem) { + C.gtk_menu_shell_select_item(v.native(), child.toWidget()) +} + +// SelectFirst is a wrapper around gtk_menu_shell_select_first(). +func (v *MenuShell) SelectFirst(searchSensitive bool) { + C.gtk_menu_shell_select_first(v.native(), gbool(searchSensitive)) +} + +// Deselect is a wrapper around gtk_menu_shell_deselect(). +func (v *MenuShell) Deselect() { + C.gtk_menu_shell_deselect(v.native()) +} + +// ActivateItem is a wrapper around gtk_menu_shell_activate_item(). +func (v *MenuShell) ActivateItem(child IMenuItem, forceDeactivate bool) { + C.gtk_menu_shell_activate_item(v.native(), child.toWidget(), gbool(forceDeactivate)) +} + +// Cancel is a wrapper around gtk_menu_shell_cancel(). +func (v *MenuShell) Cancel() { + C.gtk_menu_shell_cancel(v.native()) +} + +// SetTakeFocus is a wrapper around gtk_menu_shell_set_take_focus(). +func (v *MenuShell) SetTakeFocus(takeFocus bool) { + C.gtk_menu_shell_set_take_focus(v.native(), gbool(takeFocus)) +} + +// GetTakeFocus is a wrapper around gtk_menu_shell_get_take_focus(). +func (v *MenuShell) GetTakeFocus() bool { + return gobool(C.gtk_menu_shell_get_take_focus(v.native())) +} + +// GetSelectedItem is a wrapper around gtk_menu_shell_get_selected_item(). +func (v *MenuShell) GetSelectedItem() (IMenuItem, error) { + c := C.gtk_menu_shell_get_selected_item(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapMenuItem(obj), nil +} + +// GetParentShell is a wrapper around gtk_menu_shell_get_parent_shell(). +func (v *MenuShell) GetParentShell() (*MenuShell, error) { + c := C.gtk_menu_shell_get_parent_shell(v.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapMenuShell(obj), nil +} + +// BindModel is a wrapper around gtk_menu_shell_bind_model(). +func (v *MenuShell) BindModel(model *glib.MenuModel, + action_namespace string, with_separators bool) { + + cstr := C.CString(action_namespace) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_menu_shell_bind_model( + v.native(), + (*C.GMenuModel)(unsafe.Pointer(model.Native())), + cstr, + gbool(with_separators)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/menu_since_3_22.go b/vendor/github.com/gotk3/gotk3/gtk/menu_since_3_22.go new file mode 100644 index 0000000..5ac626c --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/menu_since_3_22.go @@ -0,0 +1,45 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16,!gtk_3_18,!gtk_3_20 + +package gtk + +// #include +// #include +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" +) + +// PopupAtRect is a wrapper around gtk_menu_popup_at_rect(). +func (v *Menu) PopupAtRect(rect_window *gdk.Window, + rect *gdk.Rectangle, rect_anchor, menu_anchor gdk.Gravity, + trigger_event *gdk.Event) { + + C.gtk_menu_popup_at_rect( + v.native(), + (*C.GdkWindow)(unsafe.Pointer(rect_window.Native())), + (*C.GdkRectangle)(unsafe.Pointer(&rect.GdkRectangle)), + C.GdkGravity(rect_anchor), + C.GdkGravity(menu_anchor), + (*C.GdkEvent)(unsafe.Pointer(trigger_event.Native()))) +} + +// PopupAtWidget() is a wrapper for gtk_menu_popup_at_widget() +func (v *Menu) PopupAtWidget(widget IWidget, widgetAnchor gdk.Gravity, menuAnchor gdk.Gravity, triggerEvent *gdk.Event) { + e := (*C.GdkEvent)(unsafe.Pointer(triggerEvent.Native())) + C.gtk_menu_popup_at_widget(v.native(), widget.toWidget(), C.GdkGravity(widgetAnchor), C.GdkGravity(menuAnchor), e) +} + +// PopupAtPointer() is a wrapper for gtk_menu_popup_at_pointer(), on older versions it uses PopupAtMouseCursor +func (v *Menu) PopupAtPointer(triggerEvent *gdk.Event) { + e := (*C.GdkEvent)(unsafe.Pointer(triggerEvent.Native())) + C.gtk_menu_popup_at_pointer(v.native(), e) +} + +// PlaceOnMonitor() is a wrapper around gtk_menu_place_on_monitor(). +func (v *Menu) PlaceOnMonitor(monitor *gdk.Monitor) { + C.gtk_menu_place_on_monitor( + v.native(), + (*C.GdkMonitor)(unsafe.Pointer(monitor.Native()))) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/print.go b/vendor/github.com/gotk3/gotk3/gtk/print.go new file mode 100644 index 0000000..e65d04c --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/print.go @@ -0,0 +1,1596 @@ +package gtk + +// #include +// #include "gtk.go.h" +// #include "print.go.h" +import "C" +import ( + "errors" + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/cairo" + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/internal/callback" + "github.com/gotk3/gotk3/pango" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.gtk_page_orientation_get_type()), marshalPageOrientation}, + {glib.Type(C.gtk_print_error_get_type()), marshalPrintError}, + {glib.Type(C.gtk_print_operation_action_get_type()), marshalPrintOperationAction}, + {glib.Type(C.gtk_print_operation_result_get_type()), marshalPrintOperationResult}, + {glib.Type(C.gtk_print_status_get_type()), marshalPrintStatus}, + {glib.Type(C.gtk_unit_get_type()), marshalUnit}, + + // Objects/Interfaces + {glib.Type(C.gtk_number_up_layout_get_type()), marshalNumberUpLayout}, + {glib.Type(C.gtk_page_orientation_get_type()), marshalPageOrientation}, + {glib.Type(C.gtk_page_set_get_type()), marshalPageSet}, + {glib.Type(C.gtk_page_setup_get_type()), marshalPageSetup}, + {glib.Type(C.gtk_print_context_get_type()), marshalPrintContext}, + {glib.Type(C.gtk_print_duplex_get_type()), marshalPrintDuplex}, + {glib.Type(C.gtk_print_operation_get_type()), marshalPrintOperation}, + {glib.Type(C.gtk_print_operation_preview_get_type()), marshalPrintOperationPreview}, + {glib.Type(C.gtk_print_pages_get_type()), marshalPrintPages}, + {glib.Type(C.gtk_print_quality_get_type()), marshalPrintQuality}, + {glib.Type(C.gtk_print_settings_get_type()), marshalPrintSettings}, + + // Boxed + {glib.Type(C.gtk_paper_size_get_type()), marshalPaperSize}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkPageSetup"] = wrapPageSetup + WrapMap["GtkPrintContext"] = wrapPrintContext + WrapMap["GtkPrintOperation"] = wrapPrintOperation + WrapMap["GtkPrintOperationPreview"] = wrapPrintOperationPreview + WrapMap["GtkPrintSettings"] = wrapPrintSettings +} + +/* + * Constants + */ + +// NumberUpLayout is a representation of GTK's GtkNumberUpLayout. +type NumberUpLayout int + +const ( + NUMBER_UP_LAYOUT_LEFT_TO_RIGHT_TOP_TO_BOTTOM NumberUpLayout = C.GTK_NUMBER_UP_LAYOUT_LEFT_TO_RIGHT_TOP_TO_BOTTOM + NUMBER_UP_LAYOUT_LEFT_TO_RIGHT_BOTTOM_TO_TOP NumberUpLayout = C.GTK_NUMBER_UP_LAYOUT_LEFT_TO_RIGHT_BOTTOM_TO_TOP + NUMBER_UP_LAYOUT_RIGHT_TO_LEFT_TOP_TO_BOTTOM NumberUpLayout = C.GTK_NUMBER_UP_LAYOUT_RIGHT_TO_LEFT_TOP_TO_BOTTOM + NUMBER_UP_LAYOUT_RIGHT_TO_LEFT_BOTTOM_TO_TOP NumberUpLayout = C.GTK_NUMBER_UP_LAYOUT_RIGHT_TO_LEFT_BOTTOM_TO_TOP + NUMBER_UP_LAYOUT_TOP_TO_BOTTOM_LEFT_TO_RIGHT NumberUpLayout = C.GTK_NUMBER_UP_LAYOUT_TOP_TO_BOTTOM_LEFT_TO_RIGHT + NUMBER_UP_LAYOUT_TOP_TO_BOTTOM_RIGHT_TO_LEFT NumberUpLayout = C.GTK_NUMBER_UP_LAYOUT_TOP_TO_BOTTOM_RIGHT_TO_LEFT + NUMBER_UP_LAYOUT_BOTTOM_TO_TOP_LEFT_TO_RIGHT NumberUpLayout = C.GTK_NUMBER_UP_LAYOUT_BOTTOM_TO_TOP_LEFT_TO_RIGHT + NUMBER_UP_LAYOUT_BOTTOM_TO_TOP_RIGHT_TO_LEFT NumberUpLayout = C.GTK_NUMBER_UP_LAYOUT_BOTTOM_TO_TOP_RIGHT_TO_LEFT +) + +func marshalNumberUpLayout(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return NumberUpLayout(c), nil +} + +// PageOrientation is a representation of GTK's GtkPageOrientation. +type PageOrientation int + +const ( + PAGE_ORIENTATION_PORTRAIT PageOrientation = C.GTK_PAGE_ORIENTATION_PORTRAIT + PAGE_ORIENTATION_LANDSCAPE PageOrientation = C.GTK_PAGE_ORIENTATION_LANDSCAPE + PAGE_ORIENTATION_REVERSE_PORTRAIT PageOrientation = C.GTK_PAGE_ORIENTATION_REVERSE_PORTRAIT + PAGE_ORIENTATION_REVERSE_LANDSCAPE PageOrientation = C.GTK_PAGE_ORIENTATION_REVERSE_LANDSCAPE +) + +func marshalPageOrientation(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PageOrientation(c), nil +} + +// PrintDuplex is a representation of GTK's GtkPrintDuplex. +type PrintDuplex int + +const ( + PRINT_DUPLEX_SIMPLEX PrintDuplex = C.GTK_PRINT_DUPLEX_SIMPLEX + PRINT_DUPLEX_HORIZONTAL PrintDuplex = C.GTK_PRINT_DUPLEX_HORIZONTAL + PRINT_DUPLEX_VERTICAL PrintDuplex = C.GTK_PRINT_DUPLEX_VERTICAL +) + +func marshalPrintDuplex(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PrintDuplex(c), nil +} + +// PrintPages is a representation of GTK's GtkPrintPages. +type PrintPages int + +const ( + PRINT_PAGES_ALL PrintPages = C.GTK_PRINT_PAGES_ALL + PRINT_PAGES_CURRENT PrintPages = C.GTK_PRINT_PAGES_CURRENT + PRINT_PAGES_RANGES PrintPages = C.GTK_PRINT_PAGES_RANGES + PRINT_PAGES_SELECTION PrintPages = C.GTK_PRINT_PAGES_SELECTION +) + +func marshalPrintPages(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PrintPages(c), nil +} + +// PageSet is a representation of GTK's GtkPageSet. +type PageSet int + +const ( + PAGE_SET_ALL PageSet = C.GTK_PAGE_SET_ALL + PAGE_SET_EVEN PageSet = C.GTK_PAGE_SET_EVEN + PAGE_SET_ODD PageSet = C.GTK_PAGE_SET_ODD +) + +func marshalPageSet(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PageSet(c), nil +} + +// PrintOperationAction is a representation of GTK's GtkPrintError. +type PrintError int + +const ( + PRINT_ERROR_GENERAL PrintError = C.GTK_PRINT_ERROR_GENERAL + PRINT_ERROR_INTERNAL_ERROR PrintError = C.GTK_PRINT_ERROR_INTERNAL_ERROR + PRINT_ERROR_NOMEM PrintError = C.GTK_PRINT_ERROR_NOMEM + PRINT_ERROR_INVALID_FILE PrintError = C.GTK_PRINT_ERROR_INVALID_FILE +) + +func marshalPrintError(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PrintError(c), nil +} + +// PrintOperationAction is a representation of GTK's GtkPrintOperationAction. +type PrintOperationAction int + +const ( + PRINT_OPERATION_ACTION_PRINT_DIALOG PrintOperationAction = C.GTK_PRINT_OPERATION_ACTION_PRINT_DIALOG + PRINT_OPERATION_ACTION_PRINT PrintOperationAction = C.GTK_PRINT_OPERATION_ACTION_PRINT + PRINT_OPERATION_ACTION_PREVIEW PrintOperationAction = C.GTK_PRINT_OPERATION_ACTION_PREVIEW + PRINT_OPERATION_ACTION_EXPORT PrintOperationAction = C.GTK_PRINT_OPERATION_ACTION_EXPORT +) + +func marshalPrintOperationAction(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PrintOperationAction(c), nil +} + +// PrintOperationResult is a representation of GTK's GtkPrintOperationResult. +type PrintOperationResult int + +const ( + PRINT_OPERATION_RESULT_ERROR PrintOperationResult = C.GTK_PRINT_OPERATION_RESULT_ERROR + PRINT_OPERATION_RESULT_APPLY PrintOperationResult = C.GTK_PRINT_OPERATION_RESULT_APPLY + PRINT_OPERATION_RESULT_CANCEL PrintOperationResult = C.GTK_PRINT_OPERATION_RESULT_CANCEL + PRINT_OPERATION_RESULT_IN_PROGRESS PrintOperationResult = C.GTK_PRINT_OPERATION_RESULT_IN_PROGRESS +) + +func marshalPrintOperationResult(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PrintOperationResult(c), nil +} + +// PrintStatus is a representation of GTK's GtkPrintStatus. +type PrintStatus int + +const ( + PRINT_STATUS_INITIAL PrintStatus = C.GTK_PRINT_STATUS_INITIAL + PRINT_STATUS_PREPARING PrintStatus = C.GTK_PRINT_STATUS_PREPARING + PRINT_STATUS_GENERATING_DATA PrintStatus = C.GTK_PRINT_STATUS_GENERATING_DATA + PRINT_STATUS_SENDING_DATA PrintStatus = C.GTK_PRINT_STATUS_SENDING_DATA + PRINT_STATUS_PENDING PrintStatus = C.GTK_PRINT_STATUS_PENDING + PRINT_STATUS_PENDING_ISSUE PrintStatus = C.GTK_PRINT_STATUS_PENDING_ISSUE + PRINT_STATUS_PRINTING PrintStatus = C.GTK_PRINT_STATUS_PRINTING + PRINT_STATUS_FINISHED PrintStatus = C.GTK_PRINT_STATUS_FINISHED + PRINT_STATUS_FINISHED_ABORTED PrintStatus = C.GTK_PRINT_STATUS_FINISHED_ABORTED +) + +func marshalPrintStatus(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PrintStatus(c), nil +} + +// PrintQuality is a representation of GTK's GtkPrintQuality. +type PrintQuality int + +const ( + PRINT_QUALITY_LOW PrintQuality = C.GTK_PRINT_QUALITY_LOW + PRINT_QUALITY_NORMAL PrintQuality = C.GTK_PRINT_QUALITY_NORMAL + PRINT_QUALITY_HIGH PrintQuality = C.GTK_PRINT_QUALITY_HIGH + PRINT_QUALITY_DRAFT PrintQuality = C.GTK_PRINT_QUALITY_DRAFT +) + +func marshalPrintQuality(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return PrintQuality(c), nil +} + +// Unit is a representation of GTK's GtkUnit. +type Unit int + +const ( + GTK_UNIT_NONE Unit = C.GTK_UNIT_NONE + GTK_UNIT_POINTS Unit = C.GTK_UNIT_POINTS + GTK_UNIT_INCH Unit = C.GTK_UNIT_INCH + GTK_UNIT_MM Unit = C.GTK_UNIT_MM +) + +func marshalUnit(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Unit(c), nil +} + +/* + * GtkPageSetup + */ +type PageSetup struct { + *glib.Object +} + +func (ps *PageSetup) native() *C.GtkPageSetup { + if ps == nil || ps.GObject == nil { + return nil + } + p := unsafe.Pointer(ps.GObject) + return C.toGtkPageSetup(p) +} + +func marshalPageSetup(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapPageSetup(obj), nil +} + +func wrapPageSetup(obj *glib.Object) *PageSetup { + if obj == nil { + return nil + } + + return &PageSetup{obj} +} + +// PageSetupNew() is a wrapper around gtk_page_setup_new(). +func PageSetupNew() (*PageSetup, error) { + c := C.gtk_page_setup_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapPageSetup(obj), nil +} + +// Copy() is a wrapper around gtk_page_setup_copy(). +func (ps *PageSetup) Copy() (*PageSetup, error) { + c := C.gtk_page_setup_copy(ps.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapPageSetup(obj), nil +} + +// GetOrientation() is a wrapper around gtk_page_setup_get_orientation(). +func (ps *PageSetup) GetOrientation() PageOrientation { + c := C.gtk_page_setup_get_orientation(ps.native()) + return PageOrientation(c) +} + +// SetOrientation() is a wrapper around gtk_page_setup_set_orientation(). +func (ps *PageSetup) SetOrientation(orientation PageOrientation) { + C.gtk_page_setup_set_orientation(ps.native(), C.GtkPageOrientation(orientation)) +} + +// GetPaperSize() is a wrapper around gtk_page_setup_get_paper_size(). +func (ps *PageSetup) GetPaperSize() *PaperSize { + c := C.gtk_page_setup_get_paper_size(ps.native()) + p := &PaperSize{c} + runtime.SetFinalizer(p, (*PaperSize).free) + return p +} + +// SetPaperSize() is a wrapper around gtk_page_setup_set_paper_size(). +func (ps *PageSetup) SetPaperSize(size *PaperSize) { + C.gtk_page_setup_set_paper_size(ps.native(), size.native()) +} + +// GetTopMargin() is a wrapper around gtk_page_setup_get_top_margin(). +func (ps *PageSetup) GetTopMargin(unit Unit) float64 { + c := C.gtk_page_setup_get_top_margin(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// SetTopMargin() is a wrapper around gtk_page_setup_set_top_margin(). +func (ps *PageSetup) SetTopMargin(margin float64, unit Unit) { + C.gtk_page_setup_set_top_margin(ps.native(), C.gdouble(margin), C.GtkUnit(unit)) +} + +// GetBottomMargin() is a wrapper around gtk_page_setup_get_bottom_margin(). +func (ps *PageSetup) GetBottomMargin(unit Unit) float64 { + c := C.gtk_page_setup_get_bottom_margin(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// SetBottomMargin() is a wrapper around gtk_page_setup_set_bottom_margin(). +func (ps *PageSetup) SetBottomMargin(margin float64, unit Unit) { + C.gtk_page_setup_set_bottom_margin(ps.native(), C.gdouble(margin), C.GtkUnit(unit)) +} + +// GetLeftMargin() is a wrapper around gtk_page_setup_get_left_margin(). +func (ps *PageSetup) GetLeftMargin(unit Unit) float64 { + c := C.gtk_page_setup_get_left_margin(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// SetLeftMargin() is a wrapper around gtk_page_setup_set_left_margin(). +func (ps *PageSetup) SetLeftMargin(margin float64, unit Unit) { + C.gtk_page_setup_set_left_margin(ps.native(), C.gdouble(margin), C.GtkUnit(unit)) +} + +// GetRightMargin() is a wrapper around gtk_page_setup_get_right_margin(). +func (ps *PageSetup) GetRightMargin(unit Unit) float64 { + c := C.gtk_page_setup_get_right_margin(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// SetRightMargin() is a wrapper around gtk_page_setup_set_right_margin(). +func (ps *PageSetup) SetRightMargin(margin float64, unit Unit) { + C.gtk_page_setup_set_right_margin(ps.native(), C.gdouble(margin), C.GtkUnit(unit)) +} + +// SetPaperSizeAndDefaultMargins() is a wrapper around gtk_page_setup_set_paper_size_and_default_margins(). +func (ps *PageSetup) SetPaperSizeAndDefaultMargins(size *PaperSize) { + C.gtk_page_setup_set_paper_size_and_default_margins(ps.native(), size.native()) +} + +// GetPaperWidth() is a wrapper around gtk_page_setup_get_paper_width(). +func (ps *PageSetup) GetPaperWidth(unit Unit) float64 { + c := C.gtk_page_setup_get_paper_width(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// GetPaperHeight() is a wrapper around gtk_page_setup_get_paper_height(). +func (ps *PageSetup) GetPaperHeight(unit Unit) float64 { + c := C.gtk_page_setup_get_paper_height(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// GetPageWidth() is a wrapper around gtk_page_setup_get_page_width(). +func (ps *PageSetup) GetPageWidth(unit Unit) float64 { + c := C.gtk_page_setup_get_page_width(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// GetPageHeight() is a wrapper around gtk_page_setup_get_page_height(). +func (ps *PageSetup) GetPageHeight(unit Unit) float64 { + c := C.gtk_page_setup_get_page_height(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// PageSetupNewFromFile() is a wrapper around gtk_page_setup_new_from_file(). +func PageSetupNewFromFile(fileName string) (*PageSetup, error) { + cstr := C.CString(fileName) + defer C.free(unsafe.Pointer(cstr)) + var err *C.GError = nil + c := C.gtk_page_setup_new_from_file((*C.gchar)(cstr), &err) + if c == nil { + defer C.g_error_free(err) + return nil, errors.New(C.GoString((*C.char)(err.message))) + } + obj := glib.Take(unsafe.Pointer(c)) + return &PageSetup{obj}, nil + +} + +// PageSetupNewFromKeyFile() is a wrapper around gtk_page_setup_new_from_key_file(). + +// PageSetupLoadFile() is a wrapper around gtk_page_setup_load_file(). +func (ps *PageSetup) PageSetupLoadFile(name string) error { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + var err *C.GError = nil + res := C.gtk_page_setup_load_file(ps.native(), cstr, &err) + if !gobool(res) { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// PageSetupLoadKeyFile() is a wrapper around gtk_page_setup_load_key_file(). + +// PageSetupToFile() is a wrapper around gtk_page_setup_to_file(). +func (ps *PageSetup) PageSetupToFile(name string) error { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + var err *C.GError = nil + res := C.gtk_page_setup_to_file(ps.native(), cstr, &err) + if !gobool(res) { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// PageSetupToKeyFile() is a wrapper around gtk_page_setup_to_key_file(). + +/* + * GtkPaperSize + */ + +// PaperSize is a representation of GTK's GtkPaperSize +type PaperSize struct { + GtkPaperSize *C.GtkPaperSize +} + +// native returns a pointer to the underlying GtkPaperSize. +func (ps *PaperSize) native() *C.GtkPaperSize { + if ps == nil { + return nil + } + return ps.GtkPaperSize +} + +func marshalPaperSize(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + return &PaperSize{(*C.GtkPaperSize)(unsafe.Pointer(c))}, nil +} + +const ( + UNIT_PIXEL int = C.GTK_UNIT_PIXEL + PAPER_NAME_A3 string = C.GTK_PAPER_NAME_A3 + PAPER_NAME_A4 string = C.GTK_PAPER_NAME_A4 + PAPER_NAME_A5 string = C.GTK_PAPER_NAME_A5 + PAPER_NAME_B5 string = C.GTK_PAPER_NAME_B5 + PAPER_NAME_LETTER string = C.GTK_PAPER_NAME_LETTER + PAPER_NAME_EXECUTIVE string = C.GTK_PAPER_NAME_EXECUTIVE + PAPER_NAME_LEGAL string = C.GTK_PAPER_NAME_LEGAL +) + +// PaperSizeNew() is a wrapper around gtk_paper_size_new(). +func PaperSizeNew(name string) (*PaperSize, error) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + var gName *C.gchar + + if name == "" { + gName = nil + } else { + gName = (*C.gchar)(cstr) + } + + c := C.gtk_paper_size_new(gName) + if c == nil { + return nil, nilPtrErr + } + + t := &PaperSize{c} + runtime.SetFinalizer(t, (*PaperSize).free) + return t, nil +} + +// PaperSizeNewFromPPD() is a wrapper around gtk_paper_size_new_from_ppd(). +func PaperSizeNewFromPPD(name, displayName string, width, height float64) (*PaperSize, error) { + cName := C.CString(name) + defer C.free(unsafe.Pointer(cName)) + cDisplayName := C.CString(displayName) + defer C.free(unsafe.Pointer(cDisplayName)) + c := C.gtk_paper_size_new_from_ppd((*C.gchar)(cName), (*C.gchar)(cDisplayName), + C.gdouble(width), C.gdouble(height)) + if c == nil { + return nil, nilPtrErr + } + t := &PaperSize{c} + runtime.SetFinalizer(t, (*PaperSize).free) + return t, nil +} + +// PaperSizeNewCustom() is a wrapper around gtk_paper_size_new_custom(). +func PaperSizeNewCustom(name, displayName string, width, height float64, unit Unit) (*PaperSize, error) { + cName := C.CString(name) + defer C.free(unsafe.Pointer(cName)) + cDisplayName := C.CString(displayName) + defer C.free(unsafe.Pointer(cDisplayName)) + c := C.gtk_paper_size_new_custom((*C.gchar)(cName), (*C.gchar)(cDisplayName), + C.gdouble(width), C.gdouble(height), C.GtkUnit(unit)) + if c == nil { + return nil, nilPtrErr + } + t := &PaperSize{c} + runtime.SetFinalizer(t, (*PaperSize).free) + return t, nil +} + +// Copy() is a wrapper around gtk_paper_size_copy(). +func (ps *PaperSize) Copy() (*PaperSize, error) { + c := C.gtk_paper_size_copy(ps.native()) + if c == nil { + return nil, nilPtrErr + } + t := &PaperSize{c} + runtime.SetFinalizer(t, (*PaperSize).free) + return t, nil +} + +// free() is a wrapper around gtk_paper_size_free(). +func (ps *PaperSize) free() { + C.gtk_paper_size_free(ps.native()) +} + +// IsEqual() is a wrapper around gtk_paper_size_is_equal(). +func (ps *PaperSize) IsEqual(other *PaperSize) bool { + c := C.gtk_paper_size_is_equal(ps.native(), other.native()) + return gobool(c) +} + +// PaperSizeGetPaperSizes() is a wrapper around gtk_paper_size_get_paper_sizes(). +func PaperSizeGetPaperSizes(includeCustom bool) *glib.List { + clist := C.gtk_paper_size_get_paper_sizes(gbool(includeCustom)) + if clist == nil { + return nil + } + + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return &PaperSize{(*C.GtkPaperSize)(ptr)} + }) + + runtime.SetFinalizer(glist, func(glist *glib.List) { + glist.FreeFull(func(item interface{}) { + ps := item.(*PaperSize) + C.gtk_paper_size_free(ps.GtkPaperSize) + }) + }) + + return glist +} + +// GetName() is a wrapper around gtk_paper_size_get_name(). +func (ps *PaperSize) GetName() string { + c := C.gtk_paper_size_get_name(ps.native()) + return C.GoString((*C.char)(c)) +} + +// GetDisplayName() is a wrapper around gtk_paper_size_get_display_name(). +func (ps *PaperSize) GetDisplayName() string { + c := C.gtk_paper_size_get_display_name(ps.native()) + return C.GoString((*C.char)(c)) +} + +// GetPPDName() is a wrapper around gtk_paper_size_get_ppd_name(). +func (ps *PaperSize) GetPPDName() (string, error) { + c := C.gtk_paper_size_get_ppd_name(ps.native()) + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +// GetWidth() is a wrapper around gtk_paper_size_get_width(). +func (ps *PaperSize) GetWidth(unit Unit) float64 { + c := C.gtk_paper_size_get_width(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// GetHeight() is a wrapper around gtk_paper_size_get_height(). +func (ps *PaperSize) GetHeight(unit Unit) float64 { + c := C.gtk_paper_size_get_width(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// IsCustom() is a wrapper around gtk_paper_size_is_custom(). +func (ps *PaperSize) IsCustom() bool { + c := C.gtk_paper_size_is_custom(ps.native()) + return gobool(c) +} + +// SetSize() is a wrapper around gtk_paper_size_set_size(). +func (ps *PaperSize) SetSize(width, height float64, unit Unit) { + C.gtk_paper_size_set_size(ps.native(), C.gdouble(width), C.gdouble(height), C.GtkUnit(unit)) +} + +// GetDefaultTopMargin() is a wrapper around gtk_paper_size_get_default_top_margin(). +func (ps *PaperSize) GetDefaultTopMargin(unit Unit) float64 { + c := C.gtk_paper_size_get_default_top_margin(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// GetDefaultBottomMargin() is a wrapper around gtk_paper_size_get_default_bottom_margin(). +func (ps *PaperSize) GetDefaultBottomMargin(unit Unit) float64 { + c := C.gtk_paper_size_get_default_bottom_margin(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// GetDefaultLeftMargin() is a wrapper around gtk_paper_size_get_default_left_margin(). +func (ps *PaperSize) GetDefaultLeftMargin(unit Unit) float64 { + c := C.gtk_paper_size_get_default_left_margin(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// GetDefaultRightMargin() is a wrapper around gtk_paper_size_get_default_right_margin(). +func (ps *PaperSize) GetDefaultRightMargin(unit Unit) float64 { + c := C.gtk_paper_size_get_default_right_margin(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// PaperSizeGetDefault() is a wrapper around gtk_paper_size_get_default(). +func PaperSizeGetDefaultRightMargin(unit Unit) string { + c := C.gtk_paper_size_get_default() + return C.GoString((*C.char)(c)) +} + +// PaperSizeNewFromKeyFile() is a wrapper around gtk_paper_size_new_from_key_file(). +// PaperSizeToKeyFile() is a wrapper around gtk_paper_size_to_key_file(). + +/* + * GtkPrintContext + */ + +// PrintContext is a representation of GTK's GtkPrintContext. +type PrintContext struct { + *glib.Object +} + +// native() returns a pointer to the underlying GtkPrintContext. +func (pc *PrintContext) native() *C.GtkPrintContext { + if pc == nil || pc.GObject == nil { + return nil + } + p := unsafe.Pointer(pc.GObject) + return C.toGtkPrintContext(p) +} + +func marshalPrintContext(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapPrintContext(obj), nil +} + +func wrapPrintContext(obj *glib.Object) *PrintContext { + if obj == nil { + return nil + } + + return &PrintContext{obj} +} + +// GetCairoContext() is a wrapper around gtk_print_context_get_cairo_context(). +func (pc *PrintContext) GetCairoContext() *cairo.Context { + c := C.gtk_print_context_get_cairo_context(pc.native()) + return cairo.WrapContext(uintptr(unsafe.Pointer(c))) +} + +// SetCairoContext() is a wrapper around gtk_print_context_set_cairo_context(). +func (pc *PrintContext) SetCairoContext(cr *cairo.Context, dpiX, dpiY float64) { + C.gtk_print_context_set_cairo_context(pc.native(), + (*C.cairo_t)(unsafe.Pointer(cr.Native())), + C.double(dpiX), C.double(dpiY)) +} + +// GetPageSetup() is a wrapper around gtk_print_context_get_page_setup(). +func (pc *PrintContext) GetPageSetup() *PageSetup { + c := C.gtk_print_context_get_page_setup(pc.native()) + obj := glib.Take(unsafe.Pointer(c)) + return wrapPageSetup(obj) +} + +// GetWidth() is a wrapper around gtk_print_context_get_width(). +func (pc *PrintContext) GetWidth() float64 { + c := C.gtk_print_context_get_width(pc.native()) + return float64(c) +} + +// GetHeight() is a wrapper around gtk_print_context_get_height(). +func (pc *PrintContext) GetHeight() float64 { + c := C.gtk_print_context_get_height(pc.native()) + return float64(c) +} + +// GetDpiX() is a wrapper around gtk_print_context_get_dpi_x(). +func (pc *PrintContext) GetDpiX() float64 { + c := C.gtk_print_context_get_dpi_x(pc.native()) + return float64(c) +} + +// GetDpiY() is a wrapper around gtk_print_context_get_dpi_y(). +func (pc *PrintContext) GetDpiY() float64 { + c := C.gtk_print_context_get_dpi_y(pc.native()) + return float64(c) +} + +// GetPangoFontMap() is a wrapper around gtk_print_context_get_pango_fontmap(). +func (pc *PrintContext) GetPangoFontMap() *pango.FontMap { + c := C.gtk_print_context_get_pango_fontmap(pc.native()) + return pango.WrapFontMap(uintptr(unsafe.Pointer(c))) +} + +// CreatePangoContext() is a wrapper around gtk_print_context_create_pango_context(). +func (pc *PrintContext) CreatePangoContext() *pango.Context { + c := C.gtk_print_context_create_pango_context(pc.native()) + return pango.WrapContext(uintptr(unsafe.Pointer(c))) +} + +// CreatePangoLayout() is a wrapper around gtk_print_context_create_pango_layout(). +func (pc *PrintContext) CreatePangoLayout() *pango.Layout { + c := C.gtk_print_context_create_pango_layout(pc.native()) + return pango.WrapLayout(uintptr(unsafe.Pointer(c))) +} + +// GetHardMargins() is a wrapper around gtk_print_context_get_hard_margins(). +func (pc *PrintContext) GetHardMargins() (float64, float64, float64, float64, error) { + var top, bottom, left, right C.gdouble + c := C.gtk_print_context_get_hard_margins(pc.native(), &top, &bottom, &left, &right) + if gobool(c) == false { + return 0.0, 0.0, 0.0, 0.0, errors.New("unable to retrieve hard margins") + } + return float64(top), float64(bottom), float64(left), float64(right), nil +} + +/* + * GtkPrintOperation + */ +type PrintOperation struct { + *glib.Object + + // Interfaces + PrintOperationPreview +} + +func (po *PrintOperation) native() *C.GtkPrintOperation { + if po == nil || po.GObject == nil { + return nil + } + p := unsafe.Pointer(po.GObject) + return C.toGtkPrintOperation(p) +} + +func (v *PrintOperation) toPrintOperationPreview() *C.GtkPrintOperationPreview { + if v == nil { + return nil + } + return C.toGtkPrintOperationPreview(unsafe.Pointer(v.GObject)) +} + +func marshalPrintOperation(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapPrintOperation(obj), nil +} + +func wrapPrintOperation(obj *glib.Object) *PrintOperation { + if obj == nil { + return nil + } + + pop := wrapPrintOperationPreview(obj) + return &PrintOperation{obj, *pop} +} + +// PrintOperationNew() is a wrapper around gtk_print_operation_new(). +func PrintOperationNew() (*PrintOperation, error) { + c := C.gtk_print_operation_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapPrintOperation(obj), nil +} + +// SetAllowAsync() is a wrapper around gtk_print_operation_set_allow_async(). +func (po *PrintOperation) PrintOperationSetAllowAsync(allowSync bool) { + C.gtk_print_operation_set_allow_async(po.native(), gbool(allowSync)) +} + +// GetError() is a wrapper around gtk_print_operation_get_error(). +func (po *PrintOperation) PrintOperationGetError() error { + var err *C.GError = nil + C.gtk_print_operation_get_error(po.native(), &err) + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) +} + +// SetDefaultPageSetup() is a wrapper around gtk_print_operation_set_default_page_setup(). +func (po *PrintOperation) SetDefaultPageSetup(ps *PageSetup) { + C.gtk_print_operation_set_default_page_setup(po.native(), ps.native()) +} + +// GetDefaultPageSetup() is a wrapper around gtk_print_operation_get_default_page_setup(). +func (po *PrintOperation) GetDefaultPageSetup() (*PageSetup, error) { + c := C.gtk_print_operation_get_default_page_setup(po.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapPageSetup(obj), nil +} + +// SetPrintSettings() is a wrapper around gtk_print_operation_set_print_settings(). +func (po *PrintOperation) SetPrintSettings(ps *PrintSettings) { + C.gtk_print_operation_set_print_settings(po.native(), ps.native()) +} + +// GetPrintSettings() is a wrapper around gtk_print_operation_get_print_settings(). +func (po *PrintOperation) GetPrintSettings(ps *PageSetup) (*PrintSettings, error) { + c := C.gtk_print_operation_get_print_settings(po.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapPrintSettings(obj), nil +} + +// SetJobName() is a wrapper around gtk_print_operation_set_job_name(). +func (po *PrintOperation) SetJobName(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_operation_set_job_name(po.native(), (*C.gchar)(cstr)) +} + +// SetNPages() is a wrapper around gtk_print_operation_set_n_pages(). +func (po *PrintOperation) SetNPages(pages int) { + C.gtk_print_operation_set_n_pages(po.native(), C.gint(pages)) +} + +// GetNPagesToPrint() is a wrapper around gtk_print_operation_get_n_pages_to_print(). +func (po *PrintOperation) GetNPagesToPrint() int { + c := C.gtk_print_operation_get_n_pages_to_print(po.native()) + return int(c) +} + +// SetCurrentPage() is a wrapper around gtk_print_operation_set_current_page(). +func (po *PrintOperation) SetCurrentPage(page int) { + C.gtk_print_operation_set_current_page(po.native(), C.gint(page)) +} + +// SetUseFullPage() is a wrapper around gtk_print_operation_set_use_full_page(). +func (po *PrintOperation) SetUseFullPage(full bool) { + C.gtk_print_operation_set_use_full_page(po.native(), gbool(full)) +} + +// SetUnit() is a wrapper around gtk_print_operation_set_unit(). +func (po *PrintOperation) SetUnit(unit Unit) { + C.gtk_print_operation_set_unit(po.native(), C.GtkUnit(unit)) +} + +// SetExportFilename() is a wrapper around gtk_print_operation_set_export_filename(). +func (po *PrintOperation) SetExportFilename(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_operation_set_export_filename(po.native(), (*C.gchar)(cstr)) +} + +// SetShowProgress() is a wrapper around gtk_print_operation_set_show_progress(). +func (po *PrintOperation) SetShowProgress(show bool) { + C.gtk_print_operation_set_show_progress(po.native(), gbool(show)) +} + +// SetTrackPrintStatus() is a wrapper around gtk_print_operation_set_track_print_status(). +func (po *PrintOperation) SetTrackPrintStatus(progress bool) { + C.gtk_print_operation_set_track_print_status(po.native(), gbool(progress)) +} + +// SetCustomTabLabel() is a wrapper around gtk_print_operation_set_custom_tab_label(). +func (po *PrintOperation) SetCustomTabLabel(label string) { + cstr := C.CString(label) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_operation_set_custom_tab_label(po.native(), (*C.gchar)(cstr)) +} + +// Run() is a wrapper around gtk_print_operation_run(). +func (po *PrintOperation) Run(action PrintOperationAction, parent IWindow) (PrintOperationResult, error) { + var err *C.GError = nil + + var w *C.GtkWindow = nil + if parent != nil { + w = parent.toWindow() + } + + c := C.gtk_print_operation_run(po.native(), C.GtkPrintOperationAction(action), w, &err) + res := PrintOperationResult(c) + if res == PRINT_OPERATION_RESULT_ERROR { + defer C.g_error_free(err) + return res, errors.New(C.GoString((*C.char)(err.message))) + } + return res, nil +} + +// Cancel() is a wrapper around gtk_print_operation_cancel(). +func (po *PrintOperation) Cancel() { + C.gtk_print_operation_cancel(po.native()) +} + +// DrawPageFinish() is a wrapper around gtk_print_operation_draw_page_finish(). +func (po *PrintOperation) DrawPageFinish() { + C.gtk_print_operation_draw_page_finish(po.native()) +} + +// SetDeferDrawing() is a wrapper around gtk_print_operation_set_defer_drawing(). +func (po *PrintOperation) SetDeferDrawing() { + C.gtk_print_operation_set_defer_drawing(po.native()) +} + +// GetStatus() is a wrapper around gtk_print_operation_get_status(). +func (po *PrintOperation) GetStatus() PrintStatus { + c := C.gtk_print_operation_get_status(po.native()) + return PrintStatus(c) +} + +// GetStatusString() is a wrapper around gtk_print_operation_get_status_string(). +func (po *PrintOperation) GetStatusString() string { + c := C.gtk_print_operation_get_status_string(po.native()) + return C.GoString((*C.char)(c)) +} + +// IsFinished() is a wrapper around gtk_print_operation_is_finished(). +func (po *PrintOperation) IsFinished() bool { + c := C.gtk_print_operation_is_finished(po.native()) + return gobool(c) +} + +// SetSupportSelection() is a wrapper around gtk_print_operation_set_support_selection(). +func (po *PrintOperation) SetSupportSelection(selection bool) { + C.gtk_print_operation_set_support_selection(po.native(), gbool(selection)) +} + +// GetSupportSelection() is a wrapper around gtk_print_operation_get_support_selection(). +func (po *PrintOperation) GetSupportSelection() bool { + c := C.gtk_print_operation_get_support_selection(po.native()) + return gobool(c) +} + +// SetHasSelection() is a wrapper around gtk_print_operation_set_has_selection(). +func (po *PrintOperation) SetHasSelection(selection bool) { + C.gtk_print_operation_set_has_selection(po.native(), gbool(selection)) +} + +// GetHasSelection() is a wrapper around gtk_print_operation_get_has_selection(). +func (po *PrintOperation) GetHasSelection() bool { + c := C.gtk_print_operation_get_has_selection(po.native()) + return gobool(c) +} + +// SetEmbedPageSetup() is a wrapper around gtk_print_operation_set_embed_page_setup(). +func (po *PrintOperation) SetEmbedPageSetup(embed bool) { + C.gtk_print_operation_set_embed_page_setup(po.native(), gbool(embed)) +} + +// GetEmbedPageSetup() is a wrapper around gtk_print_operation_get_embed_page_setup(). +func (po *PrintOperation) GetEmbedPageSetup() bool { + c := C.gtk_print_operation_get_embed_page_setup(po.native()) + return gobool(c) +} + +// PrintRunPageSetupDialog() is a wrapper around gtk_print_run_page_setup_dialog(). +func PrintRunPageSetupDialog(parent IWindow, pageSetup *PageSetup, settings *PrintSettings) *PageSetup { + + var w *C.GtkWindow = nil + if parent != nil { + w = parent.toWindow() + } + + c := C.gtk_print_run_page_setup_dialog(w, pageSetup.native(), settings.native()) + obj := glib.Take(unsafe.Pointer(c)) + return wrapPageSetup(obj) +} + +type PageSetupDoneCallback func(setup *PageSetup) + +// PrintRunPageSetupDialogAsync() is a wrapper around gtk_print_run_page_setup_dialog_async(). +func PrintRunPageSetupDialogAsync(parent IWindow, setup *PageSetup, + settings *PrintSettings, cb PageSetupDoneCallback) { + + var w *C.GtkWindow = nil + if parent != nil { + w = parent.toWindow() + } + + C._gtk_print_run_page_setup_dialog_async(w, setup.native(), + settings.native(), C.gpointer(callback.Assign(cb))) +} + +/* + * GtkPrintOperationPreview + */ + +// PrintOperationPreview is a representation of GTK's GtkPrintOperationPreview GInterface. +type PrintOperationPreview struct { + *glib.Object +} + +// IPrintOperationPreview is an interface type implemented by all structs +// embedding a PrintOperationPreview. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkPrintOperationPreview. +type IPrintOperationPreview interface { + toPrintOperationPreview() *C.GtkPrintOperationPreview +} + +// native() returns a pointer to the underlying GObject as a GtkPrintOperationPreview. +func (v *PrintOperationPreview) native() *C.GtkPrintOperationPreview { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkPrintOperationPreview(p) +} + +func marshalPrintOperationPreview(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapPrintOperationPreview(obj), nil +} + +func wrapPrintOperationPreview(obj *glib.Object) *PrintOperationPreview { + if obj == nil { + return nil + } + + return &PrintOperationPreview{obj} +} + +func (v *PrintOperationPreview) toPrintOperationPreview() *C.GtkPrintOperationPreview { + if v == nil { + return nil + } + return v.native() +} + +// RenderPage()() is a wrapper around gtk_print_operation_preview_render_page(). +func (pop *PrintOperationPreview) RenderPage(page int) { + C.gtk_print_operation_preview_render_page(pop.native(), C.gint(page)) +} + +// EndPreview()() is a wrapper around gtk_print_operation_preview_end_preview(). +func (pop *PrintOperationPreview) EndPreview() { + C.gtk_print_operation_preview_end_preview(pop.native()) +} + +// IsSelected()() is a wrapper around gtk_print_operation_preview_is_selected(). +func (pop *PrintOperationPreview) IsSelected(page int) bool { + c := C.gtk_print_operation_preview_is_selected(pop.native(), C.gint(page)) + return gobool(c) +} + +/* + * GtkPrintSettings + */ + +type PrintSettings struct { + *glib.Object +} + +func (ps *PrintSettings) native() *C.GtkPrintSettings { + if ps == nil || ps.GObject == nil { + return nil + } + + p := unsafe.Pointer(ps.GObject) + return C.toGtkPrintSettings(p) +} + +func marshalPrintSettings(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapPrintSettings(glib.Take(unsafe.Pointer(c))), nil +} + +func wrapPrintSettings(obj *glib.Object) *PrintSettings { + if obj == nil { + return nil + } + + return &PrintSettings{obj} +} + +const ( + PRINT_SETTINGS_PRINTER string = C.GTK_PRINT_SETTINGS_PRINTER + PRINT_SETTINGS_ORIENTATION string = C.GTK_PRINT_SETTINGS_ORIENTATION + PRINT_SETTINGS_PAPER_FORMAT string = C.GTK_PRINT_SETTINGS_PAPER_FORMAT + PRINT_SETTINGS_PAPER_WIDTH string = C.GTK_PRINT_SETTINGS_PAPER_WIDTH + PRINT_SETTINGS_PAPER_HEIGHT string = C.GTK_PRINT_SETTINGS_PAPER_HEIGHT + PRINT_SETTINGS_USE_COLOR string = C.GTK_PRINT_SETTINGS_USE_COLOR + PRINT_SETTINGS_COLLATE string = C.GTK_PRINT_SETTINGS_COLLATE + PRINT_SETTINGS_REVERSE string = C.GTK_PRINT_SETTINGS_REVERSE + PRINT_SETTINGS_DUPLEX string = C.GTK_PRINT_SETTINGS_DUPLEX + PRINT_SETTINGS_QUALITY string = C.GTK_PRINT_SETTINGS_QUALITY + PRINT_SETTINGS_N_COPIES string = C.GTK_PRINT_SETTINGS_N_COPIES + PRINT_SETTINGS_NUMBER_UP string = C.GTK_PRINT_SETTINGS_NUMBER_UP + PRINT_SETTINGS_NUMBER_UP_LAYOUT string = C.GTK_PRINT_SETTINGS_NUMBER_UP_LAYOUT + PRINT_SETTINGS_RESOLUTION string = C.GTK_PRINT_SETTINGS_RESOLUTION + PRINT_SETTINGS_RESOLUTION_X string = C.GTK_PRINT_SETTINGS_RESOLUTION_X + PRINT_SETTINGS_RESOLUTION_Y string = C.GTK_PRINT_SETTINGS_RESOLUTION_Y + PRINT_SETTINGS_PRINTER_LPI string = C.GTK_PRINT_SETTINGS_PRINTER_LPI + PRINT_SETTINGS_SCALE string = C.GTK_PRINT_SETTINGS_SCALE + PRINT_SETTINGS_PRINT_PAGES string = C.GTK_PRINT_SETTINGS_PRINT_PAGES + PRINT_SETTINGS_PAGE_RANGES string = C.GTK_PRINT_SETTINGS_PAGE_RANGES + PRINT_SETTINGS_PAGE_SET string = C.GTK_PRINT_SETTINGS_PAGE_SET + PRINT_SETTINGS_DEFAULT_SOURCE string = C.GTK_PRINT_SETTINGS_DEFAULT_SOURCE + PRINT_SETTINGS_MEDIA_TYPE string = C.GTK_PRINT_SETTINGS_MEDIA_TYPE + PRINT_SETTINGS_DITHER string = C.GTK_PRINT_SETTINGS_DITHER + PRINT_SETTINGS_FINISHINGS string = C.GTK_PRINT_SETTINGS_FINISHINGS + PRINT_SETTINGS_OUTPUT_BIN string = C.GTK_PRINT_SETTINGS_OUTPUT_BIN + PRINT_SETTINGS_OUTPUT_DIR string = C.GTK_PRINT_SETTINGS_OUTPUT_DIR + PRINT_SETTINGS_OUTPUT_BASENAME string = C.GTK_PRINT_SETTINGS_OUTPUT_BASENAME + PRINT_SETTINGS_OUTPUT_FILE_FORMAT string = C.GTK_PRINT_SETTINGS_OUTPUT_FILE_FORMAT + PRINT_SETTINGS_OUTPUT_URI string = C.GTK_PRINT_SETTINGS_OUTPUT_URI + PRINT_SETTINGS_WIN32_DRIVER_EXTRA string = C.GTK_PRINT_SETTINGS_WIN32_DRIVER_EXTRA + PRINT_SETTINGS_WIN32_DRIVER_VERSION string = C.GTK_PRINT_SETTINGS_WIN32_DRIVER_VERSION +) + +// PrintSettingsNew() is a wrapper around gtk_print_settings_new(). +func PrintSettingsNew() (*PrintSettings, error) { + c := C.gtk_print_settings_new() + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapPrintSettings(obj), nil +} + +// Copy() is a wrapper around gtk_print_settings_copy(). +func (ps *PrintSettings) Copy() (*PrintSettings, error) { + c := C.gtk_print_settings_copy(ps.native()) + if c == nil { + return nil, nilPtrErr + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapPrintSettings(obj), nil +} + +// HasKey() is a wrapper around gtk_print_settings_has_key(). +func (ps *PrintSettings) HasKey(key string) bool { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_print_settings_has_key(ps.native(), (*C.gchar)(cstr)) + return gobool(c) +} + +// Get() is a wrapper around gtk_print_settings_get(). +func (ps *PrintSettings) Get(key string) string { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_print_settings_get(ps.native(), (*C.gchar)(cstr)) + return C.GoString((*C.char)(c)) +} + +// Set() is a wrapper around gtk_print_settings_set(). +// TODO: Since value can't be nil, we can't unset values here. +func (ps *PrintSettings) Set(key, value string) { + cKey := C.CString(key) + defer C.free(unsafe.Pointer(cKey)) + cValue := C.CString(value) + defer C.free(unsafe.Pointer(cValue)) + C.gtk_print_settings_set(ps.native(), (*C.gchar)(cKey), (*C.gchar)(cValue)) +} + +// Unset() is a wrapper around gtk_print_settings_unset(). +func (ps *PrintSettings) Unset(key string) { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_settings_unset(ps.native(), (*C.gchar)(cstr)) +} + +type PrintSettingsCallback func(key, value string) + +// Foreach() is a wrapper around gtk_print_settings_foreach(). +func (ps *PrintSettings) ForEach(cb PrintSettingsCallback) { + // Clean up callback immediately as we only need it for the duration of this Foreach call + id := callback.Assign(cb) + defer callback.Delete(id) + + C._gtk_print_settings_foreach(ps.native(), C.gpointer(id)) +} + +// GetBool() is a wrapper around gtk_print_settings_get_bool(). +func (ps *PrintSettings) GetBool(key string) bool { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_print_settings_get_bool(ps.native(), (*C.gchar)(cstr)) + return gobool(c) +} + +// SetBool() is a wrapper around gtk_print_settings_set_bool(). +func (ps *PrintSettings) SetBool(key string, value bool) { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_settings_set_bool(ps.native(), (*C.gchar)(cstr), gbool(value)) +} + +// GetDouble() is a wrapper around gtk_print_settings_get_double(). +func (ps *PrintSettings) GetDouble(key string) float64 { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_print_settings_get_double(ps.native(), (*C.gchar)(cstr)) + return float64(c) +} + +// GetDoubleWithDefault() is a wrapper around gtk_print_settings_get_double_with_default(). +func (ps *PrintSettings) GetDoubleWithDefault(key string, def float64) float64 { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_print_settings_get_double_with_default(ps.native(), + (*C.gchar)(cstr), C.gdouble(def)) + return float64(c) +} + +// SetDouble() is a wrapper around gtk_print_settings_set_double(). +func (ps *PrintSettings) SetDouble(key string, value float64) { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_settings_set_double(ps.native(), (*C.gchar)(cstr), C.gdouble(value)) +} + +// GetLength() is a wrapper around gtk_print_settings_get_length(). +func (ps *PrintSettings) GetLength(key string, unit Unit) float64 { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_print_settings_get_length(ps.native(), (*C.gchar)(cstr), C.GtkUnit(unit)) + return float64(c) +} + +// SetLength() is a wrapper around gtk_print_settings_set_length(). +func (ps *PrintSettings) SetLength(key string, value float64, unit Unit) { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_settings_set_length(ps.native(), (*C.gchar)(cstr), C.gdouble(value), C.GtkUnit(unit)) +} + +// GetInt() is a wrapper around gtk_print_settings_get_int(). +func (ps *PrintSettings) GetInt(key string) int { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_print_settings_get_int(ps.native(), (*C.gchar)(cstr)) + return int(c) +} + +// GetIntWithDefault() is a wrapper around gtk_print_settings_get_int_with_default(). +func (ps *PrintSettings) GetIntWithDefault(key string, def int) int { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_print_settings_get_int_with_default(ps.native(), (*C.gchar)(cstr), C.gint(def)) + return int(c) +} + +// SetInt() is a wrapper around gtk_print_settings_set_int(). +func (ps *PrintSettings) SetInt(key string, value int) { + cstr := C.CString(key) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_settings_set_int(ps.native(), (*C.gchar)(cstr), C.gint(value)) +} + +// GetPrinter() is a wrapper around gtk_print_settings_get_printer(). +func (ps *PrintSettings) GetPrinter() string { + c := C.gtk_print_settings_get_printer(ps.native()) + return C.GoString((*C.char)(c)) +} + +// SetPrinter() is a wrapper around gtk_print_settings_set_printer(). +func (ps *PrintSettings) SetPrinter(printer string) { + cstr := C.CString(printer) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_settings_set_printer(ps.native(), (*C.gchar)(cstr)) +} + +// GetOrientation() is a wrapper around gtk_print_settings_get_orientation(). +func (ps *PrintSettings) GetOrientation() PageOrientation { + c := C.gtk_print_settings_get_orientation(ps.native()) + return PageOrientation(c) +} + +// SetOrientation() is a wrapper around gtk_print_settings_set_orientation(). +func (ps *PrintSettings) SetOrientation(orientation PageOrientation) { + C.gtk_print_settings_set_orientation(ps.native(), C.GtkPageOrientation(orientation)) +} + +// GetPaperSize() is a wrapper around gtk_print_settings_get_paper_size(). +func (ps *PrintSettings) GetPaperSize() (*PaperSize, error) { + c := C.gtk_print_settings_get_paper_size(ps.native()) + if c == nil { + return nil, nilPtrErr + } + p := &PaperSize{c} + runtime.SetFinalizer(p, (*PaperSize).free) + return p, nil +} + +// SetPaperSize() is a wrapper around gtk_print_settings_set_paper_size(). +func (ps *PrintSettings) SetPaperSize(size *PaperSize) { + C.gtk_print_settings_set_paper_size(ps.native(), size.native()) +} + +// GetPaperWidth() is a wrapper around gtk_print_settings_get_paper_width(). +func (ps *PrintSettings) GetPaperWidth(unit Unit) float64 { + c := C.gtk_print_settings_get_paper_width(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// SetPaperWidth() is a wrapper around gtk_print_settings_set_paper_width(). +func (ps *PrintSettings) SetPaperWidth(width float64, unit Unit) { + C.gtk_print_settings_set_paper_width(ps.native(), C.gdouble(width), C.GtkUnit(unit)) +} + +// GetPaperHeight() is a wrapper around gtk_print_settings_get_paper_height(). +func (ps *PrintSettings) GetPaperHeight(unit Unit) float64 { + c := C.gtk_print_settings_get_paper_height(ps.native(), C.GtkUnit(unit)) + return float64(c) +} + +// SetPaperHeight() is a wrapper around gtk_print_settings_set_paper_height(). +func (ps *PrintSettings) SetPaperHeight(width float64, unit Unit) { + C.gtk_print_settings_set_paper_height(ps.native(), C.gdouble(width), C.GtkUnit(unit)) +} + +// GetUseColor() is a wrapper around gtk_print_settings_get_use_color(). +func (ps *PrintSettings) GetUseColor() bool { + c := C.gtk_print_settings_get_use_color(ps.native()) + return gobool(c) +} + +// SetUseColor() is a wrapper around gtk_print_settings_set_use_color(). +func (ps *PrintSettings) SetUseColor(color bool) { + C.gtk_print_settings_set_use_color(ps.native(), gbool(color)) +} + +// GetCollate() is a wrapper around gtk_print_settings_get_collate(). +func (ps *PrintSettings) GetCollate() bool { + c := C.gtk_print_settings_get_collate(ps.native()) + return gobool(c) +} + +// SetCollate() is a wrapper around gtk_print_settings_set_collate(). +func (ps *PrintSettings) SetCollate(collate bool) { + C.gtk_print_settings_set_collate(ps.native(), gbool(collate)) +} + +// GetReverse() is a wrapper around gtk_print_settings_get_reverse(). +func (ps *PrintSettings) GetReverse() bool { + c := C.gtk_print_settings_get_reverse(ps.native()) + return gobool(c) +} + +// SetReverse() is a wrapper around gtk_print_settings_set_reverse(). +func (ps *PrintSettings) SetReverse(reverse bool) { + C.gtk_print_settings_set_reverse(ps.native(), gbool(reverse)) +} + +// GetDuplex() is a wrapper around gtk_print_settings_get_duplex(). +func (ps *PrintSettings) GetDuplex() PrintDuplex { + c := C.gtk_print_settings_get_duplex(ps.native()) + return PrintDuplex(c) +} + +// SetDuplex() is a wrapper around gtk_print_settings_set_duplex(). +func (ps *PrintSettings) SetDuplex(duplex PrintDuplex) { + C.gtk_print_settings_set_duplex(ps.native(), C.GtkPrintDuplex(duplex)) +} + +// GetQuality() is a wrapper around gtk_print_settings_get_quality(). +func (ps *PrintSettings) GetQuality() PrintQuality { + c := C.gtk_print_settings_get_quality(ps.native()) + return PrintQuality(c) +} + +// SetQuality() is a wrapper around gtk_print_settings_set_quality(). +func (ps *PrintSettings) SetQuality(quality PrintQuality) { + C.gtk_print_settings_set_quality(ps.native(), C.GtkPrintQuality(quality)) +} + +// GetNCopies() is a wrapper around gtk_print_settings_get_n_copies(). +func (ps *PrintSettings) GetNCopies() int { + c := C.gtk_print_settings_get_n_copies(ps.native()) + return int(c) +} + +// SetNCopies() is a wrapper around gtk_print_settings_set_n_copies(). +func (ps *PrintSettings) SetNCopies(copies int) { + C.gtk_print_settings_set_n_copies(ps.native(), C.gint(copies)) +} + +// GetNmberUp() is a wrapper around gtk_print_settings_get_number_up(). +func (ps *PrintSettings) GetNmberUp() int { + c := C.gtk_print_settings_get_number_up(ps.native()) + return int(c) +} + +// SetNumberUp() is a wrapper around gtk_print_settings_set_number_up(). +func (ps *PrintSettings) SetNumberUp(numberUp int) { + C.gtk_print_settings_set_number_up(ps.native(), C.gint(numberUp)) +} + +// GetNumberUpLayout() is a wrapper around gtk_print_settings_get_number_up_layout(). +func (ps *PrintSettings) GetNumberUpLayout() NumberUpLayout { + c := C.gtk_print_settings_get_number_up_layout(ps.native()) + return NumberUpLayout(c) +} + +// SetNumberUpLayout() is a wrapper around gtk_print_settings_set_number_up_layout(). +func (ps *PrintSettings) SetNumberUpLayout(numberUpLayout NumberUpLayout) { + C.gtk_print_settings_set_number_up_layout(ps.native(), C.GtkNumberUpLayout(numberUpLayout)) +} + +// GetResolution() is a wrapper around gtk_print_settings_get_resolution(). +func (ps *PrintSettings) GetResolution() int { + c := C.gtk_print_settings_get_resolution(ps.native()) + return int(c) +} + +// SetResolution() is a wrapper around gtk_print_settings_set_resolution(). +func (ps *PrintSettings) SetResolution(resolution int) { + C.gtk_print_settings_set_resolution(ps.native(), C.gint(resolution)) +} + +// SetResolutionXY() is a wrapper around gtk_print_settings_set_resolution_xy(). +func (ps *PrintSettings) SetResolutionXY(resolutionX, resolutionY int) { + C.gtk_print_settings_set_resolution_xy(ps.native(), C.gint(resolutionX), C.gint(resolutionY)) +} + +// GetResolutionX() is a wrapper around gtk_print_settings_get_resolution_x(). +func (ps *PrintSettings) GetResolutionX() int { + c := C.gtk_print_settings_get_resolution_x(ps.native()) + return int(c) +} + +// GetResolutionY() is a wrapper around gtk_print_settings_get_resolution_y(). +func (ps *PrintSettings) GetResolutionY() int { + c := C.gtk_print_settings_get_resolution_y(ps.native()) + return int(c) +} + +// GetPrinterLpi() is a wrapper around gtk_print_settings_get_printer_lpi(). +func (ps *PrintSettings) GetPrinterLpi() float64 { + c := C.gtk_print_settings_get_printer_lpi(ps.native()) + return float64(c) +} + +// SetPrinterLpi() is a wrapper around gtk_print_settings_set_printer_lpi(). +func (ps *PrintSettings) SetPrinterLpi(lpi float64) { + C.gtk_print_settings_set_printer_lpi(ps.native(), C.gdouble(lpi)) +} + +// GetScale() is a wrapper around gtk_print_settings_get_scale(). +func (ps *PrintSettings) GetScale() float64 { + c := C.gtk_print_settings_get_scale(ps.native()) + return float64(c) +} + +// SetScale() is a wrapper around gtk_print_settings_set_scale(). +func (ps *PrintSettings) SetScale(scale float64) { + C.gtk_print_settings_set_scale(ps.native(), C.gdouble(scale)) +} + +// GetPrintPages() is a wrapper around gtk_print_settings_get_print_pages(). +func (ps *PrintSettings) GetPrintPages() PrintPages { + c := C.gtk_print_settings_get_print_pages(ps.native()) + return PrintPages(c) +} + +// SetPrintPages() is a wrapper around gtk_print_settings_set_print_pages(). +func (ps *PrintSettings) SetPrintPages(pages PrintPages) { + C.gtk_print_settings_set_print_pages(ps.native(), C.GtkPrintPages(pages)) +} + +// GetPageSet() is a wrapper around gtk_print_settings_get_page_set(). +func (ps *PrintSettings) GetPageSet(pages PrintPages) PageSet { + c := C.gtk_print_settings_get_page_set(ps.native()) + return PageSet(c) +} + +// SetPageSet() is a wrapper around gtk_print_settings_set_page_set(). +func (ps *PrintSettings) SetPageSet(pageSet PageSet) { + C.gtk_print_settings_set_page_set(ps.native(), C.GtkPageSet(pageSet)) +} + +// GetDefaultSource() is a wrapper around gtk_print_settings_get_default_source(). +func (ps *PrintSettings) GetDefaultSource() string { + c := C.gtk_print_settings_get_default_source(ps.native()) + return C.GoString((*C.char)(c)) +} + +// SetSefaultSource() is a wrapper around gtk_print_settings_set_default_source(). +func (ps *PrintSettings) SetSefaultSource(defaultSource string) { + cstr := C.CString(defaultSource) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_settings_set_default_source(ps.native(), (*C.gchar)(cstr)) +} + +// GetMediaType() is a wrapper around gtk_print_settings_get_media_type(). +func (ps *PrintSettings) GetMediaType() string { + c := C.gtk_print_settings_get_media_type(ps.native()) + return C.GoString((*C.char)(c)) +} + +// SetMediaType() is a wrapper around gtk_print_settings_set_media_type(). +func (ps *PrintSettings) SetMediaType(mediaType string) { + cstr := C.CString(mediaType) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_settings_set_media_type(ps.native(), (*C.gchar)(cstr)) +} + +// GetDither() is a wrapper around gtk_print_settings_get_dither(). +func (ps *PrintSettings) GetDither() string { + c := C.gtk_print_settings_get_dither(ps.native()) + return C.GoString((*C.char)(c)) +} + +// SetDither() is a wrapper around gtk_print_settings_set_dither(). +func (ps *PrintSettings) SetDither(dither string) { + cstr := C.CString(dither) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_settings_set_dither(ps.native(), (*C.gchar)(cstr)) +} + +// GetFinishings() is a wrapper around gtk_print_settings_get_finishings(). +func (ps *PrintSettings) GetFinishings() string { + c := C.gtk_print_settings_get_finishings(ps.native()) + return C.GoString((*C.char)(c)) +} + +// SetFinishings() is a wrapper around gtk_print_settings_set_finishings(). +func (ps *PrintSettings) SetFinishings(dither string) { + cstr := C.CString(dither) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_settings_set_finishings(ps.native(), (*C.gchar)(cstr)) +} + +// GetOutputBin() is a wrapper around gtk_print_settings_get_output_bin(). +func (ps *PrintSettings) GetOutputBin() string { + c := C.gtk_print_settings_get_output_bin(ps.native()) + return C.GoString((*C.char)(c)) +} + +// SetOutputBin() is a wrapper around gtk_print_settings_set_output_bin(). +func (ps *PrintSettings) SetOutputBin(bin string) { + cstr := C.CString(bin) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_print_settings_set_output_bin(ps.native(), (*C.gchar)(cstr)) +} + +// PrintSettingsNewFromFile() is a wrapper around gtk_print_settings_new_from_file(). +func PrintSettingsNewFromFile(name string) (*PrintSettings, error) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + var err *C.GError = nil + c := C.gtk_print_settings_new_from_file((*C.gchar)(cstr), &err) + if c == nil { + defer C.g_error_free(err) + return nil, errors.New(C.GoString((*C.char)(err.message))) + } + obj := glib.Take(unsafe.Pointer(c)) + return wrapPrintSettings(obj), nil +} + +// PrintSettingsNewFromKeyFile() is a wrapper around gtk_print_settings_new_from_key_file(). + +// LoadFile() is a wrapper around gtk_print_settings_load_file(). +func (ps *PrintSettings) LoadFile(name string) error { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + var err *C.GError = nil + c := C.gtk_print_settings_load_file(ps.native(), (*C.gchar)(cstr), &err) + if gobool(c) == false { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// LoadKeyFile() is a wrapper around gtk_print_settings_load_key_file(). + +// ToFile() is a wrapper around gtk_print_settings_to_file(). +func (ps *PrintSettings) ToFile(name string) error { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + var err *C.GError = nil + c := C.gtk_print_settings_to_file(ps.native(), (*C.gchar)(cstr), &err) + if gobool(c) == false { + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// ToKeyFile() is a wrapper around gtk_print_settings_to_key_file(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/print.go.h b/vendor/github.com/gotk3/gotk3/gtk/print.go.h new file mode 100644 index 0000000..fc1587f --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/print.go.h @@ -0,0 +1,23 @@ +#pragma once + +#include +#include +#include + +extern void goPrintSettings(gchar *key, gchar *value, gpointer user_data); + +static inline void _gtk_print_settings_foreach(GtkPrintSettings *ps, + gpointer user_data) { + gtk_print_settings_foreach(ps, (GtkPrintSettingsFunc)(goPrintSettings), + user_data); +} + +extern void goPageSetupDone(GtkPageSetup *setup, gpointer data); + +static inline void +_gtk_print_run_page_setup_dialog_async(GtkWindow *parent, GtkPageSetup *setup, + GtkPrintSettings *settings, + gpointer data) { + gtk_print_run_page_setup_dialog_async( + parent, setup, settings, (GtkPageSetupDoneFunc)(goPageSetupDone), data); +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/print_export.go b/vendor/github.com/gotk3/gotk3/gtk/print_export.go new file mode 100644 index 0000000..388eff2 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/print_export.go @@ -0,0 +1,23 @@ +package gtk + +// #include +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/internal/callback" +) + +//export goPageSetupDone +func goPageSetupDone(setup *C.GtkPageSetup, data C.gpointer) { + // This callback is only used once, so we can clean up immediately + fn := callback.GetAndDelete(uintptr(data)).(PageSetupDoneCallback) + fn(wrapPageSetup(glib.Take(unsafe.Pointer(setup)))) +} + +//export goPrintSettings +func goPrintSettings(key *C.gchar, value *C.gchar, userData C.gpointer) { + fn := callback.Get(uintptr(userData)).(PrintSettingsCallback) + fn(C.GoString((*C.char)(key)), C.GoString((*C.char)(value))) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/print_since_3_16.go b/vendor/github.com/gotk3/gotk3/gtk/print_since_3_16.go new file mode 100644 index 0000000..486026d --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/print_since_3_16.go @@ -0,0 +1,34 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14 + +// See: https://developer.gnome.org/gtk3/3.16/api-index-3-16.html + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "runtime" + "unsafe" +) + +// PaperSizeNewFromIpp is a wrapper around gtk_paper_size_new_from_ipp(). +func PaperSizeNewFromIPP(name string, width, height float64) (*PaperSize, error) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + + c := C.gtk_paper_size_new_from_ipp((*C.gchar)(cstr), C.gdouble(width), C.gdouble(height)) + if c == nil { + return nil, nilPtrErr + } + + t := &PaperSize{c} + runtime.SetFinalizer(t, (*PaperSize).free) + return t, nil +} + +// IsIPP() is a wrapper around gtk_paper_size_is_ipp(). +func (ps *PaperSize) IsIPP() bool { + c := C.gtk_paper_size_is_ipp(ps.native()) + return gobool(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/print_test.go b/vendor/github.com/gotk3/gotk3/gtk/print_test.go new file mode 100644 index 0000000..30d9d3e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/print_test.go @@ -0,0 +1,55 @@ +package gtk + +import ( + "testing" +) + +func init() { + Init(nil) +} + +// TestPageSetup tests creating and manipulating PageSetup +func TestPageSetup(t *testing.T) { + _, err := PageSetupNew() + if err != nil { + t.Error(err) + } +} + +// TestPaperSize tests creating and manipulating PaperSize +func TestPaperSize(t *testing.T) { + _, err := PaperSizeNew(PAPER_NAME_A4) + if err != nil { + t.Error(err) + } +} + +// TestPrintContext tests creating and manipulating PrintContext + +// TestPrintOperation tests creating and manipulating PrintOperation +func TestPrintOperation(t *testing.T) { + _, err := PrintOperationNew() + if err != nil { + t.Error(err) + } +} + +// TestPrintOperationPreview tests creating and manipulating PrintOperationPreview + +// TestPrintSettings tests creating and manipulating PrintSettings +func TestPrintSettings(t *testing.T) { + settings, err := PrintSettingsNew() + if err != nil { + t.Error(err) + } + + settings.Set("Key1", "String1") + settings.SetBool("Key2", true) + settings.Set("Key3", "String2") + settings.SetInt("Key4", 2) + + settings.ForEach(func(key, value string) { + }, 0) +} + +// TestPrintContext tests creating and manipulating PrintContext diff --git a/vendor/github.com/gotk3/gotk3/gtk/settings.go b/vendor/github.com/gotk3/gotk3/gtk/settings.go new file mode 100644 index 0000000..a1727b4 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/settings.go @@ -0,0 +1,57 @@ +package gtk + +// #include +// #include "settings.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_settings_get_type()), marshalSettings}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkSettings"] = wrapSettings +} + +//GtkSettings +type Settings struct { + *glib.Object +} + +func (v *Settings) native() *C.GtkSettings { + if v == nil || v.GObject == nil { + return nil + } + + p := unsafe.Pointer(v.GObject) + return C.toGtkSettings(p) +} + +func marshalSettings(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + return wrapSettings(glib.Take(unsafe.Pointer(c))), nil +} + +func wrapSettings(obj *glib.Object) *Settings { + if obj == nil { + return nil + } + + return &Settings{obj} +} + +//Get the global non window specific settings +func SettingsGetDefault() (*Settings, error) { + c := C.gtk_settings_get_default() + if c == nil { + return nil, nilPtrErr + } + + return wrapSettings(glib.Take(unsafe.Pointer(c))), nil +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/settings.go.h b/vendor/github.com/gotk3/gotk3/gtk/settings.go.h new file mode 100644 index 0000000..a48a24d --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/settings.go.h @@ -0,0 +1 @@ +static GtkSettings *toGtkSettings(void *p) { return (GTK_SETTINGS(p)); } diff --git a/vendor/github.com/gotk3/gotk3/gtk/shortcutswindow_since_3_20.go b/vendor/github.com/gotk3/gotk3/gtk/shortcutswindow_since_3_20.go new file mode 100644 index 0000000..8eb2ef0 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/shortcutswindow_since_3_20.go @@ -0,0 +1,156 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16,!gtk_3_18 + +package gtk + +// #include +// #include "gtk.go.h" +// #include "shortcutswindow_since_3_20.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_shortcuts_window_get_type()), marshalShortcutsWindow}, + {glib.Type(C.gtk_shortcuts_section_get_type()), marshalShortcutsSection}, + {glib.Type(C.gtk_shortcuts_group_get_type()), marshalShortcutsGroup}, + {glib.Type(C.gtk_shortcuts_shortcut_get_type()), marshalShortcutsShortcut}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkShortcutsWindow"] = wrapShortcutsWindow + WrapMap["GtkShortcutsSection"] = wrapShortcutsSection + WrapMap["GtkShortcutsGroup"] = wrapShortcutsGroup + WrapMap["GtkShortcutsShortcut"] = wrapShortcutsShortcut +} + +/* + * GtkShortcutsWindow + */ + +// ShortcutsWindow is a representation of GTK's GtkShortcutsWindow. +type ShortcutsWindow struct { + Window +} + +func (v *ShortcutsWindow) native() *C.GtkShortcutsWindow { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkShortcutsWindow(p) +} + +func marshalShortcutsWindow(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapShortcutsWindow(obj), nil +} + +func wrapShortcutsWindow(obj *glib.Object) *ShortcutsWindow { + if obj == nil { + return nil + } + + return &ShortcutsWindow{Window{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}}} +} + +/* + * GtkShortcutsSection + */ + +// ShortcutsSection is a representation of GTK's GtkShortcutsSection. +type ShortcutsSection struct { + Box +} + +// native returns a pointer to the underlying GtkShortcutsSection. +func (v *ShortcutsSection) native() *C.GtkShortcutsSection { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkShortcutsSection(p) +} + +func marshalShortcutsSection(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapShortcutsSection(obj), nil +} + +func wrapShortcutsSection(obj *glib.Object) *ShortcutsSection { + if obj == nil { + return nil + } + + return &ShortcutsSection{Box{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +/* + * GtkShortcutsGroup + */ + +// ShortcutsGroup is a representation of GTK's GtkShortcutsGroup. +type ShortcutsGroup struct { + Box +} + +// native returns a pointer to the underlying GtkShortcutsGroup. +func (v *ShortcutsGroup) native() *C.GtkShortcutsGroup { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkShortcutsGroup(p) +} + +func marshalShortcutsGroup(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapShortcutsGroup(obj), nil +} + +func wrapShortcutsGroup(obj *glib.Object) *ShortcutsGroup { + if obj == nil { + return nil + } + + return &ShortcutsGroup{Box{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +/* + * GtkShortcutsShortcut + */ + +// ShortcutsShortcut is a representation of GTK's GtkShortcutsShortcut. +type ShortcutsShortcut struct { + Box +} + +// native returns a pointer to the underlying GtkShortcutsShortcut. +func (v *ShortcutsShortcut) native() *C.GtkShortcutsShortcut { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkShortcutsShortcut(p) +} + +func marshalShortcutsShortcut(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapShortcutsShortcut(obj), nil +} + +func wrapShortcutsShortcut(obj *glib.Object) *ShortcutsShortcut { + if obj == nil { + return nil + } + + return &ShortcutsShortcut{Box{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/shortcutswindow_since_3_20.go.h b/vendor/github.com/gotk3/gotk3/gtk/shortcutswindow_since_3_20.go.h new file mode 100644 index 0000000..1922177 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/shortcutswindow_since_3_20.go.h @@ -0,0 +1,33 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +static GtkShortcutsWindow *toGtkShortcutsWindow(void *p) { + return (GTK_SHORTCUTS_WINDOW(p)); +} + +static GtkShortcutsSection *toGtkShortcutsSection(void *p) { + return (GTK_SHORTCUTS_SECTION(p)); +} + +static GtkShortcutsGroup *toGtkShortcutsGroup(void *p) { + return (GTK_SHORTCUTS_GROUP(p)); +} + +static GtkShortcutsShortcut *toGtkShortcutsShortcut(void *p) { + return (GTK_SHORTCUTS_SHORTCUT(p)); +} \ No newline at end of file diff --git a/vendor/github.com/gotk3/gotk3/gtk/socket_plug.go b/vendor/github.com/gotk3/gotk3/gtk/socket_plug.go new file mode 100644 index 0000000..b8a5616 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/socket_plug.go @@ -0,0 +1,205 @@ +// +build linux + +package gtk + +// #include +// #include +// #include +// #include +// #include "socket_plug.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_socket_get_type()), marshalSocket}, + {glib.Type(C.gtk_plug_get_type()), marshalPlug}, + } + + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkSocket"] = wrapSocket + WrapMap["GtkPlug"] = wrapPlug +} + +/* + * GtkSocket + */ + +// Socket is a representation of GTK's GtkSocket +type Socket struct { + Container +} + +// native returns a pointer to the underlying GtkSocket +func (v *Socket) native() *C.GtkSocket { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkSocket(p) +} + +func marshalSocket(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapSocket(obj), nil +} + +func wrapSocket(obj *glib.Object) *Socket { + if obj == nil { + return nil + } + + return &Socket{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// SocketNew is a wrapper around gtk_socket_new(). +// Create a new empty GtkSocket. +func SocketNew() (*Socket, error) { + c := C.gtk_socket_new() + if c == nil { + return nil, nilPtrErr + } + return wrapSocket(glib.Take(unsafe.Pointer(c))), nil +} + +// AddId is a wrapper around gtk_socket_add_id(). +// Adds an XEMBED client, such as a GtkPlug, to the GtkSocket. The client may be in the same process or in a different +// process. +// To embed a GtkPlug in a GtkSocket, you can either create the GtkPlug with gtk_plug_new (0), call gtk_plug_get_id() +// to get the window ID of the plug, and then pass that to the gtk_socket_add_id(), or you can call gtk_socket_get_id() +// to get the window ID for the socket, and call gtk_plug_new() passing in that ID. +// The GtkSocket must have already be added into a toplevel window before you can make this call. +func (v *Socket) AddId(window uint) { + C.gtk_socket_add_id(v.native(), C.Window(window)) +} + +// GetId is a wrapper around gtk_socket_get_id(). +// Gets the window ID of a GtkSocket widget, which can then be used to create a client embedded inside the socket, +// for instance with gtk_plug_new(). +// The GtkSocket must have already be added into a toplevel window before you can make this call. +func (v *Socket) GetId() uint { + c := C.gtk_socket_get_id(v.native()) + return uint(c) +} + +// GetPlugWindow is a wrapper around gtk_socket_get_plug_window(). +// Retrieves the window of the plug. Use this to check if the plug has been created inside of the socket. +func (v *Socket) GetPlugWindow() (*Window, error) { + c := C.gtk_socket_get_plug_window(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapWindow(glib.Take(unsafe.Pointer(c))), nil +} + +/* + * GtkSocket + */ + +// Plug is a representation of GTK's GtkPlug +type Plug struct { + Window +} + +// native returns a pointer to the underlying GtkSocket +func (v *Plug) native() *C.GtkPlug { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkPlug(p) +} + +// native returns a C pointer to the underlying GdkDisplay. +func native(v *gdk.Display) *C.GdkDisplay { + // I'd love to not have to copy native() from gdk/gdk.go, but it appears you can't just + // pass C structs from package to package + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGdkDisplay(p) +} + +func marshalPlug(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapPlug(obj), nil +} + +func wrapPlug(obj *glib.Object) *Plug { + if obj == nil { + return nil + } + + return &Plug{Window{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}}} +} + +// PlugNew is a wrapper around gtk_plug_new(). +// Creates a new plug widget inside the GtkSocket identified by socket_id. +// If socket_id is 0, the plug is left “unplugged” and can later be plugged into a GtkSocket by gtk_socket_add_id(). +func PlugNew(socketId uint) (*Plug, error) { + c := C.gtk_plug_new(C.Window(socketId)) + if c == nil { + return nil, nilPtrErr + } + return wrapPlug(glib.Take(unsafe.Pointer(c))), nil +} + +// PlugNewForDisplay is a wrapper around gtk_plug_new_for_display(). +// Creates a new plug widget inside the GtkSocket identified by socket_id. +// If socket_id is 0, the plug is left “unplugged” and can later be plugged into a GtkSocket by gtk_socket_add_id(). +func PlugNewForDisplay(display *gdk.Display, socketId uint) (*Plug, error) { + c := C.gtk_plug_new_for_display(native(display), C.Window(socketId)) + if c == nil { + return nil, nilPtrErr + } + return wrapPlug(glib.Take(unsafe.Pointer(c))), nil +} + +// Construct is a wrapper around gtk_plug_construct(). +// Finish the initialization of plug for a given GtkSocket identified by socket_id. +// This function will generally only be used by classes deriving from GtkPlug. +func (v *Plug) Construct(socketId uint) { + C.gtk_plug_construct(v.native(), C.Window(socketId)) +} + +// ConstructForDisplay is a wrapper around gtk_plug_construct_for_display(). +// Finish the initialization of plug for a given GtkSocket identified by socket_id which is currently +// displayed on display. +// This function will generally only be used by classes deriving from GtkPlug. +func (v *Plug) ConstructForDisplay(display *gdk.Display, socketId uint) { + C.gtk_plug_construct_for_display(v.native(), native(display), C.Window(socketId)) +} + +// GetId is a wrapper around gtk_plug_get_id(). +// Gets the window ID of a GtkPlug widget, which can then be used to embed this window inside another window, +// for instance with gtk_socket_add_id(). +func (v *Plug) GetId() uint { + c := C.gtk_plug_get_id(v.native()) + return uint(c) +} + +// GetEmbedded is a wrapper around gtk_plug_get_embedded(). +// Determines whether the plug is embedded in a socket. +func (v *Plug) GetEmbedded() bool { + c := C.gtk_plug_get_embedded(v.native()) + return gobool(c) +} + +// GetSocketWindow is a wrapper around gtk_plug_get_socket_window(). +// Retrieves the socket the plug is embedded in. +func (v *Plug) GetSocketWindow() (*Window, error) { + c := C.gtk_plug_get_socket_window(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapWindow(glib.Take(unsafe.Pointer(c))), nil +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/socket_plug.go.h b/vendor/github.com/gotk3/gotk3/gtk/socket_plug.go.h new file mode 100644 index 0000000..0de1cbd --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/socket_plug.go.h @@ -0,0 +1,6 @@ + +static GtkSocket *toGtkSocket(void *p) { return (GTK_SOCKET(p)); } + +static GtkPlug *toGtkPlug(void *p) { return (GTK_PLUG(p)); } + +static GdkDisplay *toGdkDisplay(void *p) { return (GDK_DISPLAY(p)); } diff --git a/vendor/github.com/gotk3/gotk3/gtk/stack_since_3_12.go b/vendor/github.com/gotk3/gotk3/gtk/stack_since_3_12.go new file mode 100644 index 0000000..cce9b12 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/stack_since_3_12.go @@ -0,0 +1,32 @@ +// Same copyright and license as the rest of the files in this project +// This file contains accelerator related functions and structures + +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10 +// not use this: go build -tags gtk_3_8'. Otherwise, if no build tags are used, GTK 3.10 + +package gtk + +// #include +// #include +// #include "gtk_since_3_10.go.h" +import "C" +import ( + "unsafe" +) + +// GetChildByName is a wrapper around gtk_stack_get_child_by_name(). +func (v *Stack) GetChildByName(name string) (IWidget, error) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_stack_get_child_by_name(v.native(), (*C.gchar)(cstr)) + if c == nil { + return nil, nilPtrErr + } + return castWidget(c) +} + +// GetTransitionRunning is a wrapper around gtk_stack_get_transition_running(). +func (v *Stack) GetTransitionRunning() bool { + c := C.gtk_stack_get_transition_running(v.native()) + return gobool(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/stackswitcher_since_3_10.go b/vendor/github.com/gotk3/gotk3/gtk/stackswitcher_since_3_10.go new file mode 100644 index 0000000..d9dae76 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/stackswitcher_since_3_10.go @@ -0,0 +1,81 @@ +// Same copyright and license as the rest of the files in this project +// This file contains accelerator related functions and structures + +// +build !gtk_3_6,!gtk_3_8 +// not use this: go build -tags gtk_3_8'. Otherwise, if no build tags are used, GTK 3.10 + +package gtk + +// #include +// #include +// #include "gtk_since_3_10.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + //Contribute to casting + for k, v := range map[string]WrapFn{ + "GtkStackSwitcher": wrapStackSwitcher, + } { + WrapMap[k] = v + } +} + +/* + * GtkStackSwitcher + */ + +// StackSwitcher is a representation of GTK's GtkStackSwitcher +type StackSwitcher struct { + Box +} + +// native returns a pointer to the underlying GtkStackSwitcher. +func (v *StackSwitcher) native() *C.GtkStackSwitcher { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkStackSwitcher(p) +} + +func marshalStackSwitcher(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapStackSwitcher(obj), nil +} + +func wrapStackSwitcher(obj *glib.Object) *StackSwitcher { + if obj == nil { + return nil + } + + return &StackSwitcher{Box{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// StackSwitcherNew is a wrapper around gtk_stack_switcher_new(). +func StackSwitcherNew() (*StackSwitcher, error) { + c := C.gtk_stack_switcher_new() + if c == nil { + return nil, nilPtrErr + } + return wrapStackSwitcher(glib.Take(unsafe.Pointer(c))), nil +} + +// SetStack is a wrapper around gtk_stack_switcher_set_stack(). +func (v *StackSwitcher) SetStack(stack *Stack) { + C.gtk_stack_switcher_set_stack(v.native(), stack.native()) +} + +// GetStack is a wrapper around gtk_stack_switcher_get_stack(). +func (v *StackSwitcher) GetStack() *Stack { + c := C.gtk_stack_switcher_get_stack(v.native()) + if c == nil { + return nil + } + return wrapStack(glib.Take(unsafe.Pointer(c))) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/style.go b/vendor/github.com/gotk3/gotk3/gtk/style.go new file mode 100644 index 0000000..c750152 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/style.go @@ -0,0 +1,236 @@ +// Same copyright and license as the rest of the files in this project +// This file contains style related functions and structures + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +type StyleProviderPriority int + +const ( + STYLE_PROVIDER_PRIORITY_FALLBACK StyleProviderPriority = C.GTK_STYLE_PROVIDER_PRIORITY_FALLBACK + STYLE_PROVIDER_PRIORITY_THEME = C.GTK_STYLE_PROVIDER_PRIORITY_THEME + STYLE_PROVIDER_PRIORITY_SETTINGS = C.GTK_STYLE_PROVIDER_PRIORITY_SETTINGS + STYLE_PROVIDER_PRIORITY_APPLICATION = C.GTK_STYLE_PROVIDER_PRIORITY_APPLICATION + STYLE_PROVIDER_PRIORITY_USER = C.GTK_STYLE_PROVIDER_PRIORITY_USER +) + +/* + * GtkStyleContext + */ + +// StyleContext is a representation of GTK's GtkStyleContext. +type StyleContext struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkStyleContext. +func (v *StyleContext) native() *C.GtkStyleContext { + if v == nil || v.Object == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkStyleContext(p) +} + +func wrapStyleContext(obj *glib.Object) *StyleContext { + if obj == nil { + return nil + } + + return &StyleContext{obj} +} + +func (v *StyleContext) AddClass(class_name string) { + cstr := C.CString(class_name) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_style_context_add_class(v.native(), (*C.gchar)(cstr)) +} + +func (v *StyleContext) RemoveClass(class_name string) { + cstr := C.CString(class_name) + defer C.free(unsafe.Pointer(cstr)) + + C.gtk_style_context_remove_class(v.native(), (*C.gchar)(cstr)) +} + +func fromNativeStyleContext(c *C.GtkStyleContext) (*StyleContext, error) { + if c == nil { + return nil, nilPtrErr + } + + obj := glib.Take(unsafe.Pointer(c)) + return wrapStyleContext(obj), nil +} + +// GetStyleContext is a wrapper around gtk_widget_get_style_context(). +func (v *Widget) GetStyleContext() (*StyleContext, error) { + return fromNativeStyleContext(C.gtk_widget_get_style_context(v.native())) +} + +// GetParent is a wrapper around gtk_style_context_get_parent(). +func (v *StyleContext) GetParent() (*StyleContext, error) { + return fromNativeStyleContext(C.gtk_style_context_get_parent(v.native())) +} + +// GetProperty is a wrapper around gtk_style_context_get_property(). +func (v *StyleContext) GetProperty(property string, state StateFlags) (interface{}, error) { + cstr := (*C.gchar)(C.CString(property)) + defer C.free(unsafe.Pointer(cstr)) + + var gval C.GValue + C.gtk_style_context_get_property(v.native(), cstr, C.GtkStateFlags(state), &gval) + val := glib.ValueFromNative(unsafe.Pointer(&gval)) + return val.GoValue() +} + +// GetStyleProperty is a wrapper around gtk_style_context_get_style_property(). +func (v *StyleContext) GetStyleProperty(property string) (interface{}, error) { + cstr := (*C.gchar)(C.CString(property)) + defer C.free(unsafe.Pointer(cstr)) + + var gval C.GValue + C.gtk_style_context_get_style_property(v.native(), cstr, &gval) + val := glib.ValueFromNative(unsafe.Pointer(&gval)) + return val.GoValue() +} + +// GetScreen is a wrapper around gtk_style_context_get_screen(). +func (v *StyleContext) GetScreen() (*gdk.Screen, error) { + c := C.gtk_style_context_get_screen(v.native()) + if c == nil { + return nil, nilPtrErr + } + + d := &gdk.Screen{glib.Take(unsafe.Pointer(c))} + return d, nil +} + +// GetState is a wrapper around gtk_style_context_get_state(). +func (v *StyleContext) GetState() StateFlags { + return StateFlags(C.gtk_style_context_get_state(v.native())) +} + +// GetColor is a wrapper around gtk_style_context_get_color(). +func (v *StyleContext) GetColor(state StateFlags) *gdk.RGBA { + gdkColor := gdk.NewRGBA() + C.gtk_style_context_get_color(v.native(), C.GtkStateFlags(state), (*C.GdkRGBA)(unsafe.Pointer(gdkColor.Native()))) + return gdkColor +} + +// LookupColor is a wrapper around gtk_style_context_lookup_color(). +func (v *StyleContext) LookupColor(colorName string) (*gdk.RGBA, bool) { + cstr := (*C.gchar)(C.CString(colorName)) + defer C.free(unsafe.Pointer(cstr)) + gdkColor := gdk.NewRGBA() + ret := C.gtk_style_context_lookup_color(v.native(), cstr, (*C.GdkRGBA)(unsafe.Pointer(gdkColor.Native()))) + return gdkColor, gobool(ret) +} + +// StyleContextResetWidgets is a wrapper around gtk_style_context_reset_widgets(). +func StyleContextResetWidgets(v *gdk.Screen) { + C.gtk_style_context_reset_widgets((*C.GdkScreen)(unsafe.Pointer(v.Native()))) +} + +// Restore is a wrapper around gtk_style_context_restore(). +func (v *StyleContext) Restore() { + C.gtk_style_context_restore(v.native()) +} + +// Save is a wrapper around gtk_style_context_save(). +func (v *StyleContext) Save() { + C.gtk_style_context_save(v.native()) +} + +// SetParent is a wrapper around gtk_style_context_set_parent(). +func (v *StyleContext) SetParent(p *StyleContext) { + C.gtk_style_context_set_parent(v.native(), p.native()) +} + +// HasClass is a wrapper around gtk_style_context_has_class(). +func (v *StyleContext) HasClass(className string) bool { + cstr := C.CString(className) + defer C.free(unsafe.Pointer(cstr)) + + return gobool(C.gtk_style_context_has_class(v.native(), (*C.gchar)(cstr))) +} + +// SetScreen is a wrapper around gtk_style_context_set_screen(). +func (v *StyleContext) SetScreen(s *gdk.Screen) { + C.gtk_style_context_set_screen(v.native(), (*C.GdkScreen)(unsafe.Pointer(s.Native()))) +} + +// SetState is a wrapper around gtk_style_context_set_state(). +func (v *StyleContext) SetState(state StateFlags) { + C.gtk_style_context_set_state(v.native(), C.GtkStateFlags(state)) +} + +type IStyleProvider interface { + toStyleProvider() *C.GtkStyleProvider +} + +// AddProvider is a wrapper around gtk_style_context_add_provider(). +func (v *StyleContext) AddProvider(provider IStyleProvider, prio uint) { + C.gtk_style_context_add_provider(v.native(), provider.toStyleProvider(), C.guint(prio)) +} + +// AddProviderForScreen is a wrapper around gtk_style_context_add_provider_for_screen(). +func AddProviderForScreen(s *gdk.Screen, provider IStyleProvider, prio uint) { + C.gtk_style_context_add_provider_for_screen((*C.GdkScreen)(unsafe.Pointer(s.Native())), provider.toStyleProvider(), C.guint(prio)) +} + +// RemoveProvider is a wrapper around gtk_style_context_remove_provider(). +func (v *StyleContext) RemoveProvider(provider IStyleProvider) { + C.gtk_style_context_remove_provider(v.native(), provider.toStyleProvider()) +} + +// RemoveProviderForScreen is a wrapper around gtk_style_context_remove_provider_for_screen(). +func RemoveProviderForScreen(s *gdk.Screen, provider IStyleProvider) { + C.gtk_style_context_remove_provider_for_screen((*C.GdkScreen)(unsafe.Pointer(s.Native())), provider.toStyleProvider()) +} + +// GtkStyleContext * gtk_style_context_new () +// void gtk_style_context_get () +// GtkTextDirection gtk_style_context_get_direction () +// GtkJunctionSides gtk_style_context_get_junction_sides () +// const GtkWidgetPath * gtk_style_context_get_path () +// GdkFrameClock * gtk_style_context_get_frame_clock () +// void gtk_style_context_get_style () +// void gtk_style_context_get_style_valist () +// void gtk_style_context_get_valist () +// GtkCssSection * gtk_style_context_get_section () +// void gtk_style_context_get_background_color () +// void gtk_style_context_get_border_color () +// void gtk_style_context_get_border () +// void gtk_style_context_get_padding () +// void gtk_style_context_get_margin () +// const PangoFontDescription * gtk_style_context_get_font () +// void gtk_style_context_invalidate () +// gboolean gtk_style_context_state_is_running () +// GtkIconSet * gtk_style_context_lookup_icon_set () +// void gtk_style_context_cancel_animations () +// void gtk_style_context_scroll_animations () +// void gtk_style_context_notify_state_change () +// void gtk_style_context_pop_animatable_region () +// void gtk_style_context_push_animatable_region () +// void gtk_style_context_set_background () +// void gtk_style_context_set_direction () +// void gtk_style_context_set_junction_sides () +// void gtk_style_context_set_path () +// void gtk_style_context_add_region () +// void gtk_style_context_remove_region () +// gboolean gtk_style_context_has_region () +// GList * gtk_style_context_list_regions () +// void gtk_style_context_set_frame_clock () +// void gtk_style_context_set_scale () +// gint gtk_style_context_get_scale () +// GList * gtk_style_context_list_classes () diff --git a/vendor/github.com/gotk3/gotk3/gtk/testing.go b/vendor/github.com/gotk3/gotk3/gtk/testing.go new file mode 100644 index 0000000..8d53e98 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/testing.go @@ -0,0 +1,161 @@ +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "errors" + "os" + "unsafe" + + "github.com/gotk3/gotk3/gdk" + + "github.com/gotk3/gotk3/glib" +) + +// TestFindLabel is a wrapper around gtk_test_find_label(). +// This function will search widget and all its descendants for a GtkLabel widget with a text string matching label_pattern. +// The labelPattern may contain asterisks “*” and question marks “?” as placeholders, g_pattern_match() is used for the matching. +func TestFindLabel(widget IWidget, labelPattern string) (IWidget, error) { + cstr := C.CString(labelPattern) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_test_find_label(widget.toWidget(), (*C.gchar)(cstr)) + if c == nil { + return nil, errors.New("no label with pattern '" + labelPattern + "' found") + } + obj, err := castWidget(c) + if err != nil { + return nil, err + } + return obj, nil +} + +// TestFindSibling is a wrapper around gtk_test_find_sibling(). +// This function will search siblings of base_widget and siblings of its ancestors for all widgets matching widgetType. +// Of the matching widgets, the one that is geometrically closest to base_widget will be returned. +func TestFindSibling(baseWidget IWidget, widgetType glib.Type) (IWidget, error) { + c := C.gtk_test_find_sibling(baseWidget.toWidget(), C.GType(widgetType)) + if c == nil { + return nil, errors.New("no widget of type '" + widgetType.Name() + "' found") + } + obj, err := castWidget(c) + if err != nil { + return nil, err + } + return obj, nil +} + +// TestFindWidget is a wrapper around gtk_test_find_widget(). +// This function will search the descendants of widget for a widget of type widget_type that has a label matching labelPattern next to it. +// This is most useful for automated GUI testing, e.g. to find the “OK” button in a dialog and synthesize clicks on it. +// However see TestFindLabel(), TestFindSibling() and TestWidgetClick() (and their GTK documentation) +// for possible caveats involving the search of such widgets and synthesizing widget events. +func TestFindWidget(widget IWidget, labelPattern string, widgetType glib.Type) (IWidget, error) { + cstr := C.CString(labelPattern) + defer C.free(unsafe.Pointer(cstr)) + c := C.gtk_test_find_widget(widget.toWidget(), (*C.gchar)(cstr), C.GType(widgetType)) + if c == nil { + return nil, errors.New("no widget with label pattern '" + labelPattern + "' and type '" + widgetType.Name() + "' found") + } + obj, err := castWidget(c) + if err != nil { + return nil, err + } + return obj, nil +} + +/* +TestInit is a wrapper around gtk_test_init(). +This function is used to initialize a GTK+ test program. +It will in turn call g_test_init() and gtk_init() to properly initialize the testing framework and graphical toolkit. +It’ll also set the program’s locale to “C” and prevent loading of rc files and Gtk+ modules. +This is done to make tets program environments as deterministic as possible. + +Like gtk_init() and g_test_init(), any known arguments will be processed and stripped from argc and argv. +*/ +func TestInit(args *[]string) { + if args != nil { + argc := C.int(len(*args)) + argv := C.make_strings(argc) + defer C.destroy_strings(argv) + + for i, arg := range *args { + cstr := C.CString(arg) + C.set_string(argv, C.int(i), (*C.gchar)(cstr)) + } + + C._gtk_test_init((*C.int)(unsafe.Pointer(&argc)), + (***C.char)(unsafe.Pointer(&argv))) + + unhandled := make([]string, argc) + for i := 0; i < int(argc); i++ { + cstr := C.get_string(argv, C.int(i)) + unhandled[i] = goString(cstr) + C.free(unsafe.Pointer(cstr)) + } + *args = unhandled + } else { + // gtk_test_init does not take nil, we have to use an empty argument list + // (only containing the first arg, which is the executable name) + argc := C.int(1) + argv := C.make_strings(argc) + defer C.destroy_strings(argv) + + // Add first argument + cstr := C.CString(os.Args[0]) + C.set_string(argv, C.int(0), (*C.gchar)(cstr)) + + C._gtk_test_init((*C.int)(unsafe.Pointer(&argc)), + (***C.char)(unsafe.Pointer(&argv))) + } +} + +// TestListAllTypes is a wrapper around gtk_test_list_all_types(). +// Return the type ids that have been registered after calling TestRegisterAllTypes(). +func TestListAllTypes() []glib.Type { + var types *C.GType + var clen C.guint + + types = C.gtk_test_list_all_types(&clen) + defer C.free(unsafe.Pointer(types)) + + length := uint(clen) + + typeReturn := make([]glib.Type, length) + for i := uint(0); i < length; i++ { + current := (*C.GType)(pointerAtOffset(unsafe.Pointer(types), unsafe.Sizeof(*types), i)) + typeReturn[i] = glib.Type(*current) + } + return typeReturn +} + +// pointerAtOffset adjusts `arrayPointer` (pointer to the first element of a C array) +// to point at the offset `i`, +// to be able to read the value there without having to go through cgo. +func pointerAtOffset(arrayPointer unsafe.Pointer, elementSize uintptr, offset uint) unsafe.Pointer { + return unsafe.Pointer(uintptr(arrayPointer) + elementSize*uintptr(offset)) +} + +// TestRegisterAllTypes is a wrapper around gtk_test_register_all_types(). +// Force registration of all core Gtk+ and Gdk object types. +// This allowes to refer to any of those object types via g_type_from_name() after calling this function. +func TestRegisterAllTypes() { + C.gtk_test_register_all_types() +} + +// TestWidgetSendKey is a wrapper around gtk_test_widget_send_key() +// +// This function will generate keyboard press and release events +// in the middle of the first GdkWindow found that belongs to widget. +// For windowless widgets like GtkButton (which returns FALSE from gtk_widget_get_has_window()), +// this will often be an input-only event window. +// For other widgets, this is usually widget->window. +// +// widget: Widget to generate a key press and release on. +// keyval: A Gdk keyboard value. +// modifiers: Keyboard modifiers the event is setup with. +// +// returns: whether all actions neccessary for the key event simulation were carried out successfully. +func TestWidgetSendKey(widget IWidget, keyval uint, modifiers gdk.ModifierType) bool { + return gobool(C.gtk_test_widget_send_key(widget.toWidget(), C.guint(keyval), C.GdkModifierType(modifiers))) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/testing_deprecated_since_3_20.go b/vendor/github.com/gotk3/gotk3/gtk/testing_deprecated_since_3_20.go new file mode 100644 index 0000000..bc75d3a --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/testing_deprecated_since_3_20.go @@ -0,0 +1,62 @@ +//+build gtk_3_6 gtk_3_8 gtk_3_10 gtk_3_12 gtk_3_14 gtk_3_16 gtk_3_18 gtk_deprecated + +package gtk + +// #include +import "C" +import ( + "github.com/gotk3/gotk3/gdk" +) + +/* +GtkWidget * +gtk_test_create_simple_window (const gchar *window_title, + const gchar *dialog_text); + +GtkWidget * +gtk_test_create_widget (GType widget_type, + const gchar *first_property_name, + ...); + +GtkWidget * +gtk_test_display_button_window (const gchar *window_title, + const gchar *dialog_text, + ...); + +double +gtk_test_slider_get_value (GtkWidget *widget); + +void +gtk_test_slider_set_perc (GtkWidget *widget, + double percentage); + +gboolean +gtk_test_spin_button_click (GtkSpinButton *spinner, + guint button, + gboolean upwards); + +gchar * +gtk_test_text_get (GtkWidget *widget); + +void +gtk_test_text_set (GtkWidget *widget, + const gchar *string); +*/ + +// TestWidgetClick is a wrapper around gtk_test_widget_click() +// Deprecated since 3.20 +// +// This function will generate a button click (button press and button release event) +// in the middle of the first GdkWindow found that belongs to widget. +// For windowless widgets like GtkButton (which returns FALSE from gtk_widget_get_has_window()), +// this will often be an input-only event window. +// For other widgets, this is usually widget->window. +// +// widget: Widget to generate a button click on. +// button: Number of the pointer button for the event, usually 1, 2 or 3. +// modifiers: Keyboard modifiers the event is setup with. +// +// returns: whether all actions neccessary for the button click simulation were carried out successfully. +func TestWidgetClick(widget IWidget, button gdk.Button, modifiers gdk.ModifierType) bool { + return gobool(C.gtk_test_widget_click(widget.toWidget(), C.guint(button), C.GdkModifierType(modifiers))) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/testing_since_3_10.go b/vendor/github.com/gotk3/gotk3/gtk/testing_since_3_10.go new file mode 100644 index 0000000..55ce3d1 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/testing_since_3_10.go @@ -0,0 +1,13 @@ +// +build !gtk_3_6,!gtk_3_8 + +package gtk + +// #include +import "C" + +// TestWidgetWaitForDraw is a wrapper around gtk_test_widget_wait_for_draw(). +// Enters the main loop and waits for widget to be “drawn”. In this context that means it waits for the frame clock of widget to have run a full styling, layout and drawing cycle. +// This function is intended to be used for syncing with actions that depend on widget relayouting or on interaction with the display server. +func TestWidgetWaitForDraw(widget IWidget) { + C.gtk_test_widget_wait_for_draw(widget.toWidget()) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/testing_test.go b/vendor/github.com/gotk3/gotk3/gtk/testing_test.go new file mode 100644 index 0000000..df3c8a3 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/testing_test.go @@ -0,0 +1,125 @@ +package gtk + +import ( + "reflect" + "testing" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func TestTestRegisterAllTypes(t *testing.T) { + TestRegisterAllTypes() + types := TestListAllTypes() + + if len(types) == 0 { + t.Error("Expected at least one type to be registered") + } +} + +func TestPointerAtOffset(t *testing.T) { + // Simulate a C array by using a pointer to the first element + intArray := []int{4, 8, 2, 5, 9} + arrayPointer := unsafe.Pointer(&intArray[0]) + elementSize := unsafe.Sizeof(intArray[0]) + + for i, val := range intArray { + intAtOffset := (*int)(pointerAtOffset(arrayPointer, elementSize, uint(i))) + if val != *intAtOffset { + t.Errorf("Expected %d at offset %d, got %d", val, i, *intAtOffset) + } + } +} + +func TestTestFindLabel(t *testing.T) { + // Build a dummy widget + box, _ := BoxNew(ORIENTATION_HORIZONTAL, 0) + label1, _ := LabelNew("First") + label2, _ := LabelNew("Second") + + box.PackStart(label1, true, true, 0) + box.PackStart(label2, true, true, 0) + + // Find a label in the box with text matching Fir* + found, err := TestFindLabel(box, "Fir*") + if err != nil { + t.Error("Unexpected error:", err.Error()) + } + + // Should return the label1 + if found == nil { + t.Error("Return value is nil") + } + foundAsLabel, ok := found.(*Label) + if !ok { + t.Error("Did not return a label. Received type:", reflect.TypeOf(found)) + } + + text, _ := foundAsLabel.GetText() + if text != "First" { + t.Error("Expected: First, Got:", text) + } + +} + +func TestTestFindSibling(t *testing.T) { + // Build a dummy widget + box, _ := BoxNew(ORIENTATION_HORIZONTAL, 0) + label1, _ := LabelNew("First") + label2, _ := LabelNew("Second") + + box.PackStart(label1, true, true, 0) + box.PackStart(label2, true, true, 0) + + // Finx a sibling to label1, of type label + found, err := TestFindSibling(label1, glib.TypeFromName("GtkLabel")) + if err != nil { + t.Error("Unexpected error:", err.Error()) + } + + // Should return the label2 + if found == nil { + t.Error("Return value is nil") + } + foundAsLabel, ok := found.(*Label) + if !ok { + t.Error("Did not return a label. Received type:", reflect.TypeOf(found)) + } + + text, _ := foundAsLabel.GetText() + if text != "Second" { + t.Error("Expected: First, Got:", text) + } + +} + +func TestTestFindWidget(t *testing.T) { + // Build a dummy widget + box, _ := BoxNew(ORIENTATION_HORIZONTAL, 0) + button1, _ := ButtonNewWithLabel("First") + button2, _ := ButtonNewWithLabel("Second") + + box.PackStart(button1, true, true, 0) + box.PackStart(button2, true, true, 0) + + // Find a label in the box with text matching Fir* + found, err := TestFindWidget(box, "Sec*", glib.TypeFromName("GtkButton")) + if err != nil { + t.Error("Unexpected error:", err.Error()) + } + + // Should return the button2 + if found == nil { + t.Error("Return value is nil") + } + foundAsButton, ok := found.(*Button) + if !ok { + t.Error("Did not return a button. Received type:", reflect.TypeOf(found)) + } + + text, _ := foundAsButton.GetLabel() + if text != "Second" { + t.Error("Expected: Second, Got:", text) + } + +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/text_child_anchor.go b/vendor/github.com/gotk3/gotk3/gtk/text_child_anchor.go new file mode 100644 index 0000000..d6f8fb4 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/text_child_anchor.go @@ -0,0 +1,81 @@ +// Same copyright and license as the rest of the files in this project + +package gtk + +// #include +// #include "text_child_anchor.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Objects/Interfaces + {glib.Type(C.gtk_text_child_anchor_get_type()), marshalTextChildAnchor}, + } + glib.RegisterGValueMarshalers(tm) +} + +/* + * GtkTextChildAnchor + */ + +// TextChildAnchor is a representation of GTK's GtkTextChildAnchor +type TextChildAnchor struct { + glib.InitiallyUnowned +} + +// native returns a pointer to the underlying GtkTextChildAnchor. +func (v *TextChildAnchor) native() *C.GtkTextChildAnchor { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTextChildAnchor(p) +} + +func marshalTextChildAnchor(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTextChildAnchor(obj), nil +} + +func wrapTextChildAnchor(obj *glib.Object) *TextChildAnchor { + if obj == nil { + return nil + } + + return &TextChildAnchor{glib.InitiallyUnowned{obj}} +} + +// TextChildAnchorNew is a wrapper around gtk_text_child_anchor_new () +func TextChildAnchorNew() (*TextChildAnchor, error) { + c := C.gtk_text_child_anchor_new() + if c == nil { + return nil, nilPtrErr + } + return wrapTextChildAnchor(glib.Take(unsafe.Pointer(c))), nil +} + +// GetWidgets is a wrapper around gtk_text_child_anchor_get_widgets (). +func (v *TextChildAnchor) GetWidgets() *glib.List { + clist := C.gtk_text_child_anchor_get_widgets(v.native()) + if clist == nil { + return nil + } + + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return wrapWidget(glib.Take(ptr)) + }) + + return glist +} + +// GetDeleted is a wrapper around gtk_text_child_anchor_get_deleted(). +func (v *TextChildAnchor) GetDeleted() bool { + return gobool(C.gtk_text_child_anchor_get_deleted(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/text_child_anchor.go.h b/vendor/github.com/gotk3/gotk3/gtk/text_child_anchor.go.h new file mode 100644 index 0000000..631275d --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/text_child_anchor.go.h @@ -0,0 +1,23 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +static GtkTextChildAnchor * +toGtkTextChildAnchor(void *p) +{ + return (GTK_TEXT_CHILD_ANCHOR(p)); +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/text_iter.go b/vendor/github.com/gotk3/gotk3/gtk/text_iter.go new file mode 100644 index 0000000..b714c01 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/text_iter.go @@ -0,0 +1,423 @@ +// Same copyright and license as the rest of the files in this project + +package gtk + +// #include +// #include "gtk.go.h" +import "C" + +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +/* + * GtkTextIter + */ + +// TextIter is a representation of GTK's GtkTextIter +type TextIter C.GtkTextIter + +// native returns a pointer to the underlying GtkTextIter. +func (v *TextIter) native() *C.GtkTextIter { + if v == nil { + return nil + } + return (*C.GtkTextIter)(v) +} + +func marshalTextIter(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + return (*TextIter)(unsafe.Pointer(c)), nil +} + +// GetBuffer is a wrapper around gtk_text_iter_get_buffer(). +func (v *TextIter) GetBuffer() *TextBuffer { + c := C.gtk_text_iter_get_buffer(v.native()) + if c == nil { + return nil + } + return wrapTextBuffer(glib.Take(unsafe.Pointer(c))) +} + +// GetOffset is a wrapper around gtk_text_iter_get_offset(). +func (v *TextIter) GetOffset() int { + return int(C.gtk_text_iter_get_offset(v.native())) +} + +// GetLine is a wrapper around gtk_text_iter_get_line(). +func (v *TextIter) GetLine() int { + return int(C.gtk_text_iter_get_line(v.native())) +} + +// GetLineOffset is a wrapper around gtk_text_iter_get_line_offset(). +func (v *TextIter) GetLineOffset() int { + return int(C.gtk_text_iter_get_line_offset(v.native())) +} + +// GetLineIndex is a wrapper around gtk_text_iter_get_line_index(). +func (v *TextIter) GetLineIndex() int { + return int(C.gtk_text_iter_get_line_index(v.native())) +} + +// GetVisibleLineOffset is a wrapper around gtk_text_iter_get_visible_line_offset(). +func (v *TextIter) GetVisibleLineOffset() int { + return int(C.gtk_text_iter_get_visible_line_offset(v.native())) +} + +// GetVisibleLineIndex is a wrapper around gtk_text_iter_get_visible_line_index(). +func (v *TextIter) GetVisibleLineIndex() int { + return int(C.gtk_text_iter_get_visible_line_index(v.native())) +} + +// GetChar is a wrapper around gtk_text_iter_get_char(). +func (v *TextIter) GetChar() rune { + return rune(C.gtk_text_iter_get_char(v.native())) +} + +// GetSlice is a wrapper around gtk_text_iter_get_slice(). +func (v *TextIter) GetSlice(end *TextIter) string { + c := C.gtk_text_iter_get_slice(v.native(), end.native()) + return C.GoString((*C.char)(c)) +} + +// GetText is a wrapper around gtk_text_iter_get_text(). +func (v *TextIter) GetText(end *TextIter) string { + c := C.gtk_text_iter_get_text(v.native(), end.native()) + return C.GoString((*C.char)(c)) +} + +// GetVisibleSlice is a wrapper around gtk_text_iter_get_visible_slice(). +func (v *TextIter) GetVisibleSlice(end *TextIter) string { + c := C.gtk_text_iter_get_visible_slice(v.native(), end.native()) + return C.GoString((*C.char)(c)) +} + +// GetVisibleText is a wrapper around gtk_text_iter_get_visible_text(). +func (v *TextIter) GetVisibleText(end *TextIter) string { + c := C.gtk_text_iter_get_visible_text(v.native(), end.native()) + return C.GoString((*C.char)(c)) +} + +// EndsTag is a wrapper around gtk_text_iter_ends_tag(). +func (v *TextIter) EndsTag(v1 *TextTag) bool { + return gobool(C.gtk_text_iter_ends_tag(v.native(), v1.native())) +} + +// TogglesTag is a wrapper around gtk_text_iter_toggles_tag(). +func (v *TextIter) TogglesTag(v1 *TextTag) bool { + return gobool(C.gtk_text_iter_toggles_tag(v.native(), v1.native())) +} + +// HasTag is a wrapper around gtk_text_iter_has_tag(). +func (v *TextIter) HasTag(v1 *TextTag) bool { + return gobool(C.gtk_text_iter_has_tag(v.native(), v1.native())) +} + +// Editable is a wrapper around gtk_text_iter_editable(). +func (v *TextIter) Editable(v1 bool) bool { + return gobool(C.gtk_text_iter_editable(v.native(), gbool(v1))) +} + +// CanInsert is a wrapper around gtk_text_iter_can_insert(). +func (v *TextIter) CanInsert(v1 bool) bool { + return gobool(C.gtk_text_iter_can_insert(v.native(), gbool(v1))) +} + +// StartsWord is a wrapper around gtk_text_iter_starts_word(). +func (v *TextIter) StartsWord() bool { + return gobool(C.gtk_text_iter_starts_word(v.native())) +} + +// EndsWord is a wrapper around gtk_text_iter_ends_word(). +func (v *TextIter) EndsWord() bool { + return gobool(C.gtk_text_iter_ends_word(v.native())) +} + +// InsideWord is a wrapper around gtk_text_iter_inside_word(). +func (v *TextIter) InsideWord() bool { + return gobool(C.gtk_text_iter_inside_word(v.native())) +} + +// StartsLine is a wrapper around gtk_text_iter_starts_line(). +func (v *TextIter) StartsLine() bool { + return gobool(C.gtk_text_iter_starts_line(v.native())) +} + +// EndsLine is a wrapper around gtk_text_iter_ends_line(). +func (v *TextIter) EndsLine() bool { + return gobool(C.gtk_text_iter_ends_line(v.native())) +} + +// StartsSentence is a wrapper around gtk_text_iter_starts_sentence(). +func (v *TextIter) StartsSentence() bool { + return gobool(C.gtk_text_iter_starts_sentence(v.native())) +} + +// EndsSentence is a wrapper around gtk_text_iter_ends_sentence(). +func (v *TextIter) EndsSentence() bool { + return gobool(C.gtk_text_iter_ends_sentence(v.native())) +} + +// InsideSentence is a wrapper around gtk_text_iter_inside_sentence(). +func (v *TextIter) InsideSentence() bool { + return gobool(C.gtk_text_iter_inside_sentence(v.native())) +} + +// IsCursorPosition is a wrapper around gtk_text_iter_is_cursor_position(). +func (v *TextIter) IsCursorPosition() bool { + return gobool(C.gtk_text_iter_is_cursor_position(v.native())) +} + +// GetCharsInLine is a wrapper around gtk_text_iter_get_chars_in_line(). +func (v *TextIter) GetCharsInLine() int { + return int(C.gtk_text_iter_get_chars_in_line(v.native())) +} + +// GetBytesInLine is a wrapper around gtk_text_iter_get_bytes_in_line(). +func (v *TextIter) GetBytesInLine() int { + return int(C.gtk_text_iter_get_bytes_in_line(v.native())) +} + +// IsEnd is a wrapper around gtk_text_iter_is_end(). +func (v *TextIter) IsEnd() bool { + return gobool(C.gtk_text_iter_is_end(v.native())) +} + +// IsStart is a wrapper around gtk_text_iter_is_start(). +func (v *TextIter) IsStart() bool { + return gobool(C.gtk_text_iter_is_start(v.native())) +} + +// ForwardChar is a wrapper around gtk_text_iter_forward_char(). +func (v *TextIter) ForwardChar() bool { + return gobool(C.gtk_text_iter_forward_char(v.native())) +} + +// BackwardChar is a wrapper around gtk_text_iter_backward_char(). +func (v *TextIter) BackwardChar() bool { + return gobool(C.gtk_text_iter_backward_char(v.native())) +} + +// ForwardChars is a wrapper around gtk_text_iter_forward_chars(). +func (v *TextIter) ForwardChars(v1 int) bool { + return gobool(C.gtk_text_iter_forward_chars(v.native(), C.gint(v1))) +} + +// BackwardChars is a wrapper around gtk_text_iter_backward_chars(). +func (v *TextIter) BackwardChars(v1 int) bool { + return gobool(C.gtk_text_iter_backward_chars(v.native(), C.gint(v1))) +} + +// ForwardLine is a wrapper around gtk_text_iter_forward_line(). +func (v *TextIter) ForwardLine() bool { + return gobool(C.gtk_text_iter_forward_line(v.native())) +} + +// BackwardLine is a wrapper around gtk_text_iter_backward_line(). +func (v *TextIter) BackwardLine() bool { + return gobool(C.gtk_text_iter_backward_line(v.native())) +} + +// ForwardLines is a wrapper around gtk_text_iter_forward_lines(). +func (v *TextIter) ForwardLines(v1 int) bool { + return gobool(C.gtk_text_iter_forward_lines(v.native(), C.gint(v1))) +} + +// BackwardLines is a wrapper around gtk_text_iter_backward_lines(). +func (v *TextIter) BackwardLines(v1 int) bool { + return gobool(C.gtk_text_iter_backward_lines(v.native(), C.gint(v1))) +} + +// ForwardWordEnds is a wrapper around gtk_text_iter_forward_word_ends(). +func (v *TextIter) ForwardWordEnds(v1 int) bool { + return gobool(C.gtk_text_iter_forward_word_ends(v.native(), C.gint(v1))) +} + +// ForwardWordEnd is a wrapper around gtk_text_iter_forward_word_end(). +func (v *TextIter) ForwardWordEnd() bool { + return gobool(C.gtk_text_iter_forward_word_end(v.native())) +} + +// ForwardCursorPosition is a wrapper around gtk_text_iter_forward_cursor_position(). +func (v *TextIter) ForwardCursorPosition() bool { + return gobool(C.gtk_text_iter_forward_cursor_position(v.native())) +} + +// BackwardCursorPosition is a wrapper around gtk_text_iter_backward_cursor_position(). +func (v *TextIter) BackwardCursorPosition() bool { + return gobool(C.gtk_text_iter_backward_cursor_position(v.native())) +} + +// ForwardCursorPositions is a wrapper around gtk_text_iter_forward_cursor_positions(). +func (v *TextIter) ForwardCursorPositions(v1 int) bool { + return gobool(C.gtk_text_iter_forward_cursor_positions(v.native(), C.gint(v1))) +} + +// BackwardCursorPositions is a wrapper around gtk_text_iter_backward_cursor_positions(). +func (v *TextIter) BackwardCursorPositions(v1 int) bool { + return gobool(C.gtk_text_iter_backward_cursor_positions(v.native(), C.gint(v1))) +} + +// ForwardSentenceEnds is a wrapper around gtk_text_iter_forward_sentence_ends(). +func (v *TextIter) ForwardSentenceEnds(v1 int) bool { + return gobool(C.gtk_text_iter_forward_sentence_ends(v.native(), C.gint(v1))) +} + +// ForwardSentenceEnd is a wrapper around gtk_text_iter_forward_sentence_end(). +func (v *TextIter) ForwardSentenceEnd() bool { + return gobool(C.gtk_text_iter_forward_sentence_end(v.native())) +} + +// ForwardVisibleWordEnds is a wrapper around gtk_text_iter_forward_word_ends(). +func (v *TextIter) ForwardVisibleWordEnds(v1 int) bool { + return gobool(C.gtk_text_iter_forward_word_ends(v.native(), C.gint(v1))) +} + +// ForwardVisibleWordEnd is a wrapper around gtk_text_iter_forward_visible_word_end(). +func (v *TextIter) ForwardVisibleWordEnd() bool { + return gobool(C.gtk_text_iter_forward_visible_word_end(v.native())) +} + +// ForwardVisibleCursorPosition is a wrapper around gtk_text_iter_forward_visible_cursor_position(). +func (v *TextIter) ForwardVisibleCursorPosition() bool { + return gobool(C.gtk_text_iter_forward_visible_cursor_position(v.native())) +} + +// BackwardVisibleCursorPosition is a wrapper around gtk_text_iter_backward_visible_cursor_position(). +func (v *TextIter) BackwardVisibleCursorPosition() bool { + return gobool(C.gtk_text_iter_backward_visible_cursor_position(v.native())) +} + +// ForwardVisibleCursorPositions is a wrapper around gtk_text_iter_forward_visible_cursor_positions(). +func (v *TextIter) ForwardVisibleCursorPositions(v1 int) bool { + return gobool(C.gtk_text_iter_forward_visible_cursor_positions(v.native(), C.gint(v1))) +} + +// BackwardVisibleCursorPositions is a wrapper around gtk_text_iter_backward_visible_cursor_positions(). +func (v *TextIter) BackwardVisibleCursorPositions(v1 int) bool { + return gobool(C.gtk_text_iter_backward_visible_cursor_positions(v.native(), C.gint(v1))) +} + +// ForwardVisibleLine is a wrapper around gtk_text_iter_forward_visible_line(). +func (v *TextIter) ForwardVisibleLine() bool { + return gobool(C.gtk_text_iter_forward_visible_line(v.native())) +} + +// BackwardVisibleLine is a wrapper around gtk_text_iter_backward_visible_line(). +func (v *TextIter) BackwardVisibleLine() bool { + return gobool(C.gtk_text_iter_backward_visible_line(v.native())) +} + +// ForwardVisibleLines is a wrapper around gtk_text_iter_forward_visible_lines(). +func (v *TextIter) ForwardVisibleLines(v1 int) bool { + return gobool(C.gtk_text_iter_forward_visible_lines(v.native(), C.gint(v1))) +} + +// BackwardVisibleLines is a wrapper around gtk_text_iter_backward_visible_lines(). +func (v *TextIter) BackwardVisibleLines(v1 int) bool { + return gobool(C.gtk_text_iter_backward_visible_lines(v.native(), C.gint(v1))) +} + +// SetOffset is a wrapper around gtk_text_iter_set_offset(). +func (v *TextIter) SetOffset(v1 int) { + C.gtk_text_iter_set_offset(v.native(), C.gint(v1)) +} + +// SetLine is a wrapper around gtk_text_iter_set_line(). +func (v *TextIter) SetLine(v1 int) { + C.gtk_text_iter_set_line(v.native(), C.gint(v1)) +} + +// SetLineOffset is a wrapper around gtk_text_iter_set_line_offset(). +func (v *TextIter) SetLineOffset(v1 int) { + C.gtk_text_iter_set_line_offset(v.native(), C.gint(v1)) +} + +// SetLineIndex is a wrapper around gtk_text_iter_set_line_index(). +func (v *TextIter) SetLineIndex(v1 int) { + C.gtk_text_iter_set_line_index(v.native(), C.gint(v1)) +} + +// SetVisibleLineOffset is a wrapper around gtk_text_iter_set_visible_line_offset(). +func (v *TextIter) SetVisibleLineOffset(v1 int) { + C.gtk_text_iter_set_visible_line_offset(v.native(), C.gint(v1)) +} + +// SetVisibleLineIndex is a wrapper around gtk_text_iter_set_visible_line_index(). +func (v *TextIter) SetVisibleLineIndex(v1 int) { + C.gtk_text_iter_set_visible_line_index(v.native(), C.gint(v1)) +} + +// ForwardToEnd is a wrapper around gtk_text_iter_forward_to_end(). +func (v *TextIter) ForwardToEnd() { + C.gtk_text_iter_forward_to_end(v.native()) +} + +// ForwardToLineEnd is a wrapper around gtk_text_iter_forward_to_line_end(). +func (v *TextIter) ForwardToLineEnd() bool { + return gobool(C.gtk_text_iter_forward_to_line_end(v.native())) +} + +// ForwardToTagToggle is a wrapper around gtk_text_iter_forward_to_tag_toggle(). +func (v *TextIter) ForwardToTagToggle(v1 *TextTag) bool { + return gobool(C.gtk_text_iter_forward_to_tag_toggle(v.native(), v1.native())) +} + +// BackwardToTagToggle is a wrapper around gtk_text_iter_backward_to_tag_toggle(). +func (v *TextIter) BackwardToTagToggle(v1 *TextTag) bool { + return gobool(C.gtk_text_iter_backward_to_tag_toggle(v.native(), v1.native())) +} + +// Equal is a wrapper around gtk_text_iter_equal(). +func (v *TextIter) Equal(v1 *TextIter) bool { + return gobool(C.gtk_text_iter_equal(v.native(), v1.native())) +} + +// Compare is a wrapper around gtk_text_iter_compare(). +func (v *TextIter) Compare(v1 *TextIter) int { + return int(C.gtk_text_iter_compare(v.native(), v1.native())) +} + +// InRange is a wrapper around gtk_text_iter_in_range(). +func (v *TextIter) InRange(v1 *TextIter, v2 *TextIter) bool { + return gobool(C.gtk_text_iter_in_range(v.native(), v1.native(), v2.native())) +} + +// ForwardSearch is a wrapper around gtk_text_iter_forward_search(). +func (v *TextIter) ForwardSearch(text string, flags TextSearchFlags, limit *TextIter) (matchStart, matchEnd *TextIter, ok bool) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + + matchStart, matchEnd = new(TextIter), new(TextIter) + cbool := C.gtk_text_iter_forward_search(v.native(), (*C.gchar)(cstr), (C.GtkTextSearchFlags)(flags), + (*C.GtkTextIter)(matchStart), (*C.GtkTextIter)(matchEnd), (*C.GtkTextIter)(limit)) + return matchStart, matchEnd, gobool(cbool) +} + +// BackwardSearch is a wrapper around gtk_text_iter_backward_search(). +func (v *TextIter) BackwardSearch(text string, flags TextSearchFlags, limit *TextIter) (matchStart, matchEnd *TextIter, ok bool) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + + matchStart, matchEnd = new(TextIter), new(TextIter) + cbool := C.gtk_text_iter_backward_search(v.native(), (*C.gchar)(cstr), (C.GtkTextSearchFlags)(flags), + (*C.GtkTextIter)(matchStart), (*C.GtkTextIter)(matchEnd), (*C.GtkTextIter)(limit)) + return matchStart, matchEnd, gobool(cbool) +} + +// void gtk_text_iter_order () +// gboolean (*GtkTextCharPredicate) () +// gboolean gtk_text_iter_forward_find_char () +// gboolean gtk_text_iter_backward_find_char () +// gboolean gtk_text_iter_get_attributes () +// GtkTextIter * gtk_text_iter_copy () +// void gtk_text_iter_assign () +// void gtk_text_iter_free () +// GdkPixbuf * gtk_text_iter_get_pixbuf () +// GSList * gtk_text_iter_get_marks () +// GSList * gtk_text_iter_get_toggled_tags () +// GtkTextChildAnchor * gtk_text_iter_get_child_anchor () +// GSList * gtk_text_iter_get_tags () +// PangoLanguage * gtk_text_iter_get_language () diff --git a/vendor/github.com/gotk3/gotk3/gtk/text_mark.go b/vendor/github.com/gotk3/gotk3/gtk/text_mark.go new file mode 100644 index 0000000..dd48581 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/text_mark.go @@ -0,0 +1,97 @@ +// Same copyright and license as the rest of the files in this project + +package gtk + +// #include +// #include "gtk.go.h" +import "C" + +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + + WrapMap["GtkTextMark"] = wrapTextMark +} + +/* + * GtkTextMark + */ + +// TextMark is a representation of GTK's GtkTextMark. +// A position in the buffer preserved across buffer modifications +type TextMark struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkTextMark. +func (v *TextMark) native() *C.GtkTextMark { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTextMark(p) +} + +func marshalTextMark(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTextMark(obj), nil +} + +func wrapTextMark(obj *glib.Object) *TextMark { + if obj == nil { + return nil + } + + return &TextMark{obj} +} + +// TextMarkNew is a wrapper around gtk_text_mark_new(). +func TextMarkNew(name string, leftGravity bool) (*TextMark, error) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + + c := C.gtk_text_mark_new((*C.gchar)(cstr), gbool(leftGravity)) + if c == nil { + return nil, nilPtrErr + } + return wrapTextMark(glib.Take(unsafe.Pointer(c))), nil +} + +// SetVisible is a wrapper around gtk_text_mark_set_visible(). +func (v *TextMark) SetVisible(setting bool) { + C.gtk_text_mark_set_visible(v.native(), gbool(setting)) +} + +// GetVisible is a wrapper around gtk_text_mark_get_visible(). +func (v *TextMark) GetVisible() bool { + return gobool(C.gtk_text_mark_get_visible(v.native())) +} + +// GetDeleted is a wrapper around gtk_text_mark_get_deleted(). +func (v *TextMark) GetDeleted() bool { + return gobool(C.gtk_text_mark_get_deleted(v.native())) +} + +// GetName is a wrapper around gtk_text_mark_get_name(). +func (v *TextMark) GetName() string { + return goString(C.gtk_text_mark_get_name(v.native())) +} + +// GetBuffer is a wrapper around gtk_text_mark_get_buffer(). +func (v *TextMark) GetBuffer() (*TextBuffer, error) { + c := C.gtk_text_mark_get_buffer(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapTextBuffer(glib.Take(unsafe.Pointer(c))), nil +} + +// GetLeftGravity is a wrapper around gtk_text_mark_get_left_gravity(). +func (v *TextMark) GetLeftGravity() bool { + return gobool(C.gtk_text_mark_get_left_gravity(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/text_view.go b/vendor/github.com/gotk3/gotk3/gtk/text_view.go new file mode 100644 index 0000000..5450304 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/text_view.go @@ -0,0 +1,448 @@ +// Same copyright and license as the rest of the files in this project + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/pango" +) + +func init() { + + tm := []glib.TypeMarshaler{ + {glib.Type(C.gtk_text_window_type_get_type()), marshalTextWindowType}, + } + + glib.RegisterGValueMarshalers(tm) +} + +// TextWindowType is a representation of GTK's GtkTextWindowType. +type TextWindowType int + +const ( + TEXT_WINDOW_PRIVATE TextWindowType = C.GTK_TEXT_WINDOW_PRIVATE + TEXT_WINDOW_WIDGET TextWindowType = C.GTK_TEXT_WINDOW_WIDGET + TEXT_WINDOW_TEXT TextWindowType = C.GTK_TEXT_WINDOW_TEXT + TEXT_WINDOW_LEFT TextWindowType = C.GTK_TEXT_WINDOW_LEFT + TEXT_WINDOW_RIGHT TextWindowType = C.GTK_TEXT_WINDOW_RIGHT + TEXT_WINDOW_TOP TextWindowType = C.GTK_TEXT_WINDOW_TOP + TEXT_WINDOW_BOTTOM TextWindowType = C.GTK_TEXT_WINDOW_BOTTOM +) + +func marshalTextWindowType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return TextWindowType(c), nil +} + +/* + * GtkTextView + */ + +// TextView is a representation of GTK's GtkTextView +type TextView struct { + Container +} + +// native returns a pointer to the underlying GtkTextView. +func (v *TextView) native() *C.GtkTextView { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTextView(p) +} + +func marshalTextView(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTextView(obj), nil +} + +func wrapTextView(obj *glib.Object) *TextView { + if obj == nil { + return nil + } + + return &TextView{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +// TextViewNew is a wrapper around gtk_text_view_new(). +func TextViewNew() (*TextView, error) { + c := C.gtk_text_view_new() + if c == nil { + return nil, nilPtrErr + } + return wrapTextView(glib.Take(unsafe.Pointer(c))), nil +} + +// TextViewNewWithBuffer is a wrapper around gtk_text_view_new_with_buffer(). +func TextViewNewWithBuffer(buf *TextBuffer) (*TextView, error) { + cbuf := buf.native() + c := C.gtk_text_view_new_with_buffer(cbuf) + return wrapTextView(glib.Take(unsafe.Pointer(c))), nil +} + +// GetBuffer is a wrapper around gtk_text_view_get_buffer(). +func (v *TextView) GetBuffer() (*TextBuffer, error) { + c := C.gtk_text_view_get_buffer(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapTextBuffer(glib.Take(unsafe.Pointer(c))), nil +} + +// SetBuffer is a wrapper around gtk_text_view_set_buffer(). +func (v *TextView) SetBuffer(buffer *TextBuffer) { + C.gtk_text_view_set_buffer(v.native(), buffer.native()) +} + +// SetEditable is a wrapper around gtk_text_view_set_editable(). +func (v *TextView) SetEditable(editable bool) { + C.gtk_text_view_set_editable(v.native(), gbool(editable)) +} + +// GetEditable is a wrapper around gtk_text_view_get_editable(). +func (v *TextView) GetEditable() bool { + c := C.gtk_text_view_get_editable(v.native()) + return gobool(c) +} + +// SetWrapMode is a wrapper around gtk_text_view_set_wrap_mode(). +func (v *TextView) SetWrapMode(wrapMode WrapMode) { + C.gtk_text_view_set_wrap_mode(v.native(), C.GtkWrapMode(wrapMode)) +} + +// GetWrapMode is a wrapper around gtk_text_view_get_wrap_mode(). +func (v *TextView) GetWrapMode() WrapMode { + return WrapMode(C.gtk_text_view_get_wrap_mode(v.native())) +} + +// SetCursorVisible is a wrapper around gtk_text_view_set_cursor_visible(). +func (v *TextView) SetCursorVisible(visible bool) { + C.gtk_text_view_set_cursor_visible(v.native(), gbool(visible)) +} + +// GetCursorVisible is a wrapper around gtk_text_view_get_cursor_visible(). +func (v *TextView) GetCursorVisible() bool { + c := C.gtk_text_view_get_cursor_visible(v.native()) + return gobool(c) +} + +// SetOverwrite is a wrapper around gtk_text_view_set_overwrite(). +func (v *TextView) SetOverwrite(overwrite bool) { + C.gtk_text_view_set_overwrite(v.native(), gbool(overwrite)) +} + +// GetOverwrite is a wrapper around gtk_text_view_get_overwrite(). +func (v *TextView) GetOverwrite() bool { + c := C.gtk_text_view_get_overwrite(v.native()) + return gobool(c) +} + +// SetJustification is a wrapper around gtk_text_view_set_justification(). +func (v *TextView) SetJustification(justify Justification) { + C.gtk_text_view_set_justification(v.native(), C.GtkJustification(justify)) +} + +// GetJustification is a wrapper around gtk_text_view_get_justification(). +func (v *TextView) GetJustification() Justification { + c := C.gtk_text_view_get_justification(v.native()) + return Justification(c) +} + +// SetAcceptsTab is a wrapper around gtk_text_view_set_accepts_tab(). +func (v *TextView) SetAcceptsTab(acceptsTab bool) { + C.gtk_text_view_set_accepts_tab(v.native(), gbool(acceptsTab)) +} + +// GetAcceptsTab is a wrapper around gtk_text_view_get_accepts_tab(). +func (v *TextView) GetAcceptsTab() bool { + c := C.gtk_text_view_get_accepts_tab(v.native()) + return gobool(c) +} + +// SetPixelsAboveLines is a wrapper around gtk_text_view_set_pixels_above_lines(). +func (v *TextView) SetPixelsAboveLines(px int) { + C.gtk_text_view_set_pixels_above_lines(v.native(), C.gint(px)) +} + +// GetPixelsAboveLines is a wrapper around gtk_text_view_get_pixels_above_lines(). +func (v *TextView) GetPixelsAboveLines() int { + c := C.gtk_text_view_get_pixels_above_lines(v.native()) + return int(c) +} + +// SetPixelsBelowLines is a wrapper around gtk_text_view_set_pixels_below_lines(). +func (v *TextView) SetPixelsBelowLines(px int) { + C.gtk_text_view_set_pixels_below_lines(v.native(), C.gint(px)) +} + +// GetPixelsBelowLines is a wrapper around gtk_text_view_get_pixels_below_lines(). +func (v *TextView) GetPixelsBelowLines() int { + c := C.gtk_text_view_get_pixels_below_lines(v.native()) + return int(c) +} + +// SetPixelsInsideWrap is a wrapper around gtk_text_view_set_pixels_inside_wrap(). +func (v *TextView) SetPixelsInsideWrap(px int) { + C.gtk_text_view_set_pixels_inside_wrap(v.native(), C.gint(px)) +} + +// GetPixelsInsideWrap is a wrapper around gtk_text_view_get_pixels_inside_wrap(). +func (v *TextView) GetPixelsInsideWrap() int { + c := C.gtk_text_view_get_pixels_inside_wrap(v.native()) + return int(c) +} + +// SetLeftMargin is a wrapper around gtk_text_view_set_left_margin(). +func (v *TextView) SetLeftMargin(margin int) { + C.gtk_text_view_set_left_margin(v.native(), C.gint(margin)) +} + +// GetLeftMargin is a wrapper around gtk_text_view_get_left_margin(). +func (v *TextView) GetLeftMargin() int { + c := C.gtk_text_view_get_left_margin(v.native()) + return int(c) +} + +// SetRightMargin is a wrapper around gtk_text_view_set_right_margin(). +func (v *TextView) SetRightMargin(margin int) { + C.gtk_text_view_set_right_margin(v.native(), C.gint(margin)) +} + +// GetRightMargin is a wrapper around gtk_text_view_get_right_margin(). +func (v *TextView) GetRightMargin() int { + c := C.gtk_text_view_get_right_margin(v.native()) + return int(c) +} + +// SetIndent is a wrapper around gtk_text_view_set_indent(). +func (v *TextView) SetIndent(indent int) { + C.gtk_text_view_set_indent(v.native(), C.gint(indent)) +} + +// GetIndent is a wrapper around gtk_text_view_get_indent(). +func (v *TextView) GetIndent() int { + c := C.gtk_text_view_get_indent(v.native()) + return int(c) +} + +// SetTabs is a wrapper around gtk_text_view_set_tabs(). +func (v *TextView) SetTabs(tabs *pango.TabArray) { + C.gtk_text_view_set_tabs(v.native(), (*C.PangoTabArray)(unsafe.Pointer(tabs.Native()))) +} + +// GetTabs is a wrapper around gtk_text_view_get_tabs(). +func (v *TextView) GetTabs() (*pango.TabArray, error) { + c := C.gtk_text_view_get_tabs(v.native()) + if c == nil { + return nil, nilPtrErr + } + ta := pango.WrapTabArray(uintptr(unsafe.Pointer(c))) + runtime.SetFinalizer(ta, (*pango.TabArray).Free) + return ta, nil +} + +// SetInputHints is a wrapper around gtk_text_view_set_input_hints(). +func (v *TextView) SetInputHints(hints InputHints) { + C.gtk_text_view_set_input_hints(v.native(), C.GtkInputHints(hints)) +} + +// GetInputHints is a wrapper around gtk_text_view_get_input_hints(). +func (v *TextView) GetInputHints() InputHints { + c := C.gtk_text_view_get_input_hints(v.native()) + return InputHints(c) +} + +// SetInputPurpose is a wrapper around gtk_text_view_set_input_purpose(). +func (v *TextView) SetInputPurpose(purpose InputPurpose) { + C.gtk_text_view_set_input_purpose(v.native(), + C.GtkInputPurpose(purpose)) +} + +// GetInputPurpose is a wrapper around gtk_text_view_get_input_purpose(). +func (v *TextView) GetInputPurpose() InputPurpose { + c := C.gtk_text_view_get_input_purpose(v.native()) + return InputPurpose(c) +} + +// ScrollToMark is a wrapper around gtk_text_view_scroll_to_mark(). +func (v *TextView) ScrollToMark(mark *TextMark, within_margin float64, use_align bool, xalign, yalign float64) { + C.gtk_text_view_scroll_to_mark(v.native(), mark.native(), C.gdouble(within_margin), gbool(use_align), C.gdouble(xalign), C.gdouble(yalign)) +} + +// ScrollToIter is a wrapper around gtk_text_view_scroll_to_iter(). +func (v *TextView) ScrollToIter(iter *TextIter, within_margin float64, use_align bool, xalign, yalign float64) bool { + return gobool(C.gtk_text_view_scroll_to_iter(v.native(), iter.native(), C.gdouble(within_margin), gbool(use_align), C.gdouble(xalign), C.gdouble(yalign))) +} + +// ScrollMarkOnscreen is a wrapper around gtk_text_view_scroll_mark_onscreen(). +func (v *TextView) ScrollMarkOnscreen(mark *TextMark) { + C.gtk_text_view_scroll_mark_onscreen(v.native(), mark.native()) +} + +// MoveMarkOnscreen is a wrapper around gtk_text_view_move_mark_onscreen(). +func (v *TextView) MoveMarkOnscreen(mark *TextMark) bool { + return gobool(C.gtk_text_view_move_mark_onscreen(v.native(), mark.native())) +} + +// PlaceCursorOnscreen is a wrapper around gtk_text_view_place_cursor_onscreen(). +func (v *TextView) PlaceCursorOnscreen() bool { + return gobool(C.gtk_text_view_place_cursor_onscreen(v.native())) +} + +// GetVisibleRect is a wrapper around gtk_text_view_get_visible_rect(). +func (v *TextView) GetVisibleRect() *gdk.Rectangle { + var rect C.GdkRectangle + C.gtk_text_view_get_visible_rect(v.native(), &rect) + return gdk.WrapRectangle(uintptr(unsafe.Pointer(&rect))) +} + +// GetIterLocation is a wrapper around gtk_text_view_get_iter_location(). +func (v *TextView) GetIterLocation(iter *TextIter) *gdk.Rectangle { + var rect C.GdkRectangle + C.gtk_text_view_get_iter_location(v.native(), iter.native(), &rect) + return gdk.WrapRectangle(uintptr(unsafe.Pointer(&rect))) +} + +// GetCursorLocations is a wrapper around gtk_text_view_get_cursor_locations(). +func (v *TextView) GetCursorLocations(iter *TextIter) (strong, weak *gdk.Rectangle) { + var strongRect, weakRect C.GdkRectangle + C.gtk_text_view_get_cursor_locations(v.native(), iter.native(), &strongRect, &weakRect) + return gdk.WrapRectangle(uintptr(unsafe.Pointer(&strongRect))), gdk.WrapRectangle(uintptr(unsafe.Pointer(&weakRect))) +} + +// GetLineAtY is a wrapper around gtk_text_view_get_line_at_y(). +func (v *TextView) GetLineAtY(y int) (*TextIter, int) { + var iter TextIter + var line_top C.gint + iiter := (C.GtkTextIter)(iter) + C.gtk_text_view_get_line_at_y(v.native(), &iiter, C.gint(y), &line_top) + return &iter, int(line_top) +} + +// GetLineYrange is a wrapper around gtk_text_view_get_line_yrange(). +func (v *TextView) GetLineYrange(iter *TextIter) (y, height int) { + var yx, heightx C.gint + C.gtk_text_view_get_line_yrange(v.native(), iter.native(), &yx, &heightx) + return int(yx), int(heightx) +} + +// GetIterAtLocation is a wrapper around gtk_text_view_get_iter_at_location(). +func (v *TextView) GetIterAtLocation(x, y int) *TextIter { + var iter C.GtkTextIter + C.gtk_text_view_get_iter_at_location(v.native(), &iter, C.gint(x), C.gint(y)) + return (*TextIter)(&iter) +} + +// GetIterAtPosition is a wrapper around gtk_text_view_get_iter_at_position(). +func (v *TextView) GetIterAtPosition(x, y int) (*TextIter, int) { + var iter C.GtkTextIter + var trailing C.gint + C.gtk_text_view_get_iter_at_position(v.native(), &iter, &trailing, C.gint(x), C.gint(y)) + return (*TextIter)(&iter), int(trailing) +} + +// BufferToWindowCoords is a wrapper around gtk_text_view_buffer_to_window_coords(). +func (v *TextView) BufferToWindowCoords(win TextWindowType, buffer_x, buffer_y int) (window_x, window_y int) { + var wx, wy C.gint + C.gtk_text_view_buffer_to_window_coords(v.native(), C.GtkTextWindowType(win), C.gint(buffer_x), C.gint(buffer_y), &wx, &wy) + return int(wx), int(wy) +} + +// WindowToBufferCoords is a wrapper around gtk_text_view_window_to_buffer_coords(). +func (v *TextView) WindowToBufferCoords(win TextWindowType, window_x, window_y int) (buffer_x, buffer_y int) { + var bx, by C.gint + C.gtk_text_view_window_to_buffer_coords(v.native(), C.GtkTextWindowType(win), C.gint(window_x), C.gint(window_y), &bx, &by) + return int(bx), int(by) +} + +// GetWindow is a wrapper around gtk_text_view_get_window(). +func (v *TextView) GetWindow(win TextWindowType) *gdk.Window { + c := C.gtk_text_view_get_window(v.native(), C.GtkTextWindowType(win)) + if c == nil { + return nil + } + return &gdk.Window{glib.Take(unsafe.Pointer(c))} +} + +// GetWindowType is a wrapper around gtk_text_view_get_window_type(). +func (v *TextView) GetWindowType(w *gdk.Window) TextWindowType { + return TextWindowType(C.gtk_text_view_get_window_type(v.native(), (*C.GdkWindow)(unsafe.Pointer(w.Native())))) +} + +// SetBorderWindowSize is a wrapper around gtk_text_view_set_border_window_size(). +func (v *TextView) SetBorderWindowSize(tp TextWindowType, size int) { + C.gtk_text_view_set_border_window_size(v.native(), C.GtkTextWindowType(tp), C.gint(size)) +} + +// GetBorderWindowSize is a wrapper around gtk_text_view_get_border_window_size(). +func (v *TextView) GetBorderWindowSize(tp TextWindowType) int { + return int(C.gtk_text_view_get_border_window_size(v.native(), C.GtkTextWindowType(tp))) +} + +// ForwardDisplayLine is a wrapper around gtk_text_view_forward_display_line(). +func (v *TextView) ForwardDisplayLine(iter *TextIter) bool { + return gobool(C.gtk_text_view_forward_display_line(v.native(), iter.native())) +} + +// BackwardDisplayLine is a wrapper around gtk_text_view_backward_display_line(). +func (v *TextView) BackwardDisplayLine(iter *TextIter) bool { + return gobool(C.gtk_text_view_backward_display_line(v.native(), iter.native())) +} + +// ForwardDisplayLineEnd is a wrapper around gtk_text_view_forward_display_line_end(). +func (v *TextView) ForwardDisplayLineEnd(iter *TextIter) bool { + return gobool(C.gtk_text_view_forward_display_line_end(v.native(), iter.native())) +} + +// BackwardDisplayLineStart is a wrapper around gtk_text_view_backward_display_line_start(). +func (v *TextView) BackwardDisplayLineStart(iter *TextIter) bool { + return gobool(C.gtk_text_view_backward_display_line_start(v.native(), iter.native())) +} + +// StartsDisplayLine is a wrapper around gtk_text_view_starts_display_line(). +func (v *TextView) StartsDisplayLine(iter *TextIter) bool { + return gobool(C.gtk_text_view_starts_display_line(v.native(), iter.native())) +} + +// MoveVisually is a wrapper around gtk_text_view_move_visually(). +func (v *TextView) MoveVisually(iter *TextIter, count int) bool { + return gobool(C.gtk_text_view_move_visually(v.native(), iter.native(), C.gint(count))) +} + +// AddChildInWindow is a wrapper around gtk_text_view_add_child_in_window(). +func (v *TextView) AddChildInWindow(child IWidget, tp TextWindowType, xpos, ypos int) { + C.gtk_text_view_add_child_in_window(v.native(), child.toWidget(), C.GtkTextWindowType(tp), C.gint(xpos), C.gint(ypos)) +} + +// MoveChild is a wrapper around gtk_text_view_move_child(). +func (v *TextView) MoveChild(child IWidget, xpos, ypos int) { + C.gtk_text_view_move_child(v.native(), child.toWidget(), C.gint(xpos), C.gint(ypos)) +} + +// ImContextFilterKeypress is a wrapper around gtk_text_view_im_context_filter_keypress(). +func (v *TextView) ImContextFilterKeypress(event *gdk.EventKey) bool { + return gobool(C.gtk_text_view_im_context_filter_keypress(v.native(), (*C.GdkEventKey)(unsafe.Pointer(event.Native())))) +} + +// ResetImContext is a wrapper around gtk_text_view_reset_im_context(). +func (v *TextView) ResetImContext() { + C.gtk_text_view_reset_im_context(v.native()) +} + +// AddChildAtAnchor is a wrapper around gtk_text_view_add_child_at_anchor(). +func (v *TextView) AddChildAtAnchor(child IWidget, anchor *TextChildAnchor) { + C.gtk_text_view_add_child_at_anchor(v.native(), child.toWidget(), anchor.native()) +} + +// TODO: +// GtkTextAttributes * gtk_text_view_get_default_attributes () -- GtkTextAttributes +// GtkTextViewLayer diff --git a/vendor/github.com/gotk3/gotk3/gtk/toolshell.go b/vendor/github.com/gotk3/gotk3/gtk/toolshell.go new file mode 100644 index 0000000..11f651f --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/toolshell.go @@ -0,0 +1,13 @@ +package gtk + +// TODO: +// GtkToolShellIface +// gtk_tool_shell_get_ellipsize_mode(). +// gtk_tool_shell_get_icon_size(). +// gtk_tool_shell_get_orientation(). +// gtk_tool_shell_get_relief_style(). +// gtk_tool_shell_get_style(). +// gtk_tool_shell_get_text_alignment(). +// gtk_tool_shell_get_text_orientation(). +// gtk_tool_shell_rebuild_menu(). +// gtk_tool_shell_get_text_size_group(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/tooltip.go b/vendor/github.com/gotk3/gotk3/gtk/tooltip.go new file mode 100644 index 0000000..9283b2e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/tooltip.go @@ -0,0 +1,83 @@ +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +/* + * GtkTooltip + */ + +type Tooltip struct { + Widget +} + +// native returns a pointer to the underlying GtkIconView. +func (t *Tooltip) native() *C.GtkTooltip { + if t == nil || t.GObject == nil { + return nil + } + p := unsafe.Pointer(t.GObject) + return C.toGtkTooltip(p) +} + +func marshalTooltip(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTooltip(obj), nil +} + +func wrapTooltip(obj *glib.Object) *Tooltip { + if obj == nil { + return nil + } + + return &Tooltip{Widget{glib.InitiallyUnowned{obj}}} +} + +// SetMarkup is a wrapper around gtk_tooltip_set_markup(). +func (t *Tooltip) SetMarkup(str string) { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_tooltip_set_markup(t.native(), (*C.gchar)(cstr)) +} + +// SetText is a wrapper around gtk_tooltip_set_text(). +func (t *Tooltip) SetText(str string) { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_tooltip_set_text(t.native(), (*C.gchar)(cstr)) +} + +// SetIcon is a wrapper around gtk_tooltip_set_icon(). +func (t *Tooltip) SetIcon(pixbuf *gdk.Pixbuf) { + C.gtk_tooltip_set_icon(t.native(), + (*C.GdkPixbuf)(unsafe.Pointer(pixbuf.Native()))) +} + +// SetIconFromIconName is a wrapper around gtk_tooltip_set_icon_from_icon_name(). +func (t *Tooltip) SetIconFromIconName(iconName string, size IconSize) { + cstr := C.CString(iconName) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_tooltip_set_icon_from_icon_name(t.native(), + (*C.gchar)(cstr), + C.GtkIconSize(size)) +} + +// func (t *Tooltip) SetIconFromGIcon() { } + +// SetCustom is a wrapper around gtk_tooltip_set_custom(). +func (t *Tooltip) SetCustom(w *Widget) { + C.gtk_tooltip_set_custom(t.native(), w.native()) +} + +// SetTipArea is a wrapper around gtk_tooltip_set_tip_area(). +func (t *Tooltip) SetTipArea(rect gdk.Rectangle) { + C.gtk_tooltip_set_tip_area(t.native(), nativeGdkRectangle(rect)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/tree_view.go b/vendor/github.com/gotk3/gotk3/gtk/tree_view.go new file mode 100644 index 0000000..96817f7 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/tree_view.go @@ -0,0 +1,657 @@ +// Same copyright and license as the rest of the files in this project +// This file contains accelerator related functions and structures + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "runtime" + "strings" + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/internal/callback" +) + +/* + * GtkTreeView + */ + +// TreeView is a representation of GTK's GtkTreeView. +type TreeView struct { + Container +} + +// native returns a pointer to the underlying GtkTreeView. +func (v *TreeView) native() *C.GtkTreeView { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTreeView(p) +} + +func marshalTreeView(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTreeView(obj), nil +} + +func wrapTreeView(obj *glib.Object) *TreeView { + if obj == nil { + return nil + } + + return &TreeView{Container{Widget{glib.InitiallyUnowned{obj}}}} +} + +func setupTreeView(c unsafe.Pointer) (*TreeView, error) { + if c == nil { + return nil, nilPtrErr + } + + return wrapTreeView(glib.Take(c)), nil +} + +// TreeViewNew is a wrapper around gtk_tree_view_new(). +func TreeViewNew() (*TreeView, error) { + return setupTreeView(unsafe.Pointer(C.gtk_tree_view_new())) +} + +// TreeViewNewWithModel is a wrapper around gtk_tree_view_new_with_model(). +func TreeViewNewWithModel(model ITreeModel) (*TreeView, error) { + return setupTreeView(unsafe.Pointer(C.gtk_tree_view_new_with_model(model.toTreeModel()))) +} + +// GetModel is a wrapper around gtk_tree_view_get_model(). +func (v *TreeView) GetModel() (ITreeModel, error) { + c := C.gtk_tree_view_get_model(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castTreeModel(c) +} + +// SetModel is a wrapper around gtk_tree_view_set_model(). +func (v *TreeView) SetModel(model ITreeModel) { + var mptr *C.GtkTreeModel + if model != nil { + mptr = model.toTreeModel() + } + C.gtk_tree_view_set_model(v.native(), mptr) +} + +// GetSelection is a wrapper around gtk_tree_view_get_selection(). +func (v *TreeView) GetSelection() (*TreeSelection, error) { + c := C.gtk_tree_view_get_selection(v.native()) + if c == nil { + return nil, nilPtrErr + } + return wrapTreeSelection(glib.Take(unsafe.Pointer(c))), nil +} + +// AppendColumn is a wrapper around gtk_tree_view_append_column(). +func (v *TreeView) AppendColumn(column *TreeViewColumn) int { + c := C.gtk_tree_view_append_column(v.native(), column.native()) + return int(c) +} + +// GetPathAtPos is a wrapper around gtk_tree_view_get_path_at_pos(). +func (v *TreeView) GetPathAtPos(x, y int) (*TreePath, *TreeViewColumn, int, int, bool) { + var ( + cpath *C.GtkTreePath + ccol *C.GtkTreeViewColumn + ccellX, ccellY *C.gint + cellX, cellY int + ) + path := new(TreePath) + column := new(TreeViewColumn) + + cbool := C.gtk_tree_view_get_path_at_pos( + v.native(), + (C.gint)(x), + (C.gint)(y), + &cpath, + &ccol, + ccellX, + ccellY) + + if cpath != nil { + path = &TreePath{cpath} + runtime.SetFinalizer(path, (*TreePath).free) + } + if ccol != nil { + column = wrapTreeViewColumn(glib.Take(unsafe.Pointer(ccol))) + } + if ccellX != nil { + cellX = int(*((*C.gint)(unsafe.Pointer(ccellX)))) + } + if ccellY != nil { + cellY = int(*((*C.gint)(unsafe.Pointer(ccellY)))) + } + return path, column, cellX, cellY, gobool(cbool) +} + +// GetCellArea is a wrapper around gtk_tree_view_get_cell_area(). +func (v *TreeView) GetCellArea(path *TreePath, column *TreeViewColumn) *gdk.Rectangle { + ctp := path.native() + pctvcol := column.native() + + var rect C.GdkRectangle + + C.gtk_tree_view_get_cell_area(v.native(), ctp, pctvcol, &rect) + + return gdk.WrapRectangle(uintptr(unsafe.Pointer(&rect))) +} + +// GetLevelIndentation is a wrapper around gtk_tree_view_get_level_indentation(). +func (v *TreeView) GetLevelIndentation() int { + return int(C.gtk_tree_view_get_level_indentation(v.native())) +} + +// GetShowExpanders is a wrapper around gtk_tree_view_get_show_expanders(). +func (v *TreeView) GetShowExpanders() bool { + return gobool(C.gtk_tree_view_get_show_expanders(v.native())) +} + +// SetLevelIndentation is a wrapper around gtk_tree_view_set_level_indentation(). +func (v *TreeView) SetLevelIndentation(indent int) { + C.gtk_tree_view_set_level_indentation(v.native(), C.gint(indent)) +} + +// SetShowExpanders is a wrapper around gtk_tree_view_set_show_expanders(). +func (v *TreeView) SetShowExpanders(show bool) { + C.gtk_tree_view_set_show_expanders(v.native(), gbool(show)) +} + +// GetHeadersVisible is a wrapper around gtk_tree_view_get_headers_visible(). +func (v *TreeView) GetHeadersVisible() bool { + return gobool(C.gtk_tree_view_get_headers_visible(v.native())) +} + +// SetHeadersVisible is a wrapper around gtk_tree_view_set_headers_visible(). +func (v *TreeView) SetHeadersVisible(show bool) { + C.gtk_tree_view_set_headers_visible(v.native(), gbool(show)) +} + +// ColumnsAutosize is a wrapper around gtk_tree_view_columns_autosize(). +func (v *TreeView) ColumnsAutosize() { + C.gtk_tree_view_columns_autosize(v.native()) +} + +// GetHeadersClickable is a wrapper around gtk_tree_view_get_headers_clickable(). +func (v *TreeView) GetHeadersClickable() bool { + return gobool(C.gtk_tree_view_get_headers_clickable(v.native())) +} + +// SetHeadersClickable is a wrapper around gtk_tree_view_set_headers_clickable(). +func (v *TreeView) SetHeadersClickable(show bool) { + C.gtk_tree_view_set_headers_clickable(v.native(), gbool(show)) +} + +// GetActivateOnSingleClick is a wrapper around gtk_tree_view_get_activate_on_single_click(). +func (v *TreeView) GetActivateOnSingleClick() bool { + return gobool(C.gtk_tree_view_get_activate_on_single_click(v.native())) +} + +// SetActivateOnSingleClick is a wrapper around gtk_tree_view_set_activate_on_single_click(). +func (v *TreeView) SetActivateOnSingleClick(show bool) { + C.gtk_tree_view_set_activate_on_single_click(v.native(), gbool(show)) +} + +// RemoveColumn is a wrapper around gtk_tree_view_remove_column(). +func (v *TreeView) RemoveColumn(column *TreeViewColumn) int { + return int(C.gtk_tree_view_remove_column(v.native(), column.native())) +} + +// InsertColumn is a wrapper around gtk_tree_view_insert_column(). +func (v *TreeView) InsertColumn(column *TreeViewColumn, pos int) int { + return int(C.gtk_tree_view_insert_column(v.native(), column.native(), C.gint(pos))) +} + +// GetNColumns is a wrapper around gtk_tree_view_get_n_columns(). +func (v *TreeView) GetNColumns() uint { + return uint(C.gtk_tree_view_get_n_columns(v.native())) +} + +// GetColumn is a wrapper around gtk_tree_view_get_column(). +func (v *TreeView) GetColumn(n int) *TreeViewColumn { + c := C.gtk_tree_view_get_column(v.native(), C.gint(n)) + if c == nil { + return nil + } + return wrapTreeViewColumn(glib.Take(unsafe.Pointer(c))) +} + +// GetColumns is a wrapper around gtk_tree_view_get_columns(). +func (v *TreeView) GetColumns() *glib.List { + clist := C.gtk_tree_view_get_columns(v.native()) + if clist == nil { + return nil + } + + list := glib.WrapList(uintptr(unsafe.Pointer(clist))) + list.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return wrapTreeViewColumn(glib.Take(unsafe.Pointer(ptr))) + }) + runtime.SetFinalizer(list, func(glist *glib.List) { + glist.Free() + }) + + return list +} + +// MoveColumnAfter is a wrapper around gtk_tree_view_move_column_after(). +func (v *TreeView) MoveColumnAfter(column *TreeViewColumn, baseColumn *TreeViewColumn) { + C.gtk_tree_view_move_column_after(v.native(), column.native(), baseColumn.native()) +} + +// SetExpanderColumn is a wrapper around gtk_tree_view_set_expander_column(). +func (v *TreeView) SetExpanderColumn(column *TreeViewColumn) { + C.gtk_tree_view_set_expander_column(v.native(), column.native()) +} + +// GetExpanderColumn is a wrapper around gtk_tree_view_get_expander_column(). +func (v *TreeView) GetExpanderColumn() *TreeViewColumn { + c := C.gtk_tree_view_get_expander_column(v.native()) + if c == nil { + return nil + } + return wrapTreeViewColumn(glib.Take(unsafe.Pointer(c))) +} + +// ScrollToPoint is a wrapper around gtk_tree_view_scroll_to_point(). +func (v *TreeView) ScrollToPoint(treeX, treeY int) { + C.gtk_tree_view_scroll_to_point(v.native(), C.gint(treeX), C.gint(treeY)) +} + +// SetCursor is a wrapper around gtk_tree_view_set_cursor(). +func (v *TreeView) SetCursor(path *TreePath, focusColumn *TreeViewColumn, startEditing bool) { + C.gtk_tree_view_set_cursor(v.native(), path.native(), focusColumn.native(), gbool(startEditing)) +} + +// SetCursorOnCell is a wrapper around gtk_tree_view_set_cursor_on_cell(). +func (v *TreeView) SetCursorOnCell(path *TreePath, focusColumn *TreeViewColumn, focusCell *CellRenderer, startEditing bool) { + C.gtk_tree_view_set_cursor_on_cell(v.native(), path.native(), focusColumn.native(), focusCell.native(), gbool(startEditing)) +} + +// GetCursor is a wrapper around gtk_tree_view_get_cursor(). +func (v *TreeView) GetCursor() (p *TreePath, c *TreeViewColumn) { + var path *C.GtkTreePath + var col *C.GtkTreeViewColumn + + C.gtk_tree_view_get_cursor(v.native(), &path, &col) + + if path != nil { + p = &TreePath{path} + runtime.SetFinalizer(p, (*TreePath).free) + } + + if col != nil { + c = wrapTreeViewColumn(glib.Take(unsafe.Pointer(col))) + } + + return +} + +// RowActivated is a wrapper around gtk_tree_view_row_activated(). +func (v *TreeView) RowActivated(path *TreePath, column *TreeViewColumn) { + C.gtk_tree_view_row_activated(v.native(), path.native(), column.native()) +} + +// ExpandAll is a wrapper around gtk_tree_view_expand_all(). +func (v *TreeView) ExpandAll() { + C.gtk_tree_view_expand_all(v.native()) +} + +// CollapseAll is a wrapper around gtk_tree_view_collapse_all(). +func (v *TreeView) CollapseAll() { + C.gtk_tree_view_collapse_all(v.native()) +} + +// ExpandToPath is a wrapper around gtk_tree_view_expand_to_path(). +func (v *TreeView) ExpandToPath(path *TreePath) { + C.gtk_tree_view_expand_to_path(v.native(), path.native()) +} + +// ExpandRow is a wrapper around gtk_tree_view_expand_row(). +func (v *TreeView) ExpandRow(path *TreePath, openAll bool) bool { + return gobool(C.gtk_tree_view_expand_row(v.native(), path.native(), gbool(openAll))) +} + +// CollapseRow is a wrapper around gtk_tree_view_collapse_row(). +func (v *TreeView) CollapseRow(path *TreePath) bool { + return gobool(C.gtk_tree_view_collapse_row(v.native(), path.native())) +} + +// RowExpanded is a wrapper around gtk_tree_view_row_expanded(). +func (v *TreeView) RowExpanded(path *TreePath) bool { + return gobool(C.gtk_tree_view_row_expanded(v.native(), path.native())) +} + +// SetReorderable is a wrapper around gtk_tree_view_set_reorderable(). +func (v *TreeView) SetReorderable(b bool) { + C.gtk_tree_view_set_reorderable(v.native(), gbool(b)) +} + +// GetReorderable is a wrapper around gtk_tree_view_get_reorderable(). +func (v *TreeView) GetReorderable() bool { + return gobool(C.gtk_tree_view_get_reorderable(v.native())) +} + +// GetBinWindow is a wrapper around gtk_tree_view_get_bin_window(). +func (v *TreeView) GetBinWindow() *gdk.Window { + c := C.gtk_tree_view_get_bin_window(v.native()) + if c == nil { + return nil + } + + w := &gdk.Window{glib.Take(unsafe.Pointer(c))} + return w +} + +// ConvertWidgetToBinWindowCoords is a rapper around gtk_tree_view_convert_widget_to_bin_window_coords(). +func (v *TreeView) ConvertWidgetToBinWindowCoords(wx, wy int, bx, by *int) { + C.gtk_tree_view_convert_widget_to_bin_window_coords( + v.native(), + (C.gint)(wx), + (C.gint)(wy), + (*C.gint)(unsafe.Pointer(bx)), + (*C.gint)(unsafe.Pointer(by))) +} + +// ConvertBinWindowToWidgetCoords is a rapper around gtk_tree_view_convert_bin_window_to_widget_coords(). +func (v *TreeView) ConvertBinWindowToWidgetCoords(bx, by int, wx, wy *int) { + C.gtk_tree_view_convert_bin_window_to_widget_coords(v.native(), + (C.gint)(bx), + (C.gint)(by), + (*C.gint)(unsafe.Pointer(wx)), + (*C.gint)(unsafe.Pointer(wy))) +} + +// ConvertBinWindowToTreeCoords is a wrapper around gtk_tree_view_convert_bin_window_to_tree_coords(). +func (v *TreeView) ConvertBinWindowToTreeCoords(bx, by int, tx, ty *int) { + C.gtk_tree_view_convert_bin_window_to_tree_coords(v.native(), + (C.gint)(bx), + (C.gint)(by), + (*C.gint)(unsafe.Pointer(tx)), + (*C.gint)(unsafe.Pointer(ty))) +} + +// SetEnableSearch is a wrapper around gtk_tree_view_set_enable_search(). +func (v *TreeView) SetEnableSearch(b bool) { + C.gtk_tree_view_set_enable_search(v.native(), gbool(b)) +} + +// GetEnableSearch is a wrapper around gtk_tree_view_get_enable_search(). +func (v *TreeView) GetEnableSearch() bool { + return gobool(C.gtk_tree_view_get_enable_search(v.native())) +} + +// SetSearchColumn is a wrapper around gtk_tree_view_set_search_column(). +func (v *TreeView) SetSearchColumn(c int) { + C.gtk_tree_view_set_search_column(v.native(), C.gint(c)) +} + +// GetSearchColumn is a wrapper around gtk_tree_view_get_search_column(). +func (v *TreeView) GetSearchColumn() int { + return int(C.gtk_tree_view_get_search_column(v.native())) +} + +// GetSearchEntry is a wrapper around gtk_tree_view_get_search_entry(). +func (v *TreeView) GetSearchEntry() *Entry { + c := C.gtk_tree_view_get_search_entry(v.native()) + if c == nil { + return nil + } + return wrapEntry(glib.Take(unsafe.Pointer(c))) +} + +// SetSearchEntry is a wrapper around gtk_tree_view_set_search_entry(). +func (v *TreeView) SetSearchEntry(e *Entry) { + C.gtk_tree_view_set_search_entry(v.native(), e.native()) +} + +// TreeViewSearchEqualFunc is the callback type for TreeView's +// SetSearchEqualFunc. It is worth noting that the returned boolean should be +// false if the row matches. +type TreeViewSearchEqualFunc func(model *TreeModel, column int, key string, iter *TreeIter) (notMatch bool) + +// SetSearchEqualFunc is a wrapper around gtk_tree_view_set_search_equal_func(). +func (v *TreeView) SetSearchEqualFunc(f TreeViewSearchEqualFunc) { + C._gtk_tree_view_set_search_equal_func(v.native(), C.gpointer(callback.Assign(f))) +} + +// SetSearchEqualSubstringMatch calls SetSearchEqualFunc with a strings.Contains +// adapter. +func (v *TreeView) SetSearchEqualSubstringMatch() { + v.SetSearchEqualFunc(func(model *TreeModel, column int, key string, iter *TreeIter) bool { + return !strings.Contains(model.GetStringFromIter(iter), key) + }) +} + +// SetFixedHeightMode is a wrapper around gtk_tree_view_set_fixed_height_mode(). +func (v *TreeView) SetFixedHeightMode(b bool) { + C.gtk_tree_view_set_fixed_height_mode(v.native(), gbool(b)) +} + +// GetFixedHeightMode is a wrapper around gtk_tree_view_get_fixed_height_mode(). +func (v *TreeView) GetFixedHeightMode() bool { + return gobool(C.gtk_tree_view_get_fixed_height_mode(v.native())) +} + +// SetHoverSelection is a wrapper around gtk_tree_view_set_hover_selection(). +func (v *TreeView) SetHoverSelection(b bool) { + C.gtk_tree_view_set_hover_selection(v.native(), gbool(b)) +} + +// GetHoverSelection is a wrapper around gtk_tree_view_get_hover_selection(). +func (v *TreeView) GetHoverSelection() bool { + return gobool(C.gtk_tree_view_get_hover_selection(v.native())) +} + +// SetHoverExpand is a wrapper around gtk_tree_view_set_hover_expand(). +func (v *TreeView) SetHoverExpand(b bool) { + C.gtk_tree_view_set_hover_expand(v.native(), gbool(b)) +} + +// GetHoverExpand is a wrapper around gtk_tree_view_get_hover_expand(). +func (v *TreeView) GetHoverExpand() bool { + return gobool(C.gtk_tree_view_get_hover_expand(v.native())) +} + +// SetRubberBanding is a wrapper around gtk_tree_view_set_rubber_banding(). +func (v *TreeView) SetRubberBanding(b bool) { + C.gtk_tree_view_set_rubber_banding(v.native(), gbool(b)) +} + +// GetRubberBanding is a wrapper around gtk_tree_view_get_rubber_banding(). +func (v *TreeView) GetRubberBanding() bool { + return gobool(C.gtk_tree_view_get_rubber_banding(v.native())) +} + +// IsRubberBandingActive is a wrapper around gtk_tree_view_is_rubber_banding_active(). +func (v *TreeView) IsRubberBandingActive() bool { + return gobool(C.gtk_tree_view_is_rubber_banding_active(v.native())) +} + +// SetEnableTreeLines is a wrapper around gtk_tree_view_set_enable_tree_lines(). +func (v *TreeView) SetEnableTreeLines(b bool) { + C.gtk_tree_view_set_enable_tree_lines(v.native(), gbool(b)) +} + +// GetEnableTreeLines is a wrapper around gtk_tree_view_get_enable_tree_lines(). +func (v *TreeView) GetEnableTreeLines() bool { + return gobool(C.gtk_tree_view_get_enable_tree_lines(v.native())) +} + +// GetTooltipColumn is a wrapper around gtk_tree_view_get_tooltip_column(). +func (v *TreeView) GetTooltipColumn() int { + return int(C.gtk_tree_view_get_tooltip_column(v.native())) +} + +// SetTooltipColumn is a wrapper around gtk_tree_view_set_tooltip_column(). +func (v *TreeView) SetTooltipColumn(c int) { + C.gtk_tree_view_set_tooltip_column(v.native(), C.gint(c)) +} + +// SetGridLines is a wrapper around gtk_tree_view_set_grid_lines(). +func (v *TreeView) SetGridLines(gridLines TreeViewGridLines) { + C.gtk_tree_view_set_grid_lines(v.native(), C.GtkTreeViewGridLines(gridLines)) +} + +// GetGridLines is a wrapper around gtk_tree_view_get_grid_lines(). +func (v *TreeView) GetGridLines() TreeViewGridLines { + return TreeViewGridLines(C.gtk_tree_view_get_grid_lines(v.native())) +} + +// IsBlankAtPos is a wrapper around gtk_tree_view_is_blank_at_pos(). +func (v *TreeView) IsBlankAtPos(x, y int) (*TreePath, *TreeViewColumn, int, int, bool) { + var ( + cpath *C.GtkTreePath + ccol *C.GtkTreeViewColumn + ccellX, ccellY *C.gint + cellX, cellY int + ) + path := new(TreePath) + column := new(TreeViewColumn) + + cbool := C.gtk_tree_view_is_blank_at_pos( + v.native(), + (C.gint)(x), + (C.gint)(y), + &cpath, + &ccol, + ccellX, + ccellY) + + if cpath != nil { + path = &TreePath{cpath} + runtime.SetFinalizer(path, (*TreePath).free) + } + if ccol != nil { + column = wrapTreeViewColumn(glib.Take(unsafe.Pointer(ccol))) + } + if ccellX != nil { + cellX = int(*((*C.gint)(unsafe.Pointer(ccellX)))) + } + if ccellY != nil { + cellY = int(*((*C.gint)(unsafe.Pointer(ccellY)))) + } + return path, column, cellX, cellY, gobool(cbool) +} + +// ScrollToCell() is a wrapper around gtk_tree_view_scroll_to_cell(). +func (v *TreeView) ScrollToCell(path *TreePath, column *TreeViewColumn, align bool, xAlign, yAlign float32) { + C.gtk_tree_view_scroll_to_cell(v.native(), path.native(), column.native(), gbool(align), C.gfloat(xAlign), C.gfloat(yAlign)) +} + +// SetTooltipCell() is a wrapper around gtk_tree_view_set_tooltip_cell(). +func (v *TreeView) SetTooltipCell(tooltip *Tooltip, path *TreePath, column *TreeViewColumn, cell *CellRenderer) { + C.gtk_tree_view_set_tooltip_cell(v.native(), tooltip.native(), path.native(), column.native(), cell.native()) +} + +// SetTooltipRow() is a wrapper around gtk_tree_view_set_tooltip_row(). +func (v *TreeView) SetTooltipRow(tooltip *Tooltip, path *TreePath) { + C.gtk_tree_view_set_tooltip_row(v.native(), tooltip.native(), path.native()) +} + +// TreeViewDropPosition describes GtkTreeViewDropPosition. +type TreeViewDropPosition int + +const ( + TREE_VIEW_DROP_BEFORE TreeViewDropPosition = C.GTK_TREE_VIEW_DROP_BEFORE + TREE_VIEW_DROP_AFTER TreeViewDropPosition = C.GTK_TREE_VIEW_DROP_AFTER + TREE_VIEW_DROP_INTO_OR_BEFORE TreeViewDropPosition = C.GTK_TREE_VIEW_DROP_INTO_OR_BEFORE + TREE_VIEW_DROP_INTO_OR_AFTER TreeViewDropPosition = C.GTK_TREE_VIEW_DROP_INTO_OR_AFTER +) + +// TODO: +// GtkTreeViewDropPosition +// gboolean gtk_tree_view_get_tooltip_context () +// void (*GtkTreeDestroyCountFunc) () +// gboolean (*GtkTreeViewRowSeparatorFunc) () +// GtkTreeViewRowSeparatorFunc gtk_tree_view_get_row_separator_func () +// void gtk_tree_view_set_row_separator_func () +// void (*GtkTreeViewSearchPositionFunc) () +// GtkTreeViewSearchPositionFunc gtk_tree_view_get_search_position_func () +// void gtk_tree_view_set_search_position_func () +// GtkTreeViewSearchEqualFunc gtk_tree_view_get_search_equal_func () +// void gtk_tree_view_map_expanded_rows () +// gint gtk_tree_view_insert_column_with_attributes () +// gint gtk_tree_view_insert_column_with_data_func () +// void gtk_tree_view_set_column_drag_function () +// void gtk_tree_view_get_background_area () +// void gtk_tree_view_get_visible_rect () +// gboolean gtk_tree_view_get_visible_range () +// void gtk_tree_view_convert_tree_to_bin_window_coords () +// void gtk_tree_view_convert_tree_to_widget_coords () +// void gtk_tree_view_convert_widget_to_tree_coords () +// cairo_surface_t * gtk_tree_view_create_row_drag_icon () + +// EnableModelDragDest is a wrapper around gtk_tree_view_enable_model_drag_dest(). +func (v *TreeView) EnableModelDragDest(targets []TargetEntry, actions gdk.DragAction) { + C.gtk_tree_view_enable_model_drag_dest(v.native(), (*C.GtkTargetEntry)(&targets[0]), C.gint(len(targets)), C.GdkDragAction(actions)) +} + +// EnableModelDragSource is a wrapper around gtk_tree_view_enable_model_drag_source(). +func (v *TreeView) EnableModelDragSource(startButtonMask gdk.ModifierType, targets []TargetEntry, actions gdk.DragAction) { + C.gtk_tree_view_enable_model_drag_source(v.native(), C.GdkModifierType(startButtonMask), (*C.GtkTargetEntry)(&targets[0]), C.gint(len(targets)), C.GdkDragAction(actions)) +} + +// UnsetRowsDragSource is a wrapper around gtk_tree_view_unset_rows_drag_source(). +func (v *TreeView) UnsetRowsDragSource() { + C.gtk_tree_view_unset_rows_drag_source(v.native()) +} + +// UnsetRowsDragDest is a wrapper around gtk_tree_view_unset_rows_drag_dest(). +func (v *TreeView) UnsetRowsDragDest() { + C.gtk_tree_view_unset_rows_drag_dest(v.native()) +} + +// SetDragDestRow is a wrapper around gtk_tree_view_set_drag_dest_row(). +func (v *TreeView) SetDragDestRow(path *TreePath, pos TreeViewDropPosition) { + C.gtk_tree_view_set_drag_dest_row(v.native(), path.native(), C.GtkTreeViewDropPosition(pos)) +} + +// GetDragDestRow is a wrapper around gtk_tree_view_get_drag_dest_row(). +func (v *TreeView) GetDragDestRow() (path *TreePath, pos TreeViewDropPosition) { + var ( + cpath *C.GtkTreePath + cpos C.GtkTreeViewDropPosition + ) + + C.gtk_tree_view_get_drag_dest_row(v.native(), &cpath, &cpos) + + pos = TreeViewDropPosition(cpos) + + if cpath != nil { + path = &TreePath{cpath} + runtime.SetFinalizer(path, (*TreePath).free) + } + + return +} + +// GetDestRowAtPos is a wrapper around gtk_tree_view_get_dest_row_at_pos(). +func (v *TreeView) GetDestRowAtPos(dragX, dragY int) (path *TreePath, pos TreeViewDropPosition, ok bool) { + var ( + cpath *C.GtkTreePath + cpos C.GtkTreeViewDropPosition + ) + + cbool := C.gtk_tree_view_get_dest_row_at_pos(v.native(), C.gint(dragX), C.gint(dragY), &cpath, &cpos) + + ok = gobool(cbool) + pos = TreeViewDropPosition(cpos) + + if cpath != nil { + path = &TreePath{cpath} + runtime.SetFinalizer(path, (*TreePath).free) + } + + return +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/tree_view_column.go b/vendor/github.com/gotk3/gotk3/gtk/tree_view_column.go new file mode 100644 index 0000000..e489b72 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/tree_view_column.go @@ -0,0 +1,323 @@ +// Same copyright and license as the rest of the files in this project +// This file contains accelerator related functions and structures + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +/* + * GtkTreeViewColumn + */ + +// TreeViewColumns is a representation of GTK's GtkTreeViewColumn. +type TreeViewColumn struct { + glib.InitiallyUnowned +} + +// native returns a pointer to the underlying GtkTreeViewColumn. +func (v *TreeViewColumn) native() *C.GtkTreeViewColumn { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkTreeViewColumn(p) +} + +func marshalTreeViewColumn(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapTreeViewColumn(obj), nil +} + +func wrapTreeViewColumn(obj *glib.Object) *TreeViewColumn { + if obj == nil { + return nil + } + + return &TreeViewColumn{glib.InitiallyUnowned{obj}} +} + +// TreeViewColumnNew() is a wrapper around gtk_tree_view_column_new(). +func TreeViewColumnNew() (*TreeViewColumn, error) { + c := C.gtk_tree_view_column_new() + if c == nil { + return nil, nilPtrErr + } + return wrapTreeViewColumn(glib.Take(unsafe.Pointer(c))), nil +} + +// TreeViewColumnNewWithArea is a wrapper around gtk_tree_view_column_new_with_area(). +func TreeViewColumnNewWithArea(area ICellArea) (*TreeViewColumn, error) { + c := C.gtk_tree_view_column_new_with_area(area.toCellArea()) + if c == nil { + return nil, nilPtrErr + } + return wrapTreeViewColumn(glib.Take(unsafe.Pointer(c))), nil +} + +// TreeViewColumnNewWithAttribute() is a wrapper around +// gtk_tree_view_column_new_with_attributes() that only sets one +// attribute for one column. +func TreeViewColumnNewWithAttribute(title string, renderer ICellRenderer, attribute string, column int) (*TreeViewColumn, error) { + t_cstr := C.CString(title) + defer C.free(unsafe.Pointer(t_cstr)) + a_cstr := C.CString(attribute) + defer C.free(unsafe.Pointer(a_cstr)) + c := C._gtk_tree_view_column_new_with_attributes_one((*C.gchar)(t_cstr), + renderer.toCellRenderer(), (*C.gchar)(a_cstr), C.gint(column)) + if c == nil { + return nil, nilPtrErr + } + return wrapTreeViewColumn(glib.Take(unsafe.Pointer(c))), nil +} + +// AddAttribute() is a wrapper around gtk_tree_view_column_add_attribute(). +func (v *TreeViewColumn) AddAttribute(renderer ICellRenderer, attribute string, column int) { + cstr := C.CString(attribute) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_tree_view_column_add_attribute(v.native(), + renderer.toCellRenderer(), (*C.gchar)(cstr), C.gint(column)) +} + +// SetExpand() is a wrapper around gtk_tree_view_column_set_expand(). +func (v *TreeViewColumn) SetExpand(expand bool) { + C.gtk_tree_view_column_set_expand(v.native(), gbool(expand)) +} + +// GetExpand() is a wrapper around gtk_tree_view_column_get_expand(). +func (v *TreeViewColumn) GetExpand() bool { + c := C.gtk_tree_view_column_get_expand(v.native()) + return gobool(c) +} + +// SetMinWidth() is a wrapper around gtk_tree_view_column_set_min_width(). +func (v *TreeViewColumn) SetMinWidth(minWidth int) { + C.gtk_tree_view_column_set_min_width(v.native(), C.gint(minWidth)) +} + +// GetMinWidth() is a wrapper around gtk_tree_view_column_get_min_width(). +func (v *TreeViewColumn) GetMinWidth() int { + c := C.gtk_tree_view_column_get_min_width(v.native()) + return int(c) +} + +// PackStart() is a wrapper around gtk_tree_view_column_pack_start(). +func (v *TreeViewColumn) PackStart(cell ICellRenderer, expand bool) { + C.gtk_tree_view_column_pack_start(v.native(), cell.toCellRenderer(), gbool(expand)) +} + +// PackEnd() is a wrapper around gtk_tree_view_column_pack_end(). +func (v *TreeViewColumn) PackEnd(cell ICellRenderer, expand bool) { + C.gtk_tree_view_column_pack_end(v.native(), cell.toCellRenderer(), gbool(expand)) +} + +// Clear() is a wrapper around gtk_tree_view_column_clear(). +func (v *TreeViewColumn) Clear() { + C.gtk_tree_view_column_clear(v.native()) +} + +// ClearAttributes() is a wrapper around gtk_tree_view_column_clear_attributes(). +func (v *TreeViewColumn) ClearAttributes(cell *CellRenderer) { + C.gtk_tree_view_column_clear_attributes(v.native(), cell.native()) +} + +// SetSpacing() is a wrapper around gtk_tree_view_column_set_spacing(). +func (v *TreeViewColumn) SetSpacing(spacing int) { + C.gtk_tree_view_column_set_spacing(v.native(), C.gint(spacing)) +} + +// GetSpacing() is a wrapper around gtk_tree_view_column_get_spacing(). +func (v *TreeViewColumn) GetSpacing() int { + return int(C.gtk_tree_view_column_get_spacing(v.native())) +} + +// SetVisible() is a wrapper around gtk_tree_view_column_set_visible(). +func (v *TreeViewColumn) SetVisible(visible bool) { + C.gtk_tree_view_column_set_visible(v.native(), gbool(visible)) +} + +// GetVisible() is a wrapper around gtk_tree_view_column_get_visible(). +func (v *TreeViewColumn) GetVisible() bool { + return gobool(C.gtk_tree_view_column_get_visible(v.native())) +} + +// SetResizable() is a wrapper around gtk_tree_view_column_set_resizable(). +func (v *TreeViewColumn) SetResizable(resizable bool) { + C.gtk_tree_view_column_set_resizable(v.native(), gbool(resizable)) +} + +// GetResizable() is a wrapper around gtk_tree_view_column_get_resizable(). +func (v *TreeViewColumn) GetResizable() bool { + return gobool(C.gtk_tree_view_column_get_resizable(v.native())) +} + +// GetWidth() is a wrapper around gtk_tree_view_column_get_width(). +func (v *TreeViewColumn) GetWidth() int { + return int(C.gtk_tree_view_column_get_width(v.native())) +} + +// SetFixedWidth() is a wrapper around gtk_tree_view_column_set_fixed_width(). +func (v *TreeViewColumn) SetFixedWidth(w int) { + C.gtk_tree_view_column_set_fixed_width(v.native(), C.gint(w)) +} + +// GetFixedWidth() is a wrapper around gtk_tree_view_column_get_fixed_width(). +func (v *TreeViewColumn) GetFixedWidth() int { + return int(C.gtk_tree_view_column_get_fixed_width(v.native())) +} + +// SetMaxWidth() is a wrapper around gtk_tree_view_column_set_max_width(). +func (v *TreeViewColumn) SetMaxWidth(w int) { + C.gtk_tree_view_column_set_max_width(v.native(), C.gint(w)) +} + +// GetMaxWidth() is a wrapper around gtk_tree_view_column_get_max_width(). +func (v *TreeViewColumn) GetMaxWidth() int { + return int(C.gtk_tree_view_column_get_max_width(v.native())) +} + +// Clicked() is a wrapper around gtk_tree_view_column_clicked(). +func (v *TreeViewColumn) Clicked() { + C.gtk_tree_view_column_clicked(v.native()) +} + +// SetTitle() is a wrapper around gtk_tree_view_column_set_title(). +func (v *TreeViewColumn) SetTitle(t string) { + cstr := (*C.gchar)(C.CString(t)) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_tree_view_column_set_title(v.native(), cstr) +} + +// GetTitle() is a wrapper around gtk_tree_view_column_get_title(). +func (v *TreeViewColumn) GetTitle() string { + return C.GoString((*C.char)(C.gtk_tree_view_column_get_title(v.native()))) +} + +// SetClickable() is a wrapper around gtk_tree_view_column_set_clickable(). +func (v *TreeViewColumn) SetClickable(clickable bool) { + C.gtk_tree_view_column_set_clickable(v.native(), gbool(clickable)) +} + +// GetClickable() is a wrapper around gtk_tree_view_column_get_clickable(). +func (v *TreeViewColumn) GetClickable() bool { + return gobool(C.gtk_tree_view_column_get_clickable(v.native())) +} + +// SetReorderable() is a wrapper around gtk_tree_view_column_set_reorderable(). +func (v *TreeViewColumn) SetReorderable(reorderable bool) { + C.gtk_tree_view_column_set_reorderable(v.native(), gbool(reorderable)) +} + +// GetReorderable() is a wrapper around gtk_tree_view_column_get_reorderable(). +func (v *TreeViewColumn) GetReorderable() bool { + return gobool(C.gtk_tree_view_column_get_reorderable(v.native())) +} + +// SetSortIndicator() is a wrapper around gtk_tree_view_column_set_sort_indicator(). +func (v *TreeViewColumn) SetSortIndicator(reorderable bool) { + C.gtk_tree_view_column_set_sort_indicator(v.native(), gbool(reorderable)) +} + +// GetSortIndicator() is a wrapper around gtk_tree_view_column_get_sort_indicator(). +func (v *TreeViewColumn) GetSortIndicator() bool { + return gobool(C.gtk_tree_view_column_get_sort_indicator(v.native())) +} + +// SetSortColumnID() is a wrapper around gtk_tree_view_column_set_sort_column_id(). +func (v *TreeViewColumn) SetSortColumnID(w int) { + C.gtk_tree_view_column_set_sort_column_id(v.native(), C.gint(w)) +} + +// GetSortColumnID() is a wrapper around gtk_tree_view_column_get_sort_column_id(). +func (v *TreeViewColumn) GetSortColumnID() int { + return int(C.gtk_tree_view_column_get_sort_column_id(v.native())) +} + +// CellIsVisible() is a wrapper around gtk_tree_view_column_cell_is_visible(). +func (v *TreeViewColumn) CellIsVisible() bool { + return gobool(C.gtk_tree_view_column_cell_is_visible(v.native())) +} + +// FocusCell() is a wrapper around gtk_tree_view_column_focus_cell(). +func (v *TreeViewColumn) FocusCell(cell *CellRenderer) { + C.gtk_tree_view_column_focus_cell(v.native(), cell.native()) +} + +// QueueResize() is a wrapper around gtk_tree_view_column_queue_resize(). +func (v *TreeViewColumn) QueueResize() { + C.gtk_tree_view_column_queue_resize(v.native()) +} + +// GetXOffset() is a wrapper around gtk_tree_view_column_get_x_offset(). +func (v *TreeViewColumn) GetXOffset() int { + return int(C.gtk_tree_view_column_get_x_offset(v.native())) +} + +// void gtk_tree_view_column_set_attributes () +// void gtk_tree_view_column_set_cell_data_func () + +type TreeViewColumnSizing int + +const ( + TREE_VIEW_COLUMN_GROW_ONLY TreeViewColumnSizing = C.GTK_TREE_VIEW_COLUMN_GROW_ONLY + TREE_VIEW_COLUMN_AUTOSIZE = C.GTK_TREE_VIEW_COLUMN_AUTOSIZE + TREE_VIEW_COLUMN_FIXED = C.GTK_TREE_VIEW_COLUMN_FIXED +) + +// void gtk_tree_view_column_set_sizing () +func (v *TreeViewColumn) SetSizing(sizing TreeViewColumnSizing) { + C.gtk_tree_view_column_set_sizing(v.native(), C.GtkTreeViewColumnSizing(sizing)) +} + +// GtkTreeViewColumnSizing gtk_tree_view_column_get_sizing () +func (v *TreeViewColumn) GetSizing() TreeViewColumnSizing { + return TreeViewColumnSizing(C.gtk_tree_view_column_get_sizing(v.native())) +} + +// SetWidget() is a wrapper around gtk_tree_view_column_set_widget(). +func (v *TreeViewColumn) SetWidget(widget IWidget) { + C.gtk_tree_view_column_set_widget(v.native(), widget.toWidget()) +} + +// GetButton() is a wrapper around gtk_tree_view_column_get_button(). +func (v *TreeViewColumn) GetButton() (IWidget, error) { + widget := C.gtk_tree_view_column_get_button(v.native()) + if widget == nil { + return nil, nilPtrErr + } + return castWidget(widget) +} + +// GetWidget() is a wrapper around gtk_tree_view_column_get_widget(). +func (v *TreeViewColumn) GetWidget() (IWidget, error) { + widget := C.gtk_tree_view_column_get_widget(v.native()) + if widget == nil { + return nil, nil + } + return castWidget(widget) +} + +// void gtk_tree_view_column_set_alignment () +// gfloat gtk_tree_view_column_get_alignment () + +// void gtk_tree_view_column_set_sort_order () +func (v *TreeViewColumn) SetSortOrder(order SortType) { + C.gtk_tree_view_column_set_sort_order(v.native(), C.GtkSortType(order)) +} + +// GtkSortType gtk_tree_view_column_get_sort_order () +func (v *TreeViewColumn) GetSortOrder() SortType { + return SortType(C.gtk_tree_view_column_get_sort_order(v.native())) +} + +// void gtk_tree_view_column_cell_set_cell_data () +// void gtk_tree_view_column_cell_get_size () +// gboolean gtk_tree_view_column_cell_get_position () +// GtkWidget * gtk_tree_view_column_get_tree_view () diff --git a/vendor/github.com/gotk3/gotk3/gtk/version.go b/vendor/github.com/gotk3/gotk3/gtk/version.go new file mode 100644 index 0000000..0c20162 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/version.go @@ -0,0 +1,29 @@ +package gtk + +// #include +import "C" +import "errors" + +func CheckVersion(major, minor, micro uint) error { + errChar := C.gtk_check_version(C.guint(major), C.guint(minor), C.guint(micro)) + if errChar == nil { + return nil + } + + return errors.New(C.GoString((*C.char)(errChar))) +} + +func GetMajorVersion() uint { + v := C.gtk_get_major_version() + return uint(v) +} + +func GetMinorVersion() uint { + v := C.gtk_get_minor_version() + return uint(v) +} + +func GetMicroVersion() uint { + v := C.gtk_get_micro_version() + return uint(v) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/version_test.go b/vendor/github.com/gotk3/gotk3/gtk/version_test.go new file mode 100644 index 0000000..d68387c --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/version_test.go @@ -0,0 +1,20 @@ +package gtk + +import "testing" + +func TestCheckVersion(t *testing.T) { + err := CheckVersion(GetMajorVersion(), GetMinorVersion(), GetMicroVersion()) + if err != nil { + t.Error(err) + } + + err = CheckVersion(GetMajorVersion(), GetMinorVersion(), GetMicroVersion()-1) + if err != nil { + t.Error(err) + } + + err = CheckVersion(GetMajorVersion(), GetMinorVersion(), GetMicroVersion()+1) + if err == nil { + t.Error("Expected to fail when an more recent version is expected") + } +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/widget.go b/vendor/github.com/gotk3/gotk3/gtk/widget.go new file mode 100644 index 0000000..8842dc0 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/widget.go @@ -0,0 +1,962 @@ +// Same copyright and license as the rest of the files in this project +// This file contains accelerator related functions and structures + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "errors" + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/cairo" + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +/* + * GtkWidget + */ + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.gtk_size_request_mode_get_type()), marshalSizeRequestMode}, + + // Boxed + {glib.Type(C.gtk_requisition_get_type()), marshalRequisition}, + } + glib.RegisterGValueMarshalers(tm) + + WrapMap["GtkRequisition"] = wrapRequisition +} + +// SizeRequestMode is a representation of GTK's GtkSizeRequestMode. +type SizeRequestMode int + +const ( + SIZE_REQUEST_HEIGHT_FOR_WIDTH SizeRequestMode = C.GTK_SIZE_REQUEST_HEIGHT_FOR_WIDTH + SIZE_REQUEST_WIDTH_FOR_HEIGHT SizeRequestMode = C.GTK_SIZE_REQUEST_WIDTH_FOR_HEIGHT + SIZE_REQUEST_CONSTANT_SIZE SizeRequestMode = C.GTK_SIZE_REQUEST_CONSTANT_SIZE +) + +func marshalSizeRequestMode(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return SizeRequestMode(c), nil +} + +// Widget is a representation of GTK's GtkWidget. +type Widget struct { + glib.InitiallyUnowned +} + +// IWidget is an interface type implemented by all structs +// embedding a Widget. It is meant to be used as an argument type +// for wrapper functions that wrap around a C GTK function taking a +// GtkWidget. +type IWidget interface { + toWidget() *C.GtkWidget + ToWidget() *Widget + Set(string, interface{}) error +} + +type IWidgetable interface { + toWidget() *C.GtkWidget +} + +func nullableWidget(v IWidgetable) *C.GtkWidget { + if v == nil { + return nil + } + + return v.toWidget() +} + +// native returns a pointer to the underlying GtkWidget. +func (v *Widget) native() *C.GtkWidget { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkWidget(p) +} + +func (v *Widget) toWidget() *C.GtkWidget { + if v == nil { + return nil + } + return v.native() +} + +// ToWidget is a helper getter, e.g.: it returns *gtk.Label as a *gtk.Widget. +// In other cases, where you have a gtk.IWidget, use the type assertion. +func (v *Widget) ToWidget() *Widget { + return v +} + +// Cast changes the widget to an object of interface type IWidget. +// This is only useful if you don't already have an object of type IWidget at hand (see example below). +// This func is similar to gtk.Builder.GetObject(): +// The returned value needs to be type-asserted, before it can be used. +// +// Example: +// // you know that the parent is an object of type *gtk.ApplicationWindow, +// // or you want to check just in case +// parentWindow, _ := myWindow.GetTransientFor() +// intermediate, _ := parentWindow.Cast() +// appWindow, typeAssertSuccessful := intermediate.(*gtk.ApplicationWindow) +func (v *Widget) Cast() (IWidget, error) { + return castWidget(v.native()) +} + +func marshalWidget(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapWidget(obj), nil +} + +func wrapWidget(obj *glib.Object) *Widget { + if obj == nil { + return nil + } + + return &Widget{glib.InitiallyUnowned{obj}} +} + +// TODO: +// GtkCallback(). +// gtk_widget_new(). + +// Destroy is a wrapper around gtk_widget_destroy(). +func (v *Widget) Destroy() { + C.gtk_widget_destroy(v.native()) +} + +// HideOnDelete is a wrapper around gtk_widget_hide_on_delete(). +// Calling this func adds gtk_widget_hide_on_delete to the widget's "delete-event" signal. +func (v *Widget) HideOnDelete() { + C._gtk_widget_hide_on_delete(v.native()) +} + +// TODO: +// gtk_widget_set_direction(). +// gtk_widget_get_direction(). +// gtk_widget_set_default_direction(). +// gtk_widget_get_default_direction(). +// gtk_widget_input_shape_combine_region(). +// gtk_widget_create_pango_context(). +// gtk_widget_create_pango_context(). +// gtk_widget_get_pango_context(). +// gtk_widget_create_pango_layout(). + +// QueueDrawArea is a wrapper aroung gtk_widget_queue_draw_area(). +func (v *Widget) QueueDrawArea(x, y, w, h int) { + C.gtk_widget_queue_draw_area(v.native(), C.gint(x), C.gint(y), C.gint(w), C.gint(h)) +} + +// QueueDrawRegion is a wrapper aroung gtk_widget_queue_draw_region(). +func (v *Widget) QueueDrawRegion(region *cairo.Region) { + C.gtk_widget_queue_draw_region(v.native(), (*C.cairo_region_t)(unsafe.Pointer(region.Native()))) +} + +// TODO: +// gtk_widget_set_redraw_on_allocate(). +// gtk_widget_mnemonic_activate(). +// gtk_widget_class_install_style_property(). +// gtk_widget_class_install_style_property_parser(). +// gtk_widget_class_find_style_property(). +// gtk_widget_class_list_style_properties(). +// gtk_widget_send_focus_change(). +// gtk_widget_style_get(). +// gtk_widget_style_get_property(). +// gtk_widget_style_get_valist(). +// gtk_widget_class_set_accessible_type(). +// gtk_widget_get_accessible(). +// gtk_widget_child_focus(). +// gtk_widget_child_notify(). +// gtk_widget_get_child_visible(). +// gtk_widget_get_settings(). +// gtk_widget_get_clipboard(). + +// GetDisplay is a wrapper around gtk_widget_get_display(). +func (v *Widget) GetDisplay() (*gdk.Display, error) { + c := C.gtk_widget_get_display(v.native()) + if c == nil { + return nil, nilPtrErr + } + s := &gdk.Display{glib.Take(unsafe.Pointer(c))} + return s, nil +} + +// GetScreen is a wrapper around gtk_widget_get_screen(). +func (v *Widget) GetScreen() (*gdk.Screen, error) { + c := C.gtk_widget_get_screen(v.native()) + if c == nil { + return nil, nilPtrErr + } + s := &gdk.Screen{glib.Take(unsafe.Pointer(c))} + return s, nil +} + +// TODO: +// gtk_widget_has_screen(). +// gtk_widget_get_size_request(). +// gtk_widget_set_child_visible(). +// gtk_widget_list_mnemonic_labels(). +// gtk_widget_add_mnemonic_label(). +// gtk_widget_remove_mnemonic_label(). +// gtk_widget_error_bell(). +// gtk_widget_keynav_failed(). +// gtk_widget_get_tooltip_window(). +// gtk_widget_get_has_tooltip(). +// gtk_widget_set_has_tooltip(). +// gtk_widget_trigger_tooltip_query(). +// gtk_cairo_should_draw_window(). +// gtk_cairo_transform_to_window(). + +// DragDestSet is a wrapper around gtk_drag_dest_set(). +func (v *Widget) DragDestSet(flags DestDefaults, targets []TargetEntry, actions gdk.DragAction) { + C.gtk_drag_dest_set(v.native(), C.GtkDestDefaults(flags), (*C.GtkTargetEntry)(&targets[0]), C.gint(len(targets)), C.GdkDragAction(actions)) +} + +// DragSourceSet is a wrapper around gtk_drag_source_set(). +func (v *Widget) DragSourceSet(startButtonMask gdk.ModifierType, targets []TargetEntry, actions gdk.DragAction) { + C.gtk_drag_source_set(v.native(), C.GdkModifierType(startButtonMask), (*C.GtkTargetEntry)(&targets[0]), C.gint(len(targets)), C.GdkDragAction(actions)) +} + +// ResetStyle is a wrapper around gtk_widget_reset_style(). +func (v *Widget) ResetStyle() { + C.gtk_widget_reset_style(v.native()) +} + +// InDestruction is a wrapper around gtk_widget_in_destruction(). +func (v *Widget) InDestruction() bool { + return gobool(C.gtk_widget_in_destruction(v.native())) +} + +// TODO(jrick) this may require some rethinking +/* +// Destroyed is a wrapper around gtk_widget_destroyed(). +func (v *Widget) Destroyed(widgetPointer **Widget) { +} +*/ + +// Unparent is a wrapper around gtk_widget_unparent(). +func (v *Widget) Unparent() { + C.gtk_widget_unparent(v.native()) +} + +// Show is a wrapper around gtk_widget_show(). +func (v *Widget) Show() { + C.gtk_widget_show(v.native()) +} + +// Hide is a wrapper around gtk_widget_hide(). +func (v *Widget) Hide() { + C.gtk_widget_hide(v.native()) +} + +// GetCanFocus is a wrapper around gtk_widget_get_can_focus(). +func (v *Widget) GetCanFocus() bool { + c := C.gtk_widget_get_can_focus(v.native()) + return gobool(c) +} + +// SetCanFocus is a wrapper around gtk_widget_set_can_focus(). +func (v *Widget) SetCanFocus(canFocus bool) { + C.gtk_widget_set_can_focus(v.native(), gbool(canFocus)) +} + +// GetCanDefault is a wrapper around gtk_widget_get_can_default(). +func (v *Widget) GetCanDefault() bool { + c := C.gtk_widget_get_can_default(v.native()) + return gobool(c) +} + +// SetCanDefault is a wrapper around gtk_widget_set_can_default(). +func (v *Widget) SetCanDefault(canDefault bool) { + C.gtk_widget_set_can_default(v.native(), gbool(canDefault)) +} + +// SetMapped is a wrapper around gtk_widget_set_mapped(). +func (v *Widget) SetMapped(mapped bool) { + C.gtk_widget_set_mapped(v.native(), gbool(mapped)) +} + +// GetMapped is a wrapper around gtk_widget_get_mapped(). +func (v *Widget) GetMapped() bool { + c := C.gtk_widget_get_mapped(v.native()) + return gobool(c) +} + +// TODO: +// gtk_widget_device_is_shadowed(). +// gtk_widget_get_modifier_mask(). + +// InsertActionGroup is a wrapper around gtk_widget_insert_action_group(). +func (v *Widget) InsertActionGroup(name string, group glib.IActionGroup) { + C.gtk_widget_insert_action_group(v.native(), (*C.gchar)(C.CString(name)), C.toGActionGroup(unsafe.Pointer(group.Native()))) +} + +// TODO: +// gtk_widget_get_path(). + +// GetPreferredHeight is a wrapper around gtk_widget_get_preferred_height(). +func (v *Widget) GetPreferredHeight() (int, int) { + var minimum, natural C.gint + C.gtk_widget_get_preferred_height(v.native(), &minimum, &natural) + return int(minimum), int(natural) +} + +// GetPreferredWidth is a wrapper around gtk_widget_get_preferred_width(). +func (v *Widget) GetPreferredWidth() (int, int) { + var minimum, natural C.gint + C.gtk_widget_get_preferred_width(v.native(), &minimum, &natural) + return int(minimum), int(natural) +} + +// GetPreferredHeightForWidth is a wrapper around gtk_widget_get_preferred_height_for_width(). +func (v *Widget) GetPreferredHeightForWidth(width int) (int, int) { + + var minimum, natural C.gint + + C.gtk_widget_get_preferred_height_for_width( + v.native(), + C.gint(width), + &minimum, + &natural) + return int(minimum), int(natural) +} + +// GetPreferredWidthForHeight is a wrapper around gtk_widget_get_preferred_width_for_height(). +func (v *Widget) GetPreferredWidthForHeight(height int) (int, int) { + + var minimum, natural C.gint + + C.gtk_widget_get_preferred_width_for_height( + v.native(), + C.gint(height), + &minimum, + &natural) + return int(minimum), int(natural) +} + +// GetRequestMode is a wrapper around gtk_widget_get_request_mode(). +func (v *Widget) GetRequestMode() SizeRequestMode { + return SizeRequestMode(C.gtk_widget_get_request_mode(v.native())) +} + +// GetPreferredSize is a wrapper around gtk_widget_get_preferred_size(). +func (v *Widget) GetPreferredSize() (*Requisition, *Requisition) { + + minimum_size := new(C.GtkRequisition) + natural_size := new(C.GtkRequisition) + + C.gtk_widget_get_preferred_size(v.native(), minimum_size, natural_size) + + minR, err := requisitionFromNative(minimum_size) + if err != nil { + minR = nil + } + natR, err := requisitionFromNative(natural_size) + if err != nil { + natR = nil + } + + return minR, natR +} + +// TODO: +/* +gint +gtk_distribute_natural_allocation (gint extra_space, + guint n_requested_sizes, + GtkRequestedSize *sizes); +*/ + +// GetHAlign is a wrapper around gtk_widget_get_halign(). +func (v *Widget) GetHAlign() Align { + c := C.gtk_widget_get_halign(v.native()) + return Align(c) +} + +// SetHAlign is a wrapper around gtk_widget_set_halign(). +func (v *Widget) SetHAlign(align Align) { + C.gtk_widget_set_halign(v.native(), C.GtkAlign(align)) +} + +// GetVAlign is a wrapper around gtk_widget_get_valign(). +func (v *Widget) GetVAlign() Align { + c := C.gtk_widget_get_valign(v.native()) + return Align(c) +} + +// SetVAlign is a wrapper around gtk_widget_set_valign(). +func (v *Widget) SetVAlign(align Align) { + C.gtk_widget_set_valign(v.native(), C.GtkAlign(align)) +} + +// GetMarginTop is a wrapper around gtk_widget_get_margin_top(). +func (v *Widget) GetMarginTop() int { + c := C.gtk_widget_get_margin_top(v.native()) + return int(c) +} + +// SetMarginTop is a wrapper around gtk_widget_set_margin_top(). +func (v *Widget) SetMarginTop(margin int) { + C.gtk_widget_set_margin_top(v.native(), C.gint(margin)) +} + +// GetMarginBottom is a wrapper around gtk_widget_get_margin_bottom(). +func (v *Widget) GetMarginBottom() int { + c := C.gtk_widget_get_margin_bottom(v.native()) + return int(c) +} + +// SetMarginBottom is a wrapper around gtk_widget_set_margin_bottom(). +func (v *Widget) SetMarginBottom(margin int) { + C.gtk_widget_set_margin_bottom(v.native(), C.gint(margin)) +} + +// GetHExpand is a wrapper around gtk_widget_get_hexpand(). +func (v *Widget) GetHExpand() bool { + c := C.gtk_widget_get_hexpand(v.native()) + return gobool(c) +} + +// SetHExpand is a wrapper around gtk_widget_set_hexpand(). +func (v *Widget) SetHExpand(expand bool) { + C.gtk_widget_set_hexpand(v.native(), gbool(expand)) +} + +// TODO: +// gtk_widget_get_hexpand_set(). +// gtk_widget_set_hexpand_set(). + +// GetVExpand is a wrapper around gtk_widget_get_vexpand(). +func (v *Widget) GetVExpand() bool { + c := C.gtk_widget_get_vexpand(v.native()) + return gobool(c) +} + +// SetVExpand is a wrapper around gtk_widget_set_vexpand(). +func (v *Widget) SetVExpand(expand bool) { + C.gtk_widget_set_vexpand(v.native(), gbool(expand)) +} + +// TODO: +// gtk_widget_get_vexpand_set(). +// gtk_widget_set_vexpand_set(). +// gtk_widget_queue_compute_expand(). +// gtk_widget_compute_expand(). + +// GetRealized is a wrapper around gtk_widget_get_realized(). +func (v *Widget) GetRealized() bool { + c := C.gtk_widget_get_realized(v.native()) + return gobool(c) +} + +// SetRealized is a wrapper around gtk_widget_set_realized(). +func (v *Widget) SetRealized(realized bool) { + C.gtk_widget_set_realized(v.native(), gbool(realized)) +} + +// GetHasWindow is a wrapper around gtk_widget_get_has_window(). +func (v *Widget) GetHasWindow() bool { + c := C.gtk_widget_get_has_window(v.native()) + return gobool(c) +} + +// SetHasWindow is a wrapper around gtk_widget_set_has_window(). +func (v *Widget) SetHasWindow(hasWindow bool) { + C.gtk_widget_set_has_window(v.native(), gbool(hasWindow)) +} + +// ShowNow is a wrapper around gtk_widget_show_now(). +func (v *Widget) ShowNow() { + C.gtk_widget_show_now(v.native()) +} + +// ShowAll is a wrapper around gtk_widget_show_all(). +func (v *Widget) ShowAll() { + C.gtk_widget_show_all(v.native()) +} + +// SetNoShowAll is a wrapper around gtk_widget_set_no_show_all(). +func (v *Widget) SetNoShowAll(noShowAll bool) { + C.gtk_widget_set_no_show_all(v.native(), gbool(noShowAll)) +} + +// GetNoShowAll is a wrapper around gtk_widget_get_no_show_all(). +func (v *Widget) GetNoShowAll() bool { + c := C.gtk_widget_get_no_show_all(v.native()) + return gobool(c) +} + +// Map is a wrapper around gtk_widget_map(). +func (v *Widget) Map() { + C.gtk_widget_map(v.native()) +} + +// Unmap is a wrapper around gtk_widget_unmap(). +func (v *Widget) Unmap() { + C.gtk_widget_unmap(v.native()) +} + +// TODO: +//void gtk_widget_realize(GtkWidget *widget); +//void gtk_widget_unrealize(GtkWidget *widget); +//void gtk_widget_draw(GtkWidget *widget, cairo_t *cr); +//void gtk_widget_queue_resize(GtkWidget *widget); +//void gtk_widget_queue_resize_no_redraw(GtkWidget *widget); +// gtk_widget_queue_allocate(). + +// Event() is a wrapper around gtk_widget_event(). +func (v *Widget) Event(event *gdk.Event) bool { + c := C.gtk_widget_event(v.native(), + (*C.GdkEvent)(unsafe.Pointer(event.Native()))) + return gobool(c) +} + +// Activate() is a wrapper around gtk_widget_activate(). +func (v *Widget) Activate() bool { + return gobool(C.gtk_widget_activate(v.native())) +} + +// Intersect is a wrapper around gtk_widget_intersect(). +func (v *Widget) Intersect(area gdk.Rectangle) (*gdk.Rectangle, bool) { + var cRect *C.GdkRectangle + hadIntersection := C.gtk_widget_intersect(v.native(), nativeGdkRectangle(area), cRect) + intersection := gdk.WrapRectangle(uintptr(unsafe.Pointer(cRect))) + return intersection, gobool(hadIntersection) +} + +// IsFocus() is a wrapper around gtk_widget_is_focus(). +func (v *Widget) IsFocus() bool { + return gobool(C.gtk_widget_is_focus(v.native())) +} + +// GrabFocus() is a wrapper around gtk_widget_grab_focus(). +func (v *Widget) GrabFocus() { + C.gtk_widget_grab_focus(v.native()) +} + +// GrabDefault() is a wrapper around gtk_widget_grab_default(). +func (v *Widget) GrabDefault() { + C.gtk_widget_grab_default(v.native()) +} + +// SetName() is a wrapper around gtk_widget_set_name(). +func (v *Widget) SetName(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_widget_set_name(v.native(), (*C.gchar)(cstr)) +} + +// GetName() is a wrapper around gtk_widget_get_name(). A non-nil +// error is returned in the case that gtk_widget_get_name returns NULL to +// differentiate between NULL and an empty string. +func (v *Widget) GetName() (string, error) { + c := C.gtk_widget_get_name(v.native()) + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +// GetSensitive is a wrapper around gtk_widget_get_sensitive(). +func (v *Widget) GetSensitive() bool { + c := C.gtk_widget_get_sensitive(v.native()) + return gobool(c) +} + +// IsSensitive is a wrapper around gtk_widget_is_sensitive(). +func (v *Widget) IsSensitive() bool { + c := C.gtk_widget_is_sensitive(v.native()) + return gobool(c) +} + +// SetSensitive is a wrapper around gtk_widget_set_sensitive(). +func (v *Widget) SetSensitive(sensitive bool) { + C.gtk_widget_set_sensitive(v.native(), gbool(sensitive)) +} + +// GetVisible is a wrapper around gtk_widget_get_visible(). +func (v *Widget) GetVisible() bool { + c := C.gtk_widget_get_visible(v.native()) + return gobool(c) +} + +// SetVisible is a wrapper around gtk_widget_set_visible(). +func (v *Widget) SetVisible(visible bool) { + C.gtk_widget_set_visible(v.native(), gbool(visible)) +} + +// SetParent is a wrapper around gtk_widget_set_parent(). +func (v *Widget) SetParent(parent IWidget) { + C.gtk_widget_set_parent(v.native(), parent.toWidget()) +} + +// GetParent is a wrapper around gtk_widget_get_parent(). +func (v *Widget) GetParent() (IWidget, error) { + c := C.gtk_widget_get_parent(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// SetSizeRequest is a wrapper around gtk_widget_set_size_request(). +func (v *Widget) SetSizeRequest(width, height int) { + C.gtk_widget_set_size_request(v.native(), C.gint(width), C.gint(height)) +} + +// GetSizeRequest is a wrapper around gtk_widget_get_size_request(). +func (v *Widget) GetSizeRequest() (width, height int) { + var w, h C.gint + C.gtk_widget_get_size_request(v.native(), &w, &h) + return int(w), int(h) +} + +// SetParentWindow is a wrapper around gtk_widget_set_parent_window(). +func (v *Widget) SetParentWindow(parentWindow *gdk.Window) { + C.gtk_widget_set_parent_window(v.native(), + (*C.GdkWindow)(unsafe.Pointer(parentWindow.Native()))) +} + +// GetParentWindow is a wrapper around gtk_widget_get_parent_window(). +func (v *Widget) GetParentWindow() (*gdk.Window, error) { + c := C.gtk_widget_get_parent_window(v.native()) + if v == nil { + return nil, nilPtrErr + } + + w := &gdk.Window{glib.Take(unsafe.Pointer(c))} + return w, nil +} + +// SetEvents is a wrapper around gtk_widget_set_events(). +func (v *Widget) SetEvents(events int) { + C.gtk_widget_set_events(v.native(), C.gint(events)) +} + +// GetEvents is a wrapper around gtk_widget_get_events(). +func (v *Widget) GetEvents() int { + return int(C.gtk_widget_get_events(v.native())) +} + +// AddEvents is a wrapper around gtk_widget_add_events(). +func (v *Widget) AddEvents(events int) { + C.gtk_widget_add_events(v.native(), C.gint(events)) +} + +// TODO: +/* +// gtk_widget_set_device_events(). +func (v *Widget) SetDeviceEvents() { +} +*/ + +/* +// gtk_widget_get_device_events(). +func (v *Widget) GetDeviceEvents() { +} +*/ + +/* +// gtk_widget_add_device_events(). +func (v *Widget) AddDeviceEvents() { +} +*/ + +// FreezeChildNotify is a wrapper around gtk_widget_freeze_child_notify(). +func (v *Widget) FreezeChildNotify() { + C.gtk_widget_freeze_child_notify(v.native()) +} + +// ThawChildNotify is a wrapper around gtk_widget_thaw_child_notify(). +func (v *Widget) ThawChildNotify() { + C.gtk_widget_thaw_child_notify(v.native()) +} + +// HasDefault is a wrapper around gtk_widget_has_default(). +func (v *Widget) HasDefault() bool { + c := C.gtk_widget_has_default(v.native()) + return gobool(c) +} + +// HasFocus is a wrapper around gtk_widget_has_focus(). +func (v *Widget) HasFocus() bool { + c := C.gtk_widget_has_focus(v.native()) + return gobool(c) +} + +// HasVisibleFocus is a wrapper around gtk_widget_has_visible_focus(). +func (v *Widget) HasVisibleFocus() bool { + c := C.gtk_widget_has_visible_focus(v.native()) + return gobool(c) +} + +// HasGrab is a wrapper around gtk_widget_has_grab(). +func (v *Widget) HasGrab() bool { + c := C.gtk_widget_has_grab(v.native()) + return gobool(c) +} + +// IsDrawable is a wrapper around gtk_widget_is_drawable(). +func (v *Widget) IsDrawable() bool { + c := C.gtk_widget_is_drawable(v.native()) + return gobool(c) +} + +// IsToplevel is a wrapper around gtk_widget_is_toplevel(). +func (v *Widget) IsToplevel() bool { + c := C.gtk_widget_is_toplevel(v.native()) + return gobool(c) +} + +// FIXME: +// gtk_widget_set_window(). +// gtk_widget_set_receives_default(). +// gtk_widget_get_receives_default(). +// gtk_widget_set_support_multidevice(). +// gtk_widget_get_support_multidevice(). + +// SetDeviceEnabled is a wrapper around gtk_widget_set_device_enabled(). +func (v *Widget) SetDeviceEnabled(device *gdk.Device, enabled bool) { + C.gtk_widget_set_device_enabled(v.native(), + (*C.GdkDevice)(unsafe.Pointer(device.Native())), gbool(enabled)) +} + +// GetDeviceEnabled is a wrapper around gtk_widget_get_device_enabled(). +func (v *Widget) GetDeviceEnabled(device *gdk.Device) bool { + c := C.gtk_widget_get_device_enabled(v.native(), + (*C.GdkDevice)(unsafe.Pointer(device.Native()))) + return gobool(c) +} + +// GetToplevel is a wrapper around gtk_widget_get_toplevel(). +func (v *Widget) GetToplevel() (IWidget, error) { + c := C.gtk_widget_get_toplevel(v.native()) + if c == nil { + return nil, nilPtrErr + } + return castWidget(c) +} + +// TODO: +// gtk_widget_get_ancestor(). +// gtk_widget_get_visual(). +// gtk_widget_is_ancestor(). + +// GetTooltipMarkup is a wrapper around gtk_widget_get_tooltip_markup(). +// A non-nil error is returned in the case that gtk_widget_get_tooltip_markup +// returns NULL to differentiate between NULL and an empty string. +func (v *Widget) GetTooltipMarkup() (string, error) { + c := C.gtk_widget_get_tooltip_markup(v.native()) + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +// SetTooltipMarkup is a wrapper around gtk_widget_set_tooltip_markup(). +func (v *Widget) SetTooltipMarkup(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_widget_set_tooltip_markup(v.native(), (*C.gchar)(cstr)) +} + +// GetTooltipText is a wrapper around gtk_widget_get_tooltip_text(). +// A non-nil error is returned in the case that +// gtk_widget_get_tooltip_text returns NULL to differentiate between NULL +// and an empty string. +func (v *Widget) GetTooltipText() (string, error) { + c := C.gtk_widget_get_tooltip_text(v.native()) + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +// SetTooltipText is a wrapper around gtk_widget_set_tooltip_text(). +func (v *Widget) SetTooltipText(text string) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_widget_set_tooltip_text(v.native(), (*C.gchar)(cstr)) +} + +// TranslateCoordinates is a wrapper around gtk_widget_translate_coordinates(). +func (v *Widget) TranslateCoordinates(dest IWidget, srcX, srcY int) (destX, destY int, e error) { + cdest := nullableWidget(dest) + + var cdestX, cdestY C.gint + c := C.gtk_widget_translate_coordinates(v.native(), cdest, C.gint(srcX), C.gint(srcY), &cdestX, &cdestY) + if !gobool(c) { + return 0, 0, errors.New("translate coordinates failed") + } + return int(cdestX), int(cdestY), nil +} + +// SetVisual is a wrapper around gtk_widget_set_visual(). +func (v *Widget) SetVisual(visual *gdk.Visual) { + C.gtk_widget_set_visual(v.native(), + (*C.GdkVisual)(unsafe.Pointer(visual.Native()))) +} + +// SetAppPaintable is a wrapper around gtk_widget_set_app_paintable(). +func (v *Widget) SetAppPaintable(paintable bool) { + C.gtk_widget_set_app_paintable(v.native(), gbool(paintable)) +} + +// GetAppPaintable is a wrapper around gtk_widget_get_app_paintable(). +func (v *Widget) GetAppPaintable() bool { + c := C.gtk_widget_get_app_paintable(v.native()) + return gobool(c) +} + +// QueueDraw is a wrapper around gtk_widget_queue_draw(). +func (v *Widget) QueueDraw() { + C.gtk_widget_queue_draw(v.native()) +} + +// GetAllocation is a wrapper around gtk_widget_get_allocation(). +func (v *Widget) GetAllocation() *Allocation { + var a Allocation + C.gtk_widget_get_allocation(v.native(), a.native()) + return &a +} + +// SetAllocation is a wrapper around gtk_widget_set_allocation(). +func (v *Widget) SetAllocation(allocation *Allocation) { + C.gtk_widget_set_allocation(v.native(), allocation.native()) +} + +// SizeAllocate is a wrapper around gtk_widget_size_allocate(). +func (v *Widget) SizeAllocate(allocation *Allocation) { + C.gtk_widget_size_allocate(v.native(), allocation.native()) +} + +// TODO: +// gtk_widget_size_allocate_with_baseline(). + +// SetStateFlags is a wrapper around gtk_widget_set_state_flags(). +func (v *Widget) SetStateFlags(stateFlags StateFlags, clear bool) { + C.gtk_widget_set_state_flags(v.native(), C.GtkStateFlags(stateFlags), gbool(clear)) +} + +// TODO: +// gtk_widget_unset_state_flags(). +// gtk_widget_get_state_flags(). + +// GetWindow is a wrapper around gtk_widget_get_window(). +func (v *Widget) GetWindow() (*gdk.Window, error) { + c := C.gtk_widget_get_window(v.native()) + if c == nil { + return nil, nilPtrErr + } + + w := &gdk.Window{glib.Take(unsafe.Pointer(c))} + return w, nil +} + +/* + * GtkRequisition + */ + +// Requisition is a representation of GTK's GtkRequisition +type Requisition struct { + requisition *C.GtkRequisition + Width, + Height int +} + +func (v *Requisition) native() *C.GtkRequisition { + if v == nil { + return nil + } + v.requisition.width = C.int(v.Width) + v.requisition.height = C.int(v.Height) + return v.requisition +} + +// Native returns a pointer to the underlying GtkRequisition. +func (v *Requisition) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func marshalRequisition(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + requisition := (*C.GtkRequisition)(unsafe.Pointer(c)) + return wrapRequisition(requisition), nil +} + +func wrapRequisition(requisition *C.GtkRequisition) *Requisition { + if requisition == nil { + return nil + } + return &Requisition{requisition, int(requisition.width), int(requisition.height)} +} + +// requisitionFromNative that handle finalizer. +func requisitionFromNative(requisitionNative *C.GtkRequisition) (*Requisition, error) { + requisition := wrapRequisition(requisitionNative) + if requisition == nil { + return nil, nilPtrErr + } + runtime.SetFinalizer(requisition, (*Requisition).free) + return requisition, nil +} + +// RequisitionNew is a wrapper around gtk_requisition_new(). +func RequisitionNew() (*Requisition, error) { + c := C.gtk_requisition_new() + if c == nil { + return nil, nilPtrErr + } + return requisitionFromNative(c) +} + +// free is a wrapper around gtk_requisition_free(). +func (v *Requisition) free() { + C.gtk_requisition_free(v.native()) +} + +// Copy is a wrapper around gtk_requisition_copy(). +func (v *Requisition) Copy() (*Requisition, error) { + c := C.gtk_requisition_copy(v.native()) + if c == nil { + return nil, nilPtrErr + } + return requisitionFromNative(c) +} + +/* + * GtkAllocation + */ + +// Allocation is a representation of GTK's GtkAllocation type. +type Allocation struct { + gdk.Rectangle +} + +// Native returns a pointer to the underlying GtkAllocation. +func (v *Allocation) native() *C.GtkAllocation { + return (*C.GtkAllocation)(unsafe.Pointer(&v.GdkRectangle)) +} + +// GetAllocatedWidth() is a wrapper around gtk_widget_get_allocated_width(). +func (v *Widget) GetAllocatedWidth() int { + return int(C.gtk_widget_get_allocated_width(v.native())) +} + +// GetAllocatedHeight() is a wrapper around gtk_widget_get_allocated_height(). +func (v *Widget) GetAllocatedHeight() int { + return int(C.gtk_widget_get_allocated_height(v.native())) +} + +// TODO: +// gtk_widget_get_allocated_baseline(). +// gtk_widget_get_allocated_size(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/widget_export_since_3_8.go b/vendor/github.com/gotk3/gotk3/gtk/widget_export_since_3_8.go new file mode 100644 index 0000000..63ba965 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/widget_export_since_3_8.go @@ -0,0 +1,23 @@ +// +build !gtk_3_6 + +package gtk + +// #include +// #include +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/internal/callback" +) + +//export goTickCallbacks +func goTickCallbacks(widget *C.GtkWidget, frameClock *C.GdkFrameClock, userData C.gpointer) C.gboolean { + fn := callback.Get(uintptr(userData)).(TickCallback) + return gbool(fn( + wrapWidget(glib.Take(unsafe.Pointer(widget))), + gdk.WrapFrameClock(unsafe.Pointer(frameClock)), + )) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_10.go b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_10.go new file mode 100644 index 0000000..6d6a1c8 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_10.go @@ -0,0 +1,44 @@ +// +build !gtk_3_6,!gtk_3_8 + +package gtk + +// #include +import "C" + +// GetPreferredHeightAndBaselineForWidth is a wrapper around gtk_widget_get_preferred_height_and_baseline_for_width(). +func (v *Widget) GetPreferredHeightAndBaselineForWidth(height int) (int, int, int, int) { + + var minimum, natural, minimum_baseline, natural_baseline C.gint + + C.gtk_widget_get_preferred_height_and_baseline_for_width( + v.native(), + C.gint(height), + &minimum, + &natural, + &minimum_baseline, + &natural_baseline) + return int(minimum), + int(natural), + int(minimum_baseline), + int(natural_baseline) +} + +// TODO: +// gtk_widget_get_valign_with_baseline(). +// gtk_widget_init_template(). +// gtk_widget_class_set_template(). +// gtk_widget_class_set_template_from_resource(). +// gtk_widget_get_template_child(). +// gtk_widget_class_bind_template_child(). +// gtk_widget_class_bind_template_child_internal(). +// gtk_widget_class_bind_template_child_private(). +// gtk_widget_class_bind_template_child_internal_private(). +// gtk_widget_class_bind_template_child_full(). +// gtk_widget_class_bind_template_callback(). +// gtk_widget_class_bind_template_callback_full(). +// gtk_widget_class_set_connect_func(). + +// GetScaleFactor is a wrapper around gtk_widget_get_scale_factor(). +func (v *Widget) GetScaleFactor() int { + return int(C.gtk_widget_get_scale_factor(v.native())) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_12.go b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_12.go new file mode 100644 index 0000000..893fc1e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_12.go @@ -0,0 +1,49 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// This file includes wrapers for symbols included since GTK 3.12, and +// and should not be included in a build intended to target any older GTK +// versions. To target an older build, such as 3.10, use +// 'go build -tags gtk_3_10'. Otherwise, if no build tags are used, GTK 3.12 +// is assumed and this file is built. +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10 + +package gtk + +// #include +import "C" + +// SetMarginStart is a wrapper around gtk_widget_set_margin_start(). +func (v *Widget) SetMarginStart(margin int) { + C.gtk_widget_set_margin_start(v.native(), C.gint(margin)) +} + +// GetMarginStart is a wrapper around gtk_widget_get_margin_start(). +func (v *Widget) GetMarginStart() int { + c := C.gtk_widget_get_margin_start(v.native()) + return int(c) +} + +// SetMarginEnd is a wrapper around gtk_widget_set_margin_end(). +func (v *Widget) SetMarginEnd(margin int) { + C.gtk_widget_set_margin_end(v.native(), C.gint(margin)) +} + +// GetMarginEnd is a wrapper around gtk_widget_get_margin_end(). +func (v *Widget) GetMarginEnd() int { + c := C.gtk_widget_get_margin_end(v.native()) + return int(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_14.go b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_14.go new file mode 100644 index 0000000..c777127 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_14.go @@ -0,0 +1,20 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12 + +// See: https://developer.gnome.org/gtk3/3.14/api-index-3-14.html + +package gtk + +// #include +import "C" + +// GetClip is a wrapper around gtk_widget_get_clip(). +func (v *Widget) GetClip() *Allocation { + var clip Allocation + C.gtk_widget_get_clip(v.native(), clip.native()) + return &clip +} + +// SetClip is a wrapper around gtk_widget_set_clip(). +func (v *Widget) SetClip(clip *Allocation) { + C.gtk_widget_set_clip(v.native(), clip.native()) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_16.go b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_16.go new file mode 100644 index 0000000..d25f961 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_16.go @@ -0,0 +1,10 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14 + +package gtk + +// #include +import "C" + +// TODO: +// gtk_widget_list_action_prefixes(). +// gtk_widget_get_action_group(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_18.go b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_18.go new file mode 100644 index 0000000..0891470 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_18.go @@ -0,0 +1,12 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16 + +package gtk + +// #include +import "C" + +// TODO: +// gtk_widget_set_font_options(). +// gtk_widget_get_font_options(). +// gtk_widget_set_font_map(). +// gtk_widget_get_font_map(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_20.go b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_20.go new file mode 100644 index 0000000..1365034 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_20.go @@ -0,0 +1,21 @@ +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16,!gtk_3_18 + +package gtk + +// #include +import "C" + +// GetFocusOnClick is a wrapper around gtk_widget_get_focus_on_click(). +func (v *Widget) GetFocusOnClick() bool { + c := C.gtk_widget_get_focus_on_click(v.native()) + return gobool(c) +} + +// SetFocusOnClick is a wrapper around gtk_widget_set_focus_on_click(). +func (v *Widget) SetFocusOnClick(focusOnClick bool) { + C.gtk_widget_set_focus_on_click(v.native(), gbool(focusOnClick)) +} + +// TODO: +// gtk_widget_class_get_css_name(). +// gtk_widget_class_set_css_name(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_8.go b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_8.go new file mode 100644 index 0000000..34db307 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_8.go @@ -0,0 +1,83 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// This file includes wrapers for symbols included since GTK 3.8, and +// and should not be included in a build intended to target any older GTK +// versions. To target an older build, such as 3.8, use +// 'go build -tags gtk_3_8'. Otherwise, if no build tags are used, GTK 3.18 +// is assumed and this file is built. +// +build !gtk_3_6 + +package gtk + +// #include +// #include "widget_since_3_8.go.h" +import "C" + +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/internal/callback" +) + +/* + * GtkTickCallback + */ + +// TickCallback is a representation of GtkTickCallback +type TickCallback func(widget *Widget, frameClock *gdk.FrameClock) bool + +/* + * GtkWidget + */ + +// IsVisible is a wrapper around gtk_widget_is_visible(). +func (v *Widget) IsVisible() bool { + c := C.gtk_widget_is_visible(v.native()) + return gobool(c) +} + +// SetOpacity is a wrapper around gtk_widget_set_opacity() +func (v *Widget) SetOpacity(opacity float64) { + C.gtk_widget_set_opacity(v.native(), C.double(opacity)) +} + +// GetOpacity is a wrapper around gtk_widget_get_opacity() +func (v *Widget) GetOpacity() float64 { + c := C.gtk_widget_get_opacity(v.native()) + return float64(c) +} + +// GetFrameClock is a wrapper around gtk_widget_get_frame_clock(). +func (v *Widget) GetFrameClock() *gdk.FrameClock { + c := C.gtk_widget_get_frame_clock(v.native()) + return gdk.WrapFrameClock(unsafe.Pointer(c)) +} + +// AddTickCallback is a wrapper around gtk_widget_add_tick_callback(). +func (v *Widget) AddTickCallback(fn TickCallback) int { + return int(C._gtk_widget_add_tick_callback(v.native(), C.gpointer(callback.Assign(fn)))) +} + +// RemoveTickCallback is a wrapper around gtk_widget_remove_tick_callback(). +func (v *Widget) RemoveTickCallback(id int) { + C.gtk_widget_remove_tick_callback(v.native(), C.guint(id)) +} + +// TODO: +// gtk_widget_register_window(). +// gtk_widget_unregister_window(). diff --git a/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_8.go.h b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_8.go.h new file mode 100644 index 0000000..f9627f4 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/widget_since_3_8.go.h @@ -0,0 +1,30 @@ +/* + * Copyright (c) 2013-2014 Conformal Systems + * + * This file originated from: http://opensource.conformal.com/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include "gtk.go.h" // for gotk3_callbackDelete +#include + +extern gboolean goTickCallbacks(GtkWidget *widget, GdkFrameClock *frame_clock, + gpointer user_data); + +static inline guint _gtk_widget_add_tick_callback(GtkWidget *widget, + gpointer user_data) { + return gtk_widget_add_tick_callback( + widget, (GtkTickCallback)(goTickCallbacks), user_data, + (GDestroyNotify)(gotk3_callbackDelete)); +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/window.go b/vendor/github.com/gotk3/gotk3/gtk/window.go new file mode 100644 index 0000000..7e56e39 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/window.go @@ -0,0 +1,727 @@ +// Same copyright and license as the rest of the files in this project + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "errors" + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +/* + * GtkWindow + */ + +// gtk_window_set_has_user_ref_count is NOT included, see GTK documentation for why that is. + +// Window is a representation of GTK's GtkWindow. +type Window struct { + Bin +} + +// IWindow is an interface type implemented by all structs embedding a +// Window. It is meant to be used as an argument type for wrapper +// functions that wrap around a C GTK function taking a GtkWindow. +type IWindow interface { + toWindow() *C.GtkWindow + ToWindow() *Window +} + +// native returns a pointer to the underlying GtkWindow. +func (v *Window) native() *C.GtkWindow { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkWindow(p) +} + +func (v *Window) toWindow() *C.GtkWindow { + if v == nil { + return nil + } + return v.native() +} + +// ToWindow is a helper getter, e.g.: it returns *gtk.ApplicationWindow as a *gtk.Window. +// In other cases, where you have a gtk.IWindow, use the type assertion. +func (v *Window) ToWindow() *Window { + return v +} + +func marshalWindow(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapWindow(obj), nil +} + +func wrapWindow(obj *glib.Object) *Window { + if obj == nil { + return nil + } + + return &Window{Bin{Container{Widget{glib.InitiallyUnowned{obj}}}}} +} + +// WindowNew is a wrapper around gtk_window_new(). +func WindowNew(t WindowType) (*Window, error) { + c := C.gtk_window_new(C.GtkWindowType(t)) + if c == nil { + return nil, nilPtrErr + } + return wrapWindow(glib.Take(unsafe.Pointer(c))), nil +} + +// SetTitle is a wrapper around gtk_window_set_title(). +func (v *Window) SetTitle(title string) { + cstr := C.CString(title) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_window_set_title(v.native(), (*C.gchar)(cstr)) +} + +// SetResizable is a wrapper around gtk_window_set_resizable(). +func (v *Window) SetResizable(resizable bool) { + C.gtk_window_set_resizable(v.native(), gbool(resizable)) +} + +// GetResizable is a wrapper around gtk_window_get_resizable(). +func (v *Window) GetResizable() bool { + c := C.gtk_window_get_resizable(v.native()) + return gobool(c) +} + +// ActivateFocus is a wrapper around gtk_window_activate_focus(). +func (v *Window) ActivateFocus() bool { + c := C.gtk_window_activate_focus(v.native()) + return gobool(c) +} + +// ActivateDefault is a wrapper around gtk_window_activate_default(). +func (v *Window) ActivateDefault() bool { + c := C.gtk_window_activate_default(v.native()) + return gobool(c) +} + +// SetModal is a wrapper around gtk_window_set_modal(). +func (v *Window) SetModal(modal bool) { + C.gtk_window_set_modal(v.native(), gbool(modal)) +} + +// SetDefaultSize is a wrapper around gtk_window_set_default_size(). +func (v *Window) SetDefaultSize(width, height int) { + C.gtk_window_set_default_size(v.native(), C.gint(width), C.gint(height)) +} + +// SetIcon is a wrapper around gtk_window_set_icon(). +func (v *Window) SetIcon(icon *gdk.Pixbuf) { + iconPtr := (*C.GdkPixbuf)(unsafe.Pointer(icon.Native())) + C.gtk_window_set_icon(v.native(), iconPtr) +} + +// WindowSetDefaultIcon is a wrapper around gtk_window_set_default_icon(). +func WindowSetDefaultIcon(icon *gdk.Pixbuf) { + iconPtr := (*C.GdkPixbuf)(unsafe.Pointer(icon.Native())) + C.gtk_window_set_default_icon(iconPtr) +} + +// SetGeometryHints is a wrapper around gtk_window_set_geometry_hints(). +func (v *Window) SetGeometryHints(geometryWidget IWidget, geometry gdk.Geometry, geometryMask gdk.WindowHints) { + var gW *C.GtkWidget = nil + if geometryWidget != nil { + gW = geometryWidget.toWidget() + } + C.gtk_window_set_geometry_hints(v.native(), gW, nativeGdkGeometry(geometry), C.GdkWindowHints(geometryMask)) +} + +// SetGravity is a wrapper around gtk_window_set_gravity(). +func (v *Window) SetGravity(gravity gdk.Gravity) { + C.gtk_window_set_gravity(v.native(), C.GdkGravity(gravity)) +} + +// GetGravity is a wrapper around gtk_window_get_gravity(). +func (v *Window) GetGravity() gdk.Gravity { + c := C.gtk_window_get_gravity(v.native()) + return gdk.Gravity(c) +} + +// SetPosition is a wrapper around gtk_window_set_position(). +func (v *Window) SetPosition(position WindowPosition) { + C.gtk_window_set_position(v.native(), C.GtkWindowPosition(position)) +} + +// SetTransientFor is a wrapper around gtk_window_set_transient_for(). +func (v *Window) SetTransientFor(parent IWindow) { + var pw *C.GtkWindow = nil + if parent != nil { + pw = parent.toWindow() + } + C.gtk_window_set_transient_for(v.native(), pw) +} + +// SetAttachedTo is a wrapper around gtk_window_set_attached_to(). +func (v *Window) SetAttachedTo(attachWidget IWidget) { + var aW *C.GtkWidget = nil + if attachWidget != nil { + aW = attachWidget.toWidget() + } + C.gtk_window_set_attached_to(v.native(), aW) +} + +// SetDestroyWithParent is a wrapper around +// gtk_window_set_destroy_with_parent(). +func (v *Window) SetDestroyWithParent(setting bool) { + C.gtk_window_set_destroy_with_parent(v.native(), gbool(setting)) +} + +// SetHideTitlebarWhenMaximized is a wrapper around +// gtk_window_set_hide_titlebar_when_maximized(). +func (v *Window) SetHideTitlebarWhenMaximized(setting bool) { + C.gtk_window_set_hide_titlebar_when_maximized(v.native(), + gbool(setting)) +} + +// IsActive is a wrapper around gtk_window_is_active(). +func (v *Window) IsActive() bool { + c := C.gtk_window_is_active(v.native()) + return gobool(c) +} + +// HasToplevelFocus is a wrapper around gtk_window_has_toplevel_focus(). +func (v *Window) HasToplevelFocus() bool { + c := C.gtk_window_has_toplevel_focus(v.native()) + return gobool(c) +} + +// GetFocus is a wrapper around gtk_window_get_focus(). +func (v *Window) GetFocus() (IWidget, error) { + c := C.gtk_window_get_focus(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// SetFocus is a wrapper around gtk_window_set_focus(). +func (v *Window) SetFocus(w *Widget) { + C.gtk_window_set_focus(v.native(), w.native()) +} + +// GetDefaultWidget is a wrapper around gtk_window_get_default_widget(). +// See SetDefault() for the setter. +func (v *Window) GetDefaultWidget() (IWidget, error) { + c := C.gtk_window_get_default_widget(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// SetDefault is a wrapper around gtk_window_set_default(). +// See GetDefaultWidget() for the getter. +func (v *Window) SetDefault(widget IWidget) { + C.gtk_window_set_default(v.native(), widget.toWidget()) +} + +// Present is a wrapper around gtk_window_present(). +func (v *Window) Present() { + C.gtk_window_present(v.native()) +} + +// PresentWithTime is a wrapper around gtk_window_present_with_time(). +func (v *Window) PresentWithTime(ts uint32) { + C.gtk_window_present_with_time(v.native(), C.guint32(ts)) +} + +// Iconify is a wrapper around gtk_window_iconify(). +func (v *Window) Iconify() { + C.gtk_window_iconify(v.native()) +} + +// Deiconify is a wrapper around gtk_window_deiconify(). +func (v *Window) Deiconify() { + C.gtk_window_deiconify(v.native()) +} + +// Stick is a wrapper around gtk_window_stick(). +func (v *Window) Stick() { + C.gtk_window_stick(v.native()) +} + +// Unstick is a wrapper around gtk_window_unstick(). +func (v *Window) Unstick() { + C.gtk_window_unstick(v.native()) +} + +// Maximize is a wrapper around gtk_window_maximize(). +func (v *Window) Maximize() { + C.gtk_window_maximize(v.native()) +} + +// Unmaximize is a wrapper around gtk_window_unmaximize(). +func (v *Window) Unmaximize() { + C.gtk_window_unmaximize(v.native()) +} + +// Fullscreen is a wrapper around gtk_window_fullscreen(). +func (v *Window) Fullscreen() { + C.gtk_window_fullscreen(v.native()) +} + +// Unfullscreen is a wrapper around gtk_window_unfullscreen(). +func (v *Window) Unfullscreen() { + C.gtk_window_unfullscreen(v.native()) +} + +// SetKeepAbove is a wrapper around gtk_window_set_keep_above(). +func (v *Window) SetKeepAbove(setting bool) { + C.gtk_window_set_keep_above(v.native(), gbool(setting)) +} + +// SetKeepBelow is a wrapper around gtk_window_set_keep_below(). +func (v *Window) SetKeepBelow(setting bool) { + C.gtk_window_set_keep_below(v.native(), gbool(setting)) +} + +// SetDecorated is a wrapper around gtk_window_set_decorated(). +func (v *Window) SetDecorated(setting bool) { + C.gtk_window_set_decorated(v.native(), gbool(setting)) +} + +// SetDeletable is a wrapper around gtk_window_set_deletable(). +func (v *Window) SetDeletable(setting bool) { + C.gtk_window_set_deletable(v.native(), gbool(setting)) +} + +// SetTypeHint is a wrapper around gtk_window_set_type_hint(). +func (v *Window) SetTypeHint(typeHint gdk.WindowTypeHint) { + C.gtk_window_set_type_hint(v.native(), C.GdkWindowTypeHint(typeHint)) +} + +// SetSkipTaskbarHint is a wrapper around gtk_window_set_skip_taskbar_hint(). +func (v *Window) SetSkipTaskbarHint(setting bool) { + C.gtk_window_set_skip_taskbar_hint(v.native(), gbool(setting)) +} + +// SetSkipPagerHint is a wrapper around gtk_window_set_skip_pager_hint(). +func (v *Window) SetSkipPagerHint(setting bool) { + C.gtk_window_set_skip_pager_hint(v.native(), gbool(setting)) +} + +// SetUrgencyHint is a wrapper around gtk_window_set_urgency_hint(). +func (v *Window) SetUrgencyHint(setting bool) { + C.gtk_window_set_urgency_hint(v.native(), gbool(setting)) +} + +// SetAcceptFocus is a wrapper around gtk_window_set_accept_focus(). +func (v *Window) SetAcceptFocus(setting bool) { + C.gtk_window_set_accept_focus(v.native(), gbool(setting)) +} + +// SetFocusOnMap is a wrapper around gtk_window_set_focus_on_map(). +func (v *Window) SetFocusOnMap(setting bool) { + C.gtk_window_set_focus_on_map(v.native(), gbool(setting)) +} + +// SetStartupID is a wrapper around gtk_window_set_startup_id(). +func (v *Window) SetStartupID(sid string) { + cstr := (*C.gchar)(C.CString(sid)) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_window_set_startup_id(v.native(), cstr) +} + +// SetRole is a wrapper around gtk_window_set_role(). +func (v *Window) SetRole(s string) { + cstr := (*C.gchar)(C.CString(s)) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_window_set_role(v.native(), cstr) +} + +// GetDecorated is a wrapper around gtk_window_get_decorated(). +func (v *Window) GetDecorated() bool { + c := C.gtk_window_get_decorated(v.native()) + return gobool(c) +} + +// GetDeletable is a wrapper around gtk_window_get_deletable(). +func (v *Window) GetDeletable() bool { + c := C.gtk_window_get_deletable(v.native()) + return gobool(c) +} + +// WindowGetDefaultIconName is a wrapper around gtk_window_get_default_icon_name(). +func WindowGetDefaultIconName() (string, error) { + return stringReturn(C.gtk_window_get_default_icon_name()) +} + +// GetDefaultSize is a wrapper around gtk_window_get_default_size(). +func (v *Window) GetDefaultSize() (width, height int) { + var w, h C.gint + C.gtk_window_get_default_size(v.native(), &w, &h) + return int(w), int(h) +} + +// GetDestroyWithParent is a wrapper around +// gtk_window_get_destroy_with_parent(). +func (v *Window) GetDestroyWithParent() bool { + c := C.gtk_window_get_destroy_with_parent(v.native()) + return gobool(c) +} + +// GetHideTitlebarWhenMaximized is a wrapper around +// gtk_window_get_hide_titlebar_when_maximized(). +func (v *Window) GetHideTitlebarWhenMaximized() bool { + c := C.gtk_window_get_hide_titlebar_when_maximized(v.native()) + return gobool(c) +} + +// GetIcon is a wrapper around gtk_window_get_icon(). +func (v *Window) GetIcon() (*gdk.Pixbuf, error) { + c := C.gtk_window_get_icon(v.native()) + if c == nil { + return nil, nil + } + return &gdk.Pixbuf{glib.Take(unsafe.Pointer(c))}, nil +} + +// GetIconName is a wrapper around gtk_window_get_icon_name(). +func (v *Window) GetIconName() (string, error) { + return stringReturn(C.gtk_window_get_icon_name(v.native())) +} + +// GetModal is a wrapper around gtk_window_get_modal(). +func (v *Window) GetModal() bool { + c := C.gtk_window_get_modal(v.native()) + return gobool(c) +} + +// GetPosition is a wrapper around gtk_window_get_position(). +func (v *Window) GetPosition() (int, int) { + var x, y C.gint + C.gtk_window_get_position(v.native(), &x, &y) + return int(x), int(y) +} + +func stringReturn(c *C.gchar) (string, error) { + if c == nil { + return "", nilPtrErr + } + return C.GoString((*C.char)(c)), nil +} + +// GetRole is a wrapper around gtk_window_get_role(). +func (v *Window) GetRole() (string, error) { + return stringReturn(C.gtk_window_get_role(v.native())) +} + +// GetSize is a wrapper around gtk_window_get_size(). +func (v *Window) GetSize() (width, height int) { + var w, h C.gint + C.gtk_window_get_size(v.native(), &w, &h) + return int(w), int(h) +} + +// GetTitle is a wrapper around gtk_window_get_title(). +func (v *Window) GetTitle() (string, error) { + return stringReturn(C.gtk_window_get_title(v.native())) +} + +// GetTransientFor is a wrapper around gtk_window_get_transient_for(). +func (v *Window) GetTransientFor() (*Window, error) { + c := C.gtk_window_get_transient_for(v.native()) + if c == nil { + return nil, nil + } + return wrapWindow(glib.Take(unsafe.Pointer(c))), nil +} + +// GetAttachedTo is a wrapper around gtk_window_get_attached_to(). +func (v *Window) GetAttachedTo() (IWidget, error) { + c := C.gtk_window_get_attached_to(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// GetTypeHint is a wrapper around gtk_window_get_type_hint(). +func (v *Window) GetTypeHint() gdk.WindowTypeHint { + c := C.gtk_window_get_type_hint(v.native()) + return gdk.WindowTypeHint(c) +} + +// GetSkipTaskbarHint is a wrapper around gtk_window_get_skip_taskbar_hint(). +func (v *Window) GetSkipTaskbarHint() bool { + c := C.gtk_window_get_skip_taskbar_hint(v.native()) + return gobool(c) +} + +// GetSkipPagerHint is a wrapper around gtk_window_get_skip_pager_hint(). +func (v *Window) GetSkipPagerHint() bool { + c := C.gtk_window_get_skip_pager_hint(v.native()) + return gobool(c) +} + +// GetUrgencyHint is a wrapper around gtk_window_get_urgency_hint(). +func (v *Window) GetUrgencyHint() bool { + c := C.gtk_window_get_urgency_hint(v.native()) + return gobool(c) +} + +// GetAcceptFocus is a wrapper around gtk_window_get_accept_focus(). +func (v *Window) GetAcceptFocus() bool { + c := C.gtk_window_get_accept_focus(v.native()) + return gobool(c) +} + +// GetFocusOnMap is a wrapper around gtk_window_get_focus_on_map(). +func (v *Window) GetFocusOnMap() bool { + c := C.gtk_window_get_focus_on_map(v.native()) + return gobool(c) +} + +// GetWindowType is a wrapper around gtk_window_get_window_type(). +func (v *Window) GetWindowType() WindowType { + c := C.gtk_window_get_window_type(v.native()) + return WindowType(c) +} + +// HasGroup is a wrapper around gtk_window_has_group(). +func (v *Window) HasGroup() bool { + c := C.gtk_window_has_group(v.native()) + return gobool(c) +} + +// Move is a wrapper around gtk_window_move(). +func (v *Window) Move(x, y int) { + C.gtk_window_move(v.native(), C.gint(x), C.gint(y)) +} + +// Resize is a wrapper around gtk_window_resize(). +func (v *Window) Resize(width, height int) { + C.gtk_window_resize(v.native(), C.gint(width), C.gint(height)) +} + +// WindowSetDefaultIconFromFile is a wrapper around gtk_window_set_default_icon_from_file(). +func WindowSetDefaultIconFromFile(file string) error { + cstr := C.CString(file) + defer C.free(unsafe.Pointer(cstr)) + var err *C.GError = nil + res := C.gtk_window_set_default_icon_from_file((*C.gchar)(cstr), &err) + if res == 0 { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// WindowSetDefaultIconName is a wrapper around gtk_window_set_default_icon_name(). +func WindowSetDefaultIconName(s string) { + cstr := (*C.gchar)(C.CString(s)) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_window_set_default_icon_name(cstr) +} + +// SetIconFromFile is a wrapper around gtk_window_set_icon_from_file(). +func (v *Window) SetIconFromFile(file string) error { + cstr := C.CString(file) + defer C.free(unsafe.Pointer(cstr)) + var err *C.GError = nil + res := C.gtk_window_set_icon_from_file(v.native(), (*C.gchar)(cstr), &err) + if res == 0 { + defer C.g_error_free(err) + return errors.New(C.GoString((*C.char)(err.message))) + } + return nil +} + +// SetIconName is a wrapper around gtk_window_set_icon_name(). +func (v *Window) SetIconName(name string) { + cstr := C.CString(name) + defer C.free(unsafe.Pointer(cstr)) + C.gtk_window_set_icon_name(v.native(), (*C.gchar)(cstr)) +} + +// WindowSetAutoStartupNotification is a wrapper around +// gtk_window_set_auto_startup_notification(). +func WindowSetAutoStartupNotification(setting bool) { + C.gtk_window_set_auto_startup_notification(gbool(setting)) +} + +// GetMnemonicsVisible is a wrapper around +// gtk_window_get_mnemonics_visible(). +func (v *Window) GetMnemonicsVisible() bool { + c := C.gtk_window_get_mnemonics_visible(v.native()) + return gobool(c) +} + +// SetMnemonicsVisible is a wrapper around +// gtk_window_set_mnemonics_visible(). +func (v *Window) SetMnemonicsVisible(setting bool) { + C.gtk_window_set_mnemonics_visible(v.native(), gbool(setting)) +} + +// GetFocusVisible is a wrapper around gtk_window_get_focus_visible(). +func (v *Window) GetFocusVisible() bool { + c := C.gtk_window_get_focus_visible(v.native()) + return gobool(c) +} + +// SetFocusVisible is a wrapper around gtk_window_set_focus_visible(). +func (v *Window) SetFocusVisible(setting bool) { + C.gtk_window_set_focus_visible(v.native(), gbool(setting)) +} + +// GetApplication is a wrapper around gtk_window_get_application(). +func (v *Window) GetApplication() (*Application, error) { + c := C.gtk_window_get_application(v.native()) + if c == nil { + return nil, nil + } + return wrapApplication(glib.Take(unsafe.Pointer(c))), nil +} + +// SetApplication is a wrapper around gtk_window_set_application(). +func (v *Window) SetApplication(a *Application) { + C.gtk_window_set_application(v.native(), a.native()) +} + +// ActivateKey is a wrapper around gtk_window_activate_key(). +func (v *Window) ActivateKey(event *gdk.EventKey) bool { + c := C.gtk_window_activate_key(v.native(), (*C.GdkEventKey)(unsafe.Pointer(event.Native()))) + return gobool(c) +} + +// AddMnemonic is a wrapper around gtk_window_add_mnemonic(). +func (v *Window) AddMnemonic(keyval uint, target *Widget) { + C.gtk_window_add_mnemonic(v.native(), C.guint(keyval), target.native()) +} + +// RemoveMnemonic is a wrapper around gtk_window_remove_mnemonic(). +func (v *Window) RemoveMnemonic(keyval uint, target *Widget) { + C.gtk_window_remove_mnemonic(v.native(), C.guint(keyval), target.native()) +} + +// ActivateMnemonic is a wrapper around gtk_window_mnemonic_activate(). +func (v *Window) ActivateMnemonic(keyval uint, mods gdk.ModifierType) bool { + c := C.gtk_window_mnemonic_activate(v.native(), C.guint(keyval), C.GdkModifierType(mods)) + return gobool(c) +} + +// GetMnemonicModifier is a wrapper around gtk_window_get_mnemonic_modifier(). +func (v *Window) GetMnemonicModifier() gdk.ModifierType { + c := C.gtk_window_get_mnemonic_modifier(v.native()) + return gdk.ModifierType(c) +} + +// SetMnemonicModifier is a wrapper around gtk_window_set_mnemonic_modifier(). +func (v *Window) SetMnemonicModifier(mods gdk.ModifierType) { + C.gtk_window_set_mnemonic_modifier(v.native(), C.GdkModifierType(mods)) +} + +// SetScreen is a wrapper around gtk_window_set_screen(). +func (v *Window) SetScreen(screen *gdk.Screen) { + C.gtk_window_set_screen(v.native(), C.toGdkScreen(unsafe.Pointer(screen.Native()))) +} + +// GetScreen is a wrapper around gtk_window_get_screen(). +func (v *Window) GetScreen() *gdk.Screen { + c := C.gtk_window_get_screen(v.native()) + return &gdk.Screen{glib.Take(unsafe.Pointer(c))} +} + +// PropagateKeyEvent is a wrapper around gtk_window_propagate_key_event(). +func (v *Window) PropagateKeyEvent(event *gdk.EventKey) bool { + c := C.gtk_window_propagate_key_event(v.native(), (*C.GdkEventKey)(unsafe.Pointer(event.Native()))) + return gobool(c) +} + +// WindowListToplevels is a wrapper around gtk_window_list_toplevels(). +// Returned list is wrapped to return *gtk.Window elements. +// TODO: Use IWindow and wrap to correct type +func WindowListToplevels() *glib.List { + clist := C.gtk_window_list_toplevels() + if clist == nil { + return nil + } + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return wrapWindow(glib.Take(ptr)) + }) + runtime.SetFinalizer(glist, func(l *glib.List) { + l.Free() + }) + return glist +} + +// WindowGetDefaultIconList is a wrapper around gtk_window_get_default_icon_list(). +// Returned list is wrapped to return *gdk.Pixbuf elements. +func WindowGetDefaultIconList() *glib.List { + clist := C.gtk_window_get_default_icon_list() + if clist == nil { + return nil + } + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return &gdk.Pixbuf{glib.Take(ptr)} + }) + runtime.SetFinalizer(glist, func(l *glib.List) { + l.Free() + }) + return glist +} + +// GetIconList is a wrapper around gtk_window_get_icon_list(). +// Returned list is wrapped to return *gdk.Pixbuf elements. +func (v *Window) GetIconList() *glib.List { + clist := C.gtk_window_get_icon_list(v.native()) + if clist == nil { + return nil + } + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return &gdk.Pixbuf{glib.Take(ptr)} + }) + runtime.SetFinalizer(glist, func(l *glib.List) { + l.Free() + }) + return glist +} + +// WindowSetDefaultIconList is a wrapper around gtk_window_set_default_icon_list(). +// List should only contain *gdk.Pixbuf elements! +func WindowSetDefaultIconList(list *glib.List) { + native := (*C.struct__GList)(unsafe.Pointer(list.Native())) + C.gtk_window_set_default_icon_list(native) +} + +// SetIconList is a wrapper around gtk_window_set_icon_list(). +// List should only contain *gdk.Pixbuf elements! +func (v *Window) SetIconList(list *glib.List) { + native := (*C.struct__GList)(unsafe.Pointer(list.Native())) + C.gtk_window_set_icon_list(v.native(), native) +} + +// BeginResizeDrag is a wrapper around gtk_window_begin_resize_drag(). +func (v *Window) BeginResizeDrag(edge gdk.WindowEdge, button gdk.Button, rootX, rootY int, timestamp uint32) { + C.gtk_window_begin_resize_drag(v.native(), C.GdkWindowEdge(edge), C.gint(button), C.gint(rootX), C.gint(rootY), C.guint32(timestamp)) +} + +// BeginMoveDrag is a wrapper around gtk_window_begin_move_drag(). +func (v *Window) BeginMoveDrag(button gdk.Button, rootX, rootY int, timestamp uint32) { + C.gtk_window_begin_move_drag(v.native(), C.gint(button), C.gint(rootX), C.gint(rootY), C.guint32(timestamp)) +} + +// GetGroup is a wrapper around gtk_window_get_group(). +func (v *Window) GetGroup() *WindowGroup { + c := C.gtk_window_get_group(v.native()) + if c == nil { + return nil + } + return wrapWindowGroup(glib.Take(unsafe.Pointer(c))) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/window_since_3_10.go b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_10.go new file mode 100644 index 0000000..032d6cb --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_10.go @@ -0,0 +1,25 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gtk_3_6,!gtk_3_8 +// not use this: go build -tags gtk_3_8'. Otherwise, if no build tags are used, GTK 3.10 + +package gtk + +// #include +// #include +// #include "gtk_since_3_10.go.h" +import "C" + +/* + * GtkWindow + */ + +// SetTitlebar is a wrapper around gtk_window_set_titlebar(). +func (v *Window) SetTitlebar(titlebar IWidget) { + C.gtk_window_set_titlebar(v.native(), titlebar.toWidget()) +} + +// Close is a wrapper around gtk_window_close(). +func (v *Window) Close() { + C.gtk_window_close(v.native()) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/window_since_3_12.go b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_12.go new file mode 100644 index 0000000..4ab9475 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_12.go @@ -0,0 +1,14 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10 + +package gtk + +// #include +import "C" + +// IsMaximized is a wrapper around gtk_window_is_maximized(). +func (v *Window) IsMaximized() bool { + c := C.gtk_window_is_maximized(v.native()) + return gobool(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/window_since_3_14.go b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_14.go new file mode 100644 index 0000000..0904370 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_14.go @@ -0,0 +1,13 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12 + +package gtk + +// #include +import "C" + +// SetInteractiveDebugging is a wrapper around gtk_window_set_interactive_debugging(). +func SetInteractiveDebugging(enable bool) { + C.gtk_window_set_interactive_debugging(gbool(enable)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/window_since_3_16.go b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_16.go new file mode 100644 index 0000000..d19494d --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_16.go @@ -0,0 +1,17 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14 + +package gtk + +// #include +import "C" + +// GetTitlebar is a wrapper around gtk_window_get_titlebar(). +func (v *Window) GetTitlebar() (IWidget, error) { + c := C.gtk_window_get_titlebar(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/window_since_3_16_test.go b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_16_test.go new file mode 100644 index 0000000..94c740d --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_16_test.go @@ -0,0 +1,34 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14 + +// Package gtk_test is a separate package for unit tests. +// Doing this actually utilizes the go build cache +// for package gtk when changing unit test code. +package gtk_test + +import ( + "testing" + + "github.com/gotk3/gotk3/gtk" +) + +func TestWindowGetSetTitlebar(t *testing.T) { + win := createTestWindow(t) + + // Create test button, SetCanDefault is required for SetDefault to work + expected, err := gtk.ButtonNew() + if err != nil { + t.Error("unexpected error:", err.Error()) + } + win.SetTitlebar(expected) + + a, err := win.GetTitlebar() + if err != nil { + t.Error("unexpected cast failure:", err.Error()) + } + actual := a.ToWidget() + if expected.Native() != actual.Native() { + t.Errorf("Expected '0x%x'; Got '0x%x'", expected.Native(), actual.Native()) + } +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/window_since_3_18.go b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_18.go new file mode 100644 index 0000000..343b42e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/window_since_3_18.go @@ -0,0 +1,19 @@ +// Same copyright and license as the rest of the files in this project + +// +build !gtk_3_6,!gtk_3_8,!gtk_3_10,!gtk_3_12,!gtk_3_14,!gtk_3_16 + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/gdk" +) + +// FullscreenOnMonitor is a wrapper around gtk_window_fullscreen_on_monitor(). +func (v *Window) FullscreenOnMonitor(screen *gdk.Screen, monitor int) { + C.gtk_window_fullscreen_on_monitor(v.native(), C.toGdkScreen(unsafe.Pointer(screen.Native())), C.gint(monitor)) +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/window_test.go b/vendor/github.com/gotk3/gotk3/gtk/window_test.go new file mode 100644 index 0000000..15b7618 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/window_test.go @@ -0,0 +1,548 @@ +// Same copyright and license as the rest of the files in this project + +// Package gtk_test is a separate package for unit tests. +// Doing this actually utilizes the go build cache +// for package gtk when changing unit test code. +package gtk_test + +import ( + "testing" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/gtk" +) + +func TestWindowNew(t *testing.T) { + cut, err := gtk.WindowNew(gtk.WINDOW_TOPLEVEL) + if err != nil { + t.Error("unexpected error:", err.Error()) + } + + actual := cut.GetWindowType() + if gtk.WINDOW_TOPLEVEL != actual { + t.Errorf("Expected WindowType '%d'; Got '%d'", gtk.WINDOW_TOPLEVEL, actual) + } +} + +func createTestWindow(t *testing.T) *gtk.Window { + win, err := gtk.WindowNew(gtk.WINDOW_TOPLEVEL) + if err != nil { + t.Error("unexpected error:", err.Error()) + } + + return win +} + +func TestWindowGetSetTitle(t *testing.T) { + win := createTestWindow(t) + + expected := "Unit Test Window" + win.SetTitle(expected) + + actual, err := win.GetTitle() + if err != nil { + t.Error("unexpected error:", err.Error()) + } + if expected != actual { + t.Errorf("Expected '%s'; Got '%s'", expected, actual) + } +} + +func TestWindowGetSetIconName(t *testing.T) { + win := createTestWindow(t) + + expected := "unit-icon-symbolic" + win.SetIconName(expected) + + actual, err := win.GetIconName() + if err != nil { + t.Error("unexpected error:", err.Error()) + } + if expected != actual { + t.Errorf("Expected '%s'; Got '%s'", expected, actual) + } +} + +func TestWindowGetSetDefaultIconName(t *testing.T) { + expected := "unit-icon-symbolic" + gtk.WindowSetDefaultIconName(expected) + + actual, err := gtk.WindowGetDefaultIconName() + if err != nil { + t.Error("unexpected error:", err.Error()) + } + if expected != actual { + t.Errorf("Expected '%s'; Got '%s'", expected, actual) + } +} + +func TestWindowGetSetRole(t *testing.T) { + win := createTestWindow(t) + + expected := "Unit Test Role" + win.SetRole(expected) + + actual, err := win.GetRole() + if err != nil { + t.Error("unexpected error:", err.Error()) + } + if expected != actual { + t.Errorf("Expected '%s'; Got '%s'", expected, actual) + } +} + +func TestWindowGetSetTransientFor(t *testing.T) { + win := createTestWindow(t) + + expected := createTestWindow(t) + win.SetTransientFor(expected) + + actual, err := win.GetTransientFor() + if err != nil { + t.Error("unexpected error:", err.Error()) + } + if expected.Native() != actual.Native() { + t.Errorf("Expected '0x%x'; Got '0x%x'", expected.Native(), actual.Native()) + } +} + +func TestWindowGetSetAttachedTo(t *testing.T) { + win := createTestWindow(t) + + expected := createTestWindow(t) + win.SetAttachedTo(expected) + + a, err := win.GetAttachedTo() + if err != nil { + t.Error("unexpected error:", err.Error()) + } + actual := a.ToWidget() + if expected.Native() != actual.Native() { + t.Errorf("Expected '0x%x'; Got '0x%x'", expected.Native(), actual.Native()) + } +} + +func TestWindowGetSetDefaultSize(t *testing.T) { + win := createTestWindow(t) + + expectedW, expectedH := 123, 345 + win.SetDefaultSize(expectedW, expectedH) + + actualW, actualH := win.GetDefaultSize() + + if expectedW != actualW || expectedH != actualH { + t.Errorf("Expected %dx%d; Got %dx%d", expectedW, expectedH, actualW, actualH) + } +} + +func TestWindowGetSetGravity(t *testing.T) { + win := createTestWindow(t) + + var expected gdk.Gravity + expected = gdk.GDK_GRAVITY_EAST + win.SetGravity(expected) + + actual := win.GetGravity() + if expected != actual { + t.Errorf("Expected '%d'; Got '%d'", expected, actual) + } +} + +func TestWindowGetSetDefaultWidget(t *testing.T) { + win := createTestWindow(t) + + // Create test button, SetCanDefault is required for SetDefault to work + expected, err := gtk.ButtonNew() + if err != nil { + t.Error("unexpected error:", err.Error()) + } + expected.SetCanDefault(true) + + win.SetDefault(expected) + + a, err := win.GetDefaultWidget() + if err != nil { + t.Error("unexpected error:", err.Error()) + } + actual := a.ToWidget() + if expected.Native() != actual.Native() { + t.Errorf("Expected '0x%x'; Got '0x%x'", expected.Native(), actual.Native()) + } +} + +func TestWindowGetSetDestroyWithParent(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetDestroyWithParent(tC.value) + + actual := win.GetDestroyWithParent() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetHideTitlebarWhenMaximized(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetHideTitlebarWhenMaximized(tC.value) + + actual := win.GetHideTitlebarWhenMaximized() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetResizable(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetResizable(tC.value) + + actual := win.GetResizable() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetModal(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetModal(tC.value) + + actual := win.GetModal() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetDecorated(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetDecorated(tC.value) + + actual := win.GetDecorated() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetDeletable(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetDeletable(tC.value) + + actual := win.GetDeletable() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetSkipTaskbarHint(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetSkipTaskbarHint(tC.value) + + actual := win.GetSkipTaskbarHint() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetSkipPagerHint(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetSkipPagerHint(tC.value) + + actual := win.GetSkipPagerHint() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetUrgencyHint(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetUrgencyHint(tC.value) + + actual := win.GetUrgencyHint() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetAcceptFocus(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetAcceptFocus(tC.value) + + actual := win.GetAcceptFocus() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetFocusOnMap(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetFocusOnMap(tC.value) + + actual := win.GetFocusOnMap() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetMnemonicsVisible(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetMnemonicsVisible(tC.value) + + actual := win.GetMnemonicsVisible() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetFocusVisible(t *testing.T) { + win := createTestWindow(t) + + testCases := []struct { + desc string + value bool + }{ + { + desc: "true", + value: true, + }, + { + desc: "true", + value: false, + }, + } + for _, tC := range testCases { + t.Run(tC.desc, func(t *testing.T) { + win.SetFocusVisible(tC.value) + + actual := win.GetFocusVisible() + if tC.value != actual { + t.Errorf("Expected '%t'; Got '%t'", tC.value, actual) + } + }) + } +} + +func TestWindowGetSetTypeHint(t *testing.T) { + win := createTestWindow(t) + + var expected gdk.WindowTypeHint + expected = gdk.WINDOW_TYPE_HINT_UTILITY + win.SetTypeHint(expected) + + actual := win.GetTypeHint() + if expected != actual { + t.Errorf("Expected '%d'; Got '%d'", expected, actual) + } +} diff --git a/vendor/github.com/gotk3/gotk3/gtk/windowgroup.go b/vendor/github.com/gotk3/gotk3/gtk/windowgroup.go new file mode 100644 index 0000000..1f60b9c --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/gtk/windowgroup.go @@ -0,0 +1,108 @@ +// Same copyright and license as the rest of the files in this project + +package gtk + +// #include +// #include "gtk.go.h" +import "C" +import ( + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/glib" +) + +/* + * GtkWindowGroup + */ + +type WindowGroup struct { + *glib.Object +} + +// native returns a pointer to the underlying GtkWindowGroup. +func (v *WindowGroup) native() *C.GtkWindowGroup { + if v == nil || v.GObject == nil { + return nil + } + p := unsafe.Pointer(v.GObject) + return C.toGtkWindowGroup(p) +} + +func marshalWindowGroup(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := glib.Take(unsafe.Pointer(c)) + return wrapWindowGroup(obj), nil +} + +func wrapWindowGroup(obj *glib.Object) *WindowGroup { + if obj == nil { + return nil + } + + return &WindowGroup{obj} +} + +// WindowGroupNew is a wrapper around gtk_window_group_new(). +func WindowGroupNew() (*WindowGroup, error) { + c := C.gtk_window_group_new() + if c == nil { + return nil, nilPtrErr + } + return wrapWindowGroup(glib.Take(unsafe.Pointer(c))), nil +} + +// AddWindow is a wrapper around gtk_window_group_add_window(). +func (v *WindowGroup) AddWindow(window IWindow) { + var pw *C.GtkWindow = nil + if window != nil { + pw = window.toWindow() + } + C.gtk_window_group_add_window(v.native(), pw) +} + +// RemoveWindow is a wrapper around gtk_window_group_remove_window(). +func (v *WindowGroup) RemoveWindow(window IWindow) { + var pw *C.GtkWindow = nil + if window != nil { + pw = window.toWindow() + } + C.gtk_window_group_remove_window(v.native(), pw) +} + +// ListWindows is a wrapper around gtk_window_group_list_windows(). +// Returned list is wrapped to return *gtk.Window elements. +// TODO: Use IWindow and wrap to correct type +func (v *WindowGroup) ListWindows() *glib.List { + clist := C.gtk_window_group_list_windows(v.native()) + if clist == nil { + return nil + } + glist := glib.WrapList(uintptr(unsafe.Pointer(clist))) + glist.DataWrapper(func(ptr unsafe.Pointer) interface{} { + return wrapWindow(glib.Take(ptr)) + }) + runtime.SetFinalizer(glist, func(l *glib.List) { + l.Free() + }) + return glist +} + +// GetCurrentGrab is a wrapper around gtk_window_group_get_current_grab(). +func (v *WindowGroup) GetCurrentGrab() (IWidget, error) { + c := C.gtk_window_group_get_current_grab(v.native()) + if c == nil { + return nil, nil + } + return castWidget(c) +} + +// GetCurrentDeviceGrab is a wrapper around gtk_window_group_get_current_device_grab(). +func (v *WindowGroup) GetCurrentDeviceGrab(device *gdk.Device) (IWidget, error) { + c := C.gtk_window_group_get_current_device_grab(v.native(), C.toGdkDevice(unsafe.Pointer(device.Native()))) + if c == nil { + return nil, nil + } + return castWidget(c) +} diff --git a/vendor/github.com/gotk3/gotk3/internal/callback/callback.go b/vendor/github.com/gotk3/gotk3/internal/callback/callback.go new file mode 100644 index 0000000..47142aa --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/internal/callback/callback.go @@ -0,0 +1,37 @@ +package callback + +import ( + "sync" + + "github.com/gotk3/gotk3/internal/slab" +) + +var ( + mutex sync.RWMutex + registry slab.Slab +) + +func Assign(callback interface{}) uintptr { + mutex.Lock() + defer mutex.Unlock() + + return registry.Put(callback) +} + +func Get(ptr uintptr) interface{} { + mutex.RLock() + defer mutex.RUnlock() + + return registry.Get(ptr) +} + +func Delete(ptr uintptr) { + GetAndDelete(ptr) +} + +func GetAndDelete(ptr uintptr) interface{} { + mutex.Lock() + defer mutex.Unlock() + + return registry.Pop(ptr) +} diff --git a/vendor/github.com/gotk3/gotk3/internal/closure/closure.go b/vendor/github.com/gotk3/gotk3/internal/closure/closure.go new file mode 100644 index 0000000..d06c907 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/internal/closure/closure.go @@ -0,0 +1,79 @@ +package closure + +import ( + "sync" + "unsafe" +) + +var ( + closures = sync.Map{} // unsafe.Pointer(*GClosure) -> reflect.Value + + // use a bi-directional map to allow lookup of the closure value from both + // the SourceHandle and the closure ID in constant time. + signalMu sync.Mutex + signalClosures = map[uint]unsafe.Pointer{} // uint(SourceHandle) -> uintptr (closure key, callbackID) + closureSignals = map[unsafe.Pointer]uint{} // unsafe.Pointer(*GClosure) -> uint(SourceHandle) +) + +// RegisterSignal registers the given signal handle to be associated with the +// closure pointer. This association allows the closure to be removed as well +// when the signal removal is requested from the user using DisconnectSignal. +func RegisterSignal(handle uint, closure unsafe.Pointer) { + // Safety check omitted until the race condition in glib/connect.go is + // fixed. Check that file for more info. + + signalMu.Lock() + defer signalMu.Unlock() + + signalClosures[handle] = closure + closureSignals[closure] = handle +} + +// DisconnectSignal removes both the signal and the closure associated with it +// from the internal registry. Since this function will also remove the closure +// itself from the internal registry, Gtk's disconnect functions should be +// called first. +func DisconnectSignal(handle uint) { + signalMu.Lock() + defer signalMu.Unlock() + + closure, ok := signalClosures[handle] + if ok { + closures.Delete(closure) + delete(closureSignals, closure) + delete(signalClosures, handle) + } +} + +// Assign assigns the given FuncStack to the given closure. +func Assign(closure unsafe.Pointer, fs FuncStack) { + closures.Store(closure, fs) +} + +// Get gets the reflect-value callback from the closure pointer. +func Get(closure unsafe.Pointer) FuncStack { + v, ok := closures.Load(closure) + if ok { + return v.(FuncStack) + } + return zeroFuncStack +} + +// Delete deletes the closure pointer from the registry while also checking for +// any existing signal handler associated with the given callback ID. If a +// signal handler is found, then its behavior is similar to DisconnectSignal. +func Delete(closure unsafe.Pointer) { + funcStack := getAndDeleteClosure(closure) + if !funcStack.IsValid() { + return + } + + signalMu.Lock() + defer signalMu.Unlock() + + handle, ok := closureSignals[closure] + if ok { + delete(closureSignals, closure) + delete(signalClosures, handle) + } +} diff --git a/vendor/github.com/gotk3/gotk3/internal/closure/closure_go_1_14.go b/vendor/github.com/gotk3/gotk3/internal/closure/closure_go_1_14.go new file mode 100644 index 0000000..df85755 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/internal/closure/closure_go_1_14.go @@ -0,0 +1,14 @@ +// +build !go1.15 + +package closure + +import "unsafe" + +func getAndDeleteClosure(closure unsafe.Pointer) FuncStack { + v, ok := closures.Load(closure) + if ok { + closures.Delete(closure) + return v.(FuncStack) + } + return zeroFuncStack +} diff --git a/vendor/github.com/gotk3/gotk3/internal/closure/closure_go_1_15.go b/vendor/github.com/gotk3/gotk3/internal/closure/closure_go_1_15.go new file mode 100644 index 0000000..b862314 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/internal/closure/closure_go_1_15.go @@ -0,0 +1,13 @@ +// +build go1.15 + +package closure + +import "unsafe" + +func getAndDeleteClosure(closure unsafe.Pointer) FuncStack { + v, ok := closures.LoadAndDelete(closure) + if ok { + return v.(FuncStack) + } + return zeroFuncStack +} diff --git a/vendor/github.com/gotk3/gotk3/internal/closure/funcstack.go b/vendor/github.com/gotk3/gotk3/internal/closure/funcstack.go new file mode 100644 index 0000000..b7fef23 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/internal/closure/funcstack.go @@ -0,0 +1,94 @@ +package closure + +import ( + "fmt" + "reflect" + "runtime" + "strconv" + "strings" +) + +// FrameSize is the number of frames that FuncStack should trace back from. +const FrameSize = 3 + +// FuncStack wraps a function value and provides function frames containing the +// caller trace for debugging. +type FuncStack struct { + Func reflect.Value + Frames []uintptr +} + +var zeroFuncStack = FuncStack{} + +// NewFuncStack creates a new FuncStack. It panics if fn is not a function. The +// given frameSkip is added 2, meaning the first frame from 0 will start from +// the caller of NewFuncStack. +func NewFuncStack(fn interface{}, frameSkip int) FuncStack { + // Create a reflect.Value from f. This is called when the returned + // GClosure runs. + rf := reflect.ValueOf(fn) + + // Closures can only be created from funcs. + if rf.Type().Kind() != reflect.Func { + panic("closure value is not a func") + } + + frames := make([]uintptr, FrameSize) + frames = frames[:runtime.Callers(frameSkip+2, frames)] + + return FuncStack{ + Func: rf, + Frames: frames, + } +} + +// IsValid returns true if the given FuncStack is not a zero-value i.e. valid. +func (fs FuncStack) IsValid() bool { + return fs.Frames != nil +} + +const headerSignature = "closure error: " + +// Panicf panics with the given FuncStack printed to standard error. +func (fs FuncStack) Panicf(msgf string, v ...interface{}) { + msg := strings.Builder{} + msg.WriteString(headerSignature) + fmt.Fprintf(&msg, msgf, v...) + + msg.WriteString("\n\nClosure added at:") + + frames := runtime.CallersFrames(fs.Frames) + for { + frame, more := frames.Next() + msg.WriteString("\n\t") + msg.WriteString(frame.Function) + msg.WriteString(" at ") + msg.WriteString(frame.File) + msg.WriteByte(':') + msg.WriteString(strconv.Itoa(frame.Line)) + + if !more { + break + } + } + + panic(msg.String()) +} + +// TryRepanic attempts to recover a panic. If successful, it will re-panic with +// the trace, or none if there is already one. +func (fs FuncStack) TryRepanic() { + panicking := recover() + if panicking == nil { + return + } + + if msg, ok := panicking.(string); ok { + if strings.HasPrefix(msg, headerSignature) { + // We can just repanic as-is. + panic(msg) + } + } + + fs.Panicf("unexpected panic caught: %v", panicking) +} diff --git a/vendor/github.com/gotk3/gotk3/internal/slab/slab.go b/vendor/github.com/gotk3/gotk3/internal/slab/slab.go new file mode 100644 index 0000000..d7d99e0 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/internal/slab/slab.go @@ -0,0 +1,52 @@ +package slab + +type slabEntry struct { + Value interface{} + Index uintptr +} + +func (entry slabEntry) IsValid() bool { + return entry.Value != nil +} + +// Slab is an implementation of the internal registry free list. A zero-value +// instance is a valid instance. This data structure is not thread-safe. +type Slab struct { + entries []slabEntry + free uintptr +} + +func (s *Slab) Put(entry interface{}) uintptr { + if s.free == uintptr(len(s.entries)) { + index := uintptr(len(s.entries)) + s.entries = append(s.entries, slabEntry{entry, 0}) + s.free++ + return index + } + + index := s.free + + s.free = s.entries[index].Index + s.entries[index] = slabEntry{entry, 0} + + return index +} + +func (s *Slab) Get(i uintptr) interface{} { + // Perform bound check. + if i >= uintptr(len(s.entries)) { + return nil + } + // Perform validity check in case of invalid ID. + if entry := s.entries[i]; entry.IsValid() { + return entry.Value + } + return nil +} + +func (s *Slab) Pop(i uintptr) interface{} { + popped := s.entries[i].Value + s.entries[i] = slabEntry{nil, s.free} + s.free = i + return popped +} diff --git a/vendor/github.com/gotk3/gotk3/pango/fontconfig.go.h b/vendor/github.com/gotk3/gotk3/pango/fontconfig.go.h new file mode 100644 index 0000000..5d07873 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/fontconfig.go.h @@ -0,0 +1,7 @@ + +#include + +static int addFont(unsigned char *font) { + FcBool fontAddStatus = FcConfigAppFontAddFile(FcConfigGetCurrent(), font); + return fontAddStatus; +} \ No newline at end of file diff --git a/vendor/github.com/gotk3/gotk3/pango/pango-attributes.go b/vendor/github.com/gotk3/gotk3/pango/pango-attributes.go new file mode 100644 index 0000000..75ac4bb --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango-attributes.go @@ -0,0 +1,367 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package pango + +// #include +// #include "pango.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.pango_attr_type_get_type()), marshalAttrType}, + {glib.Type(C.pango_underline_get_type()), marshalUnderline}, + } + glib.RegisterGValueMarshalers(tm) +} + +/* PangoColor */ + +// Color is a representation of PangoColor. +type Color struct { + pangoColor *C.PangoColor +} + +// Native returns a pointer to the underlying PangoColor. +func (v *Color) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *Color) native() *C.PangoColor { + return (*C.PangoColor)(unsafe.Pointer(v.pangoColor)) +} + +func (v *Color) Set(red, green, blue uint16) { + v.native().red = C.guint16(red) + v.native().green = C.guint16(green) + v.native().blue = C.guint16(blue) +} + +func (v *Color) Get() (red, green, blue uint16) { + return uint16(v.native().red), uint16(v.native().green), uint16(v.native().blue) +} + +//PangoColor *pango_color_copy (const PangoColor *src); +func (v *Color) Copy(c *Color) *Color { + w := new(Color) + w.pangoColor = C.pango_color_copy(v.native()) + return w +} + +//void pango_color_free (PangoColor *color); +func (v *Color) Free() { + C.pango_color_free(v.native()) +} + +//gboolean pango_color_parse (PangoColor *color, +// const char *spec); +func (v *Color) Parse(spec string) bool { + cstr := C.CString(spec) + defer C.free(unsafe.Pointer(cstr)) + c := C.pango_color_parse(v.native(), (*C.char)(cstr)) + return gobool(c) +} + +//gchar *pango_color_to_string(const PangoColor *color); +func (v *Color) ToString() string { + c := C.pango_color_to_string(v.native()) + return C.GoString((*C.char)(c)) +} + +/* --- --- --- Attributes --- --- --- */ + +// AttrList is a representation of PangoAttrList. +type AttrList struct { + pangoAttrList *C.PangoAttrList +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *AttrList) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *AttrList) native() *C.PangoAttrList { + return (*C.PangoAttrList)(unsafe.Pointer(v.pangoAttrList)) +} + +func (v *AttrList) Insert(attribute *Attribute) { + C.pango_attr_list_insert(v.pangoAttrList, attribute.native()) +} + +func AttrListNew() *AttrList { + c := C.pango_attr_list_new() + attrList := new(AttrList) + attrList.pangoAttrList = c + return attrList +} + +// AttrType is a representation of Pango's PangoAttrType. +type AttrType int + +const ( + ATTR_INVALID AttrType = C.PANGO_ATTR_INVALID /* 0 is an invalid attribute type */ + ATTR_LANGUAGE AttrType = C.PANGO_ATTR_LANGUAGE /* PangoAttrLanguage */ + ATTR_FAMILY AttrType = C.PANGO_ATTR_FAMILY /* PangoAttrString */ + ATTR_STYLE AttrType = C.PANGO_ATTR_STYLE /* PangoAttrInt */ + ATTR_WEIGHT AttrType = C.PANGO_ATTR_WEIGHT /* PangoAttrInt */ + ATTR_VARIANT AttrType = C.PANGO_ATTR_VARIANT /* PangoAttrInt */ + ATTR_STRETCH AttrType = C.PANGO_ATTR_STRETCH /* PangoAttrInt */ + ATTR_SIZE AttrType = C.PANGO_ATTR_SIZE /* PangoAttrSize */ + ATTR_FONT_DESC AttrType = C.PANGO_ATTR_FONT_DESC /* PangoAttrFontDesc */ + ATTR_FOREGROUND AttrType = C.PANGO_ATTR_FOREGROUND /* PangoAttrColor */ + ATTR_BACKGROUND AttrType = C.PANGO_ATTR_BACKGROUND /* PangoAttrColor */ + ATTR_UNDERLINE AttrType = C.PANGO_ATTR_UNDERLINE /* PangoAttrInt */ + ATTR_STRIKETHROUGH AttrType = C.PANGO_ATTR_STRIKETHROUGH /* PangoAttrInt */ + ATTR_RISE AttrType = C.PANGO_ATTR_RISE /* PangoAttrInt */ + ATTR_SHAPE AttrType = C.PANGO_ATTR_SHAPE /* PangoAttrShape */ + ATTR_SCALE AttrType = C.PANGO_ATTR_SCALE /* PangoAttrFloat */ + ATTR_FALLBACK AttrType = C.PANGO_ATTR_FALLBACK /* PangoAttrInt */ + ATTR_LETTER_SPACING AttrType = C.PANGO_ATTR_LETTER_SPACING /* PangoAttrInt */ + ATTR_UNDERLINE_COLOR AttrType = C.PANGO_ATTR_UNDERLINE_COLOR /* PangoAttrColor */ + ATTR_STRIKETHROUGH_COLOR AttrType = C.PANGO_ATTR_STRIKETHROUGH_COLOR /* PangoAttrColor */ + ATTR_ABSOLUTE_SIZE AttrType = C.PANGO_ATTR_ABSOLUTE_SIZE /* PangoAttrSize */ + ATTR_GRAVITY AttrType = C.PANGO_ATTR_GRAVITY /* PangoAttrInt */ + ATTR_GRAVITY_HINT AttrType = C.PANGO_ATTR_GRAVITY_HINT /* PangoAttrInt */ + +) + +func marshalAttrType(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return AttrType(c), nil +} + +// Underline is a representation of Pango's PangoUnderline. +type Underline int + +const ( + UNDERLINE_NONE Underline = C.PANGO_UNDERLINE_NONE + UNDERLINE_SINGLE Underline = C.PANGO_UNDERLINE_SINGLE + UNDERLINE_DOUBLE Underline = C.PANGO_UNDERLINE_DOUBLE + UNDERLINE_LOW Underline = C.PANGO_UNDERLINE_LOW + UNDERLINE_ERROR Underline = C.PANGO_UNDERLINE_ERROR +) + +func marshalUnderline(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Underline(c), nil +} + +const ( + ATTR_INDEX_FROM_TEXT_BEGINNING uint = 0 + ATTR_INDEX_TO_TEXT_END uint = C.G_MAXUINT +) + +// Attribute is a representation of Pango's PangoAttribute. +type Attribute struct { + pangoAttribute *C.PangoAttribute + //start_index, end_index uint +} + +// Native returns a pointer to the underlying PangoColor. +func (v *Attribute) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *Attribute) native() *C.PangoAttribute { + return (*C.PangoAttribute)(unsafe.Pointer(v.pangoAttribute)) +} + +/* +//typedef gboolean (*PangoAttrFilterFunc) (PangoAttribute *attribute, +// gpointer user_data); +func (v *Attribute) AttrFilterFunc(user_data uintptr) bool { + c := C.PangoAttrFilterFunc(Attribute.native(), C.gpointer(user_data)) + return gobool(c) +} + +//typedef gpointer (*PangoAttrDataCopyFunc) (gconstpointer user_data); +func AttrDataCopyFunc(user_data uintptr) uintptr { + c := C.PangoAttrDataCopyFunc(C.gpointer(user_data)) + return uintptr(c) +} +*/ + +// AttrClass is a representation of Pango's PangoAttrClass. +type AttrClass struct { + //PangoAttrType type; +} + +// AttrString is a representation of Pango's PangoAttrString. +type AttrString struct { + Attribute + //char *value; +} + +// AttrLanguage is a representation of Pango's PangoAttrLanguage. +type AttrLanguage struct { + Attribute + //PangoLanguage *value; +} + +// AttrInt is a representation of Pango's PangoAttrInt. +type AttrInt struct { + Attribute + //int value; +} + +// AttrFloat is a representation of Pango's PangoAttrFloat. +type AttrFloat struct { + Attribute + //double value; +} + +// AttrColor is a representation of Pango's AttrColor. +type AttrColor struct { + Attribute + Color +} + +// AttrSize is a representation of Pango's PangoAttrSize. +type AttrSize struct { + Attribute + //int size; + //guint absolute : 1; +} + +// AttrShape is a representation of Pango's PangoAttrShape. +type AttrShape struct { + Attribute + //PangoRectangle ink_rect; + //PangoRectangle logical_rect; + + //gpointer data; + //PangoAttrDataCopyFunc copy_func; + //GDestroyNotify destroy_func; +} + +// AttrFontDesc is a representation of Pango's PangoAttrFontDesc. +type AttrFontDesc struct { + Attribute + //PangoFontDescription *desc; +} + +/* +PangoAttrType pango_attr_type_register (const gchar *name); +const char * pango_attr_type_get_name (PangoAttrType type) G_GNUC_CONST; + +void pango_attribute_init (PangoAttribute *attr, + const PangoAttrClass *klass); +PangoAttribute * pango_attribute_copy (const PangoAttribute *attr); +void pango_attribute_destroy (PangoAttribute *attr); +gboolean pango_attribute_equal (const PangoAttribute *attr1, + const PangoAttribute *attr2) G_GNUC_PURE; + +PangoAttribute *pango_attr_language_new (PangoLanguage *language); +PangoAttribute *pango_attr_family_new (const char *family); +PangoAttribute *pango_attr_foreground_new (guint16 red, + guint16 green, + guint16 blue); +PangoAttribute *pango_attr_background_new (guint16 red, + guint16 green, + guint16 blue); +PangoAttribute *pango_attr_size_new (int size); +PangoAttribute *pango_attr_size_new_absolute (int size); +PangoAttribute *pango_attr_style_new (PangoStyle style); +PangoAttribute *pango_attr_weight_new (PangoWeight weight); +PangoAttribute *pango_attr_variant_new (PangoVariant variant); +PangoAttribute *pango_attr_stretch_new (PangoStretch stretch); +PangoAttribute *pango_attr_font_desc_new (const PangoFontDescription *desc); + +PangoAttribute *pango_attr_underline_new (PangoUnderline underline); +PangoAttribute *pango_attr_underline_color_new (guint16 red, + guint16 green, + guint16 blue); +PangoAttribute *pango_attr_strikethrough_new (gboolean strikethrough); +PangoAttribute *pango_attr_strikethrough_color_new (guint16 red, + guint16 green, + guint16 blue); + +PangoAttribute *pango_attr_rise_new (int rise); +PangoAttribute *pango_attr_scale_new (double scale_factor); +PangoAttribute *pango_attr_fallback_new (gboolean enable_fallback); +PangoAttribute *pango_attr_letter_spacing_new (int letter_spacing); + +PangoAttribute *pango_attr_shape_new (const PangoRectangle *ink_rect, + const PangoRectangle *logical_rect); +PangoAttribute *pango_attr_shape_new_with_data (const PangoRectangle *ink_rect, + const PangoRectangle *logical_rect, + gpointer data, + PangoAttrDataCopyFunc copy_func, + GDestroyNotify destroy_func); + +PangoAttribute *pango_attr_gravity_new (PangoGravity gravity); +PangoAttribute *pango_attr_gravity_hint_new (PangoGravityHint hint); + +GType pango_attr_list_get_type (void) G_GNUC_CONST; +PangoAttrList * pango_attr_list_new (void); +PangoAttrList * pango_attr_list_ref (PangoAttrList *list); +void pango_attr_list_unref (PangoAttrList *list); +PangoAttrList * pango_attr_list_copy (PangoAttrList *list); +void pango_attr_list_insert (PangoAttrList *list, + PangoAttribute *attr); +void pango_attr_list_insert_before (PangoAttrList *list, + PangoAttribute *attr); +void pango_attr_list_change (PangoAttrList *list, + PangoAttribute *attr); +void pango_attr_list_splice (PangoAttrList *list, + PangoAttrList *other, + gint pos, + gint len); + +PangoAttrList *pango_attr_list_filter (PangoAttrList *list, + PangoAttrFilterFunc func, + gpointer data); + +PangoAttrIterator *pango_attr_list_get_iterator (PangoAttrList *list); + +void pango_attr_iterator_range (PangoAttrIterator *iterator, + gint *start, + gint *end); +gboolean pango_attr_iterator_next (PangoAttrIterator *iterator); +PangoAttrIterator *pango_attr_iterator_copy (PangoAttrIterator *iterator); +void pango_attr_iterator_destroy (PangoAttrIterator *iterator); +PangoAttribute * pango_attr_iterator_get (PangoAttrIterator *iterator, + PangoAttrType type); +void pango_attr_iterator_get_font (PangoAttrIterator *iterator, + PangoFontDescription *desc, + PangoLanguage **language, + GSList **extra_attrs); +GSList * pango_attr_iterator_get_attrs (PangoAttrIterator *iterator); + + +gboolean pango_parse_markup (const char *markup_text, + int length, + gunichar accel_marker, + PangoAttrList **attr_list, + char **text, + gunichar *accel_char, + GError **error); + +GMarkupParseContext * pango_markup_parser_new (gunichar accel_marker); +gboolean pango_markup_parser_finish (GMarkupParseContext *context, + PangoAttrList **attr_list, + char **text, + gunichar *accel_char, + GError **error); +*/ diff --git a/vendor/github.com/gotk3/gotk3/pango/pango-attributes.go.h b/vendor/github.com/gotk3/gotk3/pango/pango-attributes.go.h new file mode 100644 index 0000000..5f77732 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango-attributes.go.h @@ -0,0 +1,23 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include +#include +#include + +static PangoColor *toPangoColor(void *p) { return ((PangoColor *)(p)); } diff --git a/vendor/github.com/gotk3/gotk3/pango/pango-attributes_since_1_44.go b/vendor/github.com/gotk3/gotk3/pango/pango-attributes_since_1_44.go new file mode 100644 index 0000000..3dd44f0 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango-attributes_since_1_44.go @@ -0,0 +1,18 @@ +// +build !pango_1_42 + +package pango + +// #include +// #include "pango.go.h" +import "C" + +var ( + ATTR_INSERT_HYPHENS AttrType = C.PANGO_ATTR_INSERT_HYPHENS +) + +func AttrInsertHyphensNew(insertHyphens bool) *Attribute { + c := C.pango_attr_insert_hyphens_new(gbool(insertHyphens)) + attr := new(Attribute) + attr.pangoAttribute = c + return attr +} diff --git a/vendor/github.com/gotk3/gotk3/pango/pango-context.go b/vendor/github.com/gotk3/gotk3/pango/pango-context.go new file mode 100644 index 0000000..41b7e57 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango-context.go @@ -0,0 +1,139 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package pango + +// #include +// #include "pango.go.h" +import "C" +import ( + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + // {glib.Type(C.pango_alignment_get_type()), marshalAlignment}, + // {glib.Type(C.pango_ellipsize_mode_get_type()), marshalEllipsizeMode}, + // {glib.Type(C.pango_wrap_mode_get_type()), marshalWrapMode}, + + // Objects/Interfaces + // {glib.Type(C.pango_context_get_type()), marshalContext}, + } + glib.RegisterGValueMarshalers(tm) +} + +// Context is a representation of PangoContext. +type Context struct { + pangoContext *C.PangoContext +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *Context) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *Context) native() *C.PangoContext { + return (*C.PangoContext)(unsafe.Pointer(v.pangoContext)) +} + +/* +func marshalContext(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := wrapObject(unsafe.Pointer(c)) + return wrapContext(obj), nil +} + +func wrapContext(obj *glib.Object) *Context { + return &Context{obj} +} +*/ +func WrapContext(p uintptr) *Context { + context := new(Context) + context.pangoContext = (*C.PangoContext)(unsafe.Pointer(p)) + return context +} + +//PangoContext *pango_context_new (void); +func ContextNew() *Context { + c := C.pango_context_new() + + context := new(Context) + context.pangoContext = (*C.PangoContext)(c) + + return context +} + +//void pango_context_changed (PangoContext *context); +//void pango_context_set_font_map (PangoContext *context, +// PangoFontMap *font_map); +//PangoFontMap *pango_context_get_font_map (PangoContext *context); +//guint pango_context_get_serial (PangoContext *context); +//void pango_context_list_families (PangoContext *context, +// PangoFontFamily ***families, +// int *n_families); +//PangoFont * pango_context_load_font (PangoContext *context, +// const PangoFontDescription *desc); +//PangoFontset *pango_context_load_fontset (PangoContext *context, +// const PangoFontDescription *desc, +// PangoLanguage *language); +// +//PangoFontMetrics *pango_context_get_metrics (PangoContext *context, +// const PangoFontDescription *desc, +// PangoLanguage *language); +// +//void pango_context_set_font_description (PangoContext *context, +// const PangoFontDescription *desc); +//PangoFontDescription * pango_context_get_font_description (PangoContext *context); +//PangoLanguage *pango_context_get_language (PangoContext *context); +//void pango_context_set_language (PangoContext *context, +// PangoLanguage *language); +//void pango_context_set_base_dir (PangoContext *context, +// PangoDirection direction); +//PangoDirection pango_context_get_base_dir (PangoContext *context); +//void pango_context_set_base_gravity (PangoContext *context, +// PangoGravity gravity); +//PangoGravity pango_context_get_base_gravity (PangoContext *context); +//PangoGravity pango_context_get_gravity (PangoContext *context); +//void pango_context_set_gravity_hint (PangoContext *context, +// PangoGravityHint hint); +//PangoGravityHint pango_context_get_gravity_hint (PangoContext *context); +// +//void pango_context_set_matrix (PangoContext *context, +// const PangoMatrix *matrix); +//const PangoMatrix * pango_context_get_matrix (PangoContext *context); + +/* Break a string of Unicode characters into segments with + * consistent shaping/language engine and bidrectional level. + * Returns a #GList of #PangoItem's + */ +//GList *pango_itemize (PangoContext *context, +// const char *text, +// int start_index, +// int length, +// PangoAttrList *attrs, +// PangoAttrIterator *cached_iter); +//GList *pango_itemize_with_base_dir (PangoContext *context, +// PangoDirection base_dir, +// const char *text, +// int start_index, +// int length, +// PangoAttrList *attrs, +// PangoAttrIterator *cached_iter); diff --git a/vendor/github.com/gotk3/gotk3/pango/pango-font.go b/vendor/github.com/gotk3/gotk3/pango/pango-font.go new file mode 100644 index 0000000..dd3640e --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango-font.go @@ -0,0 +1,720 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package pango + +// #include +// #include "pango.go.h" +// #include "fontconfig.go.h" +import "C" +import ( + // "github.com/andre-hub/gotk3/glib" + // "github.com/andre-hub/gotk3/cairo" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + // Objects/Interfaces + {glib.Type(C.pango_font_description_get_type()), marshalFontDescription}, + } + glib.RegisterGValueMarshalers(tm) +} + +// AddFont adds the font to the configuration. +func AddFont(fontPath string) { + path := (*C.uchar)(unsafe.Pointer(C.CString(fontPath))) + C.addFont(path) +} + +// FontDescription is a representation of PangoFontDescription. +type FontDescription struct { + pangoFontDescription *C.PangoFontDescription +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *FontDescription) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *FontDescription) native() *C.PangoFontDescription { + return (*C.PangoFontDescription)(unsafe.Pointer(v.pangoFontDescription)) +} + +// FontMetrics is a representation of PangoFontMetrics. +type FontMetrics struct { + pangoFontMetrics *C.PangoFontMetrics +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *FontMetrics) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *FontMetrics) native() *C.PangoFontMetrics { + return (*C.PangoFontMetrics)(unsafe.Pointer(v.pangoFontMetrics)) +} + +const ( + PANGO_SCALE = C.PANGO_SCALE +) + +type Style int + +const ( + STYLE_NORMAL Style = C.PANGO_STYLE_NORMAL + STYLE_OBLIQUE Style = C.PANGO_STYLE_OBLIQUE + STYLE_ITALIC Style = C.PANGO_STYLE_ITALIC +) + +type Variant int + +const ( + VARIANT_NORMAL Variant = C.PANGO_VARIANT_NORMAL + VARIANT_SMALL_CAPS Variant = C.PANGO_VARIANT_SMALL_CAPS +) + +type Weight int + +const ( + WEIGHT_THIN Weight = C.PANGO_WEIGHT_THIN /* 100 */ + WEIGHT_ULTRALIGHT Weight = C.PANGO_WEIGHT_ULTRALIGHT /* 200 */ + WEIGHT_LIGHT Weight = C.PANGO_WEIGHT_LIGHT /* 300 */ + WEIGHT_SEMILIGHT Weight = 350 /* 350 */ + WEIGHT_BOOK Weight = C.PANGO_WEIGHT_BOOK /* 380 */ + WEIGHT_NORMAL Weight = C.PANGO_WEIGHT_NORMAL /* 400 */ + WEIGHT_MEDIUM Weight = C.PANGO_WEIGHT_MEDIUM /* 500 */ + WEIGHT_SEMIBOLD Weight = C.PANGO_WEIGHT_SEMIBOLD /* 600 */ + WEIGHT_BOLD Weight = C.PANGO_WEIGHT_BOLD /* 700 */ + WEIGHT_ULTRABOLD Weight = C.PANGO_WEIGHT_ULTRABOLD /* 800 */ + WEIGHT_HEAVY Weight = C.PANGO_WEIGHT_HEAVY /* 900 */ + WEIGHT_ULTRAHEAVY Weight = C.PANGO_WEIGHT_ULTRAHEAVY /* 1000 */ + +) + +type Stretch int + +const ( + STRETCH_ULTRA_CONDENSED Stretch = C.PANGO_STRETCH_ULTRA_CONDENSED + STRETCH_EXTRA_CONDENSEDStretch Stretch = C.PANGO_STRETCH_EXTRA_CONDENSED + STRETCH_CONDENSEDStretch Stretch = C.PANGO_STRETCH_CONDENSED + STRETCH_SEMI_CONDENSEDStretch Stretch = C.PANGO_STRETCH_SEMI_CONDENSED + STRETCH_NORMALStretch Stretch = C.PANGO_STRETCH_NORMAL + STRETCH_SEMI_EXPANDEDStretch Stretch = C.PANGO_STRETCH_SEMI_EXPANDED + STRETCH_EXPANDEDStretch Stretch = C.PANGO_STRETCH_EXPANDED + STRETCH_EXTRA_EXPANDEDStretch Stretch = C.PANGO_STRETCH_EXTRA_EXPANDED + STRETCH_ULTRA_EXPANDEDStretch Stretch = C.PANGO_STRETCH_ULTRA_EXPANDED +) + +type FontMask int + +const ( + FONT_MASK_FAMILY FontMask = C.PANGO_FONT_MASK_FAMILY /* 1 << 0 */ + FONT_MASK_STYLEFontMask FontMask = C.PANGO_FONT_MASK_STYLE /* 1 << 1 */ + FONT_MASK_VARIANTFontMask FontMask = C.PANGO_FONT_MASK_VARIANT /* 1 << 2 */ + FONT_MASK_WEIGHTFontMask FontMask = C.PANGO_FONT_MASK_WEIGHT /* 1 << 3 */ + FONT_MASK_STRETCHFontMask FontMask = C.PANGO_FONT_MASK_STRETCH /* 1 << 4 */ + FONT_MASK_SIZEFontMask FontMask = C.PANGO_FONT_MASK_SIZE /* 1 << 5 */ + FONT_MASK_GRAVITYFontMask FontMask = C.PANGO_FONT_MASK_GRAVITY /* 1 << 6 */ +) + +type Scale float64 + +const ( + SCALE_XX_SMALL Scale = /* C.PANGO_SCALE_XX_SMALL */ 0.5787037037037 + SCALE_X_SMALL Scale = /*C.PANGO_SCALE_X_SMALL */ 0.6444444444444 + SCALE_SMALL Scale = /*C.PANGO_SCALE_SMALL */ 0.8333333333333 + SCALE_MEDIUM Scale = /*C.PANGO_SCALE_MEDIUM */ 1.0 + SCALE_LARGE Scale = /*C.PANGO_SCALE_LARGE */ 1.2 + SCALE_X_LARGE Scale = /*C.PANGO_SCALE_X_LARGE */ 1.4399999999999 + SCALE_XX_LARGE Scale = /*C.PANGO_SCALE_XX_LARGE */ 1.728 +) + +/* + * PangoFontDescription + */ + +func marshalFontDescription(p uintptr) (interface{}, error) { + c := C.g_value_get_boxed((*C.GValue)(unsafe.Pointer(p))) + c2 := (*C.PangoFontDescription)(unsafe.Pointer(c)) + return wrapFontDescription(c2), nil +} + +func wrapFontDescription(obj *C.PangoFontDescription) *FontDescription { + return &FontDescription{obj} +} + +//PangoFontDescription *pango_font_description_new (void); +func FontDescriptionNew() *FontDescription { + c := C.pango_font_description_new() + v := new(FontDescription) + v.pangoFontDescription = c + return v +} + +//PangoFontDescription *pango_font_description_copy (const PangoFontDescription *desc); +func (v *FontDescription) Copy() *FontDescription { + c := C.pango_font_description_copy(v.native()) + v2 := new(FontDescription) + v2.pangoFontDescription = c + return v2 +} + +//PangoFontDescription *pango_font_description_copy_static (const PangoFontDescription *desc); +func (v *FontDescription) CopyStatic() *FontDescription { + c := C.pango_font_description_copy_static(v.native()) + v2 := new(FontDescription) + v2.pangoFontDescription = c + return v2 +} + +//guint pango_font_description_hash (const PangoFontDescription *desc) G_GNUC_PURE; +func (v *FontDescription) Hash() uint { + c := C.pango_font_description_hash(v.native()) + return uint(c) +} + +//gboolean pango_font_description_equal (const PangoFontDescription *desc1, +// const PangoFontDescription *desc2) G_GNUC_PURE; +func (v *FontDescription) Equal(v2 *FontDescription) bool { + c := C.pango_font_description_equal(v.native(), v2.native()) + return gobool(c) +} + +//void pango_font_description_free (PangoFontDescription *desc); +func (v *FontDescription) Free() { + C.pango_font_description_free(v.native()) +} + +//void pango_font_descriptions_free (PangoFontDescription **descs, +// int n_descs); +//func (v *FontDescription) FontDescriptionsFree(n_descs int) { +// C.pango_font_descriptions_free(v.native(), C.int(n_descs)) +//} + +//void pango_font_description_set_family (PangoFontDescription *desc, +// const char *family); +func (v *FontDescription) SetFamily(family string) { + cstr := C.CString(family) + defer C.free(unsafe.Pointer(cstr)) + C.pango_font_description_set_family(v.native(), (*C.char)(cstr)) +} + +//void pango_font_description_set_family_static (PangoFontDescription *desc, +// const char *family); +func (v *FontDescription) SetFamilyStatic(family string) { + cstr := C.CString(family) + defer C.free(unsafe.Pointer(cstr)) + C.pango_font_description_set_family_static(v.native(), (*C.char)(cstr)) +} + +//const char *pango_font_description_get_family (const PangoFontDescription *desc) G_GNUC_PURE; +func (v *FontDescription) GetFamily() string { + c := C.pango_font_description_get_family(v.native()) + return C.GoString((*C.char)(c)) +} + +//void pango_font_description_set_style (PangoFontDescription *desc, +// PangoStyle style); +func (v *FontDescription) SetStyle(style Style) { + C.pango_font_description_set_style(v.native(), (C.PangoStyle)(style)) +} + +//PangoStyle pango_font_description_get_style (const PangoFontDescription *desc) G_GNUC_PURE; +func (v *FontDescription) GetStyle() Style { + c := C.pango_font_description_get_style(v.native()) + return Style(c) +} + +//void pango_font_description_set_variant (PangoFontDescription *desc, +// PangoVariant variant); +func (v *FontDescription) SetVariant(variant Variant) { + C.pango_font_description_set_variant(v.native(), (C.PangoVariant)(variant)) +} + +//PangoVariant pango_font_description_get_variant (const PangoFontDescription *desc) G_GNUC_PURE; +func (v *FontDescription) GetVariant() Variant { + c := C.pango_font_description_get_variant(v.native()) + return Variant(c) +} + +//void pango_font_description_set_weight (PangoFontDescription *desc, +// PangoWeight weight); +func (v *FontDescription) SetWeight(weight Weight) { + C.pango_font_description_set_weight(v.native(), (C.PangoWeight)(weight)) +} + +//PangoWeight pango_font_description_get_weight (const PangoFontDescription *desc) G_GNUC_PURE; +func (v *FontDescription) GetWeight() Weight { + c := C.pango_font_description_get_weight(v.native()) + return Weight(c) +} + +//void pango_font_description_set_stretch (PangoFontDescription *desc, +// PangoStretch stretch); +func (v *FontDescription) SetStretch(stretch Stretch) { + C.pango_font_description_set_stretch(v.native(), (C.PangoStretch)(stretch)) +} + +//PangoStretch pango_font_description_get_stretch (const PangoFontDescription *desc) G_GNUC_PURE; +func (v *FontDescription) GetStretch() Stretch { + c := C.pango_font_description_get_stretch(v.native()) + return Stretch(c) +} + +//void pango_font_description_set_size (PangoFontDescription *desc, +// gint size); +func (v *FontDescription) SetSize(size int) { + C.pango_font_description_set_size(v.native(), (C.gint)(size)) +} + +//gint pango_font_description_get_size (const PangoFontDescription *desc) G_GNUC_PURE; +func (v *FontDescription) GetSize() int { + c := C.pango_font_description_get_size(v.native()) + return int(c) +} + +//void pango_font_description_set_absolute_size (PangoFontDescription *desc, +// double size); +func (v *FontDescription) SetAbsoluteSize(size float64) { + C.pango_font_description_set_absolute_size(v.native(), (C.double)(size)) +} + +//gboolean pango_font_description_get_size_is_absolute (const PangoFontDescription *desc) G_GNUC_PURE; +func (v *FontDescription) GetSizeIsAbsolute() bool { + c := C.pango_font_description_get_size_is_absolute(v.native()) + return gobool(c) +} + +//void pango_font_description_set_gravity (PangoFontDescription *desc, +// PangoGravity gravity); +func (v *FontDescription) SetGravity(gravity Gravity) { + C.pango_font_description_set_gravity(v.native(), (C.PangoGravity)(gravity)) +} + +//PangoGravity pango_font_description_get_gravity (const PangoFontDescription *desc) G_GNUC_PURE; +func (v *FontDescription) GetGravity() Gravity { + c := C.pango_font_description_get_gravity(v.native()) + return Gravity(c) +} + +//PangoFontMask pango_font_description_get_set_fields (const PangoFontDescription *desc) G_GNUC_PURE; +func (v *FontDescription) GetSetFields() FontMask { + c := C.pango_font_description_get_set_fields(v.native()) + return FontMask(c) +} + +//void pango_font_description_unset_fields (PangoFontDescription *desc, +// PangoFontMask to_unset); +func (v *FontDescription) GetUnsetFields(to_unset FontMask) { + C.pango_font_description_unset_fields(v.native(), (C.PangoFontMask)(to_unset)) +} + +//void pango_font_description_merge (PangoFontDescription *desc, +// const PangoFontDescription *desc_to_merge, +// gboolean replace_existing); +func (v *FontDescription) Merge(desc_to_merge *FontDescription, replace_existing bool) { + C.pango_font_description_merge(v.native(), desc_to_merge.native(), gbool(replace_existing)) +} + +//void pango_font_description_merge_static (PangoFontDescription *desc, +// const PangoFontDescription *desc_to_merge, +// gboolean replace_existing); +func (v *FontDescription) MergeStatic(desc_to_merge *FontDescription, replace_existing bool) { + C.pango_font_description_merge_static(v.native(), desc_to_merge.native(), gbool(replace_existing)) +} + +//gboolean pango_font_description_better_match (const PangoFontDescription *desc, +// const PangoFontDescription *old_match, +// const PangoFontDescription *new_match) G_GNUC_PURE; +func (v *FontDescription) BetterMatch(old_match, new_match *FontDescription) bool { + c := C.pango_font_description_better_match(v.native(), old_match.native(), new_match.native()) + return gobool(c) +} + +//PangoFontDescription *pango_font_description_from_string (const char *str); +func FontDescriptionFromString(str string) *FontDescription { + cstr := C.CString(str) + defer C.free(unsafe.Pointer(cstr)) + c := C.pango_font_description_from_string((*C.char)(cstr)) + v := new(FontDescription) + v.pangoFontDescription = c + return v +} + +//char * pango_font_description_to_string (const PangoFontDescription *desc); +func (v *FontDescription) ToString() string { + c := C.pango_font_description_to_string(v.native()) + return C.GoString((*C.char)(c)) +} + +//char * pango_font_description_to_filename (const PangoFontDescription *desc); +func (v *FontDescription) ToFilename() string { + c := C.pango_font_description_to_filename(v.native()) + return C.GoString((*C.char)(c)) +} + +///* +// * PangoFontMetrics +// */ +// +///** +// * PANGO_TYPE_FONT_METRICS: +// * +// * The #GObject type for #PangoFontMetrics. +// */ +//#define PANGO_TYPE_FONT_METRICS (pango_font_metrics_get_type ()) +//GType pango_font_metrics_get_type (void) G_GNUC_CONST; +//PangoFontMetrics *pango_font_metrics_ref (PangoFontMetrics *metrics); +//void pango_font_metrics_unref (PangoFontMetrics *metrics); +//int pango_font_metrics_get_ascent (PangoFontMetrics *metrics) G_GNUC_PURE; +//int pango_font_metrics_get_descent (PangoFontMetrics *metrics) G_GNUC_PURE; +//int pango_font_metrics_get_approximate_char_width (PangoFontMetrics *metrics) G_GNUC_PURE; +//int pango_font_metrics_get_approximate_digit_width (PangoFontMetrics *metrics) G_GNUC_PURE; +//int pango_font_metrics_get_underline_position (PangoFontMetrics *metrics) G_GNUC_PURE; +//int pango_font_metrics_get_underline_thickness (PangoFontMetrics *metrics) G_GNUC_PURE; +//int pango_font_metrics_get_strikethrough_position (PangoFontMetrics *metrics) G_GNUC_PURE; +//int pango_font_metrics_get_strikethrough_thickness (PangoFontMetrics *metrics) G_GNUC_PURE; +// +//#ifdef PANGO_ENABLE_BACKEND +// +//PangoFontMetrics *pango_font_metrics_new (void); +// +//struct _PangoFontMetrics +//{ +// guint ref_count; +// +// int ascent; +// int descent; +// int approximate_char_width; +// int approximate_digit_width; +// int underline_position; +// int underline_thickness; +// int strikethrough_position; +// int strikethrough_thickness; +//}; +// +//#endif /* PANGO_ENABLE_BACKEND */ +// +///* +// * PangoFontFamily +// */ +// +///** +// * PANGO_TYPE_FONT_FAMILY: +// * +// * The #GObject type for #PangoFontFamily. +// */ +///** +// * PANGO_FONT_FAMILY: +// * @object: a #GObject. +// * +// * Casts a #GObject to a #PangoFontFamily. +// */ +///** +// * PANGO_IS_FONT_FAMILY: +// * @object: a #GObject. +// * +// * Returns: %TRUE if @object is a #PangoFontFamily. +// */ +//#define PANGO_TYPE_FONT_FAMILY (pango_font_family_get_type ()) +//#define PANGO_FONT_FAMILY(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_TYPE_FONT_FAMILY, PangoFontFamily)) +//#define PANGO_IS_FONT_FAMILY(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_TYPE_FONT_FAMILY)) +// +//typedef struct _PangoFontFamily PangoFontFamily; +//typedef struct _PangoFontFace PangoFontFace; +// +//GType pango_font_family_get_type (void) G_GNUC_CONST; +// +//void pango_font_family_list_faces (PangoFontFamily *family, +// PangoFontFace ***faces, +// int *n_faces); +//const char *pango_font_family_get_name (PangoFontFamily *family) G_GNUC_PURE; +//gboolean pango_font_family_is_monospace (PangoFontFamily *family) G_GNUC_PURE; +// +//#ifdef PANGO_ENABLE_BACKEND +// +//#define PANGO_FONT_FAMILY_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PANGO_TYPE_FONT_FAMILY, PangoFontFamilyClass)) +//#define PANGO_IS_FONT_FAMILY_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PANGO_TYPE_FONT_FAMILY)) +//#define PANGO_FONT_FAMILY_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PANGO_TYPE_FONT_FAMILY, PangoFontFamilyClass)) +// +//typedef struct _PangoFontFamilyClass PangoFontFamilyClass; +// +// +///** +// * PangoFontFamily: +// * +// * The #PangoFontFamily structure is used to represent a family of related +// * font faces. The faces in a family share a common design, but differ in +// * slant, weight, width and other aspects. +// */ +//struct _PangoFontFamily +//{ +// GObject parent_instance; +//}; +// +//struct _PangoFontFamilyClass +//{ +// GObjectClass parent_class; +// +// /*< public >*/ +// +// void (*list_faces) (PangoFontFamily *family, +// PangoFontFace ***faces, +// int *n_faces); +// const char * (*get_name) (PangoFontFamily *family); +// gboolean (*is_monospace) (PangoFontFamily *family); +// +// /*< private >*/ +// +// /* Padding for future expansion */ +// void (*_pango_reserved2) (void); +// void (*_pango_reserved3) (void); +// void (*_pango_reserved4) (void); +//}; +// +//#endif /* PANGO_ENABLE_BACKEND */ +// +///* +// * PangoFontFace +// */ +// +///** +// * PANGO_TYPE_FONT_FACE: +// * +// * The #GObject type for #PangoFontFace. +// */ +///** +// * PANGO_FONT_FACE: +// * @object: a #GObject. +// * +// * Casts a #GObject to a #PangoFontFace. +// */ +///** +// * PANGO_IS_FONT_FACE: +// * @object: a #GObject. +// * +// * Returns: %TRUE if @object is a #PangoFontFace. +// */ +//#define PANGO_TYPE_FONT_FACE (pango_font_face_get_type ()) +//#define PANGO_FONT_FACE(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_TYPE_FONT_FACE, PangoFontFace)) +//#define PANGO_IS_FONT_FACE(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_TYPE_FONT_FACE)) +// +//GType pango_font_face_get_type (void) G_GNUC_CONST; +// +//PangoFontDescription *pango_font_face_describe (PangoFontFace *face); +//const char *pango_font_face_get_face_name (PangoFontFace *face) G_GNUC_PURE; +//void pango_font_face_list_sizes (PangoFontFace *face, +// int **sizes, +// int *n_sizes); +//gboolean pango_font_face_is_synthesized (PangoFontFace *face) G_GNUC_PURE; +// +//#ifdef PANGO_ENABLE_BACKEND +// +//#define PANGO_FONT_FACE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PANGO_TYPE_FONT_FACE, PangoFontFaceClass)) +//#define PANGO_IS_FONT_FACE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PANGO_TYPE_FONT_FACE)) +//#define PANGO_FONT_FACE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PANGO_TYPE_FONT_FACE, PangoFontFaceClass)) +// +//typedef struct _PangoFontFaceClass PangoFontFaceClass; +// +///** +// * PangoFontFace: +// * +// * The #PangoFontFace structure is used to represent a group of fonts with +// * the same family, slant, weight, width, but varying sizes. +// */ +//struct _PangoFontFace +//{ +// GObject parent_instance; +//}; +// +//struct _PangoFontFaceClass +//{ +// GObjectClass parent_class; +// +// /*< public >*/ +// +// const char * (*get_face_name) (PangoFontFace *face); +// PangoFontDescription * (*describe) (PangoFontFace *face); +// void (*list_sizes) (PangoFontFace *face, +// int **sizes, +// int *n_sizes); +// gboolean (*is_synthesized) (PangoFontFace *face); +// +// /*< private >*/ +// +// /* Padding for future expansion */ +// void (*_pango_reserved3) (void); +// void (*_pango_reserved4) (void); +//}; +// +//#endif /* PANGO_ENABLE_BACKEND */ +// +///* +// * PangoFont +// */ +// +///** +// * PANGO_TYPE_FONT: +// * +// * The #GObject type for #PangoFont. +// */ +///** +// * PANGO_FONT: +// * @object: a #GObject. +// * +// * Casts a #GObject to a #PangoFont. +// */ +///** +// * PANGO_IS_FONT: +// * @object: a #GObject. +// * +// * Returns: %TRUE if @object is a #PangoFont. +// */ +//#define PANGO_TYPE_FONT (pango_font_get_type ()) +//#define PANGO_FONT(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_TYPE_FONT, PangoFont)) +//#define PANGO_IS_FONT(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_TYPE_FONT)) +// +//GType pango_font_get_type (void) G_GNUC_CONST; +// +//PangoFontDescription *pango_font_describe (PangoFont *font); +//PangoFontDescription *pango_font_describe_with_absolute_size (PangoFont *font); +//PangoCoverage * pango_font_get_coverage (PangoFont *font, +// PangoLanguage *language); +//PangoEngineShape * pango_font_find_shaper (PangoFont *font, +// PangoLanguage *language, +// guint32 ch); +//PangoFontMetrics * pango_font_get_metrics (PangoFont *font, +// PangoLanguage *language); +//void pango_font_get_glyph_extents (PangoFont *font, +// PangoGlyph glyph, +// PangoRectangle *ink_rect, +// PangoRectangle *logical_rect); +//PangoFontMap *pango_font_get_font_map (PangoFont *font); +// +//#ifdef PANGO_ENABLE_BACKEND +// +//#define PANGO_FONT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), PANGO_TYPE_FONT, PangoFontClass)) +//#define PANGO_IS_FONT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), PANGO_TYPE_FONT)) +//#define PANGO_FONT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), PANGO_TYPE_FONT, PangoFontClass)) +// +//typedef struct _PangoFontClass PangoFontClass; +// +///** +// * PangoFont: +// * +// * The #PangoFont structure is used to represent +// * a font in a rendering-system-independent matter. +// * To create an implementation of a #PangoFont, +// * the rendering-system specific code should allocate +// * a larger structure that contains a nested +// * #PangoFont, fill in the klass member of +// * the nested #PangoFont with a pointer to +// * a appropriate #PangoFontClass, then call +// * pango_font_init() on the structure. +// * +// * The #PangoFont structure contains one member +// * which the implementation fills in. +// */ +//struct _PangoFont +//{ +// GObject parent_instance; +//}; +// +//struct _PangoFontClass +//{ +// GObjectClass parent_class; +// +// /*< public >*/ +// +// PangoFontDescription *(*describe) (PangoFont *font); +// PangoCoverage * (*get_coverage) (PangoFont *font, +// PangoLanguage *lang); +// PangoEngineShape * (*find_shaper) (PangoFont *font, +// PangoLanguage *lang, +// guint32 ch); +// void (*get_glyph_extents) (PangoFont *font, +// PangoGlyph glyph, +// PangoRectangle *ink_rect, +// PangoRectangle *logical_rect); +// PangoFontMetrics * (*get_metrics) (PangoFont *font, +// PangoLanguage *language); +// PangoFontMap * (*get_font_map) (PangoFont *font); +// PangoFontDescription *(*describe_absolute) (PangoFont *font); +// /*< private >*/ +// +// /* Padding for future expansion */ +// void (*_pango_reserved1) (void); +// void (*_pango_reserved2) (void); +//}; +// +///* used for very rare and miserable situtations that we cannot even +// * draw a hexbox +// */ +//#define PANGO_UNKNOWN_GLYPH_WIDTH 10 +//#define PANGO_UNKNOWN_GLYPH_HEIGHT 14 +// +//#endif /* PANGO_ENABLE_BACKEND */ +// +///** +// * PANGO_GLYPH_EMPTY: +// * +// * The %PANGO_GLYPH_EMPTY macro represents a #PangoGlyph value that has a +// * special meaning, which is a zero-width empty glyph. This is useful for +// * example in shaper modules, to use as the glyph for various zero-width +// * Unicode characters (those passing pango_is_zero_width()). +// */ +///** +// * PANGO_GLYPH_INVALID_INPUT: +// * +// * The %PANGO_GLYPH_INVALID_INPUT macro represents a #PangoGlyph value that has a +// * special meaning of invalid input. #PangoLayout produces one such glyph +// * per invalid input UTF-8 byte and such a glyph is rendered as a crossed +// * box. +// * +// * Note that this value is defined such that it has the %PANGO_GLYPH_UNKNOWN_FLAG +// * on. +// * +// * Since: 1.20 +// */ +///** +// * PANGO_GLYPH_UNKNOWN_FLAG: +// * +// * The %PANGO_GLYPH_UNKNOWN_FLAG macro is a flag value that can be added to +// * a #gunichar value of a valid Unicode character, to produce a #PangoGlyph +// * value, representing an unknown-character glyph for the respective #gunichar. +// */ +///** +// * PANGO_GET_UNKNOWN_GLYPH: +// * @wc: a Unicode character +// * +// * The way this unknown glyphs are rendered is backend specific. For example, +// * a box with the hexadecimal Unicode code-point of the character written in it +// * is what is done in the most common backends. +// * +// * Returns: a #PangoGlyph value that means no glyph was found for @wc. +// */ +//#define PANGO_GLYPH_EMPTY ((PangoGlyph)0x0FFFFFFF) +//#define PANGO_GLYPH_INVALID_INPUT ((PangoGlyph)0xFFFFFFFF) +//#define PANGO_GLYPH_UNKNOWN_FLAG ((PangoGlyph)0x10000000) +//#define PANGO_GET_UNKNOWN_GLYPH(wc) ((PangoGlyph)(wc)|PANGO_GLYPH_UNKNOWN_FLAG) +// +// diff --git a/vendor/github.com/gotk3/gotk3/pango/pango-glyph-item.go b/vendor/github.com/gotk3/gotk3/pango/pango-glyph-item.go new file mode 100644 index 0000000..bed9fc2 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango-glyph-item.go @@ -0,0 +1,43 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package pango + +// #include +// #include "pango.go.h" +// #include +import "C" +import ( + // "github.com/andre-hub/gotk3/glib" + // "github.com/andre-hub/gotk3/cairo" + "unsafe" +) + +// GlyphItem is a representation of PangoGlyphItem. +type GlyphItem struct { + pangoGlyphItem *C.PangoGlyphItem +} + +// Native returns a pointer to the underlying PangoGlyphItem. +func (v *GlyphItem) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *GlyphItem) native() *C.PangoGlyphItem { + return (*C.PangoGlyphItem)(unsafe.Pointer(v.pangoGlyphItem)) +} diff --git a/vendor/github.com/gotk3/gotk3/pango/pango-glyph.go b/vendor/github.com/gotk3/gotk3/pango/pango-glyph.go new file mode 100644 index 0000000..2ea29f7 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango-glyph.go @@ -0,0 +1,85 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package pango + +// #include +// #include "pango.go.h" +// #include +import "C" +import ( + // "github.com/andre-hub/gotk3/glib" + // "github.com/andre-hub/gotk3/cairo" + "unsafe" +) + +// GlyphGeometry is a representation of PangoGlyphGeometry. +type GlyphGeometry struct { + pangoGlyphGeometry *C.PangoGlyphGeometry +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *GlyphGeometry) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *GlyphGeometry) native() *C.PangoGlyphGeometry { + return (*C.PangoGlyphGeometry)(unsafe.Pointer(v.pangoGlyphGeometry)) +} + +// GlyphVisAttr is a representation of PangoGlyphVisAttr. +type GlyphVisAttr struct { + pangoGlyphVisAttr *C.PangoGlyphGeometry +} + +// Native returns a pointer to the underlying PangoGlyphVisAttr. +func (v *GlyphVisAttr) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *GlyphVisAttr) native() *C.PangoGlyphVisAttr { + return (*C.PangoGlyphVisAttr)(unsafe.Pointer(v.pangoGlyphVisAttr)) +} + +// GlyphInfo is a representation of PangoGlyphInfo. +type GlyphInfo struct { + pangoGlyphInfo *C.PangoGlyphInfo +} + +// Native returns a pointer to the underlying PangoGlyphInfo. +func (v *GlyphInfo) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *GlyphInfo) native() *C.PangoGlyphInfo { + return (*C.PangoGlyphInfo)(unsafe.Pointer(v.pangoGlyphInfo)) +} + +// GlyphGeometry is a representation of PangoGlyphString. +type GlyphString struct { + pangoGlyphString *C.PangoGlyphString +} + +// Native returns a pointer to the underlying PangoGlyphString. +func (v *GlyphString) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *GlyphString) native() *C.PangoGlyphString { + return (*C.PangoGlyphString)(unsafe.Pointer(v.pangoGlyphString)) +} diff --git a/vendor/github.com/gotk3/gotk3/pango/pango-gravity.go b/vendor/github.com/gotk3/gotk3/pango/pango-gravity.go new file mode 100644 index 0000000..7bd3800 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango-gravity.go @@ -0,0 +1,63 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package pango + +// #include +// #include "pango.go.h" +import "C" + +// "github.com/andre-hub/gotk3/glib" +// "github.com/andre-hub/gotk3/cairo" +// "unsafe" + +type Gravity int + +const ( + GRAVITY_SOUTH Gravity = C.PANGO_GRAVITY_SOUTH + GRAVITY_EAST Gravity = C.PANGO_GRAVITY_EAST + GRAVITY_NORTH Gravity = C.PANGO_GRAVITY_NORTH + GRAVITY_WEST Gravity = C.PANGO_GRAVITY_WEST + GRAVITY_AUTO Gravity = C.PANGO_GRAVITY_AUTO +) + +type GravityHint int + +const ( + GRAVITY_HINT_NATURAL GravityHint = C.PANGO_GRAVITY_HINT_NATURAL + GRAVITY_HINT_STRONG GravityHint = C.PANGO_GRAVITY_HINT_STRONG + GRAVITY_HINT_LINE GravityHint = C.PANGO_GRAVITY_HINT_LINE +) + +//double pango_gravity_to_rotation (PangoGravity gravity) G_GNUC_CONST; +func GravityToRotation(gravity Gravity) float64 { + c := C.pango_gravity_to_rotation((C.PangoGravity)(gravity)) + return float64(c) +} + +//PangoGravity pango_gravity_get_for_matrix (const PangoMatrix *matrix) G_GNUC_PURE; + +//PangoGravity pango_gravity_get_for_script (PangoScript script, +// PangoGravity base_gravity, +// PangoGravityHint hint) G_GNUC_CONST; + +//PangoGravity pango_gravity_get_for_script_and_width +// (PangoScript script, +// gboolean wide, +// PangoGravity base_gravity, +// PangoGravityHint hint) G_GNUC_CONST; diff --git a/vendor/github.com/gotk3/gotk3/pango/pango-layout.go b/vendor/github.com/gotk3/gotk3/pango/pango-layout.go new file mode 100644 index 0000000..6ac05c6 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango-layout.go @@ -0,0 +1,613 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package pango + +// #include +// #include "pango.go.h" +import "C" +import ( + "runtime" + "unsafe" + + "github.com/gotk3/gotk3/glib" +) + +func init() { + tm := []glib.TypeMarshaler{ + // Enums + {glib.Type(C.pango_alignment_get_type()), marshalAlignment}, + {glib.Type(C.pango_ellipsize_mode_get_type()), marshalEllipsizeMode}, + {glib.Type(C.pango_wrap_mode_get_type()), marshalWrapMode}, + {glib.Type(C.pango_tab_align_get_type()), marshalTabAlign}, + + // Objects/Interfaces + // {glib.Type(C.pango_layout_get_type()), marshalLayout}, + } + glib.RegisterGValueMarshalers(tm) +} + +// Layout is a representation of PangoLayout. +type Layout struct { + pangoLayout *C.PangoLayout +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *Layout) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *Layout) native() *C.PangoLayout { + if v == nil { + return nil + } + return (*C.PangoLayout)(unsafe.Pointer(v.pangoLayout)) +} + +func WrapLayout(p uintptr) *Layout { + layout := new(Layout) + layout.pangoLayout = (*C.PangoLayout)(unsafe.Pointer(p)) + return layout +} + +// LayoutLine is a representation of PangoLayoutLine. +type LayoutLine struct { + pangoLayoutLine *C.PangoLayout +} + +// Native returns a pointer to the underlying PangoLayoutLine. +func (v *LayoutLine) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *LayoutLine) native() *C.PangoLayoutLine { + if v == nil { + return nil + } + return (*C.PangoLayoutLine)(unsafe.Pointer(v.pangoLayoutLine)) +} + +/* + * Constants + */ + +// Alignment is a representation of Pango's PangoAlignment. +type Alignment int + +const ( + ALIGN_LEFT Alignment = C.PANGO_ALIGN_LEFT + ALIGN_CENTER Alignment = C.PANGO_ALIGN_CENTER + ALIGN_RIGHT Alignment = C.PANGO_ALIGN_RIGHT +) + +func marshalAlignment(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return Alignment(c), nil +} + +// WrapMode is a representation of Pango's PangoWrapMode. +type WrapMode int + +const ( + WRAP_WORD WrapMode = C.PANGO_WRAP_WORD + WRAP_CHAR WrapMode = C.PANGO_WRAP_CHAR + WRAP_WORD_CHAR WrapMode = C.PANGO_WRAP_WORD_CHAR +) + +func marshalWrapMode(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return WrapMode(c), nil +} + +// EllipsizeMode is a representation of Pango's PangoEllipsizeMode. +type EllipsizeMode int + +const ( + ELLIPSIZE_NONE EllipsizeMode = C.PANGO_ELLIPSIZE_NONE + ELLIPSIZE_START EllipsizeMode = C.PANGO_ELLIPSIZE_START + ELLIPSIZE_MIDDLE EllipsizeMode = C.PANGO_ELLIPSIZE_MIDDLE + ELLIPSIZE_END EllipsizeMode = C.PANGO_ELLIPSIZE_END +) + +func marshalEllipsizeMode(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return EllipsizeMode(c), nil +} + +type TabAlign int + +const ( + TAB_LEFT TabAlign = C.PANGO_TAB_LEFT +) + +func marshalTabAlign(p uintptr) (interface{}, error) { + c := C.g_value_get_enum((*C.GValue)(unsafe.Pointer(p))) + return TabAlign(c), nil +} + +/* +func marshalLayout(p uintptr) (interface{}, error) { + c := C.g_value_get_object((*C.GValue)(unsafe.Pointer(p))) + obj := wrapObject(unsafe.Pointer(c)) + return wrapLayout(obj), nil +} + +func wrapLayout(obj *glib.Object) *Layout { + return &Layout{obj} +} +*/ + +// LayoutNew is a wrapper around pango_layout_new(). +func LayoutNew(context *Context) *Layout { + c := C.pango_layout_new(context.native()) + + layout := new(Layout) + layout.pangoLayout = (*C.PangoLayout)(c) + return layout +} + +// Copy is a wrapper around pango_layout_copy(). +func (v *Layout) Copy() *Layout { + c := C.pango_layout_copy(v.native()) + + layout := new(Layout) + layout.pangoLayout = (*C.PangoLayout)(c) + return layout +} + +// GetContext is a wrapper around pango_layout_get_context(). +func (v *Layout) GetContext() *Context { + c := C.pango_layout_get_context(v.native()) + + context := new(Context) + context.pangoContext = (*C.PangoContext)(c) + + return context +} + +// SetAttributes is a wrapper around pango_layout_set_attributes(). +func (v *Layout) SetAttributes(attrs *AttrList) { + C.pango_layout_set_attributes(v.native(), attrs.native()) +} + +// GetAttributes is a wrapper around pango_layout_get_attributes(). +func (v *Layout) GetAttributes() *AttrList { + c := C.pango_layout_get_attributes(v.native()) + + attrList := new(AttrList) + attrList.pangoAttrList = (*C.PangoAttrList)(c) + + return attrList +} + +// SetText is a wrapper around pango_layout_set_text(). +func (v *Layout) SetText(text string, length int) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.pango_layout_set_text(v.native(), (*C.char)(cstr), (C.int)(length)) +} + +// GetText is a wrapper around pango_layout_get_text(). +func (v *Layout) GetText() string { + c := C.pango_layout_get_text(v.native()) + return C.GoString((*C.char)(c)) +} + +// GetCharacterCount is a wrapper around pango_layout_get_character_count(). +func (v *Layout) GetCharacterCount() int { + c := C.pango_layout_get_character_count(v.native()) + return int(c) +} + +// SetMarkup is a wrapper around pango_layout_set_markup(). +func (v *Layout) SetMarkup(text string, length int) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.pango_layout_set_markup(v.native(), (*C.char)(cstr), (C.int)(length)) +} + +//void pango_layout_set_markup_with_accel (PangoLayout *layout, +// const char *markup, +// int length, +// gunichar accel_marker, +// gunichar *accel_char); + +/* +func (v *Layout) SetMarkupWithAccel (text string, length int, accel_marker, accel_char rune){ + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.pango_layout_set_markup_with_accel (v.native(), (*C.char)(cstr), (C.int)(length), (C.gunichar)(accel_marker), (C.gunichar)(accel_char) ) +} +*/ + +// SetFontDescription is a wrapper around pango_layout_set_font_description(). +func (v *Layout) SetFontDescription(desc *FontDescription) { + C.pango_layout_set_font_description(v.native(), desc.native()) +} + +// GetFontDescription is a wrapper around pango_layout_get_font_description(). +func (v *Layout) GetFontDescription() *FontDescription { + c := C.pango_layout_get_font_description(v.native()) + + desc := new(FontDescription) + desc.pangoFontDescription = (*C.PangoFontDescription)(c) + + return desc +} + +// SetWidth is a wrapper around pango_layout_set_width(). +func (v *Layout) SetWidth(width int) { + C.pango_layout_set_width(v.native(), C.int(width)) +} + +// GetWidth is a wrapper around pango_layout_get_width(). +func (v *Layout) GetWidth() int { + c := C.pango_layout_get_width(v.native()) + return int(c) +} + +// SetHeight is a wrapper around pango_layout_set_height(). +func (v *Layout) SetHeight(width int) { + C.pango_layout_set_height(v.native(), C.int(width)) +} + +// GetHeight is a wrapper around pango_layout_get_height(). +func (v *Layout) GetHeight() int { + c := C.pango_layout_get_height(v.native()) + return int(c) +} + +// SetWrap is a wrapper around pango_layout_set_wrap(). +func (v *Layout) SetWrap(wrap WrapMode) { + C.pango_layout_set_wrap(v.native(), C.PangoWrapMode(wrap)) +} + +// WrapMode is a wrapper around pango_layout_get_wrap(). +func (v *Layout) GetWrap() WrapMode { + c := C.pango_layout_get_wrap(v.native()) + return WrapMode(c) +} + +// IsWrapped is a wrapper around pango_layout_is_wrapped(). +func (v *Layout) IsWrapped() bool { + c := C.pango_layout_is_wrapped(v.native()) + return gobool(c) +} + +// SetIndent is a wrapper around pango_layout_set_indent(). +func (v *Layout) SetIndent(indent int) { + C.pango_layout_set_indent(v.native(), C.int(indent)) +} + +// GetIndent is a wrapper around pango_layout_get_indent(). +func (v *Layout) GetIndent() int { + c := C.pango_layout_get_indent(v.native()) + return int(c) +} + +// SetTabs is a wrapper around pango_layout_set_tabs(). +func (v *Layout) SetTabs(tabs *TabArray) { + C.pango_layout_set_tabs(v.native(), tabs.native()) +} + +// GetTabs is a wrapper around pango_layout_get_tabs(). +func (v *Layout) GetTabs() (*TabArray, error) { + c := C.pango_layout_get_tabs(v.native()) + if c == nil { + return nil, nilPtrErr + } + ta := wrapTabArray(c) + runtime.SetFinalizer(ta, (*TabArray).free) + return ta, nil +} + +// GetSize is a wrapper around pango_layout_get_size(). +func (v *Layout) GetSize() (int, int) { + var w, h C.int + C.pango_layout_get_size(v.native(), &w, &h) + return int(w), int(h) +} + +/* + * TabArray + */ + +// TabArray is a representation of PangoTabArray. +type TabArray struct { + pangoTabArray *C.PangoTabArray +} + +// Native returns a pointer to the underlying PangoTabArray. +func (v *TabArray) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *TabArray) native() *C.PangoTabArray { + if v == nil { + return nil + } + return (*C.PangoTabArray)(unsafe.Pointer(v.pangoTabArray)) +} + +func wrapTabArray(tabArray *C.PangoTabArray) *TabArray { + return &TabArray{tabArray} +} + +func WrapTabArray(p uintptr) *TabArray { + tabArray := new(TabArray) + tabArray.pangoTabArray = (*C.PangoTabArray)(unsafe.Pointer(p)) + return tabArray +} + +// TabArrayNew is a wrapper around pango_tab_array_new(). +func TabArrayNew(initialSize int, positionsInPixels bool) *TabArray { + c := C.pango_tab_array_new(C.gint(initialSize), gbool(positionsInPixels)) + + tabArray := new(TabArray) + runtime.SetFinalizer(tabArray, (*TabArray).free) + tabArray.pangoTabArray = (*C.PangoTabArray)(c) + return tabArray +} + +// TabArrayNewWithPositions is a wrapper around pango_tab_array_new_with_positions(). +// func TabArrayNewWithPositions(size int, positionsInPixels bool, ...) *TabArray { +// c := C.pango_tab_array_new_with_positions(C.gint(size), gbool(positionsInPixels), ...) + +// tabArray := new(TabArray) +// runtime.SetFinalizer(e, (*TabArray).free) +// tabArray.pangoTabArray = (*C.PangoTabArray)(c) +// return tabArray +// } + +// Copy is a wrapper around pango_tab_array_copy(). +func (v *TabArray) Copy() (*TabArray, error) { + c := C.pango_tab_array_copy(v.native()) + if c == nil { + return nil, nilPtrErr + } + ta := wrapTabArray(c) + runtime.SetFinalizer(ta, (*TabArray).free) + return ta, nil +} + +// free is a wrapper around pango_tab_array_free(). +func (v *TabArray) free() { + C.pango_tab_array_free(v.native()) +} + +// free is a wrapper around pango_tab_array_free(). +// This is only to enable other packages within gotk. Should not be used outside the gotk library. +func (v *TabArray) Free() { + C.pango_tab_array_free(v.native()) +} + +// GetSize is a wrapper around pango_tab_array_get_size(). +func (v *TabArray) GetSize() int { + return int(C.pango_tab_array_get_size(v.native())) +} + +// Resize is a wrapper around pango_tab_array_resize(). +func (v *TabArray) Resize(newSize int) { + C.pango_tab_array_resize(v.native(), C.gint(newSize)) +} + +// SetTab is a wrapper around pango_tab_array_set_tab(). +func (v *TabArray) SetTab(tabIndex int, alignment TabAlign, location int) { + C.pango_tab_array_set_tab(v.native(), C.gint(tabIndex), C.PangoTabAlign(alignment), C.gint(location)) +} + +// GetTab is a wrapper around pango_tab_array_get_tab(). +func (v *TabArray) GetTab(tabIndex int) (TabAlign, int) { + var alignment C.PangoTabAlign + var location C.gint + C.pango_tab_array_get_tab(v.native(), C.gint(tabIndex), &alignment, &location) + return TabAlign(alignment), int(location) +} + +// GetTabs is a wrapper around pango_tab_array_get_tabs(). +// func (v *TabArray) GetTabs() ([]TabAlign, []int) { +// var alignment *C.PangoTabAlign +// var location *C.gint + +// C.pango_tab_array_get_tabs(v.native(), &alignment, &location) + +// size := v.GetSize() + +// var goAlignments []TabAlign +// var goLocations []int + +// if &alignment != nil { +// var ginthelp C.gint +// sizeOf := unsafe.Sizeof(ginthelp) +// for i := 0; i < int(size); i++ { +// goAlignmentElement := TabAlign(*((*C.gint)(unsafe.Pointer(location)))) +// goAlignments = append(goAlignments, goAlignmentElement) +// location += sizeOf +// } +// } + +// if &location != nil { +// var ginthelp C.gint +// sizeOf := unsafe.Sizeof(ginthelp) +// for i := 0; i < int(size); i++ { +// goLocationElement := int(*((*C.gint)(unsafe.Pointer(location)))) +// goLocations = append(goLocations, goLocationElement) +// location += sizeOf +// } + +// // TODO: free locations +// } + +// return goAlignments, goLocations +// } + +// GetPositionsInPixels is a wrapper around pango_tab_array_get_positions_in_pixels(). +func (v *TabArray) GetPositionsInPixels() bool { + return gobool(C.pango_tab_array_get_positions_in_pixels(v.native())) +} + +//void pango_layout_set_spacing (PangoLayout *layout, +// int spacing); +//int pango_layout_get_spacing (PangoLayout *layout); +//void pango_layout_set_justify (PangoLayout *layout, +// gboolean justify); +//gboolean pango_layout_get_justify (PangoLayout *layout); +//void pango_layout_set_auto_dir (PangoLayout *layout, +// gboolean auto_dir); +//gboolean pango_layout_get_auto_dir (PangoLayout *layout); +//void pango_layout_set_alignment (PangoLayout *layout, +// PangoAlignment alignment); +//PangoAlignment pango_layout_get_alignment (PangoLayout *layout); +// +//void pango_layout_set_single_paragraph_mode (PangoLayout *layout, +// gboolean setting); +//gboolean pango_layout_get_single_paragraph_mode (PangoLayout *layout); +// +//void pango_layout_set_ellipsize (PangoLayout *layout, +// PangoEllipsizeMode ellipsize); +//PangoEllipsizeMode pango_layout_get_ellipsize (PangoLayout *layout); +//gboolean pango_layout_is_ellipsized (PangoLayout *layout); +// +//int pango_layout_get_unknown_glyphs_count (PangoLayout *layout); +// +//void pango_layout_context_changed (PangoLayout *layout); +//guint pango_layout_get_serial (PangoLayout *layout); +// +//void pango_layout_get_log_attrs (PangoLayout *layout, +// PangoLogAttr **attrs, +// gint *n_attrs); +// +//const PangoLogAttr *pango_layout_get_log_attrs_readonly (PangoLayout *layout, +// gint *n_attrs); +// +//void pango_layout_index_to_pos (PangoLayout *layout, +// int index_, +// PangoRectangle *pos); +//void pango_layout_index_to_line_x (PangoLayout *layout, +// int index_, +// gboolean trailing, +// int *line, +// int *x_pos); +//void pango_layout_get_cursor_pos (PangoLayout *layout, +// int index_, +// PangoRectangle *strong_pos, +// PangoRectangle *weak_pos); +//void pango_layout_move_cursor_visually (PangoLayout *layout, +// gboolean strong, +// int old_index, +// int old_trailing, +// int direction, +// int *new_index, +// int *new_trailing); +//gboolean pango_layout_xy_to_index (PangoLayout *layout, +// int x, +// int y, +// int *index_, +// int *trailing); +//void pango_layout_get_extents (PangoLayout *layout, +// PangoRectangle *ink_rect, +// PangoRectangle *logical_rect); +//void pango_layout_get_pixel_extents (PangoLayout *layout, +// PangoRectangle *ink_rect, +// PangoRectangle *logical_rect); +//void pango_layout_get_pixel_size (PangoLayout *layout, +// int *width, +// int *height); +//int pango_layout_get_baseline (PangoLayout *layout); +// +//int pango_layout_get_line_count (PangoLayout *layout); +//PangoLayoutLine *pango_layout_get_line (PangoLayout *layout, +// int line); +//PangoLayoutLine *pango_layout_get_line_readonly (PangoLayout *layout, +// int line); +//GSList * pango_layout_get_lines (PangoLayout *layout); +//GSList * pango_layout_get_lines_readonly (PangoLayout *layout); +// +// +//#define PANGO_TYPE_LAYOUT_LINE (pango_layout_line_get_type ()) +// +//GType pango_layout_line_get_type (void) G_GNUC_CONST; +// +//PangoLayoutLine *pango_layout_line_ref (PangoLayoutLine *line); +//void pango_layout_line_unref (PangoLayoutLine *line); +// +//gboolean pango_layout_line_x_to_index (PangoLayoutLine *line, +// int x_pos, +// int *index_, +// int *trailing); +//void pango_layout_line_index_to_x (PangoLayoutLine *line, +// int index_, +// gboolean trailing, +// int *x_pos); +//void pango_layout_line_get_x_ranges (PangoLayoutLine *line, +// int start_index, +// int end_index, +// int **ranges, +// int *n_ranges); +//void pango_layout_line_get_extents (PangoLayoutLine *line, +// PangoRectangle *ink_rect, +// PangoRectangle *logical_rect); +//void pango_layout_line_get_pixel_extents (PangoLayoutLine *layout_line, +// PangoRectangle *ink_rect, +// PangoRectangle *logical_rect); +// +//typedef struct _PangoLayoutIter PangoLayoutIter; +// +//#define PANGO_TYPE_LAYOUT_ITER (pango_layout_iter_get_type ()) +// +//GType pango_layout_iter_get_type (void) G_GNUC_CONST; +// +//PangoLayoutIter *pango_layout_get_iter (PangoLayout *layout); +//PangoLayoutIter *pango_layout_iter_copy (PangoLayoutIter *iter); +//void pango_layout_iter_free (PangoLayoutIter *iter); +// +//int pango_layout_iter_get_index (PangoLayoutIter *iter); +//PangoLayoutRun *pango_layout_iter_get_run (PangoLayoutIter *iter); +//PangoLayoutRun *pango_layout_iter_get_run_readonly (PangoLayoutIter *iter); +//PangoLayoutLine *pango_layout_iter_get_line (PangoLayoutIter *iter); +//PangoLayoutLine *pango_layout_iter_get_line_readonly (PangoLayoutIter *iter); +//gboolean pango_layout_iter_at_last_line (PangoLayoutIter *iter); +//PangoLayout *pango_layout_iter_get_layout (PangoLayoutIter *iter); +// +//gboolean pango_layout_iter_next_char (PangoLayoutIter *iter); +//gboolean pango_layout_iter_next_cluster (PangoLayoutIter *iter); +//gboolean pango_layout_iter_next_run (PangoLayoutIter *iter); +//gboolean pango_layout_iter_next_line (PangoLayoutIter *iter); +// +//void pango_layout_iter_get_char_extents (PangoLayoutIter *iter, +// PangoRectangle *logical_rect); +//void pango_layout_iter_get_cluster_extents (PangoLayoutIter *iter, +// PangoRectangle *ink_rect, +// PangoRectangle *logical_rect); +//void pango_layout_iter_get_run_extents (PangoLayoutIter *iter, +// PangoRectangle *ink_rect, +// PangoRectangle *logical_rect); +//void pango_layout_iter_get_line_extents (PangoLayoutIter *iter, +// PangoRectangle *ink_rect, +// PangoRectangle *logical_rect); +/* All the yranges meet, unlike the logical_rect's (i.e. the yranges + * assign between-line spacing to the nearest line) + */ +//void pango_layout_iter_get_line_yrange (PangoLayoutIter *iter, +// int *y0_, +// int *y1_); +//void pango_layout_iter_get_layout_extents (PangoLayoutIter *iter, +// PangoRectangle *ink_rect, +// PangoRectangle *logical_rect); +//int pango_layout_iter_get_baseline (PangoLayoutIter *iter); +// diff --git a/vendor/github.com/gotk3/gotk3/pango/pango-layout.go.h b/vendor/github.com/gotk3/gotk3/pango/pango-layout.go.h new file mode 100644 index 0000000..8aa70b2 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango-layout.go.h @@ -0,0 +1,23 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include +#include +#include + +static PangoLayout *toPangoLayout(void *p) { return ((PangoLayout *)(p)); } diff --git a/vendor/github.com/gotk3/gotk3/pango/pango-types.go b/vendor/github.com/gotk3/gotk3/pango/pango-types.go new file mode 100644 index 0000000..fb08656 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango-types.go @@ -0,0 +1,135 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package pango + +// #include +// #include "pango.go.h" +// #include +import "C" +import ( + "unsafe" +) + +// LogAttr is a representation of PangoLogAttr. +type LogAttr struct { + pangoLogAttr *C.PangoLogAttr +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *LogAttr) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *LogAttr) native() *C.PangoLogAttr { + return (*C.PangoLogAttr)(unsafe.Pointer(v.pangoLogAttr)) +} + +// EngineLang is a representation of PangoEngineLang. +type EngineLang struct { + pangoEngineLang *C.PangoEngineLang +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *EngineLang) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *EngineLang) native() *C.PangoEngineLang { + return (*C.PangoEngineLang)(unsafe.Pointer(v.pangoEngineLang)) +} + +// EngineShape is a representation of PangoEngineShape. +type EngineShape struct { + pangoEngineShape *C.PangoEngineShape +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *EngineShape) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *EngineShape) native() *C.PangoEngineShape { + return (*C.PangoEngineShape)(unsafe.Pointer(v.pangoEngineShape)) +} + +// Font is a representation of PangoFont. +type Font struct { + pangoFont *C.PangoFont +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *Font) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *Font) native() *C.PangoFont { + return (*C.PangoFont)(unsafe.Pointer(v.pangoFont)) +} + +// FontMap is a representation of PangoFontMap. +type FontMap struct { + pangoFontMap *C.PangoFontMap +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *FontMap) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *FontMap) native() *C.PangoFontMap { + return (*C.PangoFontMap)(unsafe.Pointer(v.pangoFontMap)) +} + +func wrapFontMap(fontMap *C.PangoFontMap) *FontMap { + return &FontMap{fontMap} +} + +func WrapFontMap(p uintptr) *FontMap { + fontMap := (*C.PangoFontMap)(unsafe.Pointer(p)) + return wrapFontMap(fontMap) +} + +// Rectangle is a representation of PangoRectangle. +type Rectangle struct { + pangoRectangle *C.PangoRectangle +} + +// Native returns a pointer to the underlying PangoLayout. +func (v *Rectangle) Native() uintptr { + return uintptr(unsafe.Pointer(v.native())) +} + +func (v *Rectangle) native() *C.PangoRectangle { + return (*C.PangoRectangle)(unsafe.Pointer(v.pangoRectangle)) +} + +// Glyph is a representation of PangoGlyph +type Glyph uint32 + +//void pango_extents_to_pixels (PangoRectangle *inclusive, +// PangoRectangle *nearest); +func (inclusive *Rectangle) ExtentsToPixels(nearest *Rectangle) { + C.pango_extents_to_pixels(inclusive.native(), nearest.native()) +} + +func RectangleNew(x, y, width, height int) *Rectangle { + r := new(Rectangle) + r.pangoRectangle = C.createPangoRectangle((C.int)(x), (C.int)(y), (C.int)(width), (C.int)(height)) + return r +} diff --git a/vendor/github.com/gotk3/gotk3/pango/pango.go b/vendor/github.com/gotk3/gotk3/pango/pango.go new file mode 100644 index 0000000..4745ec1 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango.go @@ -0,0 +1,62 @@ +// Copyright (c) 2013-2014 Conformal Systems +// +// This file originated from: http://opensource.conformal.com/ +// +// Permission to use, copy, modify, and distribute this software for any +// purpose with or without fee is hereby granted, provided that the above +// copyright notice and this permission notice appear in all copies. +// +// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +// Go bindings for Pango. +package pango + +// #cgo pkg-config: fontconfig gobject-2.0 glib-2.0 pango pangocairo +// #include +// #include "pango.go.h" +import "C" +import "errors" + +// "github.com/andre-hub/gotk3/glib" +// "unsafe" + +func init() { + +} + +/* + * Type conversions + */ + +func gbool(b bool) C.gboolean { + if b { + return C.gboolean(1) + } + return C.gboolean(0) +} +func gobool(b C.gboolean) bool { + if b != 0 { + return true + } + return false +} + +/* + * Unexported vars + */ + +var nilPtrErr = errors.New("cgo returned unexpected nil pointer") + +/* + * Constantes + */ + +const ( + SCALE int = 1024 +) diff --git a/vendor/github.com/gotk3/gotk3/pango/pango.go.h b/vendor/github.com/gotk3/gotk3/pango/pango.go.h new file mode 100644 index 0000000..68e4159 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pango.go.h @@ -0,0 +1,36 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include +#include +#include + +#include "pango-attributes.go.h" +#include "pango-layout.go.h" + +#include "pangocairo.go.h" + +static PangoRectangle *createPangoRectangle(int x, int y, int width, + int height) { + PangoRectangle *r = (PangoRectangle *)malloc(sizeof(PangoRectangle)); + r->x = x; + r->y = y; + r->width = width; + r->height = height; + return r; +} \ No newline at end of file diff --git a/vendor/github.com/gotk3/gotk3/pango/pangocairo.go b/vendor/github.com/gotk3/gotk3/pango/pangocairo.go new file mode 100644 index 0000000..260e345 --- /dev/null +++ b/vendor/github.com/gotk3/gotk3/pango/pangocairo.go @@ -0,0 +1,138 @@ +/* + * Copyright (c) 2015- terrak + * + * This file originated from: http://www.terrak.net/ + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +package pango + +// #include +// #include +// #include +// #include "pango.go.h" +import "C" +import ( + // "github.com/gotk3/gotk3/glib" + "unsafe" + + "github.com/gotk3/gotk3/cairo" +) + +func init() { + // tm := []glib.TypeMarshaler{ + // // Enums + // {glib.Type(C.pango_alignement_get_type()), marshalAlignment}, + // {glib.Type(C.pango_ellipsize_mode_get_type()), marshalEllipsizeMode}, + // {glib.Type(C.pango_wrap_mode_get_type()), marshalWrapMode}, + // } + // glib.RegisterGValueMarshalers(tm) +} + +func cairo_context(cr *cairo.Context) *C.cairo_t { + return (*C.cairo_t)(cr.GetCContext()) +} + +/* Convenience + */ +//PangoContext *pango_cairo_create_context (cairo_t *cr); +func CairoCreateContext(cr *cairo.Context) *Context { + c := C.pango_cairo_create_context(cairo_context(cr)) + context := new(Context) + context.pangoContext = (*C.PangoContext)(c) + return context +} + +//PangoLayout *pango_cairo_create_layout (cairo_t *cr); +func CairoCreateLayout(cr *cairo.Context) *Layout { + c := C.pango_cairo_create_layout(cairo_context(cr)) + layout := new(Layout) + layout.pangoLayout = (*C.PangoLayout)(c) + return layout +} + +//void pango_cairo_update_layout (cairo_t *cr, +// PangoLayout *layout); +func CairoUpdateLayout(cr *cairo.Context, v *Layout) { + C.pango_cairo_update_layout(cairo_context(cr), v.native()) +} + +/* + * Rendering + */ +//void pango_cairo_show_glyph_string (cairo_t *cr, +// PangoFont *font, +// PangoGlyphString *glyphs); +func CairoShowGlyphString(cr *cairo.Context, font *Font, glyphs *GlyphString) { + C.pango_cairo_show_glyph_string(cairo_context(cr), font.native(), glyphs.native()) +} + +//void pango_cairo_show_glyph_item (cairo_t *cr, +// const char *text, +// PangoGlyphItem *glyph_item); +func CairoShowGlyphItem(cr *cairo.Context, text string, glyph_item *GlyphItem) { + cstr := C.CString(text) + defer C.free(unsafe.Pointer(cstr)) + C.pango_cairo_show_glyph_item(cairo_context(cr), (*C.char)(cstr), glyph_item.native()) +} + +//void pango_cairo_show_layout_line (cairo_t *cr, +// PangoLayoutLine *line); +func CairoShowLayoutLine(cr *cairo.Context, line *LayoutLine) { + C.pango_cairo_show_layout_line(cairo_context(cr), line.native()) +} + +//void pango_cairo_show_layout (cairo_t *cr, +// PangoLayout *layout); +func CairoShowLayout(cr *cairo.Context, layout *Layout) { + C.pango_cairo_show_layout(cairo_context(cr), layout.native()) +} + +//void pango_cairo_show_error_underline (cairo_t *cr, +// double x, +// double y, +// double width, +// double height); + +/* + * Rendering to a path + */ + +//void pango_cairo_glyph_string_path (cairo_t *cr, +// PangoFont *font, +// PangoGlyphString *glyphs); +func CairoGlyphStringPath(cr *cairo.Context, font *Font, glyphs *GlyphString) { + C.pango_cairo_glyph_string_path(cairo_context(cr), font.native(), glyphs.native()) +} + +//void pango_cairo_layout_line_path (cairo_t *cr, +// PangoLayoutLine *line); +func CairoLayoutLinePath(cr *cairo.Context, line *LayoutLine) { + C.pango_cairo_layout_line_path(cairo_context(cr), line.native()) +} + +//void pango_cairo_layout_path (cairo_t *cr, +// PangoLayout *layout); +func CairoLayoutPath(cr *cairo.Context, layout *Layout) { + C.pango_cairo_layout_path(cairo_context(cr), layout.native()) +} + +//void pango_cairo_error_underline_path (cairo_t *cr, +// double x, +// double y, +// double width, +// double height); +func CairoErrorUnderlinePath(cr *cairo.Context, x, y, width, height float64) { + C.pango_cairo_error_underline_path(cairo_context(cr), C.double(x), C.double(y), C.double(width), C.double(height)) +} diff --git a/vendor/github.com/gotk3/gotk3/pango/pangocairo.go.h b/vendor/github.com/gotk3/gotk3/pango/pangocairo.go.h new file mode 100644 index 0000000..e69de29 diff --git a/vendor/github.com/hfmrow/genLib/files/fileDirCopy.go b/vendor/github.com/hfmrow/genLib/files/fileDirCopy.go deleted file mode 100644 index fc2cbd8..0000000 --- a/vendor/github.com/hfmrow/genLib/files/fileDirCopy.go +++ /dev/null @@ -1,121 +0,0 @@ -// fileDirCopy.go - -package files - -// golang copy directory recursively from: https://github.com/otiai10/copy - -import ( - "io" - "io/ioutil" - "os" - "path/filepath" -) - -/******************************************************************** - - golang copy directory recursively (MIT) license. - - Hiromu OCHIAI - otiai10 - https://github.com/otiai10 - - Retrieved from: https://github.com/otiai10/copy - -*********************************************************************/ -const ( - // tmpPermissionForDirectory makes the destination directory writable, - // so that stuff can be copied recursively even if any original directory is NOT writable. - // See https://github.com/otiai10/copy/pull/9 for more information. - tmpPermissionForDirectory = os.FileMode(0755) -) - -// Copy copies src to dest, doesn't matter if src is a directory or a file -func FileDirCopy(src, dest string) error { - info, err := os.Lstat(src) - if err != nil { - return err - } - return copy(src, dest, info) -} - -// copy dispatches copy-funcs according to the mode. -// Because this "copy" could be called recursively, -// "info" MUST be given here, NOT nil. -func copy(src, dest string, info os.FileInfo) error { - if info.Mode()&os.ModeSymlink != 0 { - return lcopy(src, dest, info) - } - if info.IsDir() { - return dcopy(src, dest, info) - } - return fcopy(src, dest, info) -} - -// fcopy is for just a file, -// with considering existence of parent directory -// and file permission. -func fcopy(src, dest string, info os.FileInfo) error { - - if err := os.MkdirAll(filepath.Dir(dest), os.ModePerm); err != nil { - return err - } - - f, err := os.Create(dest) - if err != nil { - return err - } - defer f.Close() - - if err = os.Chmod(f.Name(), info.Mode()); err != nil { - return err - } - - s, err := os.Open(src) - if err != nil { - return err - } - defer s.Close() - - _, err = io.Copy(f, s) - return err -} - -// dcopy is for a directory, -// with scanning contents inside the directory -// and pass everything to "copy" recursively. -func dcopy(srcdir, destdir string, info os.FileInfo) error { - - originalMode := info.Mode() - - // Make dest dir with 0755 so that everything writable. - if err := os.MkdirAll(destdir, tmpPermissionForDirectory); err != nil { - return err - } - // Recover dir mode with original one. - defer os.Chmod(destdir, originalMode) - - contents, err := ioutil.ReadDir(srcdir) - if err != nil { - return err - } - - for _, content := range contents { - cs, cd := filepath.Join(srcdir, content.Name()), filepath.Join(destdir, content.Name()) - if err := copy(cs, cd, content); err != nil { - // If any error, exit immediately - return err - } - } - - return nil -} - -// lcopy is for a symlink, -// with just creating a new symlink by replicating src symlink. -func lcopy(src, dest string, info os.FileInfo) error { - src, err := os.Readlink(src) - if err != nil { - return err - } - return os.Symlink(src, dest) -} diff --git a/vendor/github.com/hfmrow/genLib/files/files.go b/vendor/github.com/hfmrow/genLib/files/files.go deleted file mode 100644 index 836fbba..0000000 --- a/vendor/github.com/hfmrow/genLib/files/files.go +++ /dev/null @@ -1,275 +0,0 @@ -// files.go - -package files - -import ( - "fmt" - "io/ioutil" - "os" - "path/filepath" - "strings" - - glss "github.com/hfmrow/genLib/slices" -) - -var TmpCount int - -// CompareFilesContent: -func CompareFilesContent(filename1, filename2, filenameOutDiff string) (diff []string) { - var slice1, slice2 []string - var err error - var data1, data2 []byte - if data1, err = ReadFile(filename1); err == nil { - slice1 = strings.Split(string(data1), "\n") - if data2, err = ReadFile(filename2); err == nil { - slice2 = strings.Split(string(data2), "\n") - for _, f1 := range slice1 { - if !glss.IsExistSl(slice2, f1) { - diff = append(diff, f1) - } - } - } - } - WriteFile(filenameOutDiff, []byte(strings.Join(diff, "\n"))) - return diff -} - -// writeFile: with file backup capability -func WriteFile(filename string, datas []byte, doBackup ...bool) (err error) { - if len(doBackup) != 0 { - if doBackup[0] { - if _, err = os.Stat(filename); !os.IsNotExist(err) { - if err = os.Rename(filename, filename+"~"); err != nil { - return err - } - } - } - } - return ioutil.WriteFile(filename, datas, os.ModePerm) -} - -// copyFile: -// func CopyFile(inFile, outFile string, doBackup ...bool) (err error) { -// var inBytes []byte -// if inBytes, err = ioutil.ReadFile(inFile); err == nil { -// if len(doBackup) != 0 { -// if doBackup[0] { -// if err = os.Rename(outFile, outFile+"~"); err != nil { -// return err -// } -// } -// } -// err = ioutil.WriteFile(outFile, inBytes, os.ModePerm) -// } -// return err -// } - -// ReadFile: -func ReadFile(filename string) (data []byte, err error) { - return ioutil.ReadFile(filename) -} - -// renameProjectFiles: Mass rename function -// func RenameListFiles(fromFileList, toFileList []string) (err error) { -// for idx, file := range fromFileList { -// if file != toFileList[idx] { -// if err = os.Rename(file, toFileList[idx]); err != nil { -// return err -// } -// } -// } -// return err -// } - -// GetFileBytesString: Retrieve 'from' 'to' bytes from file in string format. -func ReadFileToStrBytes(filename string, from, to int) (outString string) { - var WriteBytesString = func(p []byte) (data string) { - const lowerHex = "0123456789abcdef" - if len(p) == 0 { - return data - } - buf := []byte(`\x00`) - var b byte - for _, b = range p { - buf[2] = lowerHex[b/16] - buf[3] = lowerHex[b%16] - data += string(buf) - } - return data - } - file, err := os.Open(filename) - if err != nil { - fmt.Println(err) - } - buff := make([]byte, to-from) - _, err = file.ReadAt(buff, int64(from)) - if err != nil { - fmt.Println(err) - } - return WriteBytesString(buff) -} - -// // FindDir retrieve file in a specific directory with more options. -// func FindDir(dir, mask string, returnedStrSlice *[][]string, scanSub, showDir, followSymlinkDir bool) error { -// var fName, time, size string -// // Remove unwanted os path separator if exist -// // dir = strings.TrimSuffix(dir, string(os.PathSeparator)) - -// files, err := ioutil.ReadDir(dir) -// if err != nil { -// return err -// } -// for _, file := range files { -// fName = filepath.Join(dir, file.Name()) -// if followSymlinkDir { // Check for symlink .. -// file, err = os.Lstat(fName) -// if err != nil { -// return err -// } -// if file.Mode()&os.ModeSymlink != 0 { // Is a symlink ? -// fName, err := os.Readlink(fName) // Then read it... -// if err != nil { -// return err -// } -// file, err = os.Stat(fName) // Get symlink infos. -// if err != nil { -// return err -// } -// fName = filepath.Join(dir, file.Name()) -// } -// } -// // Recursive play if it's a directory -// if file.IsDir() && scanSub { -// tmpFileList := new([][]string) -// err = FindDir(fName, mask, tmpFileList, scanSub, true, followSymlinkDir) -// *returnedStrSlice = append(*returnedStrSlice, *tmpFileList...) -// if err != nil { -// return err -// } -// } -// // get information to be displayed. -// size = fmt.Sprintf("%s", humanize.Bytes(uint64(file.Size()))) -// time = fmt.Sprintf("%s.", humanize.Time(file.ModTime())) -// // Check for ext matching well. -// ok, err := filepath.Match(mask, file.Name()) -// if err != nil { -// return err -// } -// if ok { -// if showDir { // Limit display directories if requested -// *returnedStrSlice = append(*returnedStrSlice, []string{file.Name(), size, time, fName}) -// } else { -// if !file.IsDir() { -// *returnedStrSlice = append(*returnedStrSlice, []string{file.Name(), size, time, fName}) -// } -// } -// } -// } -// return nil -// } - -// File struct (SplitFilePath) -type Filepath struct { - Absolute string - Relative string - Path string - Base string - BaseNoExt string - Ext string - ExecFullName string - RealPath string - RealName string - OutputNewExt string - OutputAppendFilename string - OsSeparator string - IsDir bool - SymLink bool - SymLinkTo string -} - -// Split full filename into path, ext, name, ... optionally add suffix before original extension or change extension -// Relative: SplitFilepath("wanted relative path", fullpath).Relative -// Absolute: SplitFilepath("relative path", fullpath).Absolute -func SplitFilepath(filename string, newExt ...string) Filepath { - var dir, link bool - var f = Filepath{} - var newExtension, dot, addToFilename string - if len(newExt) != 0 { - addToFilename = newExt[0] - if !strings.Contains(newExt[0], ".") { - dot = "." - } - newExtension = dot + newExt[0] - } - // IsDir - fileInfos, err := os.Lstat(filename) - if err == nil { - dir = (fileInfos.Mode()&os.ModeDir != 0) - link = (fileInfos.Mode()&os.ModeSymlink != 0) - f.IsDir = dir - if link { - // IsLink - f.SymLink = link - // Symlink endpoint - f.SymLinkTo, _ = os.Readlink(filename) - // Symlink and Directory - ls, err := os.Lstat(f.SymLinkTo) - if err == nil { - f.IsDir = (ls.Mode()&os.ModeDir != 0) - } - } - } - // Absolute - f.Absolute, _ = filepath.Abs(filename) - // Relative - Use the optional argument to set as basepath ... - f.Relative, _ = filepath.Rel(newExtension, filename) - // OsSep - f.OsSeparator = string(os.PathSeparator) - // Path - if f.Path = filepath.Dir(filename); f.Path == "." { - f.Path = "" - } - // Base - f.Base = filepath.Base(filename) - // Ext - f.Ext = filepath.Ext(filename) - // BaseNoExt - splited := strings.Split(f.Base, ".") - length := len(splited) - if length == 1 { - f.BaseNoExt = f.Base - - } else { - if f.Base[:1] == "." { // Case of hidden file starting with dot - f.Ext = "" - f.BaseNoExt = f.Base - } else { - splited = splited[:length-1] - f.BaseNoExt = strings.Join(splited, ".") - } - } - // ExecFullName - f.ExecFullName, _ = os.Executable() - // RealPath - realPathName, _ := filepath.EvalSymlinks(filename) - if f.RealPath = filepath.Dir(realPathName); f.RealPath == "." { - f.RealPath = "" - } - // RealName - if f.RealName = filepath.Base(realPathName); f.RealName == "." { - f.RealName = "" - } - // OutNewExt - if f.Path == "" { - f.OutputNewExt = f.BaseNoExt + newExtension - } else { - f.OutputNewExt = f.Path + f.OsSeparator + f.BaseNoExt + newExtension - } - // OutputAppendFilename - if f.Path == "" { - f.OutputAppendFilename = f.BaseNoExt + addToFilename + f.Ext - } else { - f.OutputAppendFilename = f.Path + f.OsSeparator + f.BaseNoExt + addToFilename + f.Ext - } - return f -} diff --git a/vendor/github.com/hfmrow/genLib/files/filesTools.go b/vendor/github.com/hfmrow/genLib/files/filesTools.go index f182c89..24f0070 100644 --- a/vendor/github.com/hfmrow/genLib/files/filesTools.go +++ b/vendor/github.com/hfmrow/genLib/files/filesTools.go @@ -3,24 +3,166 @@ package files import ( "bufio" "bytes" + "crypto/rand" + "encoding/binary" + "encoding/hex" + "fmt" "io" "io/ioutil" "log" "os" + "os/user" "path" "path/filepath" + "regexp" + "strconv" "strings" + + glsg "github.com/hfmrow/genLib/strings" ) +// Retrieve current realpath and options filename. Options/Config path +// depend on devMode value, true means current directory, false means +// current/real user directory '~/.config/Creat/appName' +// 'realUser' if provided will set the current user (used for root access). +func GetAbsRealPath(optionDir string, devMode bool, realUser ...*user.User) (absoluteRealPath, optFilename string) { + + var ( + err error + cUser *user.User + base, absoluteBaseName string + + // Set wanted extension + setExt = func(filename, ext string) (out string) { + return filename[:len(filename)-len(path.Ext(filename))] + ext + } + + // Owning directories recursively until '$HOME/.config' + ownDirs = func(u *user.User, path string) (errIn error) { + var uid, gid int + if uid, errIn = strconv.Atoi(u.Uid); errIn == nil { + if gid, errIn = strconv.Atoi(u.Gid); errIn == nil { + if path, errIn = filepath.Rel(u.HomeDir, path); errIn == nil { + + for path != ".config" { + if errIn = os.Chown(filepath.Join(u.HomeDir, path), uid, gid); errIn != nil { + return + } + splitted := strings.Split(path, string(os.PathSeparator)) + path = filepath.Join(splitted[:len(splitted)-1]...) + } + } + } + } + return + } + ) + + if len(realUser) > 0 { + cUser = realUser[0] + } else { + if cUser, err = user.Current(); err != nil { + log.Fatal(err) + } + } + + if absoluteBaseName, err = os.Executable(); err == nil { + absoluteRealPath, base = filepath.Split(absoluteBaseName) + configPath := absoluteRealPath + baseNoExt := setExt(base, "") + + if !devMode { + configPath = filepath.Join(cUser.HomeDir, ".config", glsg.ToCamel(optionDir), baseNoExt) + if _, err = os.Stat(configPath); os.IsNotExist(err) { + if err = os.MkdirAll(configPath, 0755); err == nil { + err = ownDirs(cUser, configPath) + } + } + } + if err == nil { + optFilename = setExt(filepath.Join(configPath, baseNoExt), ".opt") + } + } + if err != nil { + log.Fatal(err) + } + return +} + +// DirKeepSame: returns 'same' which corresponds to the equal parts of the +// two files and 'diff' which corresponds to the change between the two, +// the 'f1' argument must be the shortest path. +func DirKeepSame(f1, f2 string) (same, diff []string) { + + var ( + one = strings.Split(f1, string(os.PathSeparator)) + two = strings.Split(f2, string(os.PathSeparator)) + ) + for idx, dir1 := range one { + for i := idx; i < len(two); i++ { + t := two[i] + if dir1 == t { + same = append(same, dir1) + break + } else { + diff = append(diff, t) + } + } + } + return append([]string{string(os.PathSeparator)}, same...), diff +} + +// CheckOutsideDir: Check if 'filenameNew' is in the same directory as +// 'filenameOrig'. returns 'false' if the 'root' directory is the same. +func CheckOutsideDir(baseFilename, newFilename string) bool { + + re := regexp.MustCompile(`^(\.\.[/\\]|\.)`) + + if re.MatchString(baseFilename) || re.MatchString(newFilename) { + return true + } + + if rel, err := filepath.Rel( + filepath.Dir(baseFilename), + filepath.Dir(newFilename)); err == nil { + if re.MatchString(rel) { + return true + } + } + return false +} + +// FileMatch: If a pattern contained in "patterns" match, +// true is returned +func ExtFileMatch(name string, patterns []string) bool { + for _, pattern := range patterns { + if match, err := filepath.Match(pattern, name); match { + return match + } else if err != nil { + fmt.Printf("FileMatch: %s, %s, - %s\n", pattern, name, err.Error()) + } + } + return false +} + +// sizeToBytes: convert uint32 size to bytes representation (32bits) "000001f1" +func SizeToBytes(size uint32) []byte { + buf := new(bytes.Buffer) + if err := binary.Write(buf, binary.BigEndian, size); err != nil { + fmt.Println("binary.Write failed:", err) + } + return buf.Bytes() +} + // splitPath: make a slice from a string path -func splitPath(path string) (outSlice []string) { +func SplitPath(path string) (outSlice []string) { // remove leading and ending "/" path = strings.Trim(path, string(os.PathSeparator)) return strings.Split(path, string(os.PathSeparator)) } // removePathBefore: remove directories before or after the chosen name -func removePathBefore(path []string, at string, after ...bool) []string { +func RemovePathBefore(path []string, at string, after ...bool) []string { var afterMark bool if len(after) > 0 { afterMark = after[0] @@ -38,6 +180,28 @@ func removePathBefore(path []string, at string, after ...bool) []string { return path } +// IsDirOrSymlinkDir: File is a directory or a symlinked directory ? +// Need: os.FileInfo - > os.Lstat +func IsDirOrSymlinkDir(slRoot string, slStat os.FileInfo) (slIsDir bool) { + var err error + var fName string + if slStat.IsDir() { + return true + } else if slStat.Mode()&os.ModeSymlink != 0 { + if fName, err = os.Readlink(filepath.Join(slRoot, slStat.Name())); err == nil { + if slStat, err = os.Stat(fName); err == nil { + if slStat.IsDir() { + return true + } + } + } + } + if err != nil { + log.Printf("Unable to scan: %s\n", err.Error) + } + return +} + // IsDirEmpty: func IsDirEmpty(name string) (empty bool, err error) { var f *os.File @@ -56,6 +220,15 @@ func GetCurrentDir() (dir string, err error) { return os.Getwd() } +// TempFileName generates a temporary filename for use +// in testing or whatever +func TempFileName(prefix, suffix string) string { + randBytes := make([]byte, 16) + rand.Read(randBytes) + // return filepath.Join(os.TempDir(), prefix+hex.EncodeToString(randBytes)+suffix) + return prefix + hex.EncodeToString(randBytes) + suffix +} + // TempMake: Make temporary directory func TempMake(prefix string) string { dir, err := ioutil.TempDir("", prefix+"-") @@ -73,14 +246,26 @@ func TempRemove(fName string) (err error) { return nil } -// ExtEnsure: ensure the filename have desired extension -func ExtEnsure(filename, ext string) (outFilename string) { - outFilename = filename - if !strings.HasSuffix(filename, ext) { - currExt := path.Ext(filename) - outFilename = filename[:len(filename)-len(currExt)] + ext +// ExtEnsure: Ensuring that the filename has the desired extension. +// 'removeAllAfterDot' set to true means remove everything after the +// first dot encountered. +// i.e: ExtEnsure("filename.new.one.gz", ".zip", true) +// will return 'filename.zip' +func ExtEnsure(filename, ext string, removeAllAfterDot ...bool) string { + + // For some double extenssions, i.e: "tar.gz", remove before apply + filename = strings.TrimSuffix(filename, ext) + + // Whethe removing all after 1st dot is requested + if len(removeAllAfterDot) > 0 { + if removeAllAfterDot[0] { + tmpSplitted := strings.Split(filename, ".") + if len(tmpSplitted) > 0 { + filename = tmpSplitted[0] + } + } } - return outFilename + return filename[:len(filename)-len(path.Ext(filename))] + ext } // BaseNoExt: get only the name without ext. @@ -94,10 +279,12 @@ var magicTable = map[string]string{ "\xFD\x37\x7A\x58\x5A\x00\x00": "xz", "\x1F\x8B\x08\x00\x00\x09\x6E\x88": "gzip", "\x75\x73\x74\x61\x72": "tar", + "\x7F\x45\x4C\x46\x02\x01\x01": "executable-linux", } -// GetFileMime: scan first bytes to detect mime type of file. -func GetFileMime(filename string) string { +// GetSimpleFileType: scan first bytes to detect type of file. +// This is a basic version for kick usage. +func GetSimpleFileType(filename string) string { if file, err := os.Open(filename); err == nil { defer file.Close() buffReader := bufio.NewReader(file) @@ -110,5 +297,39 @@ func GetFileMime(filename string) string { } } } - return "Unknown" + return "unknown" +} + +// FileInfos: As remind for available file informations. +func FileInfos(filename string) error { + + fileInfo, err := os.Lstat(filename) + + if err != nil { + return err + } + + fmt.Println("Name : ", fileInfo.Name()) + + fmt.Println("Size : ", fileInfo.Size()) + + fmt.Println("Mode/permission : ", fileInfo.Mode()) + + if fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink { + fmt.Println("File is a symbolic link") + } + + fmt.Println("Modification Time : ", fileInfo.ModTime()) + + fmt.Println("Is a directory? : ", fileInfo.IsDir()) + + fmt.Println("Is a regular file? : ", fileInfo.Mode().IsRegular()) + + fmt.Println("Unix permission bits? : ", fileInfo.Mode().Perm()) + + fmt.Println("Permission in string : ", fileInfo.Mode().String()) + + fmt.Println("What else underneath? : ", fileInfo.Sys()) + + return nil } diff --git a/vendor/github.com/hfmrow/genLib/files/findFiles/findFiles.go b/vendor/github.com/hfmrow/genLib/files/findFiles/findFiles.go index 7890641..50c9bd9 100644 --- a/vendor/github.com/hfmrow/genLib/files/findFiles/findFiles.go +++ b/vendor/github.com/hfmrow/genLib/files/findFiles/findFiles.go @@ -7,7 +7,6 @@ package findFiles import ( "errors" "fmt" - "io/ioutil" "os" "path/filepath" "regexp" @@ -15,7 +14,6 @@ import ( "time" glcc "github.com/hfmrow/genLib/strings/cClass" - glte "github.com/hfmrow/genLib/tools/errors" times "gopkg.in/djherbis/times.v1" ) @@ -43,6 +41,11 @@ type Search struct { searchForRegexpNot []*regexp.Regexp } +type StoreFiles struct { + FilePath string + FileInfo os.FileInfo +} + type searchTime struct { newerThan time.Time olderThan time.Time @@ -62,65 +65,24 @@ func (st *searchTime) ModifTime() { st.modif = true } -// Date format is set to: Day, Month, Year -- Hour, Minute, Second. -// Local time is used. -func (st *searchTime) SetNewerThan(ready bool, dateTime ...int) { - st.newerThan = time.Time{} - var H, M, S, day, year int - var Month time.Month - if ready { - if len(dateTime) != 0 { - for idx, value := range dateTime { - switch idx { - case 0: - day = value - case 1: - Month = time.Month(value) - case 2: - year = value - case 3: - H = value - case 4: - M = value - case 5: - S = value - } - } - st.newerThan = time.Date(year, Month, day, H, M, S, 0, time.Local) - st.ntReady = ready - } +func (st *searchTime) SetNewerThan(inTime time.Time) { + var blankTime time.Time + if inTime != blankTime { + st.ntReady = true + st.newerThan = inTime + } else { + st.ntReady = false } - // fmt.Printf("Newer than: %v\n", st.newerThan) /* Control */ } -// Date format is set to: Day, Month, Year -- Hour, Minute, Second. -// Local time is used. -func (st *searchTime) SetOlderThan(ready bool, dateTime ...int) { - st.olderThan = time.Time{} - var H, M, S, day, year int - var Month time.Month - if ready { - if len(dateTime) != 0 { - for idx, value := range dateTime { - switch idx { - case 0: - day = value - case 1: - Month = time.Month(value) - case 2: - year = value - case 3: - H = value - case 4: - M = value - case 5: - S = value - } - } - st.olderThan = time.Date(year, Month, day, H, M, S, 0, time.Local) - st.otReady = ready - } - // fmt.Printf("Older than: %v\n", st.olderThan) /* Control */ +func (st *searchTime) SetOlderThan(inTime time.Time) { + var blankTime time.Time + if inTime != blankTime { + st.otReady = true + st.olderThan = inTime + } else { + st.otReady = false + st.olderThan = time.Now() } } @@ -165,10 +127,6 @@ func (s *Search) SearchCompile() (err error) { var regexStr string var tmpRegexp *regexp.Regexp - if !s.SearchTime.otReady { - s.SearchTime.olderThan = time.Now() - } - if s.readyToCompile { s.Ready = true if s.Regex { @@ -206,9 +164,7 @@ func (s *Search) SearchCompile() (err error) { } regexStr += ".*" - // if tmpRegexp, err = regexp.Compile(regexStr); err != nil { - // return - // } + tmpRegexp = regexp.MustCompile(regexStr) switch values.Logical { @@ -226,11 +182,10 @@ func (s *Search) SearchCompile() (err error) { } } } - // fmt.Printf("And Or: %v\n", strings.Join(s.searchForRegStr, "")) /* Control */ - // fmt.Printf("Not: %v\n", strings.Join(s.searchForRegStrNot, "|")) /* Control */ return } -func SearchNew() *Search { // TODO comms to remove if there no issue on search function + +func SearchNew() *Search { s := new(Search) s.Type.All() s.CaseSensitive = true @@ -239,176 +194,81 @@ func SearchNew() *Search { // TODO comms to remove if there no issue on search f } // SearchAdd: Adding entry to be searched. Format: "wordToFind", "w", "&" -// "w", "", mean WholeWord or not. "&", "|", "!", mean and, or, not +// "w", "", means WholeWord or not. "&", "|", "!", means and, or, not func (s *Search) SearchAdd(searchFor, wWord, logicalOp string) { if len(searchFor) != 0 { s.readyToCompile = true s.searchFor = append(s.searchFor, word{searchFor, wWord, logicalOp}) } } -func (s *Search) SearchInAdd(searchIn string) { + +func (s *Search) searchInAdd(searchIn string) { s.searchInto = searchIn } -// FindDepth: Search for file in dir and subdir depending on depth argument. depth = -1 mean infinite. +// SIMLINK version *********** +// FindDepth: Search for file in dir and subdir depending on depth argument. depth = -1 means infinite. // This function get parameter from a Search structure which contain all search options. -func (toFind *Search) FindDepthTest(root string, depth int) (files []string, err error) { - var tmpFilesRecurse, tmpFiles []string - var depthRecurse int - - if toFind.Ready { - filesInfos, err := ioutil.ReadDir(root) - if err != nil { - return files, err - } - for _, file := range filesInfos { - depthRecurse = depth - if file.IsDir() { - if depth != 0 { - depthRecurse-- - tmpFilesRecurse, err = toFind.FindDepthTest(filepath.Join(root, file.Name()), depthRecurse) - if err != nil { - return files, err - } - } - tmpFiles = append(tmpFiles, tmpFilesRecurse...) - } - toFind.SearchInAdd(file.Name()) - if search(toFind) { - tmpFiles = append(tmpFiles, filepath.Join(root, file.Name())) - } - } - if len(tmpFiles) == 0 { - return files, err - } - files = toFind.searchFilteringTest(tmpFiles) - - } else { - err = errors.New("Error: Nothing to search in ...") - } - return files, err -} - -// Filtering results with provided options ... -func (toFind *Search) searchFilteringTest(tmpFiles []string) (files []string) { - var skip, dir, link bool - for _, file := range tmpFiles { - fileInfos, err := os.Stat(file) - glte.Check(err) +// Note: time comparisons are calculated only with UTC format by golang ... +func (toFind *Search) FindDepth(root string, depth int, showDir, followSymlink bool) (files []StoreFiles, err error) { + if files, err = toFind.passFindDepth(root, depth, showDir, followSymlink); err == nil { + var ok, dir, link bool if !toFind.Type.typeAll { - dir = (fileInfos.Mode()&os.ModeDir != 0) - link = (fileInfos.Mode()&os.ModeSymlink != 0) - switch { - case toFind.Type.typeDir && !dir: - skip = true - case toFind.Type.typeLink && !link: - skip = true - case toFind.Type.typeFile && !dir && !link: - skip = true - } - } - if !skip { - skip = false - if toFind.SearchTime.ntReady || toFind.SearchTime.otReady { - for _, file := range tmpFiles { - fileInfos, err := os.Stat(file) - glte.Check(err) - infos := times.Get(fileInfos) - if toFind.SearchTime.access { - if infos.AccessTime().After(toFind.SearchTime.newerThan) && infos.AccessTime().Before(toFind.SearchTime.olderThan) { - files = append(files, file) - } - } else { - if infos.ModTime().After(toFind.SearchTime.newerThan) && !infos.ModTime().After(toFind.SearchTime.olderThan) { - files = append(files, file) - } - } - } - } else { /* No Time control. */ - return tmpFiles - } - files = append(files, file) - } else { /* Not desired Type. */ - return tmpFiles - } - } - return files -} - -/* -// CLASSIC version *********** -// FindDepth: Search for file in dir and subdir depending on depth argument. depth = -1 mean infinite. -// This function get parameter from a Search structure which contain all search options. -func (toFind *Search) FindDepthN(root string, depth int) (files []string, err error) { - var tmpFilesRecurse, tmpFiles []string - var ok, dir, link bool - var depthRecurse int - - if toFind.Ready { - filesInfos, err := ioutil.ReadDir(root) - if err != nil && !os.IsPermission(err) { - return files, err - } - toFind.BrowsedFiles += len(filesInfos) - for _, file := range filesInfos { - depthRecurse = depth - if file.IsDir() { - if depth != 0 { - depthRecurse-- - tmpFilesRecurse, err = toFind.FindDepth(filepath.Join(root, file.Name()), depthRecurse) - if err != nil && !os.IsPermission(err) { - return files, err - } - } - tmpFiles = append(tmpFiles, tmpFilesRecurse...) - } - toFind.SearchInAdd(file.Name()) - if toFind.Type.typeAll { - ok = search(toFind) - } else { - dir = (file.Mode()&os.ModeDir != 0) - link = (file.Mode()&os.ModeSymlink != 0) + for idx := len(files) - 1; idx >= 0; idx-- { + dir = files[idx].FileInfo.Mode()&os.ModeDir != 0 + link = files[idx].FileInfo.Mode()&os.ModeSymlink != 0 + ok = false switch { case toFind.Type.typeDir && dir: - ok = search(toFind) + ok = showDir case toFind.Type.typeLink && link: - ok = search(toFind) + ok = true case toFind.Type.typeFile && (!dir && !link): - ok = search(toFind) + ok = true + } + if !ok { // Remove entry that does not match + files = append(files[:idx], files[idx+1:]...) } - } - if ok { - ok = false - tmpFiles = append(tmpFiles, filepath.Join(root, file.Name())) } } - - if len(tmpFiles) == 0 { - return files, err + // Note, time comparisons are calculated only with UTC format by golang... + if toFind.SearchTime.ntReady || toFind.SearchTime.otReady { + var infos times.Timespec + var timeCheck time.Time + if toFind.SearchTime.olderThan == timeCheck { + toFind.SearchTime.olderThan = time.Now().UTC() + } + for idx := len(files) - 1; idx >= 0; idx-- { + infos = times.Get(files[idx].FileInfo) + // Select modification or access + if toFind.SearchTime.access { + timeCheck = infos.AccessTime() + // fmt.Printf("A-%s: %v < %v < %v\n", files[idx].FileInfo.Name(), toFind.SearchTime.newerThan, timeCheck, toFind.SearchTime.olderThan) + } else { + timeCheck = infos.ModTime() + // fmt.Printf("M-%s: %v < %v < %v\n", files[idx].FileInfo.Name(), toFind.SearchTime.newerThan, timeCheck, toFind.SearchTime.olderThan) + } // Compare and Remove entry that does not match + if !(timeCheck.After(toFind.SearchTime.newerThan) && timeCheck.Before(toFind.SearchTime.olderThan)) { + files = append(files[:idx], files[idx+1:]...) + } + } + return } - files = toFind.searchFiltering(tmpFiles) - - } else { - err = errors.New("Error: Nothing to search in ...") } - return files, err + return } -*/ -// SIMLINK version *********** -// FindDepth: Search for file in dir and subdir depending on depth argument. depth = -1 mean infinite. -// This function get parameter from a Search structure which contain all search options. -func (toFind *Search) FindDepth(root string, depth int, showDir, followSymlink bool) (files []string, err error) { - var tmpFilesRecurse, tmpFiles []string +// passFindDepth: this is the first pass for ScanDir ethos +func (toFind *Search) passFindDepth(root string, depth int, showDir, followSymlink bool) (files []StoreFiles, err error) { var targetSL string - var ok, dir, link bool var depthRecurse int var osFile *os.File var osFileInfos []os.FileInfo var statSL os.FileInfo + var tmpFilesRecurse []StoreFiles if toFind.Ready { - root = strings.TrimSuffix(root, string(filepath.Separator)) + // root = strings.TrimSuffix(root, string(filepath.Separator)) if osFile, err = os.Open(root); err == nil { defer osFile.Close() if osFileInfos, err = osFile.Readdir(-1); err != nil { @@ -419,66 +279,42 @@ func (toFind *Search) FindDepth(root string, depth int, showDir, followSymlink b depthRecurse = depth if file.IsDir() { - // if showDir { - // tmpFiles = append(tmpFiles, filepath.Join(root, file.Name())) - // } if depth != 0 { depthRecurse-- - tmpFilesRecurse, err = toFind.FindDepth(filepath.Join(root, file.Name()), depthRecurse, showDir, followSymlink) + tmpFilesRecurse, err = toFind.passFindDepth(filepath.Join(root, file.Name()), depthRecurse, showDir, followSymlink) if err != nil && !os.IsPermission(err) { return files, err } } - tmpFiles = append(tmpFiles, tmpFilesRecurse...) + files = append(files, tmpFilesRecurse...) } else if followSymlink && file.Mode()&os.ModeSymlink != 0 { if targetSL, err = os.Readlink(filepath.Join(root, file.Name())); err == nil { if statSL, err = os.Lstat(targetSL); err == nil { if statSL.IsDir() { - // if showDir { - // tmpFiles = append(tmpFiles, filepath.Join(root, file.Name())) - // } if depth != 0 { depthRecurse-- - tmpFilesRecurse, err = toFind.FindDepth(filepath.Join(root, file.Name()), depthRecurse, showDir, followSymlink) + tmpFilesRecurse, err = toFind.passFindDepth(filepath.Join(root, file.Name()), depthRecurse, showDir, followSymlink) if err != nil && !os.IsPermission(err) { return files, err } } - tmpFiles = append(tmpFiles, tmpFilesRecurse...) + files = append(files, tmpFilesRecurse...) } } } else if err != nil && !os.IsPermission(err) { return files, err } } - toFind.SearchInAdd(file.Name()) - if toFind.Type.typeAll { - ok = search(toFind) - } else { - dir = file.Mode()&os.ModeDir != 0 - link = file.Mode()&os.ModeSymlink != 0 - switch { - case toFind.Type.typeDir && dir: - if showDir { - ok = search(toFind) - } - case toFind.Type.typeLink && link: - ok = search(toFind) - case toFind.Type.typeFile && (!dir && !link): - ok = search(toFind) - } - } - if ok { - ok = false - tmpFiles = append(tmpFiles, filepath.Join(root, file.Name())) + toFind.searchInto = file.Name() + if toFind.search() { + files = append(files, StoreFiles{ + FilePath: filepath.Join(root, file.Name()), + FileInfo: file}) } } - - if len(tmpFiles) == 0 { + if len(files) == 0 { return files, err } - files = toFind.searchFiltering(tmpFiles) - } else { err = errors.New(fmt.Sprintf("Nothing to search in ! : %s\n", err.Error())) } @@ -486,171 +322,8 @@ func (toFind *Search) FindDepth(root string, depth int, showDir, followSymlink b return files, err } -// FindDepth: Search for file in dir and subdir depending on depth argument. depth = -1 mean infinite. -// This function get parameter from a Search structure which contain all search options. -func (toFind *Search) FindDepthN(root string, depth int, showDir, followSymlink bool) (files []string, err error) { - var tmpFilesRecurse, tmpFiles []string - var targetSL string - var ok, dir, link bool - var depthRecurse int - var osFile *os.File - var osFileInfos []os.FileInfo - var statSL os.FileInfo - - if toFind.Ready { - - root = strings.TrimSuffix(root, string(filepath.Separator)) - - if osFile, err = os.Open(root); err == nil { - defer osFile.Close() - if osFileInfos, err = osFile.Readdir(-1); err != nil { - return files, err - } - toFind.BrowsedFiles += len(osFileInfos) - for _, file := range osFileInfos { - - if followSymlink && file.Mode()&os.ModeSymlink != 0 { - if targetSL, err = os.Readlink(filepath.Join(root, file.Name())); err == nil { - if statSL, err = os.Lstat(targetSL); err == nil { - if statSL.IsDir() { - if showDir { - tmpFiles = append(tmpFiles, filepath.Join(root, file.Name())) - } - if depth != 0 { - depthRecurse-- - tmpFilesRecurse, err = toFind.FindDepthN(filepath.Join(root, file.Name()), depthRecurse, showDir, followSymlink) - if err != nil && !os.IsPermission(err) { - return files, err - } - } - tmpFiles = append(tmpFiles, tmpFilesRecurse...) - } - } - } else if err != nil && !os.IsPermission(err) { - return files, err - } - } - // fmt.Printf("%d - %s\n", idx, file.Name()) - depthRecurse = depth - if file.IsDir() { - if showDir { - tmpFiles = append(tmpFiles, filepath.Join(root, file.Name())) - } - if depth != 0 { - depthRecurse-- - tmpFilesRecurse, err = toFind.FindDepthN(filepath.Join(root, file.Name()), depthRecurse, showDir, followSymlink) - if err != nil && !os.IsPermission(err) { - return files, err - } - } - tmpFiles = append(tmpFiles, tmpFilesRecurse...) - } - toFind.SearchInAdd(file.Name()) - if toFind.Type.typeAll { - ok = search(toFind) - } else { - dir = (file.Mode()&os.ModeDir != 0) - link = (file.Mode()&os.ModeSymlink != 0) - switch { - case toFind.Type.typeDir && dir: - ok = search(toFind) - case toFind.Type.typeLink && link: - ok = search(toFind) - case toFind.Type.typeFile && (!dir && !link): - ok = search(toFind) - } - } - if ok { - ok = false - tmpFiles = append(tmpFiles, filepath.Join(root, file.Name())) - } - } - - if len(tmpFiles) == 0 { - return files, err - } - files = toFind.searchFiltering(tmpFiles) - - } else { - err = errors.New(fmt.Sprintf("Nothing to search in ! : %s\n", err.Error())) - } - } - return files, err -} - -// Filtering results with provided options ... -func (toFind *Search) searchFiltering(tmpFiles []string) (files []string) { - if toFind.SearchTime.ntReady || toFind.SearchTime.otReady { - for _, file := range tmpFiles { - fileInfos, err := os.Stat(file) - if err != nil && !os.IsPermission(err) { - fmt.Printf("%v\n", err) - return files - } - infos := times.Get(fileInfos) - if toFind.SearchTime.access { - if infos.AccessTime().After(toFind.SearchTime.newerThan) && infos.AccessTime().Before(toFind.SearchTime.olderThan) { - files = append(files, file) - } - } else { - if infos.ModTime().After(toFind.SearchTime.newerThan) && !infos.ModTime().After(toFind.SearchTime.olderThan) { - files = append(files, file) - } - } - } - // fmt.Printf("Time control. Newer than: %v Older than: %v\n", toFind.SearchTime.newerThan, toFind.SearchTime.olderThan) /* Control */ - } else { - // fmt.Println("No time control.") /* Control */ - return tmpFiles - } - return files -} - -// Find: Search for file in dir all subdir. Equal performances between this one and the (Depth) version -// This function get parameter from a Search structure which contain all search options. -func (toFind *Search) Find(root string) (files []string, err error) { - var tmpFiles []string - var ok, dir, link bool - - if toFind.Ready { - err = filepath.Walk(root, - func(path string, info os.FileInfo, err error) error { - toFind.SearchInAdd(info.Name()) - if toFind.Type.typeAll { - ok = search(toFind) - } else { - dir = (info.Mode()&os.ModeDir != 0) - link = (info.Mode()&os.ModeSymlink != 0) - switch { - case toFind.Type.typeDir && dir: - ok = search(toFind) - case toFind.Type.typeLink && link: - ok = search(toFind) - case toFind.Type.typeFile && (!dir && !link): - ok = search(toFind) - } - } - toFind.BrowsedFiles++ - if ok { - tmpFiles = append(tmpFiles, path) - ok = false - } - return nil - }) - if err == nil { - - if len(tmpFiles) == 0 { - return files, err - } - files = toFind.searchFiltering(tmpFiles) - } - } else { - err = errors.New("Error: Nothing to search in ...") - } - return files, err -} - -func search(toFind *Search) (resp bool) { +// search: filter input to keep only that match +func (toFind *Search) search() (resp bool) { // And for _, elem := range toFind.searchForRegexpAnd { if elem.MatchString(toFind.searchInto) { @@ -659,22 +332,66 @@ func search(toFind *Search) (resp bool) { resp = false break } - } - // Or + } // Or for _, elem := range toFind.searchForRegexpOr { if elem.MatchString(toFind.searchInto) { resp = true + break } - } - // Not + } // Not for _, elem := range toFind.searchForRegexpNot { if elem.MatchString(toFind.searchInto) { resp = false + break } } - return resp + return } +// // Find: Search for file in dir all subdir. Equal performances between this one and the (Depth) version +// // This function get parameter from a Search structure which contain all search options. +// func (toFind *Search) Find(root string) (files []string, err error) { +// var tmpFiles []string +// var ok, dir, link bool + +// if toFind.Ready { +// err = filepath.Walk(root, +// func(path string, info os.FileInfo, err error) error { +// toFind.SearchInAdd(info.Name()) +// if toFind.Type.typeAll { +// ok = search(toFind) +// } else { +// dir = (info.Mode()&os.ModeDir != 0) +// link = (info.Mode()&os.ModeSymlink != 0) +// switch { +// case toFind.Type.typeDir && dir: +// ok = search(toFind) +// case toFind.Type.typeLink && link: +// ok = search(toFind) +// case toFind.Type.typeFile && (!dir && !link): +// ok = search(toFind) +// } +// } +// toFind.BrowsedFiles++ +// if ok { +// tmpFiles = append(tmpFiles, path) +// ok = false +// } +// return nil +// }) +// if err == nil { + +// if len(tmpFiles) == 0 { +// return files, err +// } +// files = toFind.searchFiltering(tmpFiles) +// } +// } else { +// err = errors.New("Error: Nothing to search in ...") +// } +// return files, err +// } + /************************* * EXAMPLE how to use. * *************************/ diff --git a/vendor/github.com/hfmrow/genLib/files/permsOwner.go b/vendor/github.com/hfmrow/genLib/files/permsOwner.go deleted file mode 100644 index f4c88a0..0000000 --- a/vendor/github.com/hfmrow/genLib/files/permsOwner.go +++ /dev/null @@ -1,77 +0,0 @@ -package files - -import ( - "fmt" - "os" - "os/exec" - "os/user" - "strconv" -) - -/* Const for FileMode -Usage to Create any directories needed to put this file in them: - var dir_file_mode os.FileMode - dir_file_mode = os.ModeDir | (OS_USER_RWX | OS_ALL_R) - os.MkdirAll(dir_str, dir_file_mode) - - fmt.Printf("%o\n%o\n%o\n%o\n", - os.ModePerm&OS_ALL_RWX, - os.ModePerm&OS_USER_RW|OS_GROUP_R|OS_OTH_R, - os.ModePerm&OS_USER_RW|OS_GROUP_RW|OS_OTH_R, - os.ModePerm&OS_USER_RWX|OS_GROUP_RWX|OS_OTH_R) -*/ -const ( - OS_READ = 04 - OS_WRITE = 02 - OS_EX = 01 - OS_USER_SHIFT = 6 - OS_GROUP_SHIFT = 3 - OS_OTH_SHIFT = 0 - - OS_USER_R = OS_READ << OS_USER_SHIFT - OS_USER_W = OS_WRITE << OS_USER_SHIFT - OS_USER_X = OS_EX << OS_USER_SHIFT - OS_USER_RW = OS_USER_R | OS_USER_W - OS_USER_RWX = OS_USER_RW | OS_USER_X - - OS_GROUP_R = OS_READ << OS_GROUP_SHIFT - OS_GROUP_W = OS_WRITE << OS_GROUP_SHIFT - OS_GROUP_X = OS_EX << OS_GROUP_SHIFT - OS_GROUP_RW = OS_GROUP_R | OS_GROUP_W - OS_GROUP_RWX = OS_GROUP_RW | OS_GROUP_X - - OS_OTH_R = OS_READ << OS_OTH_SHIFT - OS_OTH_W = OS_WRITE << OS_OTH_SHIFT - OS_OTH_X = OS_EX << OS_OTH_SHIFT - OS_OTH_RW = OS_OTH_R | OS_OTH_W - OS_OTH_RWX = OS_OTH_RW | OS_OTH_X - - OS_ALL_R = OS_USER_R | OS_GROUP_R | OS_OTH_R - OS_ALL_W = OS_USER_W | OS_GROUP_W | OS_OTH_W - OS_ALL_X = OS_USER_X | OS_GROUP_X | OS_OTH_X - OS_ALL_RW = OS_ALL_R | OS_ALL_W - OS_ALL_RWX = OS_ALL_RW | OS_ALL_X -) - -// DispRights: display right. -//i.e: g.DispRights(g.OS_GROUP_RW | g.OS_USER_RW | g.OS_ALL_R) -> 664 -func DispRights(value int) { - fmt.Printf("%o\n", value) -} - -// ChangeFileOwner: set file owner to real user instead of root. -func ChangeFileOwner(filename string) (err error) { - var realUser *user.User - cmd := exec.Command("id", "-u") - output, _ := cmd.Output() - if string(output[:len(output)-1]) == "0" { - if realUser, err = user.Lookup(os.Getenv("SUDO_USER")); err == nil { - if uid, err := strconv.Atoi(realUser.Uid); err == nil { - if gid, err := strconv.Atoi(realUser.Gid); err == nil { - err = os.Chown(filename, uid, gid) - } - } - } - } - return err -} diff --git a/vendor/github.com/hfmrow/genLib/slices/sliceOperations.go b/vendor/github.com/hfmrow/genLib/slices/sliceOperations.go index b9c7daa..72488ec 100644 --- a/vendor/github.com/hfmrow/genLib/slices/sliceOperations.go +++ b/vendor/github.com/hfmrow/genLib/slices/sliceOperations.go @@ -11,9 +11,9 @@ import ( // GetStrIndex: Get index of a string in a slice, Return -1 if no entry found ... func GetStrIndex(slice []string, item string) int { - for i, _ := range slice { - if slice[i] == item { - return i + for idx, row := range slice { + if row == item { + return idx } } return -1 @@ -31,8 +31,8 @@ func IsExistSl(slice []string, item string) bool { // GetStrIndex2dCol: Search in 2d string slice if a column's value exist and return row number. func GetStrIndex2dCol(slice [][]string, value string, col int) int { - for idx, mainRow := range slice { - if mainRow[col] == value { + for idx, row := range slice { + if row[col] == value { return idx } } @@ -49,6 +49,16 @@ func IsExist2dCol(slice [][]string, value string, col int) bool { return false } +// IsExist2d Search in 2d string slice if a row exist (deepequal row). +func IsExist2d(slice [][]string, cmpRow []string) bool { + for _, mainRow := range slice { + if reflect.DeepEqual(mainRow, cmpRow) { + return true + } + } + return false +} + // CmpRemSl2d: Compare slice1 and slice2 if row exist on both, // the raw is removed from slice2 and result returned. func CmpRemSl2d(sl1, sl2 [][]string) (outSlice [][]string) { @@ -68,16 +78,6 @@ func CmpRemSl2d(sl1, sl2 [][]string) (outSlice [][]string) { return outSlice } -// IsExist2d Search in 2d string slice if a row exist. -func IsExist2d(slice [][]string, cmpRow []string) bool { - for _, mainRow := range slice { - if reflect.DeepEqual(mainRow, cmpRow) { - return true - } - } - return false -} - // CheckForDupSl2d: Return true if duplicated row is found func CheckForDupSl2d(sl [][]string) bool { for idx := 0; idx < len(sl)-1; idx++ { diff --git a/vendor/github.com/hfmrow/genLib/strings/cClass/characterClasses.go b/vendor/github.com/hfmrow/genLib/strings/cClass/characterClasses.go index 7bc6711..766ac0a 100644 --- a/vendor/github.com/hfmrow/genLib/strings/cClass/characterClasses.go +++ b/vendor/github.com/hfmrow/genLib/strings/cClass/characterClasses.go @@ -10,7 +10,7 @@ type cClass struct { regex string } -// Convert char to char classes. strictMode mean mostly classes is applied, if set to false, matching will be made with less precision. +// Convert char to char classes. strictMode means mostly classes is applied, if set to false, matching will be made with less precision. func charToCharClasses(inpString string, caseSensitive, strictMode bool) string { var charClassesCS []cClass var charClassesCI []cClass @@ -25,6 +25,7 @@ func charToCharClasses(inpString string, caseSensitive, strictMode bool) string cClass{regex: `[[:punct:]]`}, cClass{regex: `[[:graph:]]`}} charClassesCI = []cClass{ + // cClass{regex: `[[:alnum:]]`}, cClass{regex: `[[:alpha:]]`}, cClass{regex: `[[:digit:]]`}, cClass{regex: `[[:blank:]]`}, @@ -37,10 +38,13 @@ func charToCharClasses(inpString string, caseSensitive, strictMode bool) string cClass{regex: `[[:upper:]]`}, cClass{regex: `[[:lower:]]`}, cClass{regex: `[[:digit:]]`}, + cClass{regex: `[[:space:]]`}, cClass{regex: `[[:punct:]]`}} charClassesCI = []cClass{ + // cClass{regex: `[[:alnum:]]`}, cClass{regex: `[[:alpha:]]`}, cClass{regex: `[[:digit:]]`}, + cClass{regex: `[[:space:]]`}, cClass{regex: `[[:punct:]]`}} } var tmpString string diff --git a/vendor/github.com/hfmrow/genLib/strings/eol.go b/vendor/github.com/hfmrow/genLib/strings/eol.go index d199724..d2e532e 100644 --- a/vendor/github.com/hfmrow/genLib/strings/eol.go +++ b/vendor/github.com/hfmrow/genLib/strings/eol.go @@ -1,7 +1,7 @@ // eol.go /* -* Some end of line functions used by different OS +* Some end of line functions used by different OS */ package strings @@ -10,50 +10,14 @@ import ( "bytes" "errors" "io/ioutil" + "os" "runtime" - "strings" ) -var platforms = [][]string{ - {"darwin", "386", "\n"}, - {"darwin", "amd64", "\n"}, - {"dragonfly", "amd64", "\n"}, - {"freebsd", "386", "\n"}, - {"freebsd", "amd64", "\n"}, - {"freebsd", "arm", "\n"}, - {"linux", "386", "\n"}, - {"linux", "amd64", "\n"}, - {"linux", "arm", "\n"}, - {"linux", "arm64", "\n"}, - {"linux", "ppc64", "\n"}, - {"linux", "ppc64le", "\n"}, - {"linux", "mips", "\n"}, - {"linux", "mipsle", "\n"}, - {"linux", "mips64", "\n"}, - {"linux", "mips64le", "\n"}, - {"linux", "s390x", "\n"}, - {"nacl", "386", "\n"}, - {"nacl", "amd64p32", "\n"}, - {"nacl", "arm", "\n"}, - {"netbsd", "386", "\n"}, - {"netbsd", "amd64", "\n"}, - {"netbsd", "arm", "\n"}, - {"openbsd", "386", "\n"}, - {"openbsd", "amd64", "\n"}, - {"openbsd", "arm", "\n"}, - {"plan9", "386", "\n"}, - {"plan9", "amd64", "\n"}, - {"plan9", "arm", "\n"}, - {"solaris", "amd64", "\n"}, - {"windows", "386", "\r\n"}, - {"windows", "amd64", "\r\n"}} - // GetOsLineEnd: Get current OS line-feed func GetOsLineEnd() string { - for _, row := range platforms { - if row[0] == runtime.GOOS { - return row[2] - } + if "windows" == runtime.GOOS { + return "\r\n" } return "\n" } @@ -95,14 +59,6 @@ func SetTextEOL(inTextBytes []byte, eol string) (outTextBytes []byte, err error) return outTextBytes, nil } -// SplitAtEOL: split data to slice -func SplitAtEOL(data []byte) (outSlice []string) { - bLF := []byte{0x0A} - bCRLF := []byte{0x0D, 0x0A} - data = bytes.ReplaceAll(data, bCRLF, bLF) - return strings.Split(string(data), string(bLF)) -} - // GetFileEOL: Open file and get (CR, LF, CRLF) > string or get OS line end. func GetFileEOL(filename string) (outString string, err error) { textFileBytes, err := ioutil.ReadFile(filename) @@ -123,7 +79,7 @@ func SetFileEOL(filename, eol string) error { if err != nil { return err } - err = ioutil.WriteFile(filename, textFileBytes, 0644) + err = ioutil.WriteFile(filename, textFileBytes, os.ModePerm) if err != nil { return err } diff --git a/vendor/github.com/hfmrow/genLib/strings/formatText.go b/vendor/github.com/hfmrow/genLib/strings/formatText.go index 9c9d57b..356614f 100644 --- a/vendor/github.com/hfmrow/genLib/strings/formatText.go +++ b/vendor/github.com/hfmrow/genLib/strings/formatText.go @@ -27,9 +27,6 @@ func FormatTextParagraphFormatting(str string, max int, truncateWordOverMaxSize var tmpParag, tmpFinal, indent string eol := GetTextEOL([]byte(str)) var addLine = func() { - // if indent != "" { - // tmpFinal += indent - // } tmpFinal += FormatText(tmpParag, max, truncateWordOverMaxSize, indent) } if len(indentFirstLinetr) != 0 { @@ -49,8 +46,8 @@ func FormatTextParagraphFormatting(str string, max int, truncateWordOverMaxSize return strings.TrimSuffix(tmpFinal, eol) } -// FormatText: Format words text to fit (column/windows with limited width) "max" chars. -// An unwanted behavior may occur on string where word's length > max... +// FormatText: Format words text to fit (column/windows with limited width) "max" +// chars. An unwanted behavior may occur on string where word's length > max... func FormatText(str string, max int, truncateWordOverMaxSize bool, indenT ...string) string { var indent string if len(indenT) != 0 { @@ -106,9 +103,10 @@ func FormatText(str string, max int, truncateWordOverMaxSize bool, indenT ...str return "" } -// TruncateString: Reduce string length for display (prefix is separator like: "...", option=0 -> put separator at the begening -// of output string. Option=1 -> center, is where separation is placed. option=2 -> line feed, trunc the whole string using LF -// without shorting it. Max, is max char length of the output string. +// TruncateString: Reduce string length for display (prefix is separator like: "...", +// option=0 -> put separator at the begining of output string. Option=1 -> center, +// is where separation is placed. option=2 -> line feed, trunc the whole string +// using LF without shorting it. Max, is max char length of the output string. func TruncateString(inString, prefix string, max, option int) string { var center, cutAt bool var outText string diff --git a/vendor/github.com/hfmrow/genLib/strings/stringOperations.go b/vendor/github.com/hfmrow/genLib/strings/stringOperations.go index 80b6519..c73d2be 100644 --- a/vendor/github.com/hfmrow/genLib/strings/stringOperations.go +++ b/vendor/github.com/hfmrow/genLib/strings/stringOperations.go @@ -1,12 +1,18 @@ // stringOperations.go +/* + Part of H.F.M personal GenLib p akage (not published) + Copyright ©2020 H.F.M github.com/hfmrow + This program comes with absolutely no warranty. See the The MIT License (MIT) for details: + https://opensource.org/licenses/mit-license.php +*/ + package strings import ( "crypto/md5" - "errors" "fmt" - "html" + "log" "math/rand" "os" "path/filepath" @@ -14,10 +20,45 @@ import ( "strconv" "strings" "time" + "unicode" ) +// UnescapeToUtf8: Convert raw string that contain escaped values to +// utf-8 literal string. +func UnescapeToUtf8(inStr string) string { + + var escRawConv = map[string]string{ + `\n`: "\u000A", // line feed or newline + `\t`: "\u0009", // horizontal tab + `\"`: "\u0022", // double quote + `\r`: "\u000D", // carriage return + `\\`: "\u005c", // backslash + `\f`: "\u000C", // form feed + `\v`: "\u000b", // vertical tab + `\b`: "\u0008", // backspace + `\a`: "\u0007", // alert or bell (little joke) + } + for esc, uni := range escRawConv { + inStr = strings.ReplaceAll(inStr, esc, uni) + } + + return inStr +} + +// UnEscapeString: Convert raw string that contain escaped values to +// literal string. +func UnEscapeString(inString string) string { + inString = strings.ReplaceAll(inString, `"`, `\"`) + outString, err := strconv.Unquote(`"` + inString + `"`) + if err != nil { + log.Fatalf("UnEscapeString/Unquote: %v [%v]\n", inString, err) + } + return outString +} + // LowercaseAtFirst: true if 1st char is lowercase func LowercaseAtFirst(inString string) bool { + if len(inString) != 0 { charType, _ := regexp.Compile("[[:lower:]]") return charType.MatchString(inString[:1]) @@ -25,23 +66,78 @@ func LowercaseAtFirst(inString string) bool { return true } -// ToCamel: Turn string into camel case -func ToCamel(inString string, lowerAtFirst ...bool) (outString string) { - var laf bool - if len(lowerAtFirst) != 0 { - laf = lowerAtFirst[0] +// toCamel: Turn string into camelCase or PascalCase style (Go). +func ToCamel(inString string, lowerAtFirst ...bool) string { + + lAtFirst := false + regNonAlNum := regexp.MustCompile("[^[:alnum:]]+") + + if len(lowerAtFirst) > 0 && lowerAtFirst[0] { + lAtFirst = lowerAtFirst[0] } - nonAlNum := regexp.MustCompile(`[[:punct:][:space:]]`) - tmpString := nonAlNum.Split(inString, -1) + tmpString := regNonAlNum.Split(SeparateUpper(inString, " "), -1) + sl := make([]string, len(tmpString)) for idx, word := range tmpString { - if laf && idx < 1 { - outString += strings.ToLower(word) + if lAtFirst && idx < 1 { + sl[idx] = strings.ToLower(word) } else { - outString += strings.Title(word) + sl[idx] = strings.Title(word) } } - return outString + return strings.Join(sl, "") +} + +// toSnake: Turn string into snake_case style (C). +func ToSnake(inString string, allCaps ...bool) string { + return toSnakeOrKebab(inString, "_", allCaps...) +} + +// toKebab: Turn string into kebab-case style (URLs). +func ToKebab(inString string, allCaps ...bool) string { + return toSnakeOrKebab(inString, "-", allCaps...) +} + +// toSnakeOrKebab: +func toSnakeOrKebab(inString, sep string, allCaps ...bool) string { + + allC := false + regNonAlNum := regexp.MustCompile("[^[:alnum:]]+") + + if len(allCaps) > 0 { + allC = allCaps[0] + } + tmpString := regNonAlNum.Split(SeparateUpper(strings.TrimSpace(inString), " "), -1) + var sl []string + for _, word := range tmpString { + if len(word) > 0 { + if !allC { + sl = append(sl, strings.ToLower(word)) + } else { + sl = append(sl, strings.ToUpper(word)) + } + } + } + return strings.Join(sl, sep) +} + +// SeparateUpper: Add a 'sep' before each upper case char +// except the first. +func SeparateUpper(inString, sep string) string { + + var words []string + l := 0 + for s := inString; s != ""; s = s[l:] { + l = strings.IndexFunc(s[1:], unicode.IsUpper) + 1 + if l <= 0 { + l = len(s) + } + words = append(words, s[:l]) + } + if len(words) > 0 { + return strings.Join(words, sep) + } + return inString } // GenFileName: Generate a randomized file name @@ -62,10 +158,16 @@ func RemoveNonNum(inString string) string { return nonAlNum.ReplaceAllString(inString, "") } -// ReplaceSpace: replace all [[:space::]] with underscore "_" -func ReplaceSpace(inString string) string { +// ReplaceSpace: replace all [[:space::]] with 'repl' +func ReplaceSpace(inString, repl string) string { spaceRegex := regexp.MustCompile(`[[:space:]]`) - return spaceRegex.ReplaceAllString(inString, "_") + return spaceRegex.ReplaceAllString(inString, repl) +} + +// RemoveDupSpace: Remove duplicated space/tab in string +func RemoveDupSpace(inString string) string { + remInside := regexp.MustCompile(`[\s\p{Zs}]{2,}`) // to match 2 or more whitespace symbols inside a string + return strings.TrimSpace(remInside.ReplaceAllString(inString, " ")) } // RemoveSpace: remove all [[:space::]] @@ -74,21 +176,17 @@ func RemoveSpace(inString string) string { return spaceRegex.ReplaceAllString(inString, "") } -// ReplacePunct: replace all [[:punct::]] with underscore "_" -func ReplacePunct(inString string) string { +// ReplacePunct: replace all [[:punct::]] with 'repl' +func ReplacePunct(inString, repl string) string { spaceRegex := regexp.MustCompile(`[[:punct:]]`) - return spaceRegex.ReplaceAllString(inString, "_") + return spaceRegex.ReplaceAllString(inString, repl) } // SplitNumeric: Split and keep all numeric values in a string func SplitNumeric(inString string) (outText []string, err error) { toSplit := regexp.MustCompile(`[[:alpha:][:punct:]]`) - spaceSepared := string(toSplit.ReplaceAll([]byte(inString), []byte(" "))) - spaceSepared, err = TrimSpace(spaceSepared, "-c") - if err != nil { - return outText, err - } - outText = strings.Split(spaceSepared, " ") + spaceSepared := toSplit.ReplaceAllString(inString, " ") + outText = strings.Split(RemoveDupSpace(spaceSepared), " ") return outText, err } @@ -105,46 +203,46 @@ func TruncatePath(fullpath string, count ...int) (reduced string) { return fullpath } -// TrimSpace: Some multiple way to trim strings. cmds is optionnal or accept multiples args -func TrimSpace(inputString string, cmds ...string) (newstring string, err error) { - - osForbiden := regexp.MustCompile(`[<>:"/\\|?*]`) - remInside := regexp.MustCompile(`[\s\p{Zs}]{2,}`) // to match 2 or more whitespace symbols inside a string - remInsideNoTab := regexp.MustCompile(`[\p{Zs}]{2,}`) // (preserve \t) to match 2 or more space symbols inside a string - - if len(cmds) != 0 { - for _, command := range cmds { - switch command { - case "+h": // Escape html - inputString = html.EscapeString(inputString) - case "-h": // UnEscape html - inputString = html.UnescapeString(inputString) - case "+e": // Escape specials chars - inputString = fmt.Sprintf("%q", inputString) - case "-e": // Un-Escape specials chars - tmpString, err := strconv.Unquote(`"` + inputString + `"`) - if err != nil { - return inputString, err - } - inputString = tmpString - case "-w": // Change all illegals chars (for path in linux and windows) into "-" - inputString = osForbiden.ReplaceAllString(inputString, "-") - case "+w": // clean all illegals chars (for path in linux and windows) - inputString = osForbiden.ReplaceAllString(inputString, "") - case "-c": // Trim [[:space:]] and clean multi [[:space:]] inside - inputString = strings.TrimSpace(remInside.ReplaceAllString(inputString, " ")) - case "-ct": // Trim [[:space:]] and clean multi [[:space:]] inside (preserve TAB) - inputString = strings.Trim(remInsideNoTab.ReplaceAllString(inputString, " "), " ") - case "-s": // To match 2 or more whitespace leading/ending/inside a string (include \t, \n) - inputString = strings.Join(strings.Fields(inputString), " ") - case "-&": // Replace ampersand CHAR with ampersand HTML code - inputString = strings.Replace(inputString, "&", "&", -1) - case "+&": // Replace ampersand HTML code with ampersand CHAR - inputString = strings.Replace(inputString, "&", "&", -1) - default: - return inputString, errors.New("TrimSpace, " + command + ", does not exist") - } - } - } - return inputString, nil -} +// // TrimSpace: Some multiple way to trim strings. cmds is optionnal or accept multiples args +// func TrimSpace(inputString string, cmds ...string) (newstring string, err error) { + +// osForbiden := regexp.MustCompile(`[<>:"/\\|?*]`) +// remInside := regexp.MustCompile(`[\s\p{Zs}]{2,}`) // to match 2 or more whitespace symbols inside a string +// remInsideNoTab := regexp.MustCompile(`[\p{Zs}]{2,}`) // (preserve \t) to match 2 or more space symbols inside a string + +// if len(cmds) != 0 { +// for _, command := range cmds { +// switch command { +// case "+h": // Escape html +// inputString = html.EscapeString(inputString) +// case "-h": // UnEscape html +// inputString = html.UnescapeString(inputString) +// case "+e": // Escape specials chars +// inputString = fmt.Sprintf("%q", inputString) +// case "-e": // Un-Escape specials chars +// tmpString, err := strconv.Unquote(`"` + inputString + `"`) +// if err != nil { +// return inputString, err +// } +// inputString = tmpString +// case "-w": // Change all illegals chars (for path in linux and windows) into "-" +// inputString = osForbiden.ReplaceAllString(inputString, "-") +// case "+w": // clean all illegals chars (for path in linux and windows) +// inputString = osForbiden.ReplaceAllString(inputString, "") +// case "-c": // Trim [[:space:]] and clean multi [[:space:]] inside +// inputString = strings.TrimSpace(remInside.ReplaceAllString(inputString, " ")) +// case "-ct": // Trim [[:space:]] and clean multi [[:space:]] inside (preserve TAB) +// inputString = strings.Trim(remInsideNoTab.ReplaceAllString(inputString, " "), " ") +// case "-s": // To match 2 or more whitespace leading/ending/inside a string (include \t, \n) +// inputString = strings.Join(strings.Fields(inputString), " ") +// case "-&": // Replace ampersand CHAR with ampersand HTML code +// inputString = strings.Replace(inputString, "&", "&", -1) +// case "+&": // Replace ampersand HTML code with ampersand CHAR +// inputString = strings.Replace(inputString, "&", "&", -1) +// default: +// return inputString, errors.New("TrimSpace, " + command + ", does not exist") +// } +// } +// } +// return inputString, nil +// } diff --git a/vendor/github.com/hfmrow/genLib/tools/bench/bench.go b/vendor/github.com/hfmrow/genLib/tools/bench/bench.go index 3e09a23..c515f28 100644 --- a/vendor/github.com/hfmrow/genLib/tools/bench/bench.go +++ b/vendor/github.com/hfmrow/genLib/tools/bench/bench.go @@ -1,89 +1,127 @@ // bench.go /* - Measuring lapse (may be multiples) between operations. + Copyright ©2018-19 H.F.M + This program comes with absolutely no warranty. See the The MIT License (MIT) for details: + https://opensource.org/licenses/mit-license.php + + Measuring lapse (may be multiples) between operations. Usage: - bench := BenchNew(true) // true mean we want display results at Stop(). + bench := BenchNew(true) // true means we want display results at Stop(). bench.Lapse("first lapse") // Doing something ... bench.Lapse("Nth lapse") // Doing another thing ... bench.Stop // Display results - fmt.Println(bench.Average) // Mean time - fmt.Println(bench.NumTime) // numeric sliced version of results ... */ package bench import ( "fmt" + "strings" "time" ) type Bench struct { - lapse []time.Time - label []string - totalNs int64 - Results []string - Average string - Display bool - NumTime []numeric + Lapses []lapse + Average lapse + Total lapse + + lbl string + display bool } -func BenchNew(showResults bool) (bench *Bench) { +// BenchNew: default showResult = true +func BenchNew(showResults ...bool) (bench *Bench) { bench = new(Bench) - bench.Display = showResults + bench.display = true + if len(showResults) > 0 { + bench.display = showResults[0] + } return } - -type numeric struct { - Min, Sec, Ms, Ns int64 +func (b *Bench) Start(label ...string) { + b.Lapse(label...) } - func (b *Bench) Lapse(label ...string) { - b.lapse = append(b.lapse, time.Now()) + b.lbl = "Start" + if len(label) == 0 { - label = append(label, fmt.Sprintf("%d", len(b.lapse))) + b.lbl = fmt.Sprintf("%d", len(b.Lapses)) + } else { + b.lbl = strings.Join(label, " ") } - b.label = append(b.label, label...) + + b.Lapses = append(b.Lapses, lapse{ + Time: time.Now(), + Label: b.lbl}) +} + +func (b *Bench) NanoConv(nano int64) (min, sec, ms, ns int64) { + min = nano / 60000000000 + minr := nano % 60000000000 + sec = minr / 1000000000 + secr := minr % 1000000000 + ms = secr / 1000000 + ns = secr % 1000000 + return } func (b *Bench) Stop() { - b.Lapse("Total") - lapseCount := len(b.lapse) - 1 - b.Results = b.Results[:0] - if lapseCount > 1 { - for idx := 0; idx < len(b.lapse)-1; idx++ { - b.calculateLapse(idx, b.lapse[idx], b.lapse[idx+1]) - } + b.Lapse() + var means, nano int64 + nextLbl, tmpNextLbl := b.Lapses[0].Label, "" + for t := 1; t < len(b.Lapses); t++ { // Lapses calculation + tmpNextLbl = b.Lapses[t].Label // + b.Lapses[t].Label = nextLbl // Switching labels + nextLbl = tmpNextLbl // + nano = b.Lapses[t].Time.Sub(b.Lapses[t-1].Time).Nanoseconds() + means += nano + b.Lapses[t].toLapse(nano) } - b.calculateLapse(lapseCount, b.lapse[0], b.lapse[lapseCount]) - m, s, ms, ns := b.getMSmsnano(b.totalNs / int64(len(b.lapse))) - b.Average = fmt.Sprintf("%v m, %v s, %v ms, %v ns", m, s, ms, ns) + b.Lapses = b.Lapses[1:] + if len(b.Lapses)-1 > 0 { // Average calculation + + b.Average.toLapse(means / int64(len(b.Lapses))) + b.Average.Label = "Average" - b.totalNs = 0 - b.label = b.label[:0] - b.lapse = b.lapse[:0] + b.Total.toLapse(means) + b.Total.Label = "Total" + } + + if b.display { + b.disp() + } } -func (b *Bench) getMSmsnano(diff int64) (min, sec, ms, ns int64) { - min = (diff / 1000000000) / 60 - sec = diff/1000000000 - (min * 60) - ms = (diff / 1000000) - (sec * 1000) - ns = diff - ((diff / 1000000) * 1000000) - return min, sec, ms, ns +func (b *Bench) Reset() { + b.Lapses = b.Lapses[:0] } -func (b *Bench) calculateLapse(count int, start, stop time.Time) { - diff := stop.Sub(start).Nanoseconds() - m, s, ms, ns := b.getMSmsnano(diff) - b.NumTime = append(b.NumTime, numeric{Min: m, Sec: s, Ms: ms, Ns: ns}) - b.Results = append(b.Results, fmt.Sprintf("%s: %v m, %v s, %v ms, %v ns", - b.label[count], m, s, ms, ns)) - b.totalNs += diff - if b.Display { - fmt.Println(b.Results[len(b.Results)-1]) +func (b *Bench) disp() { + if len(b.Lapses) > 1 { + for _, lps := range b.Lapses { + fmt.Printf("%s: %s\n", lps.Label, lps.String) + } + } else { + fmt.Printf("%s\n", b.Lapses[0].String) } } + +type lapse struct { + Time time.Time + Elapsed time.Time + Min, Sec, Ms, Ns int64 + StringShort, String, Label string +} + +func (l *lapse) toLapse(nano int64) { + b := new(Bench) + l.Elapsed = time.Unix(0, nano) + l.Min, l.Sec, l.Ms, l.Ns = b.NanoConv(nano) + l.StringShort = fmt.Sprintf("%dm %d.%ds", l.Min, l.Sec, l.Ms) + l.String = fmt.Sprintf("%dm %ds %dms %dns", l.Min, l.Sec, l.Ms, l.Ns) +} diff --git a/vendor/github.com/hfmrow/genLib/tools/cLine.go b/vendor/github.com/hfmrow/genLib/tools/cLine.go index 24c961d..bd5c01e 100644 --- a/vendor/github.com/hfmrow/genLib/tools/cLine.go +++ b/vendor/github.com/hfmrow/genLib/tools/cLine.go @@ -1,29 +1,118 @@ package tools import ( + "bufio" "bytes" - "errors" "fmt" "io" "os" "os/exec" - "os/user" + "strings" ) -// ExecCommand: launch commandline application with arguments -// return terminal output and error. -func ExecCommand(commands string, args ...string) (output []byte, err error) { - output, err = exec.Command(commands, args...).CombinedOutput() - if len(output) > 0 { - if err != nil { - err = errors.New(fmt.Sprintf("Issue:\n%s\nTerminal:\n%s\n", err.Error(), string(output))) - } else { - err = errors.New(fmt.Sprintf("Terminal:\n%s\n", string(output))) +// ExecCommand: execute shell command and return stdout on +// success or stderr with non nil error on fail. +func ExecCommand(cmd []string) (string, error) { + var stdout, stderr bytes.Buffer + var err error + execCmd := exec.Command(cmd[0], cmd[1:]...) + execCmd.Stdout = &stdout + execCmd.Stderr = &stderr + err = execCmd.Run() + if err != nil { + if strings.Contains(stderr.String(), "already exists. Exiting.") { + err = os.ErrExist } + return fmt.Sprintf( + "stdout:\n%s\nstderr:\n%s\n", + stdout.String(), + stderr.String()), err } - return + return stdout.String(), nil } +// ExecCommandProgress: execute command and retrieve in realtime +// the last 'lineCount' lines from the stdout. +// NOTE: the 'progress' function must contain waiting operation. +func ExecCommandProgress(cmd []string, lineCount int, progress func(lines []string)) error { + var err, errLoop error + var stdout io.ReadCloser + var stderr bytes.Buffer + // build command + execCmd := exec.Command(cmd[0], cmd[1:]...) + execCmd.Stderr = &stderr + // stdout redirection + if stdout, err = execCmd.StdoutPipe(); err == nil { + // Assignate to a reader + buf := bufio.NewReader(stdout) + if err = execCmd.Start(); err != nil { + return err + } + // main loop that retrieve 'lineCount' lines on each + // occurrence. Reader position is kept to continue reading + // at next line on the next call until EOF or error occurs. + lines := make([]string, lineCount) + var lineBytes []byte + for { + for i := 0; i < lineCount; i++ { + lineBytes, _, errLoop = buf.ReadLine() + lines[i] = string(lineBytes) + } + if errLoop != nil { + break + } + progress(lines) + } + } + err = execCmd.Wait() + if err != nil { + return fmt.Errorf("%s", stderr.String()) + } + return nil +} + +// GetTerminalOut: retrieve terminal output via 'f' func. +func GetTerminalOut(f func(item string), cmd ...string) error { + out, err := ExecCommand(cmd) + tmpOut := strings.Split(string(out), "\n") + for _, val := range tmpOut { + if len(val) > 0 { + f(val) + } + } + return err +} + +// ExecCommand: launch commandline application with arguments +// return terminal output and error. +// func ExecCommand(infos string, cmds ...string) (outTerm []byte, err error) { +// execCmd := exec.Command(cmds[0], cmds[1:]...) +// execCmd.SysProcAttr = &syscall.SysProcAttr{Setpgid: true} +// outTerm, err = execCmd.CombinedOutput() +// if err != nil { +// err = errors.New( +// fmt.Sprintf("[%s][%s]\nCommand failed: %v\nTerminal:\n%v", +// infos, +// strings.Join(cmds, " "), +// err, +// string(outTerm))) +// return +// } +// return +// } + +// // GetTerminalOut: retrieve terminal output via 'f' func. +// func GetTerminalOut(f func(item string), cmd ...string) error { +// out, err := ExecCommand(cmd[0], cmd...) +// tmpOut := strings.Split(string(out), "\n") +// for _, val := range tmpOut { +// if len(val) > 0 { +// f(val) +// } +// } +// return err +// } + // CheckCmd: Check for command if exist func CheckCmd(cmd string) bool { _, err := exec.LookPath(cmd) @@ -56,14 +145,14 @@ func PrintColored(col int, inStr ...interface{}) { } // GetEnvVar: retrieve an environment variable value. -func GetEnvVar(envVar string) string { - return os.Getenv(envVar) -} +// func GetEnvVar(envVar string) string { +// return os.Getenv(envVar) +// } // GetUser: retrieve realUser and currentUser. -func GetUser() (realUser, currentUser *user.User, err error) { - if currentUser, err = user.Current(); err == nil { - realUser, err = user.Lookup(os.Getenv("SUDO_USER")) - } - return realUser, currentUser, err -} +// func GetUser() (realUser, currentUser *user.User, err error) { +// if currentUser, err = user.Current(); err == nil { +// realUser, err = user.Lookup(os.Getenv("SUDO_USER")) +// } +// return realUser, currentUser, err +// } diff --git a/vendor/github.com/hfmrow/genLib/tools/errors/errors.go b/vendor/github.com/hfmrow/genLib/tools/errors/errors.go index 58d3d03..2e75819 100644 --- a/vendor/github.com/hfmrow/genLib/tools/errors/errors.go +++ b/vendor/github.com/hfmrow/genLib/tools/errors/errors.go @@ -3,30 +3,41 @@ package errors import ( + "bufio" "fmt" "os" + "path/filepath" + "regexp" + "runtime" "runtime/debug" "strings" + "time" ) -type errorInf struct { - fn string // function - f string // file +// WarnCallerMess: return information about caller that can be interpreted and +// clickable inside LiteIde. Output format: "./main.go:114 Warning!," +func WarnCallerMess(skip ...int) string { + var s int = 2 + if len(skip) > 0 { + s = s + skip[0] + } + _, file, line, _ := runtime.Caller(s) // error callback type handling + return fmt.Sprintf("./%s:%d Warning!,", filepath.Base(file), line) } -// Check: Display errors in conveiniant way -// bool, "options" : [0] = exit on error -func Check(err error, options ...bool) (errFound bool) { - var stacked []errorInf - var outStrErr string - var brk bool - - switch len(options) { - case 1: - brk = options[0] - } +// Check: Display errors in convenient way with stack display +// "options" set to true -> exit on error. +// NOTICE: exit option must not be used if a "defer" function +// is initiated, otherwise, defer will never be applied ! +func Check(err error, options ...bool) (isError bool) { if err != nil { - errFound = true + type errorInf struct { + fn string // function + f string // file + } + var stacked []errorInf + var outStrErr string + isError = true stack := strings.Split(string(debug.Stack()), "\n") for errIdx := 5; errIdx < len(stack)-1; errIdx++ { stacked = append(stacked, errorInf{fn: stack[errIdx], f: strings.TrimSpace(stack[errIdx+1])}) @@ -39,10 +50,151 @@ func Check(err error, options ...bool) (errFound bool) { for errIdx := 1; errIdx < len(stacked); errIdx++ { outStrErr += fmt.Sprintf("[%s]*[%s]\n", strings.SplitN(stacked[errIdx].fn, "(", 2)[0], stacked[errIdx].f) } + fmt.Print(outStrErr) + if len(options) > 0 { + if options[0] { + os.Exit(1) + } + } + } + return +} + +// Get all informations on runtime from callers functions +// include memory, processor, Goroutine ... +type FuncTracer struct { + filename string + file *os.File + writer *bufio.Writer + frames *runtime.Frames + delay time.Duration + lastNow time.Time + FiltersInclude, + FiltersExclude []string +} + +func FuncTracerNew(filename string, delay float64) (*FuncTracer, error) { + var err error + ft := new(FuncTracer) + + ft.delay = time.Duration(float64(time.Second) * delay) + ft.lastNow = time.Now() + + ft.FiltersExclude = []string{"/usr/local/go/src/"} + + if ft.file, err = os.Create(filename); err == nil { + ft.writer = bufio.NewWriter(ft.file) + err = ft.Write(fmt.Sprintf("Time;Alloc;SysMem;NumGc;nCgoCall;nGortn;Cpu%%;Rss;Line;Func;File;\n")) + } + return ft, err +} + +func (ft *FuncTracer) memStats() *runtime.MemStats { + m := new(runtime.MemStats) + runtime.ReadMemStats(m) + return m +} + +func (ft *FuncTracer) Close() (err error) { + if err = ft.writer.Flush(); err == nil { + err = ft.file.Close() + } + return +} + +func (ft *FuncTracer) Write(line string) error { + count, err := ft.writer.WriteString(line) + if count != len(line) { + err = fmt.Errorf("[Missing written bytes], Recieved bytes: %d, Written: %d", len(line), count) + } + return err +} + +func (ft *FuncTracer) match(name string) bool { + for _, excl := range ft.FiltersExclude { + if strings.Contains(name, excl) { + return true + } } - fmt.Print(outStrErr) - if brk { - os.Exit(1) + return false +} + +// DebugFunc: Retrieve informations about the caller function +// include filename, function name and line number. +type DebugFunc struct { + Frames *runtime.Frames + + File, + Caller string + Line, + + Skip int +} + +func DebugFuncNew(skip ...int) (d *DebugFunc) { + d = new(DebugFunc) + d.Skip = 1 + if len(skip) > 0 { + d.Skip = skip[0] } + d.details() return } + +func (d *DebugFunc) details() (file, fnct string, line int, ok bool) { + + var pc uintptr + pc, d.File, d.Line, ok = runtime.Caller(d.Skip) + details := runtime.FuncForPC(pc) + if ok && details != nil { + d.Caller = details.Name() + } + return d.File, d.Caller, d.Line, ok +} + +func (d *DebugFunc) GetCurrentFunctionName() string { + // Skip GetCurrentFunctionName + return d.getFrame(d.Skip).Function +} + +func (d *DebugFunc) GetCallerFunctionName() string { + // Skip GetCallerFunctionName and the function to get the caller of + return d.getFrame(d.Skip + 1).Function +} + +func (d *DebugFunc) getFrame(skipFrames int) runtime.Frame { + // We need the frame at index skipFrames+2, since we never want runtime.Callers and getFrame + targetFrameIndex := skipFrames + 2 + + // Set size to targetFrameIndex+2 to ensure we have room for one more caller than we need + programCounters := make([]uintptr, targetFrameIndex+2) + n := runtime.Callers(0, programCounters) + + frame := runtime.Frame{Function: "unknown"} + if n > 0 { + d.Frames = runtime.CallersFrames(programCounters[:n]) + for more, frameIndex := true, 0; more && frameIndex <= targetFrameIndex; frameIndex++ { + var frameCandidate runtime.Frame + frameCandidate, more = d.Frames.Next() + if frameIndex == targetFrameIndex { + frame = frameCandidate + } + } + } + + return frame +} + +var nonAlNum = regexp.MustCompile(`[[:punct:][:alpha:]]`) + +// Get current timestamp +func timeStamp() string { + date := nonAlNum.ReplaceAllString(time.Now().Format(time.RFC3339), "")[:14] + return date[:8] + "-" + date[8:] +} + +// humanReadableSize: +func humanReadableSize(size interface{}) string { + + return fmt.Sprintf("%.2fMiB", float64(size.(uint64))/1024e3) +} diff --git a/vendor/github.com/hfmrow/gtk3Import/dialog/about/aboutDialog.go b/vendor/github.com/hfmrow/gtk3Import/dialog/about/aboutDialog.go deleted file mode 100644 index 890b250..0000000 --- a/vendor/github.com/hfmrow/gtk3Import/dialog/about/aboutDialog.go +++ /dev/null @@ -1,282 +0,0 @@ -// aboutDialog.go - -// Source file auto-generated on Thu, 03 Feb 2019 00:34:15 using Gotk3ObjHandler v1.0 ©2019 H.F.M - -package gtk3Import - -import ( - "bytes" - "compress/gzip" - "fmt" - "io" - "io/ioutil" - "log" - "reflect" - "regexp" - - "github.com/gotk3/gotk3/glib" - "github.com/gotk3/gotk3/gtk" - - pm "github.com/hfmrow/gtk3Import/pango" - p "github.com/hfmrow/gtk3Import/pixbuff" -) - -// Control over all used objects from glade. -var aboutDlgControlObj *aboutDlgControlsObj - -// Assets var declarations -var aboutboxGlade interface{} // gtk3Import/aboutBox.glade - -/******************************/ -/* Main structure Declaration */ -/******************************/ - -type aboutDlgControlsObj struct { - mainUiBuilder *gtk.Builder - AboutboxButtonOk *gtk.Button - AboutboxLabelAppName *gtk.Label - AboutboxLabelDescription *gtk.Label - AboutboxLabelLicense *gtk.Label - AboutboxLabelRepolink *gtk.Label - AboutboxLabelTxtDescription *gtk.Label - AboutboxLabelTxtSourceRepo *gtk.Label - AboutboxLabelVersion *gtk.Label - AboutboxLabelYearCreator *gtk.Label - AboutboxWindow *gtk.Window - AboutTopImage *gtk.Image -} - -/* -* Aboutbox implementation - */ -type AboutInfos struct { - titleBox string - AppName string - AppVers string - AppCreats string - YearCreat string - LicenseAbrv string - LicenseShort string - Repository string - Description string - imageTop interface{} - imageOkButton interface{} - AboutDialogBox *gtk.Window - ready bool - initialised bool -} - -func (ab *AboutInfos) InitFillInfos( - TitleBox, - AppName, - AppVers, - AppCreat, - YearCreat, - LicenseAbrv, - LicenseShort, - Repository, - Description string, - topImage, - okBtnIcon interface{}) { - ab.titleBox = TitleBox - ab.AppName = AppName - ab.AppVers = AppVers - ab.AppCreats = AppCreat - ab.YearCreat = "©" + YearCreat - ab.LicenseAbrv = LicenseAbrv - ab.LicenseShort = LicenseShort - ab.Repository = Repository - ab.Description = Description - ab.imageTop = topImage - ab.imageOkButton = okBtnIcon - ab.ready = true -} - -// Display label with lower size fonts -func markupLabel(label *gtk.Label, text string) { - pm := pm.PangoMarkup{} - pm.Init(text) - mtype := [][]string{{"fsz", "small"}, {"fgc", pm.Colors.Brown}} - pm.AddTypes(mtype...) - label.SetMarkup(pm.Markup()) -} - -// Display label with lower size fonts -func markupLabels(appName, repo, License string) (outAppName, outRepo, outLicense string) { - pm := pm.PangoMarkup{} - pm.Init(appName) - mtype := [][]string{{"fsz", "x-large"}, {"bld"}, {"fgc", pm.Colors.Brown}} - pm.AddTypes(mtype...) - outAppName = pm.Markup() - - pm.Init(repo) - mtype = [][]string{{"url", "https://" + repo}} - pm.AddTypes(mtype...) - outRepo = pm.Markup() - - outLicense = License // Search for http adress to be treated as clickable link - reg := regexp.MustCompile(`(http|https|ftp|ftps)\:\/\/[a-zA-Z0-9\-\.]+\.[a-zA-Z]{2,3}(\/\S*)?`) - indexes := reg.FindAllIndex([]byte(License), 1) - - if len(indexes) != 0 { - pm.Init(License) - pm.AddPosition([]int{indexes[0][0], indexes[0][1]}) - mtype = [][]string{{"url", reg.FindString(License)}} - pm.AddTypes(mtype...) - outLicense = pm.MarkupAtPos() - } - return outAppName, outRepo, outLicense -} - -func (infos *AboutInfos) Show() { - if infos.ready && !infos.initialised { - aboutDlgStart(infos.titleBox, 100, 100, true) - infos.AboutDialogBox = aboutDlgControlObj.AboutboxWindow - // aboutDlgControlObj.AboutboxWindow.SetResizable(false) - - name, repo, lic := markupLabels(infos.AppName, infos.Repository, infos.LicenseShort) - aboutDlgControlObj.AboutboxLabelAppName.SetMarkup("\n" + name) - aboutDlgControlObj.AboutboxLabelVersion.SetLabel(infos.AppVers + "\n") - aboutDlgControlObj.AboutboxLabelYearCreator.SetLabel(infos.YearCreat + " " + infos.AppCreats + "\n") - aboutDlgControlObj.AboutboxLabelDescription.SetLabel(infos.Description + "\n") - aboutDlgControlObj.AboutboxLabelDescription.SetProperty("wrap", true) - aboutDlgControlObj.AboutboxLabelRepolink.SetMarkup(repo + "\n") - aboutDlgControlObj.AboutboxLabelLicense.SetMarkup("\n" + lic + "\n") - /* Image/Icons assignation functions */ - p.SetImage(aboutDlgControlObj.AboutTopImage, infos.imageTop) - p.SetButtonImage(aboutDlgControlObj.AboutboxButtonOk, infos.imageOkButton) - infos.initialised = true - } - if infos.initialised { - infos.AboutDialogBox.Show() - } -} - -func (infos *AboutInfos) Hide() { - hideAboutDialogWindow() -} - -/******************************/ -/* Gtk3 Window Initialisation */ -/******************************/ -func aboutDlgStart(winTitle string, width, height int, center bool) { - // initMainGladeGuiVar: initialise embedded content. - initMainGladeGuiVar() - // Assign main ctrl objects - aboutDlgControlObj = new(aboutDlgControlsObj) - // buil interface - if newBuilder(aboutboxGlade) == nil { - // Parse Gtk objects - gladeObjParser() - // Objects Signals initialisations - signalsPropHandler() - // Set Window Properties - if center { - aboutDlgControlObj.AboutboxWindow.SetPosition(gtk.WIN_POS_CENTER) - } - aboutDlgControlObj.AboutboxWindow.SetTitle(winTitle) - aboutDlgControlObj.AboutboxWindow.SetSizeRequest(width, height) - } else { - log.Fatal("Builder initialisation error.") - } -} - -/***************************/ -/* Signals Implementations */ -/***************************/ -func signalsPropHandler() { - aboutDlgControlObj.AboutboxButtonOk.Connect("clicked", hideAboutDialogWindow) - aboutDlgControlObj.AboutboxWindow.Connect("delete-event", hideAboutDialogWindow) -} - -/***************************/ -/* Controls Initialisation */ -/***************************/ - -func gladeObjParser() { - aboutDlgControlObj.AboutboxButtonOk = loadObject("AboutboxButtonOk").(*gtk.Button) - aboutDlgControlObj.AboutboxLabelAppName = loadObject("AboutboxLabelAppName").(*gtk.Label) - aboutDlgControlObj.AboutboxLabelDescription = loadObject("AboutboxLabelDescription").(*gtk.Label) - aboutDlgControlObj.AboutboxLabelLicense = loadObject("AboutboxLabelLicense").(*gtk.Label) - aboutDlgControlObj.AboutboxLabelRepolink = loadObject("AboutboxLabelRepolink").(*gtk.Label) - aboutDlgControlObj.AboutboxLabelTxtDescription = loadObject("AboutboxLabelTxtDescription").(*gtk.Label) - aboutDlgControlObj.AboutboxLabelTxtSourceRepo = loadObject("AboutboxLabelTxtSourceRepo").(*gtk.Label) - aboutDlgControlObj.AboutboxLabelVersion = loadObject("AboutboxLabelVersion").(*gtk.Label) - aboutDlgControlObj.AboutboxLabelYearCreator = loadObject("AboutboxLabelYearCreator").(*gtk.Label) - aboutDlgControlObj.AboutboxWindow = loadObject("AboutboxWindow").(*gtk.Window) - aboutDlgControlObj.AboutTopImage = loadObject("AboutTopImage").(*gtk.Image) -} - -/*******************************************************/ -/* Functions declarations, used to initialize objects */ -/*****************************************************/ -// newBuilder: initialise builder with glade xml string -func newBuilder(varPath interface{}) (err error) { - if aboutDlgControlObj.mainUiBuilder, err = gtk.BuilderNew(); err == nil { - if Gtk3Interface, err := getBytesFromVarAsset(varPath); err == nil { - err = aboutDlgControlObj.mainUiBuilder.AddFromString(string(Gtk3Interface)) - } - } - return err -} - -// loadObject: Load GtkObject to be transtyped ... -func loadObject(name string) (newObj glib.IObject) { - var err error - newObj, err = aboutDlgControlObj.mainUiBuilder.GetObject(name) - if err != nil { - log.Panic(err) - } - return newObj -} - -// WindowDestroy is the triggered handler when closing/destroying the gui window. -func WindowDestroy() { - // Bye ... - gtk.MainQuit() -} - -// Signal handler delete_event (hidding window) -func hideAboutDialogWindow() bool { - if aboutDlgControlObj.AboutboxWindow.GetVisible() { - aboutDlgControlObj.AboutboxWindow.Hide() - } - return true -} - -// getBytesFromVarAsset: Get []byte representation from file or asset, depending on type -func getBytesFromVarAsset(varPath interface{}) (outBytes []byte, err error) { - // outBytes = new([]byte) - var rBytes []byte - switch reflect.TypeOf(varPath).String() { - case "string": - rBytes, err = ioutil.ReadFile(varPath.(string)) - case "[]uint8": - rBytes = varPath.([]byte) - } - return rBytes, err -} - -// HexToBytes: Convert Gzip Hex to []byte used for embedded binary in source code -func HexToBytes(varPath string, gzipData []byte) (outByte []byte) { - r, err := gzip.NewReader(bytes.NewBuffer(gzipData)) - if err == nil { - var bBuffer bytes.Buffer - _, err = io.Copy(&bBuffer, r) - if err == nil { - err = r.Close() - if err == nil { - return bBuffer.Bytes() - } - } - } - if err != nil { - fmt.Printf("An error occurred while reading: %s\n%v\n", varPath, err.Error()) - } - return outByte -} - -// initMainGladeGuiVar: initialise embedded content. -func initMainGladeGuiVar() { - aboutboxGlade = HexToBytes("aboutboxGlade", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\xec\x9a\x6d\x8f\x9b\x46\x10\xc7\xdf\xdf\xa7\xd8\xee\xab\x56\x95\xed\xb3\xaf\x49\xd3\xca\x26\x4a\x5b\x25\x3a\x29\x69\xa4\x9e\xdb\xaa\x52\x24\x6b\x81\x31\x4c\x58\x76\xc9\xee\xe0\x87\x7e\xfa\x08\x63\xeb\xcc\x05\x9f\x81\xcb\x45\x70\xe2\x9d\xbd\xcc\x1f\x66\x66\x7f\x33\x3c\xec\x4e\x5f\x6e\x62\xc9\x56\x60\x2c\x6a\x35\xe3\xe3\xe1\x25\x67\xa0\x3c\xed\xa3\x0a\x66\xfc\xef\xf9\xeb\xc1\x0b\xfe\xd2\xb9\x98\x7e\x37\x18\xb0\x37\xa0\xc0\x08\x02\x9f\xad\x91\x42\x16\x48\xe1\x03\xbb\x1a\x4e\x26\xc3\x31\x1b\x0c\x9c\x8b\x29\x2a\x02\xb3\x14\x1e\x38\x17\x8c\x4d\x0d\x7c\x4a\xd1\x80\x65\x12\xdd\x19\x0f\x28\xfa\x91\xdf\x5e\xe8\x6a\x38\x7e\xce\x47\x3b\x3b\xed\x7e\x04\x8f\x98\x27\x85\xb5\x33\xfe\x86\xa2\x7f\x51\xf9\x7a\xcd\x19\xfa\x33\xfe\xca\xd5\x29\xb9\x7a\xb3\x1f\xcb\x04\x8c\x4d\x13\xa3\x13\x30\xb4\x65\x4a\xc4\x30\xe3\x2b\xb4\xe8\x4a\xe0\xce\xdc\xa4\x30\x1d\x1d\x8e\x96\x1b\x7b\x42\x2d\x96\xda\x4b\x6d\x35\xf3\x10\x36\x89\x50\x7e\x35\xe3\x55\x1d\xe3\x58\xfb\x42\x56\x33\x5d\xef\xa2\x5f\x24\xda\x22\xa1\x56\xdc\xf1\x20\x4b\xf5\x39\x19\x6d\x13\x58\x84\xa8\x88\x3b\x3e\x0a\xa9\x83\x73\x02\x1b\x61\xb2\x20\x61\x23\x57\x98\xbd\xb0\xd4\x3d\x2f\x44\xe9\xe7\xbf\xb3\x93\x48\xe1\x41\xa8\xa5\x0f\x66\xb4\x37\x18\x1d\x59\xdc\xb1\xfe\x62\xba\x7f\xd3\x9b\x7c\xae\x5d\xbd\x19\xf3\x83\x5d\xcd\x59\x3e\x33\xd3\xaf\x85\xb4\x95\x34\xda\x20\x28\x12\x79\x96\x57\x60\x08\x3d\x21\x4b\x85\x85\xa8\xca\x23\xbb\x8e\x45\x00\x47\x1c\xcf\x75\x92\x0f\x1d\xcb\x1a\x04\xda\x34\xd8\x52\xbe\x85\xc4\xe0\x24\x51\x27\x5d\x6c\xa4\xb2\xa4\xbd\x88\x3b\x01\x45\x83\x18\xad\x45\x15\x0c\x30\xcb\x47\xb9\x7e\x3a\xca\x13\x5a\x18\x4b\x84\x17\xa1\x0a\xee\xbf\xce\x7d\x55\x78\x4a\xb3\x44\x29\xeb\x29\x6e\xab\xf1\xf2\x54\x00\x5f\x78\x5b\x28\x8c\xaa\x18\x1d\x17\xc8\xa4\x4d\xec\x54\x2e\x96\xf2\x48\xcb\xa3\x7d\x2b\x5c\x90\xc5\xe6\xbf\x1b\x7a\x95\x24\x7f\x8a\xf8\x6e\xed\x34\xce\xc1\x43\xf2\x50\xa6\x95\xb9\xdb\x64\x84\xb2\x52\x90\x70\x25\xcc\xf8\x16\x2c\x77\xf6\x8e\xd7\x39\xd9\xc7\xd4\x12\x2e\xb7\xe7\xea\xab\xbc\x46\x4e\xd7\xc9\x7d\xb5\x52\x3b\xe0\xf3\x05\xd3\xa8\x68\x4e\x14\x4e\x69\xf1\x7c\x0d\xac\xfe\xc9\x9f\x48\xba\x87\xd5\xde\xf1\x1e\xab\x22\x56\xe3\x76\x60\xf5\x1f\x08\xf3\xbb\x01\x41\xda\x74\x0f\xad\xcc\x79\x36\x62\x7b\xff\x7b\xc2\x8a\x84\x4d\xbe\x2d\x61\x37\x90\x08\xb3\xe3\x68\x47\x99\x3d\xfc\x1d\xb7\x95\xab\x58\x98\x00\xd5\x42\xc2\x92\xb8\xf3\xac\x81\xd2\x60\x10\x36\x94\x92\x4e\x9a\x09\x5d\x4d\xa4\xe3\x7b\xb5\x1d\x46\xf6\xaa\x1d\x4d\x71\xbe\xa1\x3f\xc0\x7a\x06\x13\xea\xe4\x2d\xf7\xc8\xf9\x5f\xfb\xae\x58\x44\xec\xa7\x76\x20\xf6\x54\xf8\x62\x04\x1b\x7a\x14\xc6\x4a\xbe\x2e\x19\x91\x9c\x4b\x41\x87\xc9\x7c\xd6\x9a\xe6\x77\xa3\x53\xe3\xc1\x5f\x90\xe8\xee\xb1\x99\xfb\xce\x0c\xec\x12\xab\xcd\xb6\xef\x80\x77\x38\x7b\xde\x0e\xce\x32\xbc\x24\xaa\xa8\x7b\x88\x65\x9e\xb3\xcc\xf5\x9e\xac\x22\x59\x3f\xb7\xe3\x8d\x63\xd2\xbf\x71\xf4\x6f\x1c\x15\x91\x7d\xd1\x8e\x66\xf8\x16\x3d\x50\xb6\x83\x1f\x8d\x3f\xa8\x79\x88\x96\x25\x46\x07\x46\xc4\xcc\xd3\x31\xd8\x7c\xd9\x55\xb8\x56\xcb\x94\x40\x6e\x99\xd2\x6c\x2d\x8c\x11\x8a\xb6\xc3\x0f\xea\x06\x80\x51\x08\x6c\x1e\x02\x7b\x77\x3d\x67\xfb\xd8\xd9\xf7\xef\xae\xe7\x3f\xb0\xa5\x36\xcc\x07\x12\x28\xed\xf0\x1b\x3d\x57\x82\x94\x98\x58\xfc\x1f\xb8\x13\xa3\xef\xcb\xa7\xf9\x78\xf9\x4b\x3b\x9a\xf3\x55\xdf\x9c\xfb\xe6\x5c\xf5\x1b\xf9\x57\x59\x7b\xe9\xce\xfa\xec\xf8\x91\xd7\x67\x53\x22\xad\x8a\x77\x9f\x7c\xec\x7d\x74\x66\xb9\xf6\xf4\x0d\xe0\x7d\x54\x35\xce\x35\xfa\x14\x2e\x0c\x7c\x4a\xc1\x52\x36\xb9\x97\x95\x57\xf1\x1f\xb8\x58\x5c\x47\x66\xc0\x03\x5c\x81\x5d\xf8\xb0\x14\xa9\xa4\x7a\xea\xc3\x2e\x05\x50\x7e\xdd\x2d\x0a\x35\x24\x85\x56\x35\xa9\xa9\xda\xb7\xa9\xba\xb2\x5d\x8b\xaa\x2b\x3a\xb4\xa7\xc9\x63\xed\x9c\xa8\xb5\x0d\xe0\x21\xa5\x39\x69\x5a\x9a\xc5\x18\x8f\x0e\xde\x1e\x98\x8e\x8e\x36\xa4\x7d\x0e\x00\x00\xff\xff\x82\x40\x8d\xbe\xe9\x26\x00\x00")) -} diff --git a/vendor/github.com/hfmrow/gtk3Import/dialog/aboutBox.go b/vendor/github.com/hfmrow/gtk3Import/dialog/aboutBox.go new file mode 100755 index 0000000..20dc529 --- /dev/null +++ b/vendor/github.com/hfmrow/gtk3Import/dialog/aboutBox.go @@ -0,0 +1,226 @@ +// aboutBox.go + +/* + Source file auto-generated on Sat, 19 Oct 2019 22:06:16 using Gotk3ObjHandler v1.3.9 ©2018-19 H.F.M + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2019 H.F.M - about box v2.0 + This program comes with absolutely no warranty. See the The MIT License (MIT) for details: + https://opensource.org/licenses/mit-license.php + +Usage: + About := new(AboutInfos) + About.InitFillInfos( + mainObjects.MainWindow, + "About "+Name, + Name, + Vers, + Creat, + YearCreat, + LicenseAbrv, + LicenseShort, + Repository, + Descr, + searchAndReplaceTop27,// As []byte or a filename + signSelect20) // As []byte or a filename + About.Width = 400 + + if err := About.Show(); err != nil { + log.Fatal(err) + } +*/ + +package gtk3Import + +import ( + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/gtk" + + glsg "github.com/hfmrow/genLib/strings" + + gipops "github.com/hfmrow/gtk3Import/pango/pangoSimple" + gipf "github.com/hfmrow/gtk3Import/pixbuff" +) + +/* +* Aboutbox implementation + */ + +type AboutInfos struct { + TitleWindow, + AppName, + AppVers, + AppCreats, + YearCreat, + LicenseAbrv, + LicenseShort, + Repository, + CssName, // Used to access dialog fromm CSS + Description string + + ImageTop, + ImageOkButton interface{} + + MaxCharWidthText, + ImageOkButtonSize, + Width, + HttpKeepFromEnd, // how many elements from end of http adress will be displayed in description and licence text. + Height int + + Resizable, + KeepAbove bool + + parentWindow *gtk.Window + DlgBoxStruct *DialogBoxStructure +} + +func AboutInfosNew(parentWindow *gtk.Window, titleWindow, appName, appVers, appCreat, yearCreat, licenseAbrv, + licenseShort, repository, description string, topImage, okBtnIcon interface{}) (ab *AboutInfos) { + ab = new(AboutInfos) + ab.InitFillInfos(parentWindow, titleWindow, appName, appVers, appCreat, yearCreat, + licenseAbrv, licenseShort, repository, description, topImage, okBtnIcon) + return +} + +// InitFillInfos: Initialize structure +func (ab *AboutInfos) InitFillInfos(parentWindow *gtk.Window, titleWindow, appName, appVers, appCreat, + yearCreat, licenseAbrv, licenseShort, repository, description string, topImage, okBtnIcon interface{}) { + + if ab.MaxCharWidthText == 0 { + ab.MaxCharWidthText = 80 + } + + ab.parentWindow = parentWindow + ab.TitleWindow = titleWindow + ab.AppName = appName + ab.AppVers = appVers + ab.AppCreats = appCreat + ab.YearCreat = "©" + yearCreat + ab.LicenseAbrv = licenseAbrv + ab.LicenseShort = licenseShort + ab.Repository = repository + ab.Description = glsg.FormatText(description, ab.MaxCharWidthText, true) + ab.ImageTop = topImage + ab.ImageOkButton = okBtnIcon + ab.CssName = "AboutBox" + ab.HttpKeepFromEnd = 2 + ab.Width = 425 + ab.Height = 100 + ab.ImageOkButtonSize = 24 + ab.Resizable = false +} + +// Show: Display about box +func (ab *AboutInfos) Show() (err error) { + if err = ab.build(); err == nil { + + ab.DlgBoxStruct.CssName = ab.CssName + ab.DlgBoxStruct.KeepAbove = ab.KeepAbove + // ab.DlgBoxStruct.WidgetExpend = true + ab.DlgBoxStruct.SetSize(ab.Width, ab.Height) + ab.DlgBoxStruct.Resizable = ab.Resizable + ab.DlgBoxStruct.IconsSize = ab.ImageOkButtonSize + ab.DlgBoxStruct.Run() + } + return +} + +// build: +func (ab *AboutInfos) build() (err error) { + var labelAppName, labelVersion, labelYearCreator, labelDescriptionLbl, + labelDescription, labelRepolinkLbl, labelRepolink, labelLicense *gtk.Label + var sep1, sep2, sep3 *gtk.Separator + var box *gtk.Box + var pixbuf *gdk.Pixbuf + var imageTop *gtk.Image + + ps := gipops.PangoSimpleNew() + pc := gipops.PangoColorNew() + + // Create new dialogbox structure + ab.DlgBoxStruct = DialogBoxNew(ab.parentWindow, box, ab.TitleWindow, "Ok") + ab.DlgBoxStruct.ButtonsImages = []interface{}{ab.ImageOkButton} + + // Add markup for some elements + name, repo, lic := doMarkup(ab.AppName, ab.Repository, ab.LicenseShort, ab.HttpKeepFromEnd) + + // Build widgets used to this About box window + pixbuf, _ = gipf.GetPixBuf(ab.ImageTop, nil) // If an error occurs pixbuf will be nul and imageTop too. So, no image displayed. + if imageTop, err = gtk.ImageNewFromPixbuf(pixbuf); err == nil { + if labelAppName, err = gtk.LabelNew(""); err == nil { + labelAppName.SetMarkup("\n" + name) + + if labelVersion, err = gtk.LabelNew(ab.AppVers + "\n"); err == nil { + if labelYearCreator, err = gtk.LabelNew(ab.YearCreat + " " + ab.AppCreats + "\n"); err == nil { + + if labelDescriptionLbl, err = gtk.LabelNew(""); err == nil { + labelDescriptionLbl.SetMarkup("\n" + ps.ApplyMarkup(``, `Description:`) + "") + + if labelDescription, err = gtk.LabelNew(""); err == nil { + labelDescription.SetMarkup(ps.MarkupHttpClickable(ab.Description+"\n", ab.HttpKeepFromEnd)) + + if labelRepolinkLbl, err = gtk.LabelNew(""); err == nil { + labelRepolinkLbl.SetMarkup("\n" + ps.ApplyMarkup(``, `Source repository:`) + "") + + if labelRepolink, err = gtk.LabelNew(""); err == nil { + labelRepolink.SetMarkup(repo + "\n") + + if labelLicense, err = gtk.LabelNew(""); err == nil { + labelLicense.SetMarkup("\n" + lic + "\n") + + if sep1, err = gtk.SeparatorNew(gtk.ORIENTATION_HORIZONTAL); err == nil { + if sep2, err = gtk.SeparatorNew(gtk.ORIENTATION_HORIZONTAL); err == nil { + if sep3, err = gtk.SeparatorNew(gtk.ORIENTATION_HORIZONTAL); err == nil { + + // Add some properties + ab.DlgBoxStruct.WidgetsProps.AddProperty("margin-top", 2) + ab.DlgBoxStruct.WidgetsProps.AddProperty("justify", gtk.JUSTIFY_CENTER) + ab.DlgBoxStruct.WidgetsProps.AddProperty("wrap", true) + + // Add widgets to the [DialogBox] structure + ab.DlgBoxStruct.Widgets = []gtk.IWidget{ + imageTop, + labelAppName, + labelVersion, + labelYearCreator, + sep1, + labelDescriptionLbl, + labelDescription, + labelRepolinkLbl, + labelRepolink, + sep2, + labelLicense, + sep3} + } + } + } + } + } + } + } + } + } + } + } + } + return +} + +func doMarkup(appName, repo, licence string, keepFromEnd ...int) (outAppName, outRepo, outLicense string) { + kfe := 2 + if len(keepFromEnd) > 0 { + kfe = keepFromEnd[0] + } + ps := gipops.PangoSimpleNew() + pc := gipops.PangoColorNew() + + outAppName = ps.ApplyMarkup(``, appName) + outAppName = ps.ApplyMarkupAgain(``, outAppName) + outAppName = ps.ApplyMarkupAgain(``, outAppName) + + outRepo = ps.ApplyMarkup(``, repo) + + outLicense = ps.MarkupHttpClickable(licence, kfe) + return +} diff --git a/vendor/github.com/hfmrow/gtk3Import/dialog/chooser/calendarChooser.go b/vendor/github.com/hfmrow/gtk3Import/dialog/chooser/calendarChooser.go new file mode 100755 index 0000000..64f999e --- /dev/null +++ b/vendor/github.com/hfmrow/gtk3Import/dialog/chooser/calendarChooser.go @@ -0,0 +1,306 @@ +// calendarChooser.go + +/// +build ignore + +/* + Source file auto-generated on Sat, 19 Oct 2019 22:06:16 using Gotk3ObjHandler v1.3.9 ©2018-19 H.F.M + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2019 H.F.M - calendar chooser v2.0 + This program comes with absolutely no warranty. See the The MIT License (MIT) for details: + https://opensource.org/licenses/mit-license.php + + This structure and methods give a convenient way to display an use a calendar window to + setting and retrieving calendar values. + +Usage: + var err error + var ok bool + + calData := new(gidgcr.CalendarData) + calData.FromLayout("2019.09.21.04.30.32") + + // []string{"Reset", "Ok"} means there is two button, "ok" will be emitted whether the button > 0 is clicked + cal := gidgcr.CalendarNew(mainObjects.MainWindow, calData, "Test calendar", logout48, []string{"Reset", "Ok"}, crossIcon48, tickIcon48) + cal.ButtonsSize = 24 + cal.DisplayTime = true + + ok, err = cal.Run() + if err != nil { + log.Fatalf("%s\n", err.Error()) + } + + if ok { + fmt.Printf("%#v\n", cal.Result.ToLayout()) + } + + - The layout parameter describes the format of a time value. + It should be the magical reference date: "Mon Jan 2 15:04:05 MST 2006" +*/ + +package gtk3Import + +import ( + "fmt" + "strconv" + "strings" + "time" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/gtk" + + gidg "github.com/hfmrow/gtk3Import/dialog" + gipf "github.com/hfmrow/gtk3Import/pixbuff" +) + +/* +* Calendar implementation + */ + +// This structure and methods give a convenient way to display and +// use a calendar window to setting and retrieving calendar values. +type Calendar struct { + TitleWindow string + ImageTop interface{} + LabelHour string + ButtonsImages []interface{} + ButtonsLabels []string + ButtonsSize int + ButtonOkPosition int // Specify the position of the "validate" button (start at 0 from left) + Width int + Height int + Resizable bool + KeepAbove bool + Result *CalendarData + DisplayTime bool + + parentWindow *gtk.Window + dbs *gidg.DialogBoxStructure + calendar *gtk.Calendar + spinH, spinM, spinS *gtk.SpinButton +} + +// CalendarNew: create new structure and initialize it. +func CalendarNew(parentWindow *gtk.Window, calData *CalendarData, titleWindow string, + topImage interface{}, buttons []string, imagesButtons ...interface{}) *Calendar { + cal := new(Calendar) + cal.Init(parentWindow, calData, titleWindow, topImage, buttons, imagesButtons...) + return cal +} + +// Init: Initialize structure +func (cal *Calendar) Init(parentWindow *gtk.Window, calData *CalendarData, titleWindow string, + topImage interface{}, buttons []string, imagesButtons ...interface{}) { + + cal.parentWindow = parentWindow + cal.TitleWindow = titleWindow + cal.ImageTop = topImage + cal.ButtonsLabels = buttons + cal.ButtonsImages = imagesButtons + + cal.Result = calData + cal.LabelHour = "Time" + cal.Width = 100 + cal.Height = 100 + cal.ButtonsSize = 18 + cal.Width = 425 + cal.Resizable = false +} + +// Show: Display about box +func (cal *Calendar) Run() (ok bool, err error) { + if err = cal.build(); err == nil { + cal.dbs.KeepAbove = cal.KeepAbove + cal.dbs.WidgetExpend = true + cal.dbs.SetSize(cal.Width, cal.Height) + cal.dbs.Resizable = cal.Resizable + cal.dbs.IconsSize = cal.ButtonsSize + // Get cal values if ok button is pressed + cal.dbs.ResponseCallBack = func(dlg *gtk.Dialog, resp int) { + if resp == cal.ButtonOkPosition { + cal.Result.ToCalData(cal) + ok = true + } + } + cal.dbs.Run() + } + return +} + +// build: +func (cal *Calendar) build() (err error) { + var boxHMS *gtk.Box + var lblHour *gtk.Label + var sep1, sep2, sep3 *gtk.Separator + var pixbuf *gdk.Pixbuf + var imageTop *gtk.Image + + // Create new dialogbox structure + cal.dbs = gidg.DialogBoxNew(cal.parentWindow, nil, cal.TitleWindow, cal.ButtonsLabels...) + cal.dbs.ButtonsImages = cal.ButtonsImages + + // Build widgets used to this Calendar window. + pixbuf, _ = gipf.GetPixBuf(cal.ImageTop) // If an error occurs pixbuf will be nul and imageTop too. So, no image displayed. + if imageTop, err = gtk.ImageNewFromPixbuf(pixbuf); err == nil { + if sep1, err = gtk.SeparatorNew(gtk.ORIENTATION_HORIZONTAL); err == nil { + if sep2, err = gtk.SeparatorNew(gtk.ORIENTATION_HORIZONTAL); err == nil { + if sep3, err = gtk.SeparatorNew(gtk.ORIENTATION_HORIZONTAL); err == nil { + if cal.calendar, err = gtk.CalendarNew(); err == nil { + // Validate for double-click on Day + cal.calendar.Connect("day-selected-double-click", func() { + cal.dbs.Dialog.Response(gtk.ResponseType(cal.ButtonOkPosition)) + }) + if boxHMS, err = gtk.BoxNew(gtk.ORIENTATION_HORIZONTAL, 2); err == nil { + if cal.spinH, err = gtk.SpinButtonNewWithRange(0, 23, 1); err == nil { + if cal.spinM, err = gtk.SpinButtonNewWithRange(0, 59, 1); err == nil { + if cal.spinS, err = gtk.SpinButtonNewWithRange(0, 59, 1); err == nil { + if lblHour, err = gtk.LabelNew(cal.LabelHour); err == nil { + // // Define default values for calendar + if cal.Result == nil { + cal.Result = CalendarDataNew() + } + // Set default values to calendar + cal.Result.ToCalendar(cal) + + // Add some properties + cal.dbs.WidgetsProps.AddProperty("margin-top", 1) + cal.dbs.WidgetsProps.AddProperty("margin-bottom", 1) + cal.dbs.WidgetsProps.AddProperty("margin-start", 2) + cal.dbs.WidgetsProps.AddProperty("margin-end", 2) + // cal.dbs.WidgetsProps.AddProperty("relief", gtk.RELIEF_NONE) + + // Add time controls if requested + if cal.DisplayTime { + boxHMS.PackStart(lblHour, true, true, 2) + boxHMS.Add(cal.spinH) + boxHMS.Add(cal.spinM) + boxHMS.Add(cal.spinS) + } + // Add widgets to the [DialogBox] structure + cal.dbs.Widgets = []gtk.IWidget{ + imageTop, + sep1, + cal.calendar, + sep2, + boxHMS, + sep3} + } + } + } + } + } + } + } + } + } + } + return +} + +type CalendarData struct { + Year, + Month, + Day, + Hour, + Min, + Sec int + BlankTime time.Time // Used when no time is defined + + layout string +} + +// CalendarDataNew: create a new calendarData structure +func CalendarDataNew() (calData *CalendarData) { + calData = new(CalendarData) + calData.Init(time.Now().UTC()) + return +} + +// Init: set values relatives "t" or time.Time{} if not specified. +func (calData *CalendarData) Init(t ...time.Time) { + + calData.BlankTime = time.Time{} // Init to nul date. means no date time was specified. + + teaTime := calData.BlankTime + if len(t) > 0 { + teaTime = t[0] + } + + calData.Year = teaTime.Year() + calData.Month = int(teaTime.Month()) + calData.Day = teaTime.Day() + calData.Hour = teaTime.Hour() + calData.Min = teaTime.Minute() + calData.Sec = teaTime.Second() + calData.layout = "2006.01.02.15.04.05" + +} + +// calDataToCalendar: +func (calData *CalendarData) ToCalendar(cal *Calendar) { + cal.calendar.SetProperty("year", uint(calData.Year)) + cal.calendar.SetProperty("month", uint(calData.Month-1)) + cal.calendar.SetProperty("day", uint(calData.Day)) + cal.spinH.SetValue(float64(calData.Hour)) + cal.spinM.SetValue(float64(calData.Min)) + cal.spinS.SetValue(float64(calData.Sec)) +} + +// calendarToCalData: +func (calData *CalendarData) ToCalData(cal *Calendar) { + Y, M, D := cal.calendar.GetDate() + calData.Year, calData.Month, calData.Day = int(Y), int(M)+1, int(D) + calData.Hour, calData.Min, calData.Sec = cal.spinH.GetValueAsInt(), cal.spinM.GetValueAsInt(), cal.spinS.GetValueAsInt() +} + +// ToTime: +func (calData *CalendarData) ToTime() (outTime time.Time) { + var err error + if outTime, err = time.Parse(calData.layout, calData.ToLayout()); err != nil { + outTime = calData.BlankTime + } + return +} + +// ToTimeAsUTC: convert given time to native UTC (based on local time zone), +// entered time H,M,S will be considered as UTC (useful for files time +// comparaison that always calculated using UTC). +func (calData *CalendarData) ToTimeAsUTC() (outTime time.Time) { + var err error + if outTime, err = time.Parse(calData.layout, calData.ToLayout()); err != nil { + outTime = calData.BlankTime + } else { + _, offset := outTime.Local().Zone() + outTime = time.Unix(outTime.Unix()-int64(offset), 0) + } + return +} + +// FromTime +func (calData *CalendarData) FromTime(inTime time.Time) { + calData.FromLayout(inTime.Format(calData.layout)) +} + +// ToLayout: fill missing char to complies with "2006.01.02.15.04.05", +// the magical reference format. +func (calData *CalendarData) ToLayout() (out string) { + return fmt.Sprintf("%4d.%02d.%02d.%02d.%02d.%02d", calData.Year, calData.Month, calData.Day, calData.Hour, calData.Min, calData.Sec) +} + +// FromLayout: build CalendarData using this layout: "2006.01.02.15.04.05" +func (calData *CalendarData) FromLayout(in string) (err error) { + sl := strings.Split(in, ".") + if calData.Year, err = strconv.Atoi(sl[0]); err == nil { + if calData.Month, err = strconv.Atoi(sl[1]); err == nil { + if calData.Day, err = strconv.Atoi(sl[2]); err == nil { + if calData.Hour, err = strconv.Atoi(sl[3]); err == nil { + if calData.Min, err = strconv.Atoi(sl[4]); err == nil { + calData.Sec, err = strconv.Atoi(sl[5]) + } + } + } + } + } + return +} diff --git a/vendor/github.com/hfmrow/gtk3Import/dialog/chooser/colorChooser.go b/vendor/github.com/hfmrow/gtk3Import/dialog/chooser/colorChooser.go index 00ed218..d499b83 100644 --- a/vendor/github.com/hfmrow/gtk3Import/dialog/chooser/colorChooser.go +++ b/vendor/github.com/hfmrow/gtk3Import/dialog/chooser/colorChooser.go @@ -4,49 +4,25 @@ package gtk3Import import ( "fmt" - "regexp" - "strconv" "github.com/gotk3/gotk3/gdk" "github.com/gotk3/gotk3/gtk" + + gipfmcrr "github.com/hfmrow/gtk3Import/pixbuff/misc/RGBA" ) /************************************ * ColorChooserDialog implementation. ************************************/ -// Convert gdk.RGBA to Hex string value: "#EF2929". -func ColGdkRGBA2Hex(value *gdk.RGBA) string { - // Convert int string value to Hex with 2 digits. - var build2DigitsHex = func(intValueStr string) string { - xi, _ := strconv.Atoi(intValueStr) - xs := fmt.Sprintf("%X", xi) - if len(xs) == 1 { - xs = "0" + xs - } - return xs - } - - regOne := regexp.MustCompile(`[()]`) - regTwo := regexp.MustCompile(`[,]`) - tmpStrSl := regOne.Split(value.String(), -1) - tmpStrSl = regTwo.Split(tmpStrSl[1], -1) - rr := build2DigitsHex(tmpStrSl[0]) - gg := build2DigitsHex(tmpStrSl[1]) - bb := build2DigitsHex(tmpStrSl[2]) - aa := "FF" - if len(tmpStrSl) > 3 { - aa = build2DigitsHex(tmpStrSl[3]) - } - return fmt.Sprintf("#%s%s%s%s", rr, gg, bb, aa) -} - // ColorChooserDialogAndGetHexValue: Open color chooser dialog and retrieve value. String return is // converted like this: "rgb(239,41,41)" to "#EF2929". func ColorChooserDialogAndGetFloat64Val(parentWindow *gtk.Window, title string, orgCol []float64) (outFloat64 []float64, outStr string) { + // Build Color chooser dialog en give it some basic parameters. if ColorChooserDialog, err := gtk.ColorChooserDialogNew(title, parentWindow); err == nil { if len(orgCol) != 0 { + RGBA := gdk.NewRGBA(orgCol...) fmt.Println(RGBA.String()) ColorChooserDialog.ColorChooser.SetRGBA(RGBA) @@ -57,11 +33,16 @@ func ColorChooserDialogAndGetFloat64Val(parentWindow *gtk.Window, title string, ColorChooserDialog.SetResizable(false) ColorChooserDialog.SetModal(true) ColorChooserDialog.ColorChooser.SetUseAlpha(true) + switch ColorChooserDialog.Run() { case gtk.RESPONSE_OK: + ColorChooserDialog.Close() - return ColorChooserDialog.ColorChooser.GetRGBA().Floats(), ColGdkRGBA2Hex(ColorChooserDialog.ColorChooser.GetRGBA()) + return ColorChooserDialog.ColorChooser.GetRGBA().Floats(), + gipfmcrr.ColGdkRGBA2Hex(ColorChooserDialog.ColorChooser.GetRGBA()) + case gtk.RESPONSE_CANCEL: + ColorChooserDialog.Close() } } diff --git a/vendor/github.com/hfmrow/gtk3Import/dialog/chooser/fileChooser.go b/vendor/github.com/hfmrow/gtk3Import/dialog/chooser/fileChooser.go index a74650a..2c5f5fa 100644 --- a/vendor/github.com/hfmrow/gtk3Import/dialog/chooser/fileChooser.go +++ b/vendor/github.com/hfmrow/gtk3Import/dialog/chooser/fileChooser.go @@ -3,7 +3,8 @@ package gtk3Import import ( - "fmt" + "errors" + "log" "os" "path/filepath" @@ -18,13 +19,17 @@ var FileChooserAction = map[string]gtk.FileChooserAction{ "select-folder": gtk.FILE_CHOOSER_ACTION_SELECT_FOLDER, "create-folder": gtk.FILE_CHOOSER_ACTION_CREATE_FOLDER, "open": gtk.FILE_CHOOSER_ACTION_OPEN, + "open-entry": gtk.FILE_CHOOSER_ACTION_SAVE, // Open with 'entry' like in 'save' dialog "save": gtk.FILE_CHOOSER_ACTION_SAVE, } +var UserAbortError = errors.New("Action aborted by user !") + // FileChooser: Display a file chooser dialog. // dlgType: "open", "save", "create-folder", "select-folder" as dlgType. // title = "": auto choice based on dialog type. // options: 1-keepAbove, 2-enablePreviewImages, 3-setModal, 4-askOverwrite +// Default: 1- true, 2- false, 3- true, 4- true func FileChooser(window *gtk.Window, dlgType, title, filename string, options ...bool) (outFilename string, result bool, err error) { var preview, folder bool var fileChooser *gtk.FileChooserDialog @@ -50,14 +55,18 @@ func FileChooser(window *gtk.Window, dlgType, title, filename string, options .. if len(title) == 0 { switch dlgType { + case "create-folder": title = "Create folder" folder = true + case "select-folder": title = "Select directory" folder = true - case "open": + + case "open", "open-entry": title = "Select file to open" + case "save": title = "Select file to save" } @@ -79,7 +88,7 @@ func FileChooser(window *gtk.Window, dlgType, title, filename string, options .. fileChooser.SetPreviewWidgetActive(true) if pixbuf.GetWidth() > 640 || pixbuf.GetHeight() > 480 { if pixbuf, err = gdk.PixbufNewFromFileAtScale(fc.GetFilename(), 200, 200, true); err != nil { - fmt.Printf("Image '%s' cannot be loaded, got error: %s", fc.GetFilename(), err.Error()) + log.Fatalf("Image '%s' cannot be loaded, got error: %s", fc.GetFilename(), err.Error()) } } previewImage.SetFromPixbuf(pixbuf) @@ -91,6 +100,8 @@ func FileChooser(window *gtk.Window, dlgType, title, filename string, options .. } } + fileChooser.SetFilename(filename) + if dlgType == "save" { fileChooser.SetCurrentName(filepath.Base(filename)) } @@ -106,10 +117,35 @@ func FileChooser(window *gtk.Window, dlgType, title, filename string, options .. fileChooser.SetSkipTaskbarHint(true) fileChooser.SetKeepAbove(kpAbove) - switch int(fileChooser.Run()) { - case -3: + if dlgType == "open-entry" { + fileChooser.SetDoOverwriteConfirmation(false) + fileChooser.SetCurrentName(filepath.Base(filename)) + } + + // fmt.Println(gtk.RESPONSE_ACCEPT) //-3 + // fmt.Println(gtk.RESPONSE_DELETE_EVENT) //-4 + // fmt.Println(gtk.RESPONSE_OK) //-5 + // fmt.Println(gtk.RESPONSE_CANCEL) //-6 + // fmt.Println(gtk.RESPONSE_CLOSE) //-7 + // fmt.Println(gtk.RESPONSE_YES) //-8 + + resp := fileChooser.Run() + + switch resp { + case gtk.RESPONSE_CANCEL, gtk.RESPONSE_DELETE_EVENT: + + result = false + err = UserAbortError + case gtk.RESPONSE_ACCEPT: + result = true outFilename = fileChooser.GetFilename() + + if dlgType == "open-entry" { + if _, err = os.Stat(outFilename); err != nil { + result = false + } + } } fileChooser.Destroy() diff --git a/vendor/github.com/hfmrow/gtk3Import/dialog/dialogBox.go b/vendor/github.com/hfmrow/gtk3Import/dialog/dialogBox.go index cd2cd9b..b9ab405 100644 --- a/vendor/github.com/hfmrow/gtk3Import/dialog/dialogBox.go +++ b/vendor/github.com/hfmrow/gtk3Import/dialog/dialogBox.go @@ -2,133 +2,237 @@ /* Create a Dialog, who accept GtkWidgets defined into structure. - The Structure contain all needed options to fill most of usages. + The Structure contain all needed options to fill most of usages, + including scrolling capabilities. Usage: if tw, err := gtk.TreeViewNew(); err == nil { dbs := gi.DialogBoxNew(MainWindow, gtk.DIALOG_DESTROY_WITH_PARENT, tw, "test Title", "No", "Yes", "why") dbs.ButtonsImages = dbs.ValuesToInterfaceSlice("assets/images/Sign-cancel-20.png", "", signSelect20) // "signSelect20" is []byte of image dbs.ScrolledArea = true - dbs.SetModal = false result=dbs.Run() // Do what you want with "result" } + + - A full examples: + - In file "aboutBox.go", that use the majority of the functionalities allowed by the code below. + - Another full example in file "calendar.go" */ package gtk3Import import ( - "fmt" "log" - "reflect" - "github.com/gotk3/gotk3/gdk" "github.com/gotk3/gotk3/gtk" "github.com/gotk3/gotk3/pango" - p "github.com/hfmrow/gtk3Import/pixbuff" + gipf "github.com/hfmrow/gtk3Import/pixbuff" + gitsws "github.com/hfmrow/gtk3Import/tools/widgets" ) // DialogBoxStructure: Wrap a Dialog with desired count of // buttons and widgets. The structure have defaults parameters type DialogBoxStructure struct { - BoxHAlign gtk.Align - BoxVAlign gtk.Align - BoxOrientation gtk.Orientation - BoxHExpand bool - BoxVExpand bool - WidgetExpend bool - WidgetFill bool - HSize, VSize int - SkipTaskbarHint bool - KeepAbove bool - Flag gtk.DialogFlags - SetModal bool - ScrolledArea bool - Buttons []string - ButtonsImages []interface{} // image representation from file or []byte, depending on type - Widgets []gtk.IWidget - Title, Text string - MarkupLabel bool - LabelLineWrap bool - Padding uint + BoxHAlign, + BoxVAlign gtk.Align + + BoxOrientation gtk.Orientation + + BoxHExpand, + BoxVExpand, + WidgetExpend, + SkipTaskbarHint, + KeepAbove, + Resizable, + ScrolledArea, + WidgetFill, + MarkupLabel, + LabelLineWrap bool + Padding uint + + width, + height, + posX, + posY, + Response, + IconsSize int + + Title, + Text, + CssName string + Buttons []string + ButtonsImages []interface{} // image representation from file or []byte, depending on type + Dialog *gtk.Dialog + ButtonReliefStyle gtk.ReliefStyle + Widgets []gtk.IWidget + WidgetsProps gitsws.WidgetProperties // each property applyed to each object + // Widgets below will be added after scrolled window without any property, + // they must be applyed mlanually on creation by the caller (useful to add + // some checkboxes or others after a TreeView). + WidgetsOutOfScrolledArea []gtk.IWidget + + // Function used when a button is clicked or window is closed + // This public function is wrapped with "internalResponseCallBack" + ResponseCallBack func(dlg *gtk.Dialog, response int) + + dialogFlag gtk.DialogFlags + + modal, buttonsWithImages bool - dialog *gtk.Dialog - label *gtk.Label - box *gtk.Box - scrolledWindow *gtk.ScrolledWindow - window *gtk.Window + + label *gtk.Label + box *gtk.Box + scrolledWindow *gtk.ScrolledWindow + window *gtk.Window + + internalResponseCallBack func(dlg *gtk.Dialog, response int) } // DialogBoxNew: Create a new structure to wrap a GtkDialog including // defaults parameters. "widget" can be "nul" to only display "text". -func DialogBoxNew(window *gtk.Window, flag gtk.DialogFlags, widget gtk.IWidget, title string, buttons ...string) *DialogBoxStructure { +func DialogBoxNew(window *gtk.Window, widget gtk.IWidget, title string, buttons ...string) *DialogBoxStructure { dbs := new(DialogBoxStructure) + dbs.DialogBoxInit(window, widget, title, buttons...) + return dbs +} + +func (dbs *DialogBoxStructure) DialogBoxInit(window *gtk.Window, widget gtk.IWidget, title string, buttons ...string) { dbs.window = window - dbs.Flag = flag + dbs.ButtonReliefStyle = gtk.RELIEF_NONE dbs.BoxHAlign = gtk.ALIGN_FILL dbs.BoxVAlign = gtk.ALIGN_FILL dbs.BoxOrientation = gtk.ORIENTATION_VERTICAL + dbs.dialogFlag = gtk.DIALOG_DESTROY_WITH_PARENT + dbs.width, dbs.height, + dbs.posX, dbs.posY = 640, 480, -1, -1 + dbs.IconsSize = 18 dbs.BoxHExpand = true dbs.BoxVExpand = true - dbs.HSize, dbs.VSize = 640, 480 + dbs.WidgetExpend = true + dbs.WidgetFill = true dbs.SkipTaskbarHint = true dbs.KeepAbove = true - dbs.Flag = flag - dbs.SetModal = false + dbs.Resizable = true dbs.Title = title dbs.LabelLineWrap = true - dbs.WidgetExpend = true - dbs.WidgetFill = true dbs.Padding = 0 + dbs.CssName = "CustomDialog" + dbs.ResponseCallBack = func(dlg *gtk.Dialog, response int) { // Init default callback + } + dbs.internalResponseCallBack = func(dlg *gtk.Dialog, response int) { // Init internal and wrap default callback + dbs.Response = response + dbs.ResponseCallBack(dlg, response) + } + if widget != nil { - dbs.Widgets = append(dbs.Widgets, widget) + dbs.Widgets = append([]gtk.IWidget{widget}, dbs.Widgets...) // Prepend } if len(buttons) == 0 { dbs.Buttons = []string{"Ok"} } else { dbs.Buttons = buttons } - return dbs } -// SliceToInterface: Convert String slice to interface, for simplify adding text rows -func (dbs *DialogBoxStructure) ValuesToInterfaceSlice(inSlice ...interface{}) (outIface []interface{}) { - for _, value := range inSlice { - outIface = append(outIface, value) - } +// Run: function return "value" < 0 for cross closed or >= 0 +// corresponding to buttons order representation starting with 0 at left. +// The dialog is destroyed at the end of process. +// Only the Modal Dialog window is allowed with this function. +// Use RunForResults() to allow non Modal usage. +func (dbs *DialogBoxStructure) Run() (value int) { + dbs.modal = true + dbs.buildDialog() + value = int(dbs.Dialog.Run()) + dbs.Dialog.Destroy() return } -// Run: calling Run function return "value" < 0 for cross closed or >= 0 -// corresponding to buttons order representation starting with 0 at left. -func (dbs *DialogBoxStructure) Run() (value int) { +// RunNonModal: allow non modal Dialog "respCallBack()" is executed on button click or exit window +func (dbs *DialogBoxStructure) RunNonModal(respCallBack ...func(dlg *gtk.Dialog, response int)) { + dbs.modal = false + if len(respCallBack) > 0 { + dbs.ResponseCallBack = respCallBack[0] + } + dbs.internalResponseCallBack = func(dlg *gtk.Dialog, response int) { // Default callback function + dbs.Response = response + dbs.ResponseCallBack(dlg, response) + dbs.Dialog.Destroy() + } + dbs.buildDialog() +} + +// SetSize: +func (dbs *DialogBoxStructure) SetSize(width, height int) { + dbs.width = width + dbs.height = height +} + +// SetPosition: +func (dbs *DialogBoxStructure) SetPosition(posX, posY int) { + dbs.posX = posX + dbs.posY = posY +} + +// GetSize: +func (dbs *DialogBoxStructure) GetSize() (width, height int) { + return dbs.Dialog.GetSize() +} + +// GetPosition: +func (dbs *DialogBoxStructure) GetPosition() (posX, posY int) { + return dbs.Dialog.GetPosition() +} + +// BringToFront: Set window position to be over all others windows +// without staying on top whether another window come to be selected. +func (dbs *DialogBoxStructure) BringToFront() { + dbs.Dialog.Deiconify() + dbs.Dialog.ShowAll() + dbs.Dialog.GrabFocus() +} + +// buildDialog: Create the dialog window with defined parameters. +func (dbs *DialogBoxStructure) buildDialog() (err error) { var btnObj *gtk.Button - var err error - // Build Objects - // if dbs.dialog, err = gtk.DialogNewWithButtons(dbs.Title, dbs.window, dbs.Flag); err == nil { // is waiting merging, pull request #425 - if dbs.dialog, err = gtk.DialogNew(); err == nil { - dbs.dialog.SetTransientFor(dbs.window) - dbs.dialog.SetModal(dbs.SetModal) + // Build Dialog + if dbs.modal { + dbs.dialogFlag = gtk.DIALOG_MODAL + } + if dbs.Dialog, err = gtk.DialogNewWithButtons(dbs.Title, dbs.window, dbs.dialogFlag); err == nil { + // Dialog options + dbs.Dialog.SetDefaultSize(dbs.width, dbs.height) - if dbs.label, err = gtk.LabelNew(""); err == nil { - dbs.box, err = dbs.dialog.GetContentArea() + if dbs.posX != -1 && dbs.posY != -1 { + dbs.Dialog.Move(dbs.posX, dbs.posY) + } + + dbs.Dialog.SetName(dbs.CssName) + dbs.Dialog.SetSkipTaskbarHint(dbs.SkipTaskbarHint) + dbs.Dialog.SetKeepAbove(dbs.KeepAbove) + dbs.Dialog.SetResizable(dbs.Resizable) + dbs.Dialog.SetModal(dbs.modal) + dbs.Dialog.Connect("response", dbs.internalResponseCallBack) // Default callback function + + if dbs.box, err = dbs.Dialog.GetContentArea(); err == nil { + if dbs.label, err = gtk.LabelNew(""); err == nil { + // Markup & Label options + dbs.label.SetSizeRequest(dbs.box.GetSizeRequest()) // Size, same as parent + dbs.label.SetLineWrap(dbs.LabelLineWrap) + dbs.label.SetLineWrapMode(pango.WRAP_WORD) + if dbs.MarkupLabel { + dbs.label.SetLabel(dbs.Text) + } else { + dbs.label.SetMarkup(dbs.Text) + } + } } - } - if err != nil { - log.Fatalf("Enable to create dialog: %s\n", err.Error()) } - // Markup & Label options - dbs.label.SetSizeRequest(dbs.box.GetSizeRequest()) - dbs.label.SetLineWrap(dbs.LabelLineWrap) - dbs.label.SetLineWrapMode(pango.WRAP_WORD) - if dbs.MarkupLabel { - dbs.label.SetLabel(dbs.Text) - } else { - dbs.label.SetMarkup(dbs.Text) + if err != nil { + return } // Control @@ -138,110 +242,54 @@ func (dbs *DialogBoxStructure) Run() (value int) { len(dbs.Buttons), len(dbs.ButtonsImages)) } - // Dialog options - dbs.dialog.SetTitle(dbs.Title) - dbs.dialog.SetSkipTaskbarHint(dbs.SkipTaskbarHint) - dbs.dialog.SetKeepAbove(dbs.KeepAbove) - // Box options dbs.box.SetHAlign(dbs.BoxHAlign) dbs.box.SetVAlign(dbs.BoxVAlign) dbs.box.SetOrientation(dbs.BoxOrientation) dbs.box.SetHExpand(dbs.BoxHExpand) dbs.box.SetVExpand(dbs.BoxVExpand) - dbs.box.SetSizeRequest(dbs.HSize, dbs.VSize) // Buttons for idxBtn, btnLbl := range dbs.Buttons { - if btnObj, err = dbs.dialog.AddButton(btnLbl, gtk.ResponseType(idxBtn)); err == nil { - if dbs.buttonsWithImages && len(dbs.ButtonsImages[idxBtn].(string)) != 0 { - p.SetButtonImage(btnObj, dbs.ButtonsImages[idxBtn]) + if btnObj, err = dbs.Dialog.AddButton(btnLbl, gtk.ResponseType(idxBtn)); err == nil { + if dbs.buttonsWithImages { + gipf.SetPict(btnObj, dbs.ButtonsImages[idxBtn], dbs.IconsSize) + btnObj.SetRelief(dbs.ButtonReliefStyle) } } } // Packing - if len(dbs.Text) != 0 { + if len(dbs.Text) > 0 { dbs.box.PackStart(dbs.label, dbs.WidgetExpend, dbs.WidgetFill, dbs.Padding) } - if len(dbs.Widgets) != 0 { + if len(dbs.Widgets) > 0 { if dbs.ScrolledArea { if dbs.scrolledWindow, err = gtk.ScrolledWindowNew(nil, nil); err == nil { - for _, wdg := range dbs.Widgets { - dbs.scrolledWindow.Add(wdg) - } - dbs.box.PackStart(dbs.scrolledWindow, dbs.WidgetExpend, dbs.WidgetFill, dbs.Padding) - } - } else { - for _, wdg := range dbs.Widgets { - dbs.box.PackStart(wdg, dbs.WidgetExpend, dbs.WidgetFill, dbs.Padding) + dbs.box.PackStart(dbs.scrolledWindow, dbs.WidgetExpend, dbs.WidgetFill, dbs.Padding) // Add ScrolledWindow to box + } else { + return } } - } - dbs.box.ShowAll() - dbs.dialog.ShowAll() - // The show must go on - value = int(dbs.dialog.Run()) - dbs.dialog.Destroy() - return value -} -/**********************/ -/* PixBuff functions */ -/********************/ - -// setButtonImage: Set Icon to GtkButton objects -func SetButtonImage(object *gtk.Button, varPath interface{}, size ...int) { - var image *gtk.Image - inPixbuf, err := GetPixBuff(varPath, size...) - if err == nil { - if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { - object.SetImage(image) - object.SetAlwaysShowImage(true) - return - } - } - if err != nil && len(varPath.(string)) != 0 { - fmt.Printf("SetButtonImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } -} + for _, wdg := range dbs.Widgets { + if wdg != nil { + dbs.WidgetsProps.PropsToWidget(wdg) // Set properties to widget -// GetPixBuff: Get gtk.Pixbuff image representation from file or []byte, depending on type -// size: resize height keeping porportions. 0 = no change -func GetPixBuff(varPath interface{}, size ...int) (outPixbuf *gdk.Pixbuf, err error) { - sze := 0 - if len(size) != 0 { - sze = size[0] - } - switch reflect.TypeOf(varPath).String() { - case "string": - outPixbuf, err = gdk.PixbufNewFromFile(varPath.(string)) - case "[]uint8": - pbLoader, err := gdk.PixbufLoaderNew() - if err == nil { - outPixbuf, err = pbLoader.WriteAndReturnPixbuf(varPath.([]byte)) + if dbs.ScrolledArea { + dbs.scrolledWindow.Add(wdg) // Add objects to ScrolledWindow + } else { + dbs.box.PackStart(wdg, dbs.WidgetExpend, dbs.WidgetFill, dbs.Padding) // Add objects to box + } + } + } + if len(dbs.WidgetsOutOfScrolledArea) > 0 { + for _, wdg := range dbs.WidgetsOutOfScrolledArea { + dbs.box.PackEnd(wdg, false, false, dbs.Padding) // Add objects to box + } } } - if err == nil && sze != 0 { - newWidth, wenHeight := normalizeSize(outPixbuf.GetWidth(), outPixbuf.GetHeight(), sze, 2) - outPixbuf, err = outPixbuf.ScaleSimple(newWidth, wenHeight, gdk.INTERP_BILINEAR) - } - return outPixbuf, err -} - -// NormalizeSize: compute new size with kept proportions based on defined format. -// format: 0 percent, 1 reducing width, 2 reducing height -func normalizeSize(oldWidth, oldHeight, newValue, format int) (outWidth, outHeight int) { - switch format { - case 0: // percent - outWidth = int((float64(oldWidth) * float64(newValue)) / 100) - outHeight = int((float64(oldHeight) * float64(newValue)) / 100) - case 1: // Width - outWidth = newValue - outHeight = int(float64(oldHeight) * (float64(newValue) / float64(oldWidth))) - case 2: // Height - outWidth = int(float64(oldWidth) * (float64(newValue) / float64(oldHeight))) - outHeight = newValue - } - return outWidth, outHeight + // The show must go on + dbs.Dialog.ShowAll() + return } diff --git a/vendor/github.com/hfmrow/gtk3Import/dialog/dialogError.go b/vendor/github.com/hfmrow/gtk3Import/dialog/dialogError.go index e54d165..5fa234b 100644 --- a/vendor/github.com/hfmrow/gtk3Import/dialog/dialogError.go +++ b/vendor/github.com/hfmrow/gtk3Import/dialog/dialogError.go @@ -7,30 +7,52 @@ import ( "os" "github.com/gotk3/gotk3/gtk" + gler "github.com/hfmrow/genLib/tools/errors" ) // DialogError: Display error messaged dialog returning true in error case. -// options: devMode, forceExit bool +// options: devMode, forceExit, markupEnabled bool +// NOTICE: exit option must not be used if a "defer" function is initiated ! func DialogError(window *gtk.Window, title, text string, err error, options ...bool) bool { - var devMode, forceExit = true, false + + var ( + devMode, + forceExit, + markupEnabled = true, false, false + ) + switch { case len(options) == 1: devMode = options[0] + case len(options) == 2: devMode = options[0] forceExit = options[1] - case len(options) > 2: - fmt.Printf("Wrong , arguments number, %v\n", options) + + case len(options) == 3: + devMode = options[0] + forceExit = options[1] + markupEnabled = options[2] + + case len(options) > 3: + fmt.Printf("DialogError: Bad, number of arguments, %v\n", options) os.Exit(1) + } + + dialogType := "error" + if markupEnabled { + dialogType = "errorWithMarkup" + } + if gler.Check(err) { if devMode { if DialogMessage( window, - "error", + dialogType, title, - fmt.Sprintf("\n\n"+text+":\n%s", err.Error()), + fmt.Sprintf("\n\n"+text+":\n\n%s", err.Error()), "", "Stop", "Continue") == 0 { @@ -39,9 +61,9 @@ func DialogError(window *gtk.Window, title, text string, err error, options ...b } else { DialogMessage( window, - "error", + dialogType, title, - fmt.Sprintf("\n\n"+text+":\n%s", err.Error()), + fmt.Sprintf("\n\n"+text+":\n\n%s", err.Error()), "", "Ok") if forceExit { diff --git a/vendor/github.com/hfmrow/gtk3Import/dialog/dialogMessage.go b/vendor/github.com/hfmrow/gtk3Import/dialog/dialogMessage.go index 6893885..4234523 100644 --- a/vendor/github.com/hfmrow/gtk3Import/dialog/dialogMessage.go +++ b/vendor/github.com/hfmrow/gtk3Import/dialog/dialogMessage.go @@ -16,7 +16,7 @@ import ( "github.com/gotk3/gotk3/gtk" - p "github.com/hfmrow/gtk3Import/pixbuff" + gipf "github.com/hfmrow/gtk3Import/pixbuff" ) /*************************** @@ -38,7 +38,7 @@ var dialogType = map[string]gtk.MessageType{ // DlgMessage: Display message dialog with multiples buttons. // return get <0 for cross closed or >-1 correspondig to buttons order representation. // dlgType accepte: "info", "warning", "question", "error", "other", by adding "WithMarkup" you enable it. -// iconFileName: can be a []byte or a string. "" = No image +// iconFileName: can be a []byte or a string. '' or nil -> No image func DialogMessage(window *gtk.Window, dlgType, title, text string, iconFileName interface{}, buttons ...string) (value int) { var msgDialog *gtk.MessageDialog var box *gtk.Box @@ -49,14 +49,19 @@ func DialogMessage(window *gtk.Window, dlgType, title, text string, iconFileName dialogType[dlgType], gtk.BUTTONS_NONE, "") + // Image - if len(iconFileName.(string)) != 0 { - if box, err = msgDialog.GetContentArea(); err == nil { - p.SetBoxImage(box, iconFileName) - } else { - fmt.Println(fmt.Sprintf("DlgMessage, could not get content area: %s", err)) + switch iconFileName.(type) { + case string: + if len(iconFileName.(string)) != 0 { + if box, err = msgDialog.GetContentArea(); err == nil { + gipf.SetPict(box, iconFileName, 18) + } else { + fmt.Println(fmt.Sprintf("DlgMessage, could not get content area: %s", err)) + } } } + msgDialog.SetSkipTaskbarHint(true) msgDialog.SetKeepAbove(true) // Check for link to make it clickable @@ -74,8 +79,10 @@ func DialogMessage(window *gtk.Window, dlgType, title, text string, iconFileName if err != nil { log.Fatal(btn+" button could not be created: ", err) } - parent, _ := button.GetParent() - parent.SetHAlign(gtk.ALIGN_END) + if iWidget, err := button.GetParent(); err == nil { + parent := iWidget.ToWidget() + parent.SetHAlign(gtk.ALIGN_END) + } button.SetSizeRequest(100, 1) button.SetBorderWidth(2) } diff --git a/vendor/github.com/hfmrow/gtk3Import/misc/clipboard.go b/vendor/github.com/hfmrow/gtk3Import/misc/clipboard.go index f382272..88eecd0 100644 --- a/vendor/github.com/hfmrow/gtk3Import/misc/clipboard.go +++ b/vendor/github.com/hfmrow/gtk3Import/misc/clipboard.go @@ -16,21 +16,33 @@ type Clipboard struct { Entity *gtk.Clipboard } -// Initialise clipboard +// ClipboardNew: Create new clipboard structure +func ClipboardNew() (c *Clipboard, err error) { + + c = new(Clipboard) + err = c.Init() + return +} + +// Init: Initialise clipboard func (c *Clipboard) Init() (err error) { + c.Entity, err = gtk.ClipboardGet(gdk.SELECTION_CLIPBOARD) - return err + return } +// GetText: Get text from clipboard func (c *Clipboard) GetText() (clipboardContent string, err error) { return c.Entity.WaitForText() } +// SetText: Set text to clipboard func (c *Clipboard) SetText(clipboardContent string) { c.Entity.SetText(clipboardContent) } -// Stores the current clipboard data somewhere so that it will stay around after the application has quit. +// Store: the current clipboard data somewhere so that it will stay around +// after the application has quit. func (c *Clipboard) Store() { c.Entity.Store() } diff --git a/vendor/github.com/hfmrow/gtk3Import/misc/cssWdgScnLoad.go b/vendor/github.com/hfmrow/gtk3Import/misc/cssWdgScnLoad.go index 55417dd..5f22a58 100644 --- a/vendor/github.com/hfmrow/gtk3Import/misc/cssWdgScnLoad.go +++ b/vendor/github.com/hfmrow/gtk3Import/misc/cssWdgScnLoad.go @@ -7,7 +7,6 @@ package gtk3Import import ( - "fmt" "io/ioutil" "github.com/gotk3/gotk3/gdk" @@ -16,17 +15,23 @@ import ( // CssWidgetLoad: Load or read from data and apply css to // widget if it's provided. Apply to screen otherwise. -func CssWdgScnLoad(filename string, wdgt ...*gtk.Widget) { - var err error - var cssProv *gtk.CssProvider +func CssWdgScnLoad(filename string, wdgt ...*gtk.Widget) (err error) { + + data := []byte(filename) - if bytes, err := ioutil.ReadFile(filename); err == nil { - filename = string(bytes) + if data, err = ioutil.ReadFile(filename); err == nil { + err = CssWdgScnBytes(data, wdgt...) } + return +} + +func CssWdgScnBytes(data []byte, wdgt ...*gtk.Widget) (err error) { + + var cssProv *gtk.CssProvider if cssProv, err = gtk.CssProviderNew(); err == nil { - if err = cssProv.LoadFromData(filename); err == nil { + if err = cssProv.LoadFromData(string(data)); err == nil { if len(wdgt) == 0 { var screen *gdk.Screen if screen, err = gdk.ScreenGetDefault(); err == nil { @@ -40,32 +45,5 @@ func CssWdgScnLoad(filename string, wdgt ...*gtk.Widget) { } } } - if err != nil { - fmt.Println(err.Error()) - } + return } - -/* - #MainTextViewEditorText * { - color: shade (#332211, 1.06); - background-color: #fefefe; - opacity: 0.99; -} - - #MainTextViewEditorText text selection { - background-color: #aaddff; - color:shade (#332211, 1.06); -} - - #MainTextViewEditorNumbers * { - color: shade (#0033ff, 1.06); - background-color: #eeeeee; - opacity: 0.99; -} - - #MainTextViewEditorNumbers text { - color: shade (#0022ff, 1.06); - background-color: #eeeeee; - opacity: 0.99; -} -*/ diff --git a/vendor/github.com/hfmrow/gtk3Import/misc/dnd.go b/vendor/github.com/hfmrow/gtk3Import/misc/dnd.go index f10735b..aec2eee 100644 --- a/vendor/github.com/hfmrow/gtk3Import/misc/dnd.go +++ b/vendor/github.com/hfmrow/gtk3Import/misc/dnd.go @@ -15,7 +15,6 @@ import ( "bytes" "log" "net/url" - "reflect" "strings" "github.com/gotk3/gotk3/gdk" @@ -23,65 +22,163 @@ import ( ) type DragNDropStruct struct { - Object interface{} // gtkObject that receive DND - FilesList *[]string // Contain the files list received - CallBack func() // Function called after receiving datas + // gtkObject that receive DND + Object interface{} + // Contain the files list received + FilesList *[]string + // Callback called after data was received. + callBackRecieveDone func() + // Callback called during data reception. If false is returned, the loop ends + callBackOnRecieve func(item interface{}, context *gdk.DragContext) bool + // To build dnd context + targets []gtk.TargetEntry } -// initDropSets: configure controls to receive dndcontent. -func DragNDropNew(objects interface{}, filesList *[]string, callBack func()) *DragNDropStruct { +// DragNDropNew: configure controls to receive dndcontent. "filesList" can be "nil" +func DragNDropNew(objects interface{}, filesList *[]string, + callBackRecieveDone func(), + callBackOnRecieve ...func(item interface{}, context *gdk.DragContext) bool) *DragNDropStruct { + ds := new(DragNDropStruct) ds.Object = objects - ds.CallBack = callBack - ds.FilesList = filesList + + ds.callBackOnRecieve = nil + if len(callBackOnRecieve) > 0 { + ds.callBackOnRecieve = callBackOnRecieve[0] + } + ds.callBackRecieveDone = callBackRecieveDone + + switch filesList { + case nil: + ds.FilesList = new([]string) + default: + ds.FilesList = filesList + } ds.init() return ds } +// Dispatching reciever object type (TreeView, Button ...) func (ds *DragNDropStruct) init() { - var targets []gtk.TargetEntry // Build dnd context - te, err := gtk.TargetEntryNew("text/uri-list", gtk.TARGET_OTHER_APP, 0) - if err != nil { - log.Fatal(err) + + // Build DnD context + targetTypes := []string{ + "x-special/mate-icon-list", + "text/uri-list", + "UTF8_STRING", + "COMPOUND_TEXT", + "TEXT", + "STRING", + "text/plain;charset=utf-8", + "text/plain"} + + for _, tType := range targetTypes { + te, err := gtk.TargetEntryNew(tType, gtk.TARGET_OTHER_APP, 0) + if err != nil { + log.Fatal(err) + } + ds.targets = append(ds.targets, *te) } - targets = append(targets, *te) - objType := reflect.TypeOf(ds.Object).String() - switch objType { - case "*gtk.TreeView": + + switch ds.Object.(type) { + + case *gtk.Window: + ds.Object.(*gtk.Window).DragDestSet( + gtk.DEST_DEFAULT_ALL, + ds.targets, + gdk.ACTION_COPY) + ds.Object.(*gtk.Window).Connect("drag-data-received", ds.dndFilesReceived) + + case *gtk.Entry: + ds.Object.(*gtk.Entry).DragDestSet( + gtk.DEST_DEFAULT_ALL, + ds.targets, + gdk.ACTION_COPY) + ds.Object.(*gtk.Entry).Connect("drag-data-received", ds.dndFilesReceived) + + case *gtk.EventBox: + ds.Object.(*gtk.EventBox).DragDestSet( + gtk.DEST_DEFAULT_ALL, + ds.targets, + gdk.ACTION_COPY) + ds.Object.(*gtk.EventBox).Connect("drag-data-received", ds.dndFilesReceived) + + case *gtk.TreeView: ds.Object.(*gtk.TreeView).DragDestSet( gtk.DEST_DEFAULT_ALL, - targets, + ds.targets, gdk.ACTION_COPY) ds.Object.(*gtk.TreeView).Connect("drag-data-received", ds.dndFilesReceived) - case "gtk.Button": + + case *gtk.TextView: + ds.Object.(*gtk.TextView).DragDestSet( + gtk.DEST_DEFAULT_ALL, + ds.targets, + gdk.ACTION_COPY) + ds.Object.(*gtk.TextView).Connect("drag-data-received", ds.dndFilesReceived) + + case *gtk.Button: ds.Object.(*gtk.Button).DragDestSet( gtk.DEST_DEFAULT_ALL, - targets, + ds.targets, gdk.ACTION_COPY) ds.Object.(*gtk.Button).Connect("drag-data-received", ds.dndFilesReceived) + + case *gtk.Image: + ds.Object.(*gtk.Image).DragDestSet( + gtk.DEST_DEFAULT_ALL, + ds.targets, + gdk.ACTION_COPY) + ds.Object.(*gtk.Image).Connect("drag-data-received", ds.dndFilesReceived) + + // Already handled natively !!! + // case *gtk.FileChooserButton: + // ds.Object.(*gtk.FileChooserButton).DragDestSet( + // gtk.DEST_DEFAULT_ALL, + // ds.targets, + // gdk.ACTION_COPY) + // ds.Object.(*gtk.FileChooserButton).Connect("drag-data-received", ds.dndFilesReceived) } } // ButtonInFilesReceived: Store in files list -func (ds *DragNDropStruct) dndFilesReceived(object interface{}, context *gdk.DragContext, x, y int, data_ptr uintptr, info, time uint) { +func (ds *DragNDropStruct) dndFilesReceived(object interface{}, context *gdk.DragContext, x, y int, selData *gtk.SelectionData, info, time uint) { + *ds.FilesList = (*ds.FilesList)[:0] - data := gtk.GetData(data_ptr) + data := selData.GetData() list := strings.Split(string(data), getTextEOL(data)) - for _, file := range list { - if len(file) != 0 { - if u, err := url.PathUnescape(file); err == nil { - *ds.FilesList = append(*ds.FilesList, strings.TrimPrefix(u, "file://")) + + for _, item := range list { + if len(item) != 0 { + + if ds.callBackOnRecieve != nil { + // For other type than string, callback permit to handle anything + if !ds.callBackOnRecieve(item, context) { + break + } + } else { + // Default handling as a string + if u, err := url.PathUnescape(item); err == nil { + + *ds.FilesList = append(*ds.FilesList, strings.TrimPrefix(u, "file://")) + } } } } - ds.CallBack() + if ds.callBackRecieveDone != nil { + ds.callBackRecieveDone() + } } // GetTextEOL: Get EOL from text bytes (CR, LF, CRLF) func getTextEOL(inTextBytes []byte) (outString string) { - bCR := []byte{0x0D} - bLF := []byte{0x0A} - bCRLF := []byte{0x0D, 0x0A} + + var ( + bCR = []byte{0x0D} + bLF = []byte{0x0A} + bCRLF = []byte{0x0D, 0x0A} + ) + switch { case bytes.Contains(inTextBytes, bCRLF): outString = string(bCRLF) diff --git a/vendor/github.com/hfmrow/gtk3Import/misc/popupMenu.go b/vendor/github.com/hfmrow/gtk3Import/misc/popupMenu.go index f894380..deebfad 100644 --- a/vendor/github.com/hfmrow/gtk3Import/misc/popupMenu.go +++ b/vendor/github.com/hfmrow/gtk3Import/misc/popupMenu.go @@ -1,136 +1,899 @@ // popupMenu.go /* - ©2019 H.F.M. MIT license + ©2019-21 H.F.M. MIT license - Make popup menu menu -*/ - -/* * * * * * -* Usage: * -* * * * * -func initPopup() { - mainOptions.popupMenu = new(PopupMenu) - mainOptions.popupMenu.WithIcons = false - mainOptions.popupMenu.LMB = false - mainOptions.popupMenu.PopupAddItem("_small", func() { assignTagToolButton("small") }, "") - mainOptions.popupMenu.PopupAddSeparator() - mainOptions.popupMenu.PopupAddItem("_medium", func() { assignTagToolButton("medium") }, "") - mainOptions.popupMenu.PopupAddSeparator() - mainOptions.popupMenu.PopupAddItem("_large", func() { assignTagToolButton("large") }, "") - mainOptions.popupMenu.PopupMenuBuild() -} - -SIGNAL: - - obj.Connect("button-press-event", ObjectButtonReleaseEvent) - -func ObjectButtonReleaseEvent(obj interface{}, event *gdk.Event) bool { - return mainOptions.PopupCheckRMB(event) -} + A simple builder for popup menu that can handle icons or not. */ package gtk3Import import ( + "fmt" "log" "github.com/gotk3/gotk3/gdk" "github.com/gotk3/gotk3/gtk" - p "github.com/hfmrow/gtk3Import/pixbuff" + gipf "github.com/hfmrow/gtk3Import/pixbuff" ) -type PopupMenu struct { - Menu *gtk.Menu - WithIcons bool // Adding icon or not - LMB bool // left mouse button instead of right - items []*gtk.MenuItem - separators []*gtk.SeparatorMenuItem +var ( // Lib mapping + HexToBytes = gipf.HexToBytes + GetPixBuf = gipf.GetPixBuf +) + +type ItemOptionsType int + +const ( + // Like GtkMenuItem + ITEM_OPT_NORMAL ItemOptionsType = 1 << 0 + // Like GtkCheckMenuItem + ITEM_OPT_CHECK ItemOptionsType = 1 << 1 + // Like GtkRadioMenuItem + ITEM_OPT_RADIO ItemOptionsType = 1 << 2 + // Like GtkSeparatorMenuItem + ITEM_OPT_SEPARATOR ItemOptionsType = 1 << 3 + // Add icon before GtkMenuItem + ITEM_OPT_ICON ItemOptionsType = 1 << 4 + // Disable the use of mnemonic + ITEM_OPT_NO_MNEMONIC ItemOptionsType = 1 << 5 + // Start a new group for GtkRadioButton(s) + ITEM_OPT_RADIO_NEW_GRP ItemOptionsType = 1 << 6 + // align label to other (adding blank icon) + ITEM_OPT_ALGN_LBL ItemOptionsType = 1 << 7 + // Box container alignement centered + ITEM_OPT_ALGN_BOX_CNTR ItemOptionsType = 1 << 8 +) + +// PopupMenuStruct: means that only standard widgets will be used +// If you want to add icons, prefere using next structure 'PopupMenuIconStruct' +type PopupMenuStruct struct { + Menu *gtk.Menu + // Indicate what type of function the window has. + WindowTypeHint gdk.WindowTypeHint // default (WINDOW_TYPE_HINT_POPUP_MENU) + // left mouse button instead of right + LMB, + // Reserving space to toggle (gtkCheckMenuItem/GtkRadioMenuItem) + ReserveToggleSize bool + // space separator for box (used when image is present) + BoxSpacing, + // Contain the index of last GtkMenuItem created + nextMenuItemIdx int + // Used to link radio button within a group + lastRadioMenuItmGroup *gtk.RadioMenuItem + // Where menuitems are stored + items []combObj + // Options that can be used with designed function + OPT_NORMAL, + OPT_CHECK, + OPT_RADIO, + OPT_SEPARATOR, + OPT_NO_MNEMONIC, + OPT_RADIO_NEW_GRP ItemOptionsType } -// PopupCheckRMB: Check if event come from right mouse button, and display popup if it is. -func (pop *PopupMenu) PopupCheckRMB(event *gdk.Event) bool { - mouseBTN := uint(3) - if pop.LMB { - mouseBTN = 1 +type combObj struct { + widget interface{} + tType ItemOptionsType + combined bool + xMenuItem *gtk.MenuItem + hasCallback bool +} + +func combObjNew() combObj { + c := new(combObj) + return *c +} + +/* + * Classic version + */ +// Retrieve current underlayed Gtk MenuItem +func (c *combObj) getMenuItem() *gtk.MenuItem { + obj := c.widget + menuItem, ok := obj.(*gtk.MenuItem) + if !ok { + log.Printf("[Warning!]: Unable to convert %T to (*gtk.MenuItem)", obj) } - eventButton := gdk.EventButtonNewFromEvent(event) - if eventButton.Button() == mouseBTN { - pop.Menu.PopupAtPointer(event) - return true // return true to stop propagate event. + // } + return menuItem +} + +// Retrieve current underlayed GtkCheckMenuItem +func (c *combObj) getCheckMenuItem() *gtk.CheckMenuItem { + obj := c.widget + menuItem, ok := obj.(*gtk.CheckMenuItem) + if !ok { + log.Printf("[Warning!]: Unable to convert %T to (*gtk.CheckMenuItem)", obj) } - return false // return false to propagate event. + return menuItem } -// PopupAddItem: Add items to menu. -func (pop *PopupMenu) PopupAddItem(lbl string, activateFunction interface{}, icon ...interface{}) (err error) { - var menuItem *gtk.MenuItem - var image interface{} - if len(icon) != 0 { - image = icon[0] +// Retrieve current underlayed GtkRadioMenuItem +func (c *combObj) getRadioMenuItem() *gtk.RadioMenuItem { + obj := c.widget + menuItem, ok := obj.(*gtk.RadioMenuItem) + if !ok { + log.Printf("[Warning!]: Unable to convert %T to (*gtk.RadioMenuItem)", obj) } - if pop.WithIcons { - menuItem, err = pop.menuItemNewWithImage(lbl, image) - } else { - menuItem, err = gtk.MenuItemNewWithMnemonic(lbl) + return menuItem +} + +// Retrieve current underlayed GtkSeparatorMenuItem +func (c *combObj) getSeparatorMenuItem() *gtk.SeparatorMenuItem { + obj := c.widget + menuItem, ok := obj.(*gtk.SeparatorMenuItem) + if !ok { + log.Printf("[Warning!]: Unable to convert %T to (*gtk.SeparatorMenuItem)", obj) + } + return menuItem +} + +// Retrieve current underlayed GtkMenuItem combined version (Icon) +func (c *combObj) getCombMenuItem() *gtk.MenuItem { + return c.xMenuItem +} + +/* + * Icon version + */ +// Retrieve current underlayed GtkLabel +func (c *combObj) getLabel() *gtk.Label { + obj := c.widget + menuItem, ok := obj.(*gtk.Label) + if !ok { + log.Printf("[Warning!]: Unable to convert %T to (*gtk.Label)", obj) } - if err == nil { - menuItem.Connect("activate", activateFunction.(func())) - pop.items = append(pop.items, menuItem) - pop.separators = append(pop.separators, nil) + return menuItem +} + +// Retrieve current underlayed GtkCheckButton +func (c *combObj) getCheckButton() *gtk.CheckButton { + obj := c.widget + menuItem, ok := obj.(*gtk.CheckButton) + if !ok { + log.Printf("[Warning!]: Unable to convert %T to (*gtk.CheckButton)", obj) } - return err + return menuItem } -// PopupAddSeparator: Add separator to menu. -func (pop *PopupMenu) PopupAddSeparator() (err error) { - if separatorItem, err := gtk.SeparatorMenuItemNew(); err == nil { - pop.items = append(pop.items, nil) - pop.separators = append(pop.separators, separatorItem) +// Retrieve current underlayed GtkRadioButton +func (c *combObj) getRadioButton() *gtk.RadioButton { + obj := c.widget + menuItem, ok := obj.(*gtk.RadioButton) + if !ok { + log.Printf("[Warning!]: Unable to convert %T to (*gtk.RadioButton)", obj) } - return err + return menuItem } -// PopupMenuBuild: Build popupmenu. -func (pop *PopupMenu) PopupMenuBuild() *gtk.Menu { +// PopupMenuNew: return a new PopupMenuStruct structure +func PopupMenuStructNew() (pop *PopupMenuStruct) { + pop = new(PopupMenuStruct) + + pop.lastRadioMenuItmGroup = nil + pop.ReserveToggleSize = false + pop.WindowTypeHint = gdk.WINDOW_TYPE_HINT_POPUP_MENU + + pop.OPT_NORMAL = ITEM_OPT_NORMAL + pop.OPT_CHECK = ITEM_OPT_CHECK + pop.OPT_RADIO = ITEM_OPT_RADIO + pop.OPT_SEPARATOR = ITEM_OPT_SEPARATOR + pop.OPT_NO_MNEMONIC = ITEM_OPT_NO_MNEMONIC + pop.OPT_RADIO_NEW_GRP = ITEM_OPT_RADIO_NEW_GRP + return +} + +// Retrieve current GtkMenuItem +func (pop *PopupMenuStruct) GetMenuItemCurrent() *gtk.MenuItem { + return pop.items[pop.nextMenuItemIdx-1].getMenuItem() +} + +// Retrieve current GtkCheckMenuItem +func (pop *PopupMenuStruct) GetCheckMenuItemCurrent() *gtk.CheckMenuItem { + return pop.items[pop.nextMenuItemIdx-1].getCheckMenuItem() +} + +// Retrieve current GtkRadioMenuItem +func (pop *PopupMenuStruct) GetRadioMenuItemCurrent() *gtk.RadioMenuItem { + return pop.items[pop.nextMenuItemIdx-1].getRadioMenuItem() +} + +// Retrieve current GtkSeparatorMenuItem +func (pop *PopupMenuStruct) GetSeparatorMenuItemCurrent() *gtk.SeparatorMenuItem { + return pop.items[pop.nextMenuItemIdx-1].getSeparatorMenuItem() +} + +// Retrieve the IMenuItem at 'idx' require type assertion +func (pop *PopupMenuStruct) GetIMenuItemIdx(idx int) gtk.IMenuItem { + return pop.items[idx].widget.(gtk.IMenuItem) +} + +func (pop *PopupMenuStruct) buildXMenuItem(lbl string, ico, activateFunction interface{}, opt ItemOptionsType) (*combObj, error) { + var ( + cmbo combObj + err error + menuItem *gtk.MenuItem + checkMenuItem *gtk.CheckMenuItem + radioMenuItem *gtk.RadioMenuItem + separatorMenuItem *gtk.SeparatorMenuItem + ) + switch { + case opt&ITEM_OPT_SEPARATOR != 0: + separatorMenuItem, err = gtk.SeparatorMenuItemNew() + if err == nil { + if len(lbl) > 0 { + separatorMenuItem.SetLabel(lbl) + } + cmbo = combObj{widget: separatorMenuItem, tType: ITEM_OPT_SEPARATOR, combined: false} + return &cmbo, nil + } + case opt&ITEM_OPT_CHECK != 0: + if opt&ITEM_OPT_NO_MNEMONIC != 0 { + checkMenuItem, err = gtk.CheckMenuItemNewWithLabel(lbl) + } else { + checkMenuItem, err = gtk.CheckMenuItemNewWithMnemonic(lbl) + } + if err == nil { + switch f := activateFunction.(type) { + case func(c *gtk.CheckMenuItem): + checkMenuItem.Connect("activate", f) + default: + return nil, fmt.Errorf( + "AddItem: callback for %T require 'func(c *gtk.CheckMenuItem)' type!", + checkMenuItem) + } + cmbo = combObj{widget: checkMenuItem, tType: ITEM_OPT_CHECK, combined: false} + return &cmbo, nil + } + return nil, err + + case opt&ITEM_OPT_RADIO != 0, opt&ITEM_OPT_RADIO_NEW_GRP != 0: + if opt&ITEM_OPT_NO_MNEMONIC != 0 { + radioMenuItem, err = gtk.RadioMenuItemNewWithLabel(nil, lbl) + } else { + radioMenuItem, err = gtk.RadioMenuItemNewWithMnemonic(nil, lbl) + } + if err == nil { + switch f := activateFunction.(type) { + case func(r *gtk.RadioMenuItem): + radioMenuItem.Connect("activate", f) + default: + return nil, fmt.Errorf( + "AddItem: callback for %T require 'func(r *gtk.RadioMenuItem)' type!", + radioMenuItem) + } + + cmbo = combObj{widget: radioMenuItem, tType: ITEM_OPT_RADIO, combined: false} + return &cmbo, nil + } + case opt&ITEM_OPT_NORMAL != 0: + if opt&ITEM_OPT_NO_MNEMONIC != 0 { + menuItem, err = gtk.MenuItemNewWithLabel(lbl) + } else { + menuItem, err = gtk.MenuItemNewWithMnemonic(lbl) + } + if err == nil { + if activateFunction != nil { + switch f := activateFunction.(type) { + case func(): + menuItem.Connect("activate", f) + } + } + cmbo = combObj{widget: menuItem, tType: ITEM_OPT_NORMAL, combined: false} + return &cmbo, nil + } + default: + return nil, fmt.Errorf("AddItemWithOptions: Unable to define choosen option(s)") + } + + return nil, err +} + +// AddItem: Add item to menu. This version handle +// checkbutton/radiobutton with groups and classic labels +func (pop *PopupMenuStruct) AddItem( + lbl string, activateFunction interface{}, options ...interface{}) (widgetIdx int, err error) { + + var ( + opt ItemOptionsType = ITEM_OPT_NORMAL // Default Option + icon interface{} + ) + switch len(options) { + case 1: + opt = opt | options[0].(ItemOptionsType) + icon = nil + } + + cmbo, err := pop.buildXMenuItem(lbl, icon, activateFunction, opt) + if err != nil { + return -1, err + } + pop.items = append(pop.items, *cmbo) + + // Handling RadioMenuItem groups + if opt&ITEM_OPT_RADIO != 0 || opt&ITEM_OPT_RADIO_NEW_GRP != 0 { + if opt&ITEM_OPT_RADIO_NEW_GRP != 0 { + pop.lastRadioMenuItmGroup = cmbo.getRadioMenuItem() + } + if pop.lastRadioMenuItmGroup == nil { + pop.lastRadioMenuItmGroup = cmbo.getRadioMenuItem() + } + cmbo.getRadioMenuItem().JoinGroup(pop.lastRadioMenuItmGroup) + } + + pop.nextMenuItemIdx++ + return pop.nextMenuItemIdx - 1, err +} + +// MenuBuild: Build popupmenu. +func (pop *PopupMenuStruct) MenuBuild() *gtk.Menu { var err error if pop.Menu, err = gtk.MenuNew(); err == nil { - for idx, menuItem := range pop.items { - if pop.separators[idx] != nil { - pop.Menu.Append(pop.separators[idx]) + pop.Menu = appendToExistingMenu(pop.items, pop.Menu) + } else { + log.Println("Popup menu creation error !") + return nil + } + pop.Menu.SetProperty("reserve_toggle_size", pop.ReserveToggleSize) + pop.Menu.SetProperty("menu_type_hint", pop.WindowTypeHint) + return pop.Menu +} + +// CheckRMB: Check whether an event comes from the right button of the +// mouse and display the popup if it is the case at the mouse position. +func (pop *PopupMenuStruct) CheckRMB(obj interface{}, event *gdk.Event) bool { + return checkRMB(pop.LMB, pop.Menu, event) +} + +// CheckRMBFromTreeView: May be directly used as callback function for +// TreeView' "button-press-event" signal, considere to initialize the +// popup menu before setting this function as callback. Otherwise, the +// call will generate error "nil pointer ..." +func (pop *PopupMenuStruct) CheckRMBFromTreeView(tv *gtk.TreeView, event *gdk.Event) bool { + return checkRMBFromTreeView(pop.LMB, pop.Menu, tv, event) +} + +// AppendToExistingMenu: append "MenuItems" to an existing "*gtk.Menu" +// Useful when you want to just add some entries to the context menu that +// already exist in a gtk.TextView or gtk.Entry by using "populate-popup" +// signal. Notice: GtkWidget > GtkMenu: +// menu := >k.Menu{gtk.MenuShell{gtk.Container{*w}}} +// Each connection to signal need to re-create the entire menu. +func (pop *PopupMenuStruct) AppendToExistingMenu(menu *gtk.Menu) *gtk.Menu { + return appendToExistingMenu(pop.items, menu) +} + +func appendToExistingMenu(menuItems []combObj, menu *gtk.Menu) *gtk.Menu { + for _, menuItem := range menuItems { + switch menuItem.tType { + case ITEM_OPT_SEPARATOR: + menu.Append(menuItem.getSeparatorMenuItem()) + default: + if menuItem.combined { + menu.Append(menuItem.xMenuItem) } else { - pop.Menu.Append(menuItem) + switch menuItem.tType { + case ITEM_OPT_NORMAL: + menu.Append(menuItem.getMenuItem()) + case ITEM_OPT_CHECK: + menu.Append(menuItem.getCheckMenuItem()) + case ITEM_OPT_RADIO: + menu.Append(menuItem.getRadioMenuItem()) + } } } - pop.Menu.ShowAll() + } + menu.ShowAll() + return menu +} + +/* + * Icon version, this structure hold a home-made version of GtkMenu with Icon + * handling. Since Gtk3 does not include icon possibility anymore, i've made + * this implementation to continue using icons in my menu. + * - GtkMenuItem is replaced by a GtkBox which embeds a GtkLabel, everything will be embedded in a GtkMenuItem. + * - GtkCheckMenuItem is replaced by a GtkBox which embeds a GtkCheckButton, everything will be embedded in a GtkMenuItem. + * - GtkRadioMenuItem is replaced by a GtkBox which embeds a GtkRadioButton, everything will be embedded in a GtkMenuItem. + * - GtkSeparatorMenuItem still untouched. + * Note: for Icon, each GtkBox may embed/or not a GtkImage at first. + * The "signal" emitted by the objects is processed transparently. + * All objects are accessible using they own method just after +* creation or later, using they indexes and respective methods. +*/ +// PopupMenuIconStruct: Structure that hold popup menu options and methods. +// A simple builder for popup menu that may handle icons. +// Instead of classics GtkMenuItem, this structure use: +// - GtkLabel as GtkMenuItem, it will be embedded in a GtkMenuItem +// - GtkCheckButton as GtkCheckMenuItem, it will be embedded in a GtkMenuItem +// - GtkRadioButton as GtkRadioMenuItem, it will be embedded in a GtkMenuItem +// To get the active widget, you can use 'GetXXXCurrent' or 'GetXXXIdx' method +// Note: the "toggled" signal is handled as transparent as possible. +type PopupMenuIconStruct struct { + Menu *gtk.Menu + // Indicate what type of function the window has. + WindowTypeHint gdk.WindowTypeHint // default (WINDOW_TYPE_HINT_POPUP_MENU) + // left mouse button instead of right + LMB, + // Reserving space to toggle (gtkCheckMenuItem/GtkRadioMenuItem) + ReserveToggleSize bool + // Define icons size + IconsSize, + // space separator for box (used for image) + BoxSpacing, + // Contain the last GtkMenuItme created + nextMenuItemIdx, + // Used to link radio button within a group + lastRadioButtonGroupIdx int + // Used to link radio button within a group + lastRadioButtonGroup *gtk.RadioButton + // Where menuitems are stored + items []combObj + // Options that can be used with designed function + OPT_NORMAL, + OPT_CHECK, + OPT_RADIO, + OPT_SEPARATOR, + OPT_ICON, + OPT_NO_MNEMONIC, + OPT_RADIO_NEW_GRP, + OPT_ALGN_LBL, + OPT_ALGN_BOX_CNTR ItemOptionsType +} + +// PopupMenuNew: return a new PopupMenuIconStruct structure +func PopupMenuIconStructNew() (pop *PopupMenuIconStruct) { + pop = new(PopupMenuIconStruct) + pop.IconsSize = 18 + pop.BoxSpacing = 4 + + pop.lastRadioButtonGroup = nil + pop.ReserveToggleSize = false + pop.WindowTypeHint = gdk.WINDOW_TYPE_HINT_POPUP_MENU + + pop.OPT_NORMAL = ITEM_OPT_NORMAL + pop.OPT_CHECK = ITEM_OPT_CHECK + pop.OPT_RADIO = ITEM_OPT_RADIO + pop.OPT_SEPARATOR = ITEM_OPT_SEPARATOR + pop.OPT_ICON = ITEM_OPT_ICON + pop.OPT_NO_MNEMONIC = ITEM_OPT_NO_MNEMONIC + pop.OPT_RADIO_NEW_GRP = ITEM_OPT_RADIO_NEW_GRP + pop.OPT_ALGN_LBL = ITEM_OPT_ALGN_LBL + pop.OPT_ALGN_BOX_CNTR = ITEM_OPT_ALGN_BOX_CNTR + return +} + +// Retrieve current GtkMenuItem +func (pop *PopupMenuIconStruct) GetMenuItemCurrent() *gtk.MenuItem { + return pop.items[pop.nextMenuItemIdx-1].getCombMenuItem() +} + +// Retrieve current undferlayed GtkLabel +func (pop *PopupMenuIconStruct) GetLabelCurrent() *gtk.Label { + return pop.items[pop.nextMenuItemIdx-1].getLabel() +} + +// Retrieve current undferlayed GtkCheckButton +func (pop *PopupMenuIconStruct) GetCheckButtonCurrent() *gtk.CheckButton { + return pop.items[pop.nextMenuItemIdx-1].getCheckButton() +} + +// Retrieve current undferlayed GtkRadioButton +func (pop *PopupMenuIconStruct) GetRadioButtonCurrent() *gtk.RadioButton { + return pop.items[pop.nextMenuItemIdx-1].getRadioButton() +} + +// Retrieve current GtkSeparatorMenuItem +func (pop *PopupMenuIconStruct) GetSeparatorMenuItemCurrent() *gtk.SeparatorMenuItem { + return pop.items[pop.nextMenuItemIdx-1].getSeparatorMenuItem() +} + +// Get the MenuItem at 'idx', which contains underlying widgets +func (pop *PopupMenuIconStruct) GetMenuItemIdx(idx int) *gtk.MenuItem { + return pop.items[idx].xMenuItem +} + +// Retrieve the underlayed IWidget at 'idx' +func (pop *PopupMenuIconStruct) GetIWidgetIdx(idx int) gtk.IWidget { + return pop.items[idx].widget.(gtk.IWidget) +} + +// AddItemWithOptions: Add items to menu. This version handle +// checkbutton/radiobutton with groups and classic labels with +// or without icon and more options ... +func (pop *PopupMenuIconStruct) buildXMenuItem(lbl string, ico, activateFunction interface{}, opt ItemOptionsType) (*combObj, error) { + var ( + cmbo combObj + err error + menuItem *gtk.MenuItem + pixbuf *gdk.Pixbuf + image *gtk.Image + label *gtk.Label + checkbutton *gtk.CheckButton + radiobutton *gtk.RadioButton + box *gtk.Box + + addImage = func(ico interface{}) error { + // The function below is a part of personal gotk3 library that + // allow to load image with some facilities. May handle a full + // filename or an embedded binary data (hex/zip compressed). + if pixbuf, err = GetPixBuf(ico, pop.IconsSize); err == nil { + if image, err = gtk.ImageNewFromPixbuf(pixbuf); err == nil { + box.PackStart(image, false, false, 0) + return nil + } + } + return err + } + ) + if box, err = gtk.BoxNew(gtk.ORIENTATION_HORIZONTAL, pop.BoxSpacing); err == nil { + if opt&ITEM_OPT_ALGN_BOX_CNTR == 0 { + box.SetHAlign(gtk.ALIGN_START) + } + if menuItem, err = gtk.MenuItemNew(); err == nil { + menuItem.Container.Add(box) + + if opt&ITEM_OPT_ICON != 0 { + if ico == nil { + return nil, fmt.Errorf("AddItemWithOptions: Icon requested but not provided") + } + err = addImage(ico) + } else if opt&ITEM_OPT_ALGN_LBL != 0 { + err = addImage(blankIcon) + image.SetOpacity(0) + } + if err != nil { + return nil, err + } + + switch { + case opt&ITEM_OPT_SEPARATOR != 0: + separatorItem, err := gtk.SeparatorMenuItemNew() + if err != nil { + return nil, err + } + // If empty, do not cast SetLabel, permit to draw a 1 pixel line + // instead of a plain (full height) mark as separator. + if len(lbl) > 0 { + separatorItem.SetLabel(lbl) + } + cmbo = combObj{widget: separatorItem, tType: ITEM_OPT_SEPARATOR, combined: false} + + case opt&ITEM_OPT_CHECK != 0: + if opt&ITEM_OPT_NO_MNEMONIC != 0 { + checkbutton, err = gtk.CheckButtonNewWithLabel(lbl) + } else { + checkbutton, err = gtk.CheckButtonNewWithMnemonic(lbl) + } + if err != nil { + return nil, err + } + box.PackEnd(checkbutton, true, true, 0) + switch f := activateFunction.(type) { + case func(chk *gtk.CheckButton): + menuItem.Connect("activate", func() { + checkbutton.SetActive(!checkbutton.GetActive()) + f(checkbutton) + }) + default: + return nil, fmt.Errorf("AddItemWithOptions: callback type 'func(chk *gtk.CheckButton)' required!") + } + cmbo = combObj{widget: checkbutton, tType: ITEM_OPT_CHECK, combined: true, xMenuItem: menuItem} + + case opt&ITEM_OPT_RADIO != 0, opt&ITEM_OPT_RADIO_NEW_GRP != 0: + if opt&ITEM_OPT_NO_MNEMONIC != 0 { + radiobutton, err = gtk.RadioButtonNewWithLabel(nil, lbl) + } else { + radiobutton, err = gtk.RadioButtonNewWithMnemonic(nil, lbl) + } + if err != nil { + return nil, err + } + box.PackEnd(radiobutton, true, true, 0) + switch f := activateFunction.(type) { + case func(chk *gtk.RadioButton): + menuItem.Connect("activate", func() { + radiobutton.SetActive(!radiobutton.GetActive()) + f(radiobutton) + }) + default: + return nil, fmt.Errorf("AddItemWithOptions: callback type 'func(rbn *gtk.RadioButton)' required!") + } + cmbo = combObj{widget: radiobutton, tType: ITEM_OPT_RADIO, combined: true, xMenuItem: menuItem} + + case opt&ITEM_OPT_NORMAL != 0: + if opt&ITEM_OPT_NO_MNEMONIC != 0 { + label, err = gtk.LabelNew(lbl) + } else { + label, err = gtk.LabelNewWithMnemonic(lbl) + } + if err != nil { + return nil, err + } + box.PackEnd(label, true, true, 0) + switch f := activateFunction.(type) { + case func(): + menuItem.Connect("activate", f) + } + cmbo = combObj{widget: label, tType: ITEM_OPT_NORMAL, combined: true, xMenuItem: menuItem} + + default: + return nil, fmt.Errorf("AddItemWithOptions: Unable to define choosen option(s)") + } + menuItem.ShowAll() + return &cmbo, nil + } + } + + return nil, err +} + +// AddItem: Add item to menu. This version handle +// checkbutton/radiobutton with groups and classic labels with +// or without icon and more options ... +func (pop *PopupMenuIconStruct) AddItem( + lbl string, activateFunction interface{}, options ...interface{}) (widgetIdx int, err error) { + + var ( + opt ItemOptionsType = ITEM_OPT_NORMAL // Default Option + icon interface{} = nil + ) + switch len(options) { + case 1: + opt = opt | options[0].(ItemOptionsType) + case 2: + opt = opt | options[0].(ItemOptionsType) + icon = options[1] + } + + cmbo, err := pop.buildXMenuItem(lbl, icon, activateFunction, opt) + if err != nil { + return -1, err + } + pop.items = append(pop.items, *cmbo) + + // Handling RadioMenuItem groups + if opt&ITEM_OPT_RADIO != 0 || opt&ITEM_OPT_RADIO_NEW_GRP != 0 { + if opt&ITEM_OPT_RADIO_NEW_GRP != 0 { + pop.lastRadioButtonGroup = cmbo.getRadioButton() + } + if pop.lastRadioButtonGroup == nil { + pop.lastRadioButtonGroup = cmbo.getRadioButton() + } + cmbo.getRadioButton().JoinGroup(pop.lastRadioButtonGroup) + } + + pop.nextMenuItemIdx++ + return pop.nextMenuItemIdx - 1, err +} + +// MenuBuild: Build popupmenu. +func (pop *PopupMenuIconStruct) MenuBuild() *gtk.Menu { + var err error + if pop.Menu, err = gtk.MenuNew(); err == nil { + pop.Menu = appendToExistingMenu(pop.items, pop.Menu) } else { log.Println("Popup menu creation error !") return nil } + pop.Menu.SetProperty("reserve_toggle_size", pop.ReserveToggleSize) + pop.Menu.SetProperty("menu_type_hint", pop.WindowTypeHint) return pop.Menu } -// menuItemNewWithImage: Build an item containing an image. -func (pop *PopupMenu) menuItemNewWithImage(label string, icon interface{}) (menuItem *gtk.MenuItem, err error) { - box, err := gtk.BoxNew(gtk.ORIENTATION_HORIZONTAL, 1) - if err == nil { - image, err := gtk.ImageNew() - if err == nil { - p.SetImage(image, icon, 14) - label, err := gtk.LabelNewWithMnemonic(label) - if err == nil { - menuItem, err = gtk.MenuItemNew() - if err == nil { - label.SetHAlign(gtk.ALIGN_START) - box.Add(image) - box.PackEnd(label, true, true, 8) - box.SetHAlign(gtk.ALIGN_START) - menuItem.Container.Add(box) - menuItem.ShowAll() +// CheckRMB: Check whether an event comes from the right button of the +// mouse and display the popup if it is the case at the mouse position. +func (pop *PopupMenuIconStruct) CheckRMB(obj interface{}, event *gdk.Event) bool { + return checkRMB(pop.LMB, pop.Menu, event) +} + +// CheckRMBFromTreeView: May be directly used as callback function for +// TreeView' "button-press-event" signal, considere to initialize the +// popup menu before setting this function as callback. Otherwise, the +// call will generate error "nil pointer ..." +func (pop *PopupMenuIconStruct) CheckRMBFromTreeView(tv *gtk.TreeView, event *gdk.Event) bool { + return checkRMBFromTreeView(pop.LMB, pop.Menu, tv, event) +} + +func (pop *PopupMenuIconStruct) AppendToExistingMenu(menu *gtk.Menu) *gtk.Menu { + return appendToExistingMenu(pop.items, menu) +} + +func checkRMB(popLMB bool, menu *gtk.Menu, event *gdk.Event) bool { + eventButton := gdk.EventButtonNewFromEvent(event) + if uint(eventButton.Button()) == mouseBtn(popLMB) { + menu.PopupAtPointer(event) + return true /* we handled this */ + } + return false /* we did not handle this */ +} + +func checkRMBFromTreeView(popLMB bool, menu *gtk.Menu, tv *gtk.TreeView, event *gdk.Event) bool { + if selection, err := tv.GetSelection(); err == nil { + + eventButton := gdk.EventButtonNewFromEvent(event) + if uint(eventButton.Button()) == mouseBtn(popLMB) { + // If right click is not over a selected row then + // unselect all and select the row under the cursor + eventMotion := gdk.EventMotionNewFromEvent(event) + x, y := eventMotion.MotionVal() + if path, _, _, _, ok := tv.GetPathAtPos(int(x), int(y)); ok { + if !selection.PathIsSelected(path) { + selection.UnselectAll() + selection.SelectPath(path) } } + if selection.CountSelectedRows() > 0 { + // Display popup menu + menu.PopupAtPointer(event) + return true /* we handled this */ + } } } - return menuItem, err + return false /* we did not handle this */ +} + +// mouseBtn: get uint value of specified button to match +func mouseBtn(popLMB bool) uint { + if popLMB { + return 1 // LMB + } + return 3 // RMB } + +// Icon used as transparent to fill space before underlayed widget when +// ITEM_OPT_ALGN_LBL is used. +var blankIcon = HexToBytes("blank", []byte("\x1f\x8b\x08\x00\x00\x00\x00\x00\x02\xff\x00\x3a\x02\xc5\xfd\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44\x52\x00\x00\x00\x10\x00\x00\x00\x10\x08\x06\x00\x00\x00\x1f\xf3\xff\x61\x00\x00\x01\x84\x69\x43\x43\x50\x49\x43\x43\x20\x70\x72\x6f\x66\x69\x6c\x65\x00\x00\x28\x91\x7d\x91\x3d\x48\xc3\x40\x1c\xc5\x5f\x53\xa5\x22\x15\x41\x0b\x8a\x38\x64\xa8\x4e\x16\x44\x45\x74\xd3\x2a\x14\xa1\x42\xa8\x15\x5a\x75\x30\xb9\xf4\x43\x68\xd2\x90\xa4\xb8\x38\x0a\xae\x05\x07\x3f\x16\xab\x0e\x2e\xce\xba\x3a\xb8\x0a\x82\xe0\x07\x88\x9b\x9b\x93\xa2\x8b\x94\xf8\xbf\xa4\xd0\x22\xc6\x83\xe3\x7e\xbc\xbb\xf7\xb8\x7b\x07\x08\xb5\x12\xd3\xac\xb6\x51\x40\xd3\x6d\x33\x95\x88\x8b\x99\xec\x8a\x18\x7a\x85\x80\x1e\xf4\x61\x1a\x82\xcc\x2c\x63\x56\x92\x92\xf0\x1d\x5f\xf7\x08\xf0\xf5\x2e\xc6\xb3\xfc\xcf\xfd\x39\xba\xd4\x9c\xc5\x80\x80\x48\x3c\xc3\x0c\xd3\x26\x5e\x27\x9e\xdc\xb4\x0d\xce\xfb\xc4\x11\x56\x94\x55\xe2\x73\xe2\x11\x93\x2e\x48\xfc\xc8\x75\xc5\xe3\x37\xce\x05\x97\x05\x9e\x19\x31\xd3\xa9\x39\xe2\x08\xb1\x58\x68\x61\xa5\x85\x59\xd1\xd4\x88\x27\x88\xa3\xaa\xa6\x53\xbe\x90\xf1\x58\xe5\xbc\xc5\x59\x2b\x55\x58\xe3\x9e\xfc\x85\xe1\x9c\xbe\xbc\xc4\x75\x9a\x83\x48\x60\x01\x8b\x90\x20\x42\x41\x05\x1b\x28\xc1\x46\x8c\x56\x9d\x14\x0b\x29\xda\x8f\xfb\xf8\x07\x5c\xbf\x44\x2e\x85\x5c\x1b\x60\xe4\x98\x47\x19\x1a\x64\xd7\x0f\xfe\x07\xbf\xbb\xb5\xf2\xe3\x63\x5e\x52\x38\x0e\xb4\xbf\x38\xce\xc7\x10\x10\xda\x05\xea\x55\xc7\xf9\x3e\x76\x9c\xfa\x09\x10\x7c\x06\xae\xf4\xa6\xbf\x5c\x03\xa6\x3e\x49\xaf\x36\xb5\xe8\x11\xd0\xbd\x0d\x5c\x5c\x37\x35\x65\x0f\xb8\xdc\x01\xfa\x9f\x0c\xd9\x94\x5d\x29\x48\x53\xc8\xe7\x81\xf7\x33\xfa\xa6\x2c\xd0\x7b\x0b\x74\xae\x7a\xbd\x35\xf6\x71\xfa\x00\xa4\xa9\xab\xe4\x0d\x70\x70\x08\x0c\x17\x28\x7b\xcd\xe7\xdd\x1d\xad\xbd\xfd\x7b\xa6\xd1\xdf\x0f\x6b\xbe\x72\xa4\xea\xad\xb2\x9e\x00\x00\x00\x06\x62\x4b\x47\x44\x00\xff\x00\xff\x00\xff\xa0\xbd\xa7\x93\x00\x00\x00\x09\x70\x48\x59\x73\x00\x00\x2e\x23\x00\x00\x2e\x23\x01\x78\xa5\x3f\x76\x00\x00\x00\x07\x74\x49\x4d\x45\x07\xe5\x02\x12\x17\x3b\x0b\xb8\x84\x6f\xa0\x00\x00\x00\x19\x74\x45\x58\x74\x43\x6f\x6d\x6d\x65\x6e\x74\x00\x43\x72\x65\x61\x74\x65\x64\x20\x77\x69\x74\x68\x20\x47\x49\x4d\x50\x57\x81\x0e\x17\x00\x00\x00\x12\x49\x44\x41\x54\x38\xcb\x63\x60\x18\x05\xa3\x60\x14\x8c\x02\x08\x00\x00\x04\x10\x00\x01\x85\x3f\xaa\x72\x00\x00\x00\x00\x49\x45\x4e\x44\xae\x42\x60\x82\x01\x00\x00\xff\xff\x1a\x3e\x56\xc7\x3a\x02\x00\x00")) + +/******************** OUTDATED START ********************** + * Methods below MUST NOT be used anymore to display icons + * Otherwise, without icon they still available + */ +// AddItem: Add items to menu. +// func (pop *PopupMenuIconStruct) AddItem(lbl string, activateFunction interface{}, +// icon ...interface{}) (err error) { + +// fmt.Printf("Warning!: POPUP/MENU implementation must be changed using new version\n") + +// var menuItem *gtk.MenuItem +// var pixbuf *gdk.Pixbuf + +// if len(icon) != 0 { +// // The function below is a part of personal gotk3 library +// // allow to load image with some facilities. May handle +// // filename or embedded binary data (hex/zip compressed). +// // pixbuf, err = gdk.PixbufNewFromFile(filename) +// pixbuf, err = GetPixBuf(icon[0], pop.IconsSize) +// } + +// if pop.WithIcons { +// menuItem, err = pop.menuItemNewWithImage(lbl, pixbuf) +// } else { +// menuItem, err = gtk.MenuItemNewWithMnemonic(lbl) +// } + +// // Handle the "activate" signal from the related item. +// if err == nil { +// menuItem.SetUseUnderline(true) +// if activateFunction != nil { +// menuItem.Connect("activate", activateFunction.(func())) +// } +// pop.Items = append(pop.Items, menuItem) +// // pop.separators = append(pop.separators, nil) +// pop.nextMenuItemIdx++ +// } +// return err +// } + +// // AddCheckMenuItem: Add items to menu. +// func (pop *PopupMenuIconStruct) AddCheckMenuItem(lbl string, activateFunction interface{}) (err error) { + +// fmt.Printf("Warning!: POPUP/MENU implementation must be changed using new version\n") + +// var menuItem *gtk.CheckMenuItem +// menuItem, err = gtk.CheckMenuItemNewWithMnemonic(lbl) + +// // Handle the "activate" signal from the related item. +// if err == nil { +// menuItem.SetUseUnderline(true) +// if activateFunction != nil { +// menuItem.Connect("activate", activateFunction.(func())) +// } +// pop.Items = append(pop.Items, menuItem) +// // pop.separators = append(pop.separators, nil) +// pop.nextMenuItemIdx++ +// } +// return err +// } + +// // menuItemNewWithImage: Build an item containing an image. +// func (pop *PopupMenuIconStruct) menuItemNewWithImage(label string, +// pixbuf *gdk.Pixbuf) (menuItem *gtk.MenuItem, err error) { + +// fmt.Printf("Warning!: POPUP/MENU implementation must be changed using new version\n") + +// var image *gtk.Image +// box, err := gtk.BoxNew(gtk.ORIENTATION_HORIZONTAL, pop.BoxSpacing) +// if err == nil { +// if image, err = gtk.ImageNewFromPixbuf(pixbuf); err == nil { +// label, err := gtk.LabelNewWithMnemonic(label) +// if err == nil { +// menuItem, err = gtk.MenuItemNew() +// if err == nil { +// label.SetHAlign(gtk.ALIGN_START) +// box.Add(image) +// box.PackEnd(label, true, true, 0) +// box.SetHAlign(gtk.ALIGN_START) +// menuItem.Container.Add(box) +// menuItem.ShowAll() +// } +// } +// } +// } +// return menuItem, err +// } + +// AddSeparator: Add separator to menu. +// func (pop *PopupMenuIconStruct) AddSeparator(label ...string) (err error) { + +// if separatorItem, err := gtk.SeparatorMenuItemNew(); err == nil { +// if len(label) > 0 { +// separatorItem.SetLabel(label[0]) +// } +// pop.Items = append(pop.Items, separatorItem) +// pop.nextMenuItemIdx++ +// } +// return err +// } + +// MenuBuild: Build popupmenu. +// func (pop *PopupMenuIconStruct) MenuBuild() *gtk.Menu { +// var err error +// if pop.Menu, err = gtk.MenuNew(); err == nil { +// for _, menuItem := range pop.Items { +// switch m := menuItem.(type) { +// case *gtk.SeparatorMenuItem: +// pop.Menu.Append(m) +// case *gtk.MenuItem: +// pop.Menu.Append(m) +// case *gtk.CheckMenuItem: +// pop.Menu.Append(m) +// case *gtk.RadioMenuItem: +// pop.Menu.Append(m) +// } +// } +// pop.Menu.ShowAll() +// } else { +// log.Println("Popup menu creation error !") +// return nil +// } + +// pop.Menu.SetReserveToggleSize(pop.SetReserveToggleSize) +// return pop.Menu +// } + +// AppendToExistingMenu: append "MenuItems" to an existing "*gtk.Menu" +// Useful when you want to just add some entries to the context menu that +// already exist in a gtk.TextView or gtk.Entry by using "populate-popup" +// signal. Notice: GtkWidget > GtkMenu: +// menu := >k.Menu{gtk.MenuShell{gtk.Container{*w}}} +// Each connection to signal need to re-create the entire menu. +// func (pop *PopupMenuIconStruct) AppendToExistingMenu(menu *gtk.Menu) *gtk.Menu { +// for _, menuItem := range pop.Items { +// switch m := menuItem.(type) { +// case *gtk.SeparatorMenuItem: +// pop.Menu.Append(m) +// case *gtk.MenuItem: +// pop.Menu.Append(m) +// case *gtk.CheckMenuItem: +// pop.Menu.Append(m) +// case *gtk.RadioMenuItem: +// pop.Menu.Append(m) +// } +// } +// menu.ShowAll() +// return menu +// } + +/******************** OUTDATED END **********************/ diff --git a/vendor/github.com/hfmrow/gtk3Import/misc/progress.go b/vendor/github.com/hfmrow/gtk3Import/misc/progress.go new file mode 100755 index 0000000..1e56e61 --- /dev/null +++ b/vendor/github.com/hfmrow/gtk3Import/misc/progress.go @@ -0,0 +1,142 @@ +// progress.go + +/* + Source file auto-generated on Thu, 17 Oct 2019 02:33:04 using Gotk3ObjHandler v1.3.9 ©2018-19 H.F.M + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + This structure implement a progressbar. +*/ + +package gtk3Import + +import ( + "sync" + "time" + + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/gtk" +) + +type ProgressBarStruct struct { + RefreshMs uint + GifImageName string + + gifImage *gtk.Image + box *gtk.Box + boxPosition int + fMain, fEnd func() (err error) + progressBar *gtk.ProgressBar + TimeOutContinue bool + ticker *time.Ticker +} + +func ProgressBarNew(progressBar *gtk.ProgressBar, fMain, fEnd func() (err error)) (pbs *ProgressBarStruct) { + pbs = new(ProgressBarStruct) + pbs.Init(progressBar, fMain, fEnd) + return +} + +func ProgressGifNew(gifImage *gtk.Image, box *gtk.Box, position int, fMain, fEnd func() (err error)) (pbs *ProgressBarStruct) { + pbs = new(ProgressBarStruct) + pbs.Init(nil, fMain, fEnd) + pbs.box = box + pbs.boxPosition = position + pbs.gifImage = gifImage + pbs.box.Add(pbs.gifImage) + pbs.gifImage.SetHAlign(gtk.ALIGN_FILL) + pbs.gifImage.SetHExpand(true) + pbs.box.ReorderChild(pbs.gifImage, position) + // pbs.gifImage.Show() + return +} + +func (pbs *ProgressBarStruct) Init(progressBar *gtk.ProgressBar, fMain, fEnd func() (err error)) { + pbs.RefreshMs = 100 + pbs.progressBar = progressBar + pbs.fMain, pbs.fEnd = fMain, fEnd +} + +func (pbs *ProgressBarStruct) StartGif() (err error) { + pbs.gifImage.Show() + waitGroup := new(sync.WaitGroup) + waitGroup.Add(1) + go func() { + defer waitGroup.Done() + err = pbs.fMain() + }() + + waitGroup.Wait() + if err != nil { + return + } + glib.IdleAdd(func() { + pbs.removeGifFromTopBox() + err = pbs.fEnd() + }) + return +} + +func (pbs *ProgressBarStruct) removeGifFromTopBox() { + pbs.box.Remove(pbs.gifImage) +} + +func (pbs *ProgressBarStruct) StartTicker() (err error) { + + pbs.ticker = time.NewTicker(time.Millisecond * time.Duration(pbs.RefreshMs)) + go func() { + for _ = range pbs.ticker.C { + glib.IdleAdd(func() { + pbs.progressBar.Pulse() + }) + } + }() + + waitGroup := new(sync.WaitGroup) + waitGroup.Add(1) + go func() { + defer waitGroup.Done() + err = pbs.fMain() + }() + + waitGroup.Wait() + if err != nil { + return + } + glib.IdleAdd(func() { + pbs.progressBar.SetFraction(0) + err = pbs.fEnd() + pbs.ticker.Stop() + }) + + return +} + +func (pbs *ProgressBarStruct) StartTimeOut() { + + pbs.TimeOutContinue = true + glib.TimeoutAdd(pbs.RefreshMs, func() bool { + glib.IdleAdd(func() { + pbs.progressBar.Pulse() + }) + if pbs.TimeOutContinue { + return true + } else { + glib.IdleAdd(func() { + pbs.progressBar.SetFraction(0) + pbs.fEnd() + }) + return false + } + }) + + waitGroup := new(sync.WaitGroup) + waitGroup.Add(1) + go func() { + defer waitGroup.Done() + pbs.fMain() + }() + waitGroup.Wait() + pbs.TimeOutContinue = false + return +} diff --git a/vendor/github.com/hfmrow/gtk3Import/misc/statusBar.go b/vendor/github.com/hfmrow/gtk3Import/misc/statusBar.go index 84a9f1a..fab17d4 100644 --- a/vendor/github.com/hfmrow/gtk3Import/misc/statusBar.go +++ b/vendor/github.com/hfmrow/gtk3Import/misc/statusBar.go @@ -1,13 +1,18 @@ // statusBar.go /* -* ©2019 H.F.M. MIT license -* Handle Statusbar messages. - */ + This library use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2019 H.F.M - Handle Statusbar messages & Window Title + This program comes with absolutely no warranty. See the The MIT License (MIT) for details: + https://opensource.org/licenses/mit-license.php +*/ package gtk3Import import ( + "log" "strconv" "strings" @@ -17,35 +22,37 @@ import ( /*************/ /* Titlebar */ /***********/ + type TitleBar struct { - MainTitle string + MainTitle string + Separator string + appendTitle string prependTitle string - separator string window *gtk.Window titleNew string } -func TitleBarNew(window *gtk.Window, mainTitle string, separator ...string) *TitleBar { +func TitleBarStructureNew(window *gtk.Window, title ...string) *TitleBar { tb := new(TitleBar) - tb.window = window - tb.separator = " - " - if len(separator) > 0 { - tb.separator = separator[0] - } - tb.MainTitle = mainTitle + tb.Init(window, title...) return tb } // * Alternative use of TitleBarNew() * in the case where we need // to import the structure rather than using it via the imported library. -func (tb *TitleBar) StructureSetup(window *gtk.Window, mainTitle string, separator ...string) { +func (tb *TitleBar) Init(window *gtk.Window, title ...string) { + var err error tb.window = window - tb.separator = " - " - if len(separator) > 0 { - tb.separator = separator[0] + tb.Separator = " - " + + if len(title) > 0 { + tb.MainTitle = strings.Join(title, " ") + } else { + if tb.MainTitle, err = tb.window.GetTitle(); err != nil { + log.Fatalf("Unable to acquire window title: %s\n", err.Error()) + } } - tb.MainTitle = mainTitle } func (tb *TitleBar) Reset() string { @@ -60,10 +67,10 @@ func (tb *TitleBar) Update(toAdd []string, appendTo ...bool) string { } if len(toAdd) > 0 { if appendToTitle && len(toAdd) != 0 { - tb.titleNew = tb.MainTitle + tb.separator + strings.Join(toAdd, tb.separator) + tb.titleNew = tb.MainTitle + tb.Separator + strings.Join(toAdd, tb.Separator) } else if len(toAdd) != 0 { - tb.titleNew = strings.Join(toAdd, tb.separator) + tb.separator + tb.MainTitle + tb.titleNew = strings.Join(toAdd, tb.Separator) + tb.Separator + tb.MainTitle } } else { tb.titleNew = tb.MainTitle @@ -75,8 +82,10 @@ func (tb *TitleBar) Update(toAdd []string, appendTo ...bool) string { /**************/ /* Statusbar */ /************/ + type StatusBar struct { Messages []string /* Each row contain associated strings refere to contextId number */ + Separator string statusbar *gtk.Statusbar contextId uint Prefix []string @@ -85,35 +94,28 @@ type StatusBar struct { /* Init: Initialise structure to handle elements to be displayed. */ func StatusBarStructureNew(originStatusbar *gtk.Statusbar, prefix []string, stackId ...int) (bar *StatusBar) { bar = new(StatusBar) - var stack int - if len(stackId) == 0 { - stack = 0 - } else { - stack = stackId[0] - } - bar.statusbar = originStatusbar - bar.contextId = bar.statusbar.GetContextId(strconv.Itoa(stack)) /* get contextId of stack */ - bar.Messages = make([]string, len(prefix)) - for _, pre := range prefix { - bar.Prefix = append(bar.Prefix, pre) - } + bar.Init(originStatusbar, prefix, stackId...) return } +// Show: display / hide statusbar +func (bar *StatusBar) Show(state bool) { + bar.statusbar.SetVisible(state) +} + /* Init: Initialise structure to handle elements to be displayed. */ -func (bar *StatusBar) StructureSetup(originStatusbar *gtk.Statusbar, prefix []string, stackId ...int) { +func (bar *StatusBar) Init(originStatusbar *gtk.Statusbar, prefix []string, stackId ...int) { var stack int if len(stackId) == 0 { stack = 0 } else { stack = stackId[0] } + bar.Separator = " | " bar.statusbar = originStatusbar bar.contextId = bar.statusbar.GetContextId(strconv.Itoa(stack)) /* get contextId of stack */ bar.Messages = make([]string, len(prefix)) - for _, pre := range prefix { - bar.Prefix = append(bar.Prefix, pre) - } + bar.Prefix = prefix } /* Add: add new element and return his own position. */ @@ -149,6 +151,7 @@ func (bar *StatusBar) CleanAll() { for idx, _ := range bar.Messages { bar.Messages[idx] = "" } + bar.Disp() } /* Disp: display content of stored elements into statusbar */ @@ -159,5 +162,5 @@ func (bar *StatusBar) Disp() { dispMessages = append(dispMessages, bar.Prefix[idxMessage]+" "+message) } } - bar.statusbar.Push(bar.contextId, strings.Join(dispMessages, " | ")) + bar.statusbar.Push(bar.contextId, strings.Join(dispMessages, bar.Separator)) } diff --git a/vendor/github.com/hfmrow/gtk3Import/misc/timeOut.go b/vendor/github.com/hfmrow/gtk3Import/misc/timeOut.go new file mode 100644 index 0000000..5985821 --- /dev/null +++ b/vendor/github.com/hfmrow/gtk3Import/misc/timeOut.go @@ -0,0 +1,85 @@ +// +build ignore + +package main + +import ( + "fmt" + "log" + + "github.com/gotk3/gotk3/glib" + "github.com/gotk3/gotk3/gtk" +) + +var timeoutContinue = true +var tos glib.SourceHandle + +// Create and initialize the window +func setupWindow(title string) *gtk.Window { + win, err := gtk.WindowNew(gtk.WINDOW_TOPLEVEL) + if err != nil { + log.Fatal("Unable to create window:", err) + } + + win.SetTitle(title) + win.Connect("destroy", func() { + gtk.MainQuit() + }) + win.SetPosition(gtk.WIN_POS_CENTER) + width, height := 600, 300 + win.SetDefaultSize(width, height) + + box, _ := gtk.BoxNew(gtk.ORIENTATION_VERTICAL, 0) + btn, _ := gtk.ButtonNew() + btn.Connect("clicked", ButtonClicked) + btn.SetLabel("Stop timeout") + + box.Add(btn) + win.Add(box) + + return win +} + +func main() { + gtk.Init(nil) + + win := setupWindow("Go Example Testreport") + + win.ShowAll() + + // Init timeout: + tos, _ = glib.TimeoutAdd(uint(1000), func() bool { + fmt.Println("timed out") + + return timeoutContinue + }) + + gtk.Main() +} + +func ButtonClicked() { + var methode int + + // Three methods to stop timeout: + // 1- Destroying + // 2- Removing + // 3- Returning false by called function + + // Choose one of them: + methode = 3 + + switch methode { + case 1: // 1- Destroying + mcd := glib.MainContextDefault() + src := mcd.FindSourceById(tos) + src.Destroy() + fmt.Printf("Timeout stopped & IsDestroyed: %v\n", src.IsDestroyed()) + + case 2: // 2- Removing + glib.SourceRemove(tos) + fmt.Printf("Timeout stopped but still referenced\n") + + case 3: // 3- Returning false by called function + timeoutContinue = !timeoutContinue + fmt.Printf("Timeout stopped but still in memory and referenced\n") + } +} diff --git a/vendor/github.com/hfmrow/gtk3Import/pango/pangoMarkupBinder.go b/vendor/github.com/hfmrow/gtk3Import/pango/pangoMarkupBinder.go deleted file mode 100644 index ff83977..0000000 --- a/vendor/github.com/hfmrow/gtk3Import/pango/pangoMarkupBinder.go +++ /dev/null @@ -1,282 +0,0 @@ -// PangoMarkupBinder.go - -/* -* ©2019 H.F.M. MIT license -* Handle Pango markup functions. - -* This is a pango markup binder to gotk3 pango library ... -* I have made it to make more simple markup handling when i'm working on gtk objects. -* It can be used in treeview, dialog, label, ... Each object where you ca.n set "markup" content - */ - -package gtk3Import - -import ( - "bytes" - "fmt" - "sort" - "strings" -) - -var pangoEscapeChar = [][]string{{"<", "<", string([]byte{0x15})}, {"&", "&", string([]byte{0x16})}} - -var markupType = map[string][]string{ - - "bold": {"", ""}, "bld": {"", ""}, // Bold - "big": {"", ""}, // Makes font relatively larger, equivalent to - "small": {"", ""}, "sml": {"", ""}, // Makes font relatively smaller, equivalent to - "italic": {"", ""}, "ita": {"", ""}, // Italic - "subscript": {"", ""}, "sub": {"", ""}, // Subscript - "supscript": {"", ""}, "sup": {"", ""}, // Superscript - "monospace": {"", ""}, "msp": {"", ""}, // Monospace font - - "font_family": {``, ``}, - "ffy": {``, ``}, // A font family name - - /* A font description string, such as "Sans Italic 12". See pango_font_description_from_string() for a description of the format of the - string representation. Note that any other span attributes will override this description. - So if you have "Sans Italic" and also a style="normal" attribute, you will get Sans normal, not italic.*/ - "font": {``, ``}, - "fnt": {``, ``}, - - /* Font size in 1024ths of a point, or one of the absolute sizes 'xx-small', 'x-small', 'small', 'medium', 'large', 'x-large', 'xx-large' - or one of the relative sizes 'smaller' or 'larger'. If you want to specify a absolute size, it's usually easier to take advantage of - the ability to specify a partial font description using 'font'; you can use font='12.5' rather than size='12800'.*/ - "font_size": {``, ``}, - "fsz": {``, ``}, - - "strike": {"", ""}, "stk": {"", ""}, // Strikethrough - "strikethrough_color": {``, ``}, // 'true' or 'false' whether to strike through the text - "stc": {``, ``}, // An RGB color specification such as '#00FF00' or a color name such as 'blue'. - - "underline": {"", ""}, "und": {"", ""}, // Underline - "underline_color": {``, ``}, // One of 'none', 'single', 'double', 'low', 'error' - "udc": {``, ``}, // An RGB color specification such as '#00FF00' or a color name such as 'red'. - - "foreground": {``, ``}, "fgc": {``, ``}, // An RGB color specification such as '#00FF00' or a color name such as 'red'. - "background": {``, ``}, "bgc": {``, ``}, // An RGB color specification such as '#00FF00' or a color name such as 'red'. - "fgalpha": {``, ``}, "fga": {``, ``}, // An alpha value for the background color, either a plain integer between 1 and 65536 or a percentage value like '50%'. - "bgalpha": {``, ``}, "bga": {``, ``}, // An alpha value for the background color, either a plain integer between 1 and 65536 or a percentage value like '50%'. - - "url": {``, ``}, // Url clickable 1st arg: adress - - "font_style": {``, ``}, // font_style: One of 'normal', 'oblique', 'italic'. N.b: 'oblique' seems to be the same as 'italic' - "fst": {``, ``}, // font_style: One of 'normal', 'oblique', 'italic'. So, look really useless ... - - "font_variant": {``, ``}, - "fvt": {``, ``}, // One of 'normal' or 'smallcaps' - - "font_stretch": {``, ``}, - "fsh": {``, ``}, // One of 'ultracondensed', 'extracondensed', 'condensed', 'semicondensed', 'normal', 'semiexpanded', 'expanded', 'extraexpanded', 'ultraexpanded' - - "font_weight": {``, ``}, - "wgt": {``, ``}, // One of 'ultralight', 'light', 'normal', 'bold', 'ultrabold', 'heavy', or a numeric weight -} - -type PangoColor struct { - Black string - Brown string - White string - Red string - Green string - Blue string - Cyan string - Magenta string - Purple string - Turquoise string - Violet string - - Darkred string - Darkgreen string - Darkblue string - Darkgray string - Darkcyan string - - Lightblue string - Lightgray string - Lightgreen string - Lightturquoise string - Lightred string - Lightyellow string -} - -func (pc *PangoColor) Init() { - // Colors initialisation - pc.Black = "#000000" - pc.Brown = "#7C2020" - pc.White = "#FFFFFF" - pc.Red = "#FF2222" - pc.Green = "#22BB22" - pc.Blue = "#0044FF" - pc.Cyan = "#14FFFA" - pc.Magenta = "#D72D6C" - pc.Purple = "#8B0037" - pc.Turquoise = "#009187" - pc.Violet = "#7F00FF" - pc.Darkred = "#300000" - pc.Darkgreen = "#003000" - pc.Darkblue = "#000030" - pc.Darkcyan = "#003333" - pc.Darkgray = "#303030" - pc.Lightturquoise = "#80FFE7" - pc.Lightblue = "#ADD8E6" - pc.Lightgray = "#E4DDDD" - pc.Lightgreen = "#87FF87" - pc.Lightred = "#FF6666" - pc.Lightyellow = "#FFFF6F" -} - -type PangoMarkup struct { - InString string - OutString string - OutStringSl []string - markPositions [][]int - markTypes [][]string - Colors PangoColor -} - -func (pm *PangoMarkup) Init(inString string) { - pm.Colors.Init() - // Object initialisation/cleaning - pm.InString = inString - pm.markPositions = [][]int{} - pm.markTypes = [][]string{} - pm.OutString = "" -} - -// Add multiples positions, (where markup is applied) -func (pm *PangoMarkup) AddPosition(pos ...[]int) { - pm.markPositions = append(pm.markPositions, pos...) -} - -// Add multiples markup types, (the style applied at given positions) -func (pm *PangoMarkup) AddTypes(mType ...[]string) { - pm.markTypes = append(pm.markTypes, mType...) -} - -// Apply multiples pango markups to the whole text. -func (pm *PangoMarkup) Markup() string { - pm.prepare() - text := pm.InString - for _, mType := range pm.markTypes { - text = markup(text, mType...) - } - pm.OutString = text - pm.finalize() - return pm.OutString -} - -// Apply multiples pango markups to the whole text. -func (pm *PangoMarkup) MarkupSeparate() (outStrSl []string) { - pm.prepare() - text := pm.InString - - for _, mType := range pm.markTypes { - outStrSl = append(outStrSl, markupSeparate(text, mType...)...) - } - copy(pm.OutStringSl, outStrSl) - pm.finalizeSeparate() - return pm.OutStringSl -} - -// Apply multiples pango markups to text at specified positions given into 2d slices. -func (pm *PangoMarkup) MarkupAtPos() string { - var eol = [][]byte{{0x0D, 0x0A}, {0x0D}, {0x0A}} - var actEol string - var multiMarks []string - pm.prepare() - // Sorting slice to get positions from the last to the first, (preserve positions in string) - sort.SliceStable(pm.markPositions, func(i, j int) bool { - return pm.markPositions[i][0] > pm.markPositions[j][0] - }) - pm.OutString = pm.InString - - for _, pos := range pm.markPositions { - prefix := pm.OutString[:pos[0]] - toMark := pm.OutString[pos[0]:pos[1]] - suffix := pm.OutString[pos[1]:] - - multiMarks = []string{toMark} - for idx, val := range eol { - if bytes.Contains([]byte(toMark), val) { - actEol = string(eol[idx]) - multiMarks = strings.Split(toMark, actEol) - } - } - for idx, _ := range multiMarks { - for _, mType := range pm.markTypes { - multiMarks[idx] = markup(multiMarks[idx], mType...) - } - } - pm.OutString = prefix + strings.Join(multiMarks, actEol) + suffix - } - pm.finalize() - return pm.OutString -} - -// Prepare string with special characters to be marked ("<", "&") -func (pm *PangoMarkup) prepare() { - pm.InString = strings.Replace(pm.InString, - pangoEscapeChar[1][0], pangoEscapeChar[1][2], -1) - pm.InString = strings.Replace(pm.InString, - pangoEscapeChar[0][0], pangoEscapeChar[0][2], -1) -} - -// Escape special characters after marking ("<", "&") -func (pm *PangoMarkup) finalize() { - pm.OutString = strings.Replace(pm.OutString, - pangoEscapeChar[1][2], pangoEscapeChar[1][1], -1) - pm.OutString = strings.Replace(pm.OutString, - pangoEscapeChar[0][2], pangoEscapeChar[0][1], -1) -} - -// Escape special characters after marking ("<", "&"), SEPARATE version -func (pm *PangoMarkup) finalizeSeparate() { - for idx, _ := range pm.OutStringSl { - pm.OutStringSl[idx] = strings.Replace(pm.OutStringSl[idx], - pangoEscapeChar[1][2], pangoEscapeChar[1][1], -1) - pm.OutStringSl[idx] = strings.Replace(pm.OutStringSl[idx], - pangoEscapeChar[0][2], pangoEscapeChar[0][1], -1) - } -} - -// Apply pango markup format to text. They can be combined. -func markup(text string, mType ...string) string { - switch len(mType) { - case 1: - // i.e: markup("display", "sub") - return fmt.Sprint(markupType[mType[0]][0], text, markupType[mType[0]][1]) - case 2: - // i.e: markup("display", "stc", "red") - return fmt.Sprint(markupType[mType[0]][0], mType[1], - markupType[mType[0]][1], text, markupType[mType[0]][2]) - case 3: - // i.e: markup("display", "stc", "double", "red") - return fmt.Sprint(markupType[mType[0]][0], mType[1], - markupType[mType[0]][1], mType[2], markupType[mType[0]][2], - text, markupType[mType[0]][3]) - default: - return fmt.Sprint("Markup type error: ", mType) - } -} - -// Apply pango markup format to text. They can be combined. -// Output will give []sting containing each markup sections separatly. -func markupSeparate(text string, mType ...string) []string { - switch len(mType) { - case 1: - // i.e: markup("display", "sub") - return []string{markupType[mType[0]][0], text, markupType[mType[0]][1]} - case 2: - // i.e: markup("display", "stc", "red") - return []string{markupType[mType[0]][0], mType[1], - markupType[mType[0]][1], text, markupType[mType[0]][2]} - case 3: - // i.e: markup("display", "stc", "double", "red") - return []string{markupType[mType[0]][0], mType[1], - markupType[mType[0]][1], mType[2], - markupType[mType[0]][2], text, markupType[mType[0]][3]} - default: - return []string{fmt.Sprint("Markup type error: ", mType)} - } -} diff --git a/vendor/github.com/hfmrow/gtk3Import/pango/pangoSimple/pangoSimple.go b/vendor/github.com/hfmrow/gtk3Import/pango/pangoSimple/pangoSimple.go new file mode 100644 index 0000000..a312c99 --- /dev/null +++ b/vendor/github.com/hfmrow/gtk3Import/pango/pangoSimple/pangoSimple.go @@ -0,0 +1,151 @@ +// PangoMarkupBinder.go + +/* +* ©2019 H.F.M. MIT license +* Handle Pango markup functions. + +* This is a pango markup binder to gotk3 pango library ... +* I have made it to make more simple markup handling when i'm working on gtk objects. +* It can be used in treeview, dialog, label, ... Each object where you can set "markup" content + + */ + +package gtk3Import + +import ( + "fmt" + "regexp" + "strings" +) + +type PangoSimple struct { + pangoEscapeChar [][]string +} + +func PangoSimpleNew() (ps *PangoSimple) { + ps = new(PangoSimple) + ps.Init() + return +} + +// Init: Init [PangoSimple] structure +func (pm *PangoSimple) Init() { + // pm.pangoEscapeChar = [][]string{{"<", "<", string([]byte{0x15})}, {"&", "&", string([]byte{0x16})}} + pm.pangoEscapeChar = [][]string{{"<", "<", "lOwErThAnTmPrEpLaCeMeNt"}, {"&", "&", "aMpErSaNdTmPrEpLaCeMeNt"}} +} + +// MarkupHttpClickable: Search for http adresses in the input text and make http adress as clickable links +func (pm *PangoSimple) MarkupHttpClickable(inString string, keepFromEnd ...int) (outString string) { + var adrToDisp string + outString = pm.Prepare(inString) // In case nothing is found, returned value is same as entered value + reg := regexp.MustCompile(`(http|https|ftp|ftps)\:\/\/[a-zA-Z0-9\-\.]+\.[a-zA-Z]{2,3}(\/\S*)?`) + indexes := reg.FindAllIndex([]byte(outString), -1) + + removePrefix := regexp.MustCompile(`(http|https|ftp|ftps)\:\/\/`) + + for idx := len(indexes) - 1; idx >= 0; idx-- { + inLeft := outString[:indexes[idx][0]] + inRight := outString[indexes[idx][1]:] + url := outString[indexes[idx][0]:indexes[idx][1]] + + adrToDisp = removePrefix.ReplaceAllString(url, "") + if len(keepFromEnd) > 0 { + tmpUrl := strings.Split(url, "/") + adrToDisp = strings.Join(tmpUrl[len(tmpUrl)-keepFromEnd[0]:], "/") + } + + outString = inLeft + `` + adrToDisp + `` + inRight + } + return pm.Finalize(outString) +} + +// ApplyMarkup: This method add automatically the closer at end. +// ie: ApplyMarkup(``, "hello") +func (pm *PangoSimple) ApplyMarkup(markup ...string) string { + return pm.Finalize(markup[0] + pm.Prepare(markup[1]) + pm.getClose(markup[0])) +} + +func (pm *PangoSimple) ApplyMarkupAgain(markup ...string) string { + return markup[0] + markup[1] + pm.getClose(markup[0]) +} + +// getClose: return the last argument derived from the first to close the pango string +func (pm *PangoSimple) getClose(in string) string { + if strings.HasPrefix(in, `` + } + if strings.HasPrefix(in, `` + } + return fmt.Sprintf("", strings.Split(in, `>`)[0][1:]) +} + +// prepare: sanitize input string to safely use with pango +func (pm *PangoSimple) Prepare(inString string) string { + inString = strings.ReplaceAll(inString, pm.pangoEscapeChar[1][0], pm.pangoEscapeChar[1][2]) + return strings.ReplaceAll(inString, pm.pangoEscapeChar[0][0], pm.pangoEscapeChar[0][2]) +} + +// finalize: restore originals characters using markup replacement +func (pm *PangoSimple) Finalize(inString string) string { + inString = strings.ReplaceAll(inString, pm.pangoEscapeChar[1][2], pm.pangoEscapeChar[1][1]) + return strings.ReplaceAll(inString, pm.pangoEscapeChar[0][2], pm.pangoEscapeChar[0][1]) +} + +type PangoColor struct { + Black string + Brown string + White string + Red string + Green string + Blue string + Cyan string + Magenta string + Purple string + Turquoise string + Violet string + + Darkred string + Darkgreen string + Darkblue string + Darkgray string + Darkcyan string + + Lightblue string + Lightgray string + Lightgreen string + Lightturquoise string + Lightred string + Lightyellow string +} + +func PangoColorNew() (pc *PangoColor) { + pc = new(PangoColor) + pc.Init() + return +} +func (pc *PangoColor) Init() { + // Colors initialisation + pc.Black = "#000000" + pc.Brown = "#7C2020" + pc.White = "#FFFFFF" + pc.Red = "#FF2222" + pc.Green = "#22BB22" + pc.Blue = "#0044FF" + pc.Cyan = "#14FFFA" + pc.Magenta = "#D72D6C" + pc.Purple = "#8B0037" + pc.Turquoise = "#009187" + pc.Violet = "#7F00FF" + pc.Darkred = "#300000" + pc.Darkgreen = "#003000" + pc.Darkblue = "#000030" + pc.Darkcyan = "#003333" + pc.Darkgray = "#303030" + pc.Lightturquoise = "#80FFE7" + pc.Lightblue = "#ADD8E6" + pc.Lightgray = "#E4DDDD" + pc.Lightgreen = "#87FF87" + pc.Lightred = "#FF6666" + pc.Lightyellow = "#FFFF6F" +} diff --git a/vendor/github.com/hfmrow/gtk3Import/pixbuff/misc/RGBA/RGBA.go b/vendor/github.com/hfmrow/gtk3Import/pixbuff/misc/RGBA/RGBA.go new file mode 100644 index 0000000..3d2aff5 --- /dev/null +++ b/vendor/github.com/hfmrow/gtk3Import/pixbuff/misc/RGBA/RGBA.go @@ -0,0 +1,133 @@ +// RGBA.go + +/* + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2020 H.F.M - RGBA package github.com/hfmrow + This program comes with absolutely no warranty. See the The MIT + License (MIT) for details: + https://opensource.org/licenses/mit-license.php +*/ + +package RGBA + +import ( + "fmt" + "math" + "regexp" + "strconv" + + "github.com/gotk3/gotk3/gdk" +) + +// Rgba: Contains RGBA values to facilitate transfer between local +// storage intended to be backed up such as in an 'option' file +// and the GdkRGBA object. +type Rgba struct { + Red, + Green, + Blue int + Alpha float64 +} + +func RgbaNew(r, g, b int, a float64) *Rgba { + return &Rgba{ + Red: r, + Green: g, + Blue: b, + Alpha: a} +} + +// ToGdkRGBA: Set values to a new GdkRGBA object +// 'options' means 1st = invert, 2nd = preserve alpha +func (rgba *Rgba) ToGdkRGBA(options ...bool) *gdk.RGBA { + i := 0 + ia := 0.0 + if len(options) > 0 && options[0] { + i = 255 + } + if len(options) > 1 && !options[1] { + ia = 1.0 + } + r := math.Abs(float64(i-rgba.Red)) / 255.0 + g := math.Abs(float64(i-rgba.Green)) / 255.0 + b := math.Abs(float64(i-rgba.Blue)) / 255.0 + a := math.Abs(ia - rgba.Alpha) + + return gdk.NewRGBA(r, g, b, a) +} + +// FromGdkRGBA: Set values from GdkRGBA object +func (rgba *Rgba) FromGdkRGBA(RGBA *gdk.RGBA) { + rgba.Red = int(RGBA.GetRed() * 255) + rgba.Green = int(RGBA.GetGreen() * 255) + rgba.Blue = int(RGBA.GetBlue() * 255) + rgba.Alpha = RGBA.GetAlpha() +} + +// RGBAInvert: do a color video inversion preserving original GdkRBGA +// func RGBAInvert(rgba *gdk.RGBA, invert bool, preserveAlpha ...bool) *gdk.RGBA { + +// var i, ia float64 = 1, 1 +// if !invert { +// i = 0 +// ia = 0 +// } +// if len(preserveAlpha) > 0 && preserveAlpha[0] { +// ia = 0 +// } +// return gdk.NewRGBA( +// math.Abs(i-rgba.GetRed()), +// math.Abs(i-rgba.GetGreen()), +// math.Abs(i-rgba.GetBlue()), +// math.Abs(ia-rgba.GetAlpha())) +// } + +// RGBAParseFromCss: Convert CSS RGBA synbtax to GdkRGBA structure. +func RGBAParseFromCss(r, g, b int, a float64) *gdk.RGBA { + return gdk.NewRGBA(float64(r)/255.0, float64(g)/255.0, float64(b)/255.0, a) +} + +// RGBAParseToCss: Convert GdkRGBA to string that match required format +// by CSS syntax. '255, 255, 255, 0.5'. 'invert' indicate that result +// will be inversed. +func RGBAParseToCss(rgba *gdk.RGBA, invert ...bool) string { + + var inv float64 + if len(invert) > 0 && invert[0] { + inv = 1 + } + return fmt.Sprintf("%d, %d, %d, %1.3f", + int(math.Abs(inv-rgba.Floats()[0])*255), + int(math.Abs(inv-rgba.Floats()[1])*255), + int(math.Abs(inv-rgba.Floats()[2])*255), + math.Abs(inv-rgba.Floats()[3])) +} + +// TODO Checkout for ALPHA chanel +// Convert gdk.RGBA to Hex string value: "#EF2929". +func ColGdkRGBA2Hex(value *gdk.RGBA) string { + // Convert int string value to Hex with 2 digits. + var build2DigitsHex = func(intValueStr string) string { + xi, _ := strconv.Atoi(intValueStr) + xs := fmt.Sprintf("%X", xi) + if len(xs) == 1 { + xs = "0" + xs + } + return xs + } + + regOne := regexp.MustCompile(`[()]`) + regTwo := regexp.MustCompile(`[,]`) + tmpStrSl := regOne.Split(value.String(), -1) + tmpStrSl = regTwo.Split(tmpStrSl[1], -1) + rr := build2DigitsHex(tmpStrSl[0]) + gg := build2DigitsHex(tmpStrSl[1]) + bb := build2DigitsHex(tmpStrSl[2]) + aa := "FF" + if len(tmpStrSl) > 3 { + aa = build2DigitsHex(tmpStrSl[3]) + } + return fmt.Sprintf("#%s%s%s%s", rr, gg, bb, aa) +} diff --git a/vendor/github.com/hfmrow/gtk3Import/pixbuff/pixbufByte.go b/vendor/github.com/hfmrow/gtk3Import/pixbuff/pixbufByte.go new file mode 100644 index 0000000..052235a --- /dev/null +++ b/vendor/github.com/hfmrow/gtk3Import/pixbuff/pixbufByte.go @@ -0,0 +1,652 @@ +// pixbuffByte.go + +/* + Source file auto-generated on Sun, 20 Oct 2019 13:50:31 using Gotk3ObjHandler v1.3.9 ©2018-19 H.F.M + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + ©2019 H.F.M + + This program comes with absolutely no warranty. See the The MIT License (MIT) for details: + https://opensource.org/licenses/mit-license.php +*/ + +package gtk3Import + +import ( + "bytes" + "compress/gzip" + "fmt" + "io" + "io/ioutil" + "os" + "reflect" + + "github.com/gotk3/gotk3/gdk" + "github.com/gotk3/gotk3/gtk" +) + +/*************************************************/ +/* Images functions, used to initialize objects */ +/* You can use it to load your own embedded */ +/* images, icons ... */ +/*********************************************/ + +// TryStockIcon: Convenience function to combine a stock-icons-theme +// and an asset/filename icon to send to "GetPixBuf()" function. +func TryStockIcon(iconLookupFlag gtk.IconLookupFlags, stockName, assetName interface{}) (names []interface{}) { + names = append(names, stockName) + names = append(names, iconLookupFlag) + names = append(names, assetName) + return +} + +// OptPict: hold options for SetPict(), you can use OptPictStructNew() +// to set defaults values. +type OptPict struct { + Size int + // 0 = limit height, 1 = limit width, 2 = percents, + // 3 = limit height or width depending on MaxSize value. + ResizeMethode int + // Rotate image / icon + Rotate gdk.PixbufRotation + // SpinButton / Entry ... icon positions + Position gtk.EntryIconPosition + // Opacity [0.01 to 1.0] work with: Box, ToggleButton, ToolButton, MenuButton, Button + // a value of 0 means 1.0; 0.01 means 0 + Opacity float64 + // Ask for a GdkPixbufAnimation image + Animated bool + // Max size accepted relative to "ResizeMethode" = 3 + MaxSize int +} + +// OptPictStructNew: 'values' options can be nil, ther is no obligation +// to use this function to create the structure because functions are +// designed to handle defaults options automatically, this is a convenient use. +// The options (each values can be nil) order (if used) must be: +// Size, ResizeMethode, Rotate, Position, Opacity, Animated, MaxSize. +func OptPictStructNew(values ...interface{}) OptPict { + + // Set default options + opt := OptPict{ + Size: 0, + ResizeMethode: 0, + Rotate: gdk.PIXBUF_ROTATE_NONE, + Position: gtk.ENTRY_ICON_PRIMARY, + Opacity: 1.0, + Animated: false, + MaxSize: 256, + } + + var fillOptInt = func(i, index int) { + switch index { + + case 0: + opt.Size = i + case 1: + opt.ResizeMethode = i + case 6: + opt.MaxSize = i + } + } + // Fill opt with given values + if values != nil { + for idx, val := range values { + switch val.(type) { + + case nil: + continue + case gdk.PixbufRotation: + opt.Rotate = val.(gdk.PixbufRotation) + case gtk.EntryIconPosition: + opt.Position = val.(gtk.EntryIconPosition) + case float64: + opt.Opacity = val.(float64) + case bool: + opt.Animated = val.(bool) + case int: + fillOptInt(val.(int), idx) + } + } + } + return opt +} + +// getOptPict: Handling OptPict for many usages +func _getOptPict(options ...interface{}) OptPict { + + opt := OptPictStructNew() + + if len(options) > 0 { + switch options[0].(type) { + case int: + opt.Size = options[0].(int) + case interface{}: + opt = options[0].(OptPict) + } + } + return opt +} + +// SetPic: Assign image to an Object depending on type, accept stock-icons-theme, +// filename or []byte. Use OptPict{} struct to set options, size can be applied +// directly as int or be nil. +// The options are described below: +// - Load a gif animated image and specify using animation (true), resizing not +// allowed with animations. +// SetPict(GtkImage, "linearProgressHorzBlue.gif", OptPict{Animated: true}) +// - Resize to 32 pixels height, keep porportions & assign image to GtkButton. +// SetPict(GtkButton, "stillImage.png", 32) or +// SetPict(GtkButton, "stillImage.png", OptPict{Size: 32}) +// - With default size, resizing not allowed for GtkSpinButton position at right-end. +// SetPict(GtkSpinButton, "stillImage.png", OptPict{Position: gtk.ENTRY_ICON_SECONDARY}) +// - Load a stock-icons-theme or an asset/filename icon to a GtkMenuButton where stock not available. +// SetPict(gtk.MenuButton, TryStockIcon("open-menu-symbolic", "stillImage.png"), 18) or +// SetPict(gtk.MenuButton, TryStockIcon("open-menu-symbolic", "stillImage.png"), OptPict{Size: 18}) +// - Rotate upsidedown, resize 14px: +// SetPict(gtk.MenuButton, TryStockIcon("open-menu-symbolic", "stillImage.png"), OptPict{Size: 14, Rotate: gdk.PIXBUF_ROTATE_UPSIDEDOWN}) +func SetPict(iObject, varPath interface{}, options ...interface{}) (err error) { + var inPixbuf *gdk.Pixbuf + var inPixbufAnimation *gdk.PixbufAnimation + var image *gtk.Image + + opt := _getOptPict(options...) + + // Since the default initialization value is set to 0, + // we need to change it to show a visible image ... + if opt.Opacity == 0 { + opt.Opacity = 1 + } + + // Get pixbuff type (normal or animation for GtkImage) + if opt.Animated { + if inPixbufAnimation, err = GetPixBufAnimation(varPath); err == nil { + image, err = gtk.ImageNewFromAnimation(inPixbufAnimation) + } + } else { + if inPixbuf, err = GetPixBuf(varPath, opt); err == nil { + image, err = gtk.ImageNewFromPixbuf(inPixbuf) + } + } + + // Handling the error if there is + if err != nil { + var filename string + // Look for a stock icon or a filename or an ambedded asset + switch path := varPath.(type) { + case []interface{}: + filename = path[2].(string) + default: + filename = path.(string) + } + if _, err = os.Stat(filename); len(filename) > 0 /*os.IsNotExist(err)*/ { + err = fmt.Errorf("SetPict: [%v] %v", varPath, err) + fmt.Println(err.Error()) // double output + } + return + } + + // Objects parsing + if image != nil { + + image.SetOpacity(opt.Opacity) + + switch object := iObject.(type) { + + case *gtk.Button: // Set Image to GtkButton + object.SetImage(image) + object.SetAlwaysShowImage(true) + + case *gtk.MenuButton: // Set Image to GtkMenuButton + object.SetImage(image) + object.SetAlwaysShowImage(true) + + case *gtk.ToggleButton: // Set Image to GtkToggleButton + object.SetImage(image) + object.SetAlwaysShowImage(true) + + case *gtk.ToolButton: // Set Image to GtkToolButton + object.SetIconWidget(image) + + case *gtk.Box: // Add Image to GtkBox + object.Add(image) + + case *gtk.SpinButton: // Set Icon to GtkSpinButton, No resize, No Animate. + object.SetIconFromPixbuf(opt.Position, inPixbuf) + + case *gtk.ApplicationWindow: // Set Icon to GtkApplicationWindow, No Animate. + object.SetIcon(inPixbuf) + + case *gtk.Window: // Set Icon to GtkWindow, No Animate. + object.SetIcon(inPixbuf) + + case *gtk.Image: // Set Image to GtkImage + if opt.Animated { + object.SetFromAnimation(inPixbufAnimation) + } else { + object.SetFromPixbuf(inPixbuf) + } + } + } else { + err = fmt.Errorf("Image error: %v", err) + } + return +} + +// GetPixBuf: Get gdk.PixBuf from stock, filename or []byte, depending +// on type. For an explanation of the options, see above, OptPict{}. +// note: If stock-icons-theme does not exist, the asset/filename icon is used. +func GetPixBuf(varPath interface{}, options ...interface{}) (outPixbuf *gdk.Pixbuf, err error) { + var pixbufLoader *gdk.PixbufLoader + + opt := _getOptPict(options...) + + // Look for a stock icon and a filename or ambedded asset + switch varPath.(type) { + case []interface{}: + var iconTheme *gtk.IconTheme + if iconTheme, err = gtk.IconThemeGetDefault(); err == nil { + stock := varPath.([]interface{})[0].(string) + iconLookupFlags := varPath.([]interface{})[1].(gtk.IconLookupFlags) + outPixbuf, err = iconTheme.LoadIcon(stock, opt.Size, iconLookupFlags) + } + if err != nil { + varPath = varPath.([]interface{})[2] + fmt.Println(err.Error() + ". try to load the secondary choice.") + } + } + + if outPixbuf == nil { // in this case, no stock icon was found or was not requested + switch varPath.(type) { + case string: // Its a filename + outPixbuf, err = gdk.PixbufNewFromFile(varPath.(string)) + case []uint8: // Its a binary data (embedded asset) + if pixbufLoader, err = gdk.PixbufLoaderNew(); err == nil { + outPixbuf, err = pixbufLoader.WriteAndReturnPixbuf(varPath.([]byte)) + } + } + + if err == nil && opt.Size != 0 { + newWidth, newHeight := NormalizeSize(outPixbuf.GetWidth(), outPixbuf.GetHeight(), opt) + if outPixbuf, err = outPixbuf.ScaleSimple(newWidth, newHeight, gdk.INTERP_HYPER); err == nil { + outPixbuf, err = outPixbuf.RotateSimple(opt.Rotate) + } + } + } + return +} + +// GetPixBufAnimation: Get gdk.PixBufAnimation from filename or []byte, depending on type +func GetPixBufAnimation(varPath interface{}) (outPixbufAnimation *gdk.PixbufAnimation, err error) { + var pixbufLoader *gdk.PixbufLoader + switch varPath.(type) { + case string: + outPixbufAnimation, err = gdk.PixbufAnimationNewFromFile(varPath.(string)) + case []uint8: + if pixbufLoader, err = gdk.PixbufLoaderNew(); err == nil { + outPixbufAnimation, err = pixbufLoader.WriteAndReturnPixbufAnimation(varPath.([]byte)) + } + } + return +} + +// NormalizeSize: compute new size with kept proportions based on defined format. +// formats: 0 = limit height, 1 = limit width, 2 = percents, +// 3 = limit height or width depending on MaxSize value. +func NormalizeSize(oldWidth, oldHeight int, options ...interface{}) (outWidth, outHeight int) { + + opt := _getOptPict(options...) + + switch opt.ResizeMethode { + case 0: // limit Height + outWidth = int(float64(oldWidth) * (float64(opt.Size) / float64(oldHeight))) + outHeight = opt.Size + case 1: // limit Width + outWidth = opt.Size + outHeight = int(float64(oldHeight) * (float64(opt.Size) / float64(oldWidth))) + case 2: // percent + outWidth = int((float64(oldWidth) * float64(opt.Size)) / 100) + outHeight = int((float64(oldHeight) * float64(opt.Size)) / 100) + case 3: // limit Height or Width + switch { + case oldWidth >= opt.MaxSize: + opt.Size = opt.MaxSize + opt.ResizeMethode = 1 + return NormalizeSize(oldWidth, oldHeight, opt) + case oldHeight >= opt.MaxSize: + opt.Size = opt.MaxSize + opt.ResizeMethode = 0 + return NormalizeSize(oldWidth, oldHeight, opt) + } + opt.ResizeMethode = 0 + return NormalizeSize(oldWidth, oldHeight, opt) + } + return +} + +/***************************************/ +/* Embedded data conversion functions */ +/* Used to make variable content */ +/* available in go-source */ +/***********************************/ +// GetBytesFromVarAsset: Get []byte representation from file or asset, depending on type +func GetBytesFromVarAsset(varPath interface{}) (outBytes []byte, err error) { + switch reflect.TypeOf(varPath).String() { + case "string": + return ioutil.ReadFile(varPath.(string)) + case "[]uint8": + return varPath.([]byte), err + } + return +} + +// HexToBytes: Convert Gzip Hex to []byte used for embedded binary in source code +func HexToBytes(varPath string, gzipData []byte) (outByte []byte) { + r, err := gzip.NewReader(bytes.NewBuffer(gzipData)) + if err == nil { + var bBuffer bytes.Buffer + if _, err = io.Copy(&bBuffer, r); err == nil { + if err = r.Close(); err == nil { + return bBuffer.Bytes() + } + } + } + if err != nil { + fmt.Printf("An error occurred while reading: %s\n%v\n", varPath, err.Error()) + } + return +} + +/* +* Previous VERSION + */ + +// /*************************************************/ +// /* Images functions, used to initialize objects */ +// /* You can use it to load your own embedded */ +// /* images, icons ... */ +// /*********************************************/ + +// // SetPic: Assign image to an Object depending on type, accept filename or []byte. +// // options: 1- size (int), 2- enable animation (bool) +// // ie: +// // - Load a gif animated image and specify using animation (true), resizing not allowed with animations. +// // SetPict(GtkImage, "linearProgressHorzBlue.gif", 0, true) +// // - Resize to 32 pixels height, keep porportions & assign image to GtkButton. +// // SetPict(GtkButton, "stillImage.png", 32) +// // - With default size, resizing not allowed for GtkSpinButton. +// // SetPict(GtkSpinButton, "stillImage.png") +// func SetPict(iObject, varPath interface{}, options ...interface{}) { +// var err error +// var sze int +// var inPixbuf *gdk.Pixbuf +// var inPixbufAnimation *gdk.PixbufAnimation +// var image *gtk.Image +// var isAnim bool +// pos := gtk.ENTRY_ICON_PRIMARY +// // Options parsing +// var getSizeOrPos = func() { +// switch s := options[0].(type) { +// case int: +// sze = s +// case string: +// if s == "right" { +// pos = gtk.ENTRY_ICON_SECONDARY +// } +// } +// } +// switch len(options) { +// case 1: +// getSizeOrPos() +// case 2: // +// getSizeOrPos() +// isAnim = options[1].(bool) +// } +// if isAnim { // PixbufAnimation case +// if inPixbufAnimation, err = GetPixBufAnimation(varPath); err == nil { +// image, err = gtk.ImageNewFromAnimation(inPixbufAnimation) +// } +// } else { // Pixbuf case +// if inPixbuf, err = GetPixBuf(varPath, sze); err == nil { +// image, err = gtk.ImageNewFromPixbuf(inPixbuf) +// } +// } +// if err != nil { +// if _, err = os.Stat(varPath.(string)); !os.IsNotExist(err) { +// log.Fatalf("SetPict: %v\n%s\n", varPath, err.Error()) +// return +// } +// } +// // Objects parsing +// if image != nil { +// switch object := iObject.(type) { +// case *gtk.Image: // Set Image to GtkImage +// if isAnim { +// object.SetFromAnimation(inPixbufAnimation) +// } else { +// object.SetFromPixbuf(inPixbuf) +// } +// case *gtk.Window: // Set Icon to GtkWindow, No Animate. +// object.SetIcon(inPixbuf) +// case *gtk.Button: // Set Image to GtkButton +// object.SetImage(image) +// object.SetAlwaysShowImage(true) +// case *gtk.ToolButton: // Set Image to GtkToolButton +// object.SetIconWidget(image) +// case *gtk.ToggleButton: // Set Image to GtkToggleButton +// object.SetImage(image) +// object.SetAlwaysShowImage(true) +// case *gtk.SpinButton: // Set Icon to GtkSpinButton. options[0] = "left" or "right", No resize, No Animate. +// object.SetIconFromPixbuf(pos, inPixbuf) +// case *gtk.Box: // Add Image to GtkBox +// object.Add(image) +// } +// } +// return +// } + +// // GetPixBuf: Get gdk.PixBuf from filename or []byte, depending on type +// // size: resize height keeping porportions. 0 = no change +// func GetPixBuf(varPath interface{}, size ...int) (outPixbuf *gdk.Pixbuf, err error) { +// var pixbufLoader *gdk.PixbufLoader +// sze := 0 +// if len(size) != 0 { +// sze = size[0] +// } +// switch varPath.(type) { +// case string: +// outPixbuf, err = gdk.PixbufNewFromFile(varPath.(string)) +// case []uint8: +// if pixbufLoader, err = gdk.PixbufLoaderNew(); err == nil { +// outPixbuf, err = pixbufLoader.WriteAndReturnPixbuf(varPath.([]byte)) +// } +// } +// if err == nil && sze != 0 { +// newWidth, newHeight := NormalizeSize(outPixbuf.GetWidth(), outPixbuf.GetHeight(), sze, 2) +// outPixbuf, err = outPixbuf.ScaleSimple(newWidth, newHeight, gdk.INTERP_BILINEAR) +// } +// return +// } + +// // GetPixBufAnimation: Get gdk.PixBufAnimation from filename or []byte, depending on type +// func GetPixBufAnimation(varPath interface{}) (outPixbufAnimation *gdk.PixbufAnimation, err error) { +// var pixbufLoader *gdk.PixbufLoader +// switch varPath.(type) { +// case string: +// outPixbufAnimation, err = gdk.PixbufAnimationNewFromFile(varPath.(string)) +// case []uint8: +// if pixbufLoader, err = gdk.PixbufLoaderNew(); err == nil { +// outPixbufAnimation, err = pixbufLoader.WriteAndReturnPixbufAnimation(varPath.([]byte)) +// } +// } +// return +// } + +// // NormalizeSize: compute new size with kept proportions based on defined format. +// // format: 0 percent, 1 reducing width, 2 reducing height +// func NormalizeSize(oldWidth, oldHeight, newValue, format int) (outWidth, outHeight int) { +// switch format { +// case 0: // percent +// outWidth = int((float64(oldWidth) * float64(newValue)) / 100) +// outHeight = int((float64(oldHeight) * float64(newValue)) / 100) +// case 1: // Width +// outWidth = newValue +// outHeight = int(float64(oldHeight) * (float64(newValue) / float64(oldWidth))) +// case 2: // Height +// outWidth = int(float64(oldWidth) * (float64(newValue) / float64(oldHeight))) +// outHeight = newValue +// } +// return +// } + +// // ResizeImage: Get Resized gtk.Pixbuff image representation from file or []byte, depending on type +// // interp: 0 GDK_INTERP_NEAREST, 1 GDK_INTERP_TILES, 2 GDK_INTERP_BILINEAR (default), 3 GDK_INTERP_HYPER. +// func ResizeImage(varPath interface{}, width, height int, interp ...int) (outPixbuf *gdk.Pixbuf, err error) { +// interpolation := gdk.INTERP_BILINEAR +// if len(interp) != 0 { +// switch interp[0] { +// case 0: +// interpolation = gdk.INTERP_NEAREST +// case 1: +// interpolation = gdk.INTERP_TILES +// case 3: +// interpolation = gdk.INTERP_HYPER +// } +// } +// if outPixbuf, err = GetPixBuf(varPath); err == nil { +// if width != outPixbuf.GetWidth() || height != outPixbuf.GetHeight() { +// outPixbuf, err = outPixbuf.ScaleSimple(width, height, interpolation) +// } +// } +// return +// } + +// // RotateImage: Rotate by 90,180,270 degres and get gdk.PixBuf image representation from file or []byte, depending on type +// func RotateImage(varPath interface{}, angle gdk.PixbufRotation) (outPixbuf *gdk.Pixbuf, err error) { +// if outPixbuf, err = GetPixBuf(varPath); err == nil { +// switch angle { +// case 90: +// outPixbuf, err = outPixbuf.RotateSimple(gdk.PIXBUF_ROTATE_COUNTERCLOCKWISE) +// case 180: +// outPixbuf, err = outPixbuf.RotateSimple(gdk.PIXBUF_ROTATE_UPSIDEDOWN) +// case 270: +// outPixbuf, err = outPixbuf.RotateSimple(gdk.PIXBUF_ROTATE_CLOCKWISE) +// default: +// return nil, errors.New("Rotation not allowed: " + fmt.Sprintf("%d", angle)) +// } +// } +// return +// } + +// // FlipImage: Get Flipped gdk.PixBuf image representation from file or []byte, depending on type +// func FlipImage(varPath interface{}, horizontal bool) (outPixbuf *gdk.Pixbuf, err error) { +// if outPixbuf, err = GetPixBuf(varPath); err == nil { +// outPixbuf, err = outPixbuf.Flip(horizontal) +// } +// return +// } + +// /* +// Old functions, not used in new programs written and +// will be deleted after updating all other programs +// */ +// // setImage: Set Image to GtkImage objects +// func SetImage(object *gtk.Image, varPath interface{}, size ...int) { +// if inPixbuf, err := GetPixBuf(varPath, size...); err == nil { +// object.SetFromPixbuf(inPixbuf) +// return +// } else if len(varPath.(string)) != 0 { +// fmt.Printf("SetImage: An error occurred on image: %v\n%s\n", varPath, err.Error()) +// } +// } + +// // setWinIcon: Set Icon to GtkWindow objects +// func SetWinIcon(object *gtk.Window, varPath interface{}, size ...int) { +// if inPixbuf, err := GetPixBuf(varPath, size...); err == nil { +// object.SetIcon(inPixbuf) +// } else if len(varPath.(string)) != 0 { +// fmt.Printf("SetWinIcon: An error occurred on image: %v\n%s\n", varPath, err.Error()) +// } +// } + +// // setButtonImage: Set Icon to GtkButton objects +// func SetButtonImage(object *gtk.Button, varPath interface{}, size ...int) { +// var image *gtk.Image +// inPixbuf, err := GetPixBuf(varPath, size...) +// if err == nil { +// if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { +// object.SetImage(image) +// object.SetAlwaysShowImage(true) +// return +// } +// } +// if err != nil && len(varPath.(string)) != 0 { +// fmt.Printf("SetButtonImage: An error occurred on image: %v\n%s\n", varPath, err.Error()) +// } +// } + +// // setToolButtonImage: Set Icon to GtkToolButton objects +// func SetToolButtonImage(object *gtk.ToolButton, varPath interface{}, size ...int) { +// var image *gtk.Image +// inPixbuf, err := GetPixBuf(varPath, size...) +// if err == nil { +// if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { +// object.SetIconWidget(image) +// return +// } +// } +// if err != nil && len(varPath.(string)) != 0 { +// fmt.Printf("setToolButtonImage: An error occurred on image: %v\n%s\n", varPath, err.Error()) +// } +// } + +// // setToggleButtonImage: Set Icon to GtkToggleButton objects +// func SetToggleButtonImage(object *gtk.ToggleButton, varPath interface{}, size ...int) { +// var image *gtk.Image +// inPixbuf, err := GetPixBuf(varPath, size...) +// if err == nil { +// if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { +// object.SetImage(image) +// object.SetAlwaysShowImage(true) +// return +// } +// } +// if err != nil && len(varPath.(string)) != 0 { +// fmt.Printf("SetToggleButtonImage: An error occurred on image: %v\n%s\n", varPath, err.Error()) +// } +// } + +// // SetSpinButtonImage: Set Icon to GtkSpinButton objects. Position = "left" or "right" +// func SetSpinButtonImage(object *gtk.SpinButton, varPath interface{}, position ...string) { +// var inPixbuf *gdk.Pixbuf +// var err error +// pos := gtk.ENTRY_ICON_PRIMARY +// if len(position) > 0 { +// if position[0] == "right" { +// pos = gtk.ENTRY_ICON_SECONDARY +// } +// } +// if inPixbuf, err = GetPixBuf(varPath); err == nil { +// object.SetIconFromPixbuf(pos, inPixbuf) +// return +// } else if len(varPath.(string)) != 0 { +// fmt.Printf("SetSpinButtonImage: An error occurred on image: %v\n%s\n", varPath, err.Error()) +// } +// } + +// // setBoxImage: Set Image to GtkBox objects +// func SetBoxImage(object *gtk.Box, varPath interface{}, size ...int) { +// var image *gtk.Image +// inPixbuf, err := GetPixBuf(varPath, size...) +// if err == nil { +// if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { +// image.Show() +// object.Add(image) +// return +// } +// } +// if err != nil && len(varPath.(string)) != 0 { +// fmt.Printf("setBoxImage: An error occurred on image: %v\n%s\n", varPath, err.Error()) +// } +// } diff --git a/vendor/github.com/hfmrow/gtk3Import/pixbuff/pixbuffByte.go b/vendor/github.com/hfmrow/gtk3Import/pixbuff/pixbuffByte.go deleted file mode 100644 index 026661a..0000000 --- a/vendor/github.com/hfmrow/gtk3Import/pixbuff/pixbuffByte.go +++ /dev/null @@ -1,211 +0,0 @@ -// pixbuffByte.go - -// Source file auto-generated on Thu, 21 Feb 2019 00:54:07 using Gotk3ObjHandler v1.0 ©2019 H.F.M - -/* - ©2019 H.F.M - - This program comes with absolutely no warranty. See the The MIT License (MIT) for details: - https://opensource.org/licenses/mit-license.php -*/ - -package gtk3Import - -import ( - "errors" - "fmt" - "reflect" - - "github.com/gotk3/gotk3/gdk" - "github.com/gotk3/gotk3/gtk" -) - -/*************************************************/ -/* Images functions, used to initialize objects */ -/***********************************************/ -// setImage: Set Image to GtkImage objects -func SetImage(object *gtk.Image, varPath interface{}, size ...int) { - if inPixbuf, err := GetPixBuff(varPath, size...); err == nil { - object.SetFromPixbuf(inPixbuf) - return - } else if len(varPath.(string)) != 0 { - fmt.Printf("SetImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } -} - -// setWinIcon: Set Icon to GtkWindow objects -func SetWinIcon(object *gtk.Window, varPath interface{}, size ...int) { - if inPixbuf, err := GetPixBuff(varPath, size...); err == nil { - object.SetIcon(inPixbuf) - } else if len(varPath.(string)) != 0 { - fmt.Printf("SetWinIcon: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } -} - -// setButtonImage: Set Icon to GtkButton objects -func SetButtonImage(object *gtk.Button, varPath interface{}, size ...int) { - var image *gtk.Image - inPixbuf, err := GetPixBuff(varPath, size...) - if err == nil { - if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { - object.SetImage(image) - object.SetAlwaysShowImage(true) - return - } - } - if err != nil && len(varPath.(string)) != 0 { - fmt.Printf("SetButtonImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } -} - -// setToolButtonImage: Set Icon to GtkToolButton objects -func SetToolButtonImage(object *gtk.ToolButton, varPath interface{}, size ...int) { - var image *gtk.Image - inPixbuf, err := GetPixBuff(varPath, size...) - if err == nil { - if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { - object.SetIconWidget(image) - return - } - } - if err != nil && len(varPath.(string)) != 0 { - fmt.Printf("setToolButtonImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } -} - -// setToggleButtonImage: Set Icon to GtkToggleButton objects -func SetToggleButtonImage(object *gtk.ToggleButton, varPath interface{}, size ...int) { - var image *gtk.Image - inPixbuf, err := GetPixBuff(varPath, size...) - if err == nil { - if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { - object.SetImage(image) - object.SetAlwaysShowImage(true) - return - } - } - if err != nil && len(varPath.(string)) != 0 { - fmt.Printf("SetToggleButtonImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } -} - -// SetSpinButtonImage: Set Icon to GtkSpinButton objects. Position = "left" or "right" -func SetSpinButtonImage(object *gtk.SpinButton, varPath interface{}, position ...string) { - var inPixbuf *gdk.Pixbuf - var err error - pos := gtk.ENTRY_ICON_PRIMARY - if len(position) > 0 { - if position[0] == "right" { - pos = gtk.ENTRY_ICON_SECONDARY - } - } - if inPixbuf, err = GetPixBuff(varPath); err == nil { - object.SetIconFromPixbuf(pos, inPixbuf) - return - } else if len(varPath.(string)) != 0 { - fmt.Printf("SetSpinButtonImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } -} - -// setBoxImage: Set Image to GtkBox objects -func SetBoxImage(object *gtk.Box, varPath interface{}, size ...int) { - var image *gtk.Image - inPixbuf, err := GetPixBuff(varPath, size...) - if err == nil { - if image, err = gtk.ImageNewFromPixbuf(inPixbuf); err == nil { - image.Show() - object.Add(image) - return - } - } - if err != nil && len(varPath.(string)) != 0 { - fmt.Printf("setBoxImage: An error occurred on image: %s\n%v\n", varPath, err.Error()) - } -} - -// GetPixBuff: Get gtk.Pixbuff image representation from file or []byte, depending on type -// size: resize height keeping porportions. 0 = no change -func GetPixBuff(varPath interface{}, size ...int) (outPixbuf *gdk.Pixbuf, err error) { - sze := 0 - if len(size) != 0 { - sze = size[0] - } - switch reflect.TypeOf(varPath).String() { - case "string": - outPixbuf, err = gdk.PixbufNewFromFile(varPath.(string)) - case "[]uint8": - pbLoader, err := gdk.PixbufLoaderNew() - if err == nil { - outPixbuf, err = pbLoader.WriteAndReturnPixbuf(varPath.([]byte)) - } - } - if err == nil && sze != 0 { - newWidth, wenHeight := normalizeSize(outPixbuf.GetWidth(), outPixbuf.GetHeight(), sze, 2) - outPixbuf, err = outPixbuf.ScaleSimple(newWidth, wenHeight, gdk.INTERP_BILINEAR) - } - return outPixbuf, err -} - -// NormalizeSize: compute new size with kept proportions based on defined format. -// format: 0 percent, 1 reducing width, 2 reducing height -func normalizeSize(oldWidth, oldHeight, newValue, format int) (outWidth, outHeight int) { - switch format { - case 0: // percent - outWidth = int((float64(oldWidth) * float64(newValue)) / 100) - outHeight = int((float64(oldHeight) * float64(newValue)) / 100) - case 1: // Width - outWidth = newValue - outHeight = int(float64(oldHeight) * (float64(newValue) / float64(oldWidth))) - case 2: // Height - outWidth = int(float64(oldWidth) * (float64(newValue) / float64(oldHeight))) - outHeight = newValue - } - return outWidth, outHeight -} - -// ResizeImage: Get Resized gtk.Pixbuff image representation from file or []byte, depending on type -// interp: 0 GDK_INTERP_NEAREST, 1 GDK_INTERP_TILES, 2 GDK_INTERP_BILINEAR (default), 3 GDK_INTERP_HYPER. -func ResizeImage(varPath interface{}, width, height int, interp ...int) (outPixbuf *gdk.Pixbuf, err error) { - interpolation := gdk.INTERP_BILINEAR - if len(interp) != 0 { - switch interp[0] { - case 0: - interpolation = gdk.INTERP_NEAREST - case 1: - interpolation = gdk.INTERP_TILES - case 3: - interpolation = gdk.INTERP_HYPER - } - } - if outPixbuf, err = GetPixBuff(varPath); err == nil { - if width != outPixbuf.GetWidth() || height != outPixbuf.GetHeight() { - return outPixbuf.ScaleSimple(width, height, interpolation) - } - } - return nil, err -} - -// RotateImage: Rotate by 90,180,270 degres and get gtk.Pixbuff image representation from file or []byte, depending on type -func RotateImage(varPath interface{}, angle gdk.PixbufRotation) (outPixbuf *gdk.Pixbuf, err error) { - if outPixbuf, err = GetPixBuff(varPath); err == nil { - switch angle { - case 90: - return outPixbuf.RotateSimple(gdk.PIXBUF_ROTATE_COUNTERCLOCKWISE) - case 180: - return outPixbuf.RotateSimple(gdk.PIXBUF_ROTATE_UPSIDEDOWN) - case 270: - return outPixbuf.RotateSimple(gdk.PIXBUF_ROTATE_CLOCKWISE) - default: - return nil, errors.New("Rotation options not allowed: " + fmt.Sprintf("%d", angle)) - } - } - return outPixbuf, err -} - -// FlipImage: Get Flipped gtk.Pixbuff image representation from file or []byte, depending on type -func FlipImage(varPath interface{}, horizontal bool) (outPixbuf *gdk.Pixbuf, err error) { - if outPixbuf, err = GetPixBuff(varPath); err == nil { - return outPixbuf.Flip(horizontal) - } - return nil, err -} diff --git a/vendor/github.com/hfmrow/gtk3Import/tools/widgets/widgets.go b/vendor/github.com/hfmrow/gtk3Import/tools/widgets/widgets.go new file mode 100644 index 0000000..1275b1f --- /dev/null +++ b/vendor/github.com/hfmrow/gtk3Import/tools/widgets/widgets.go @@ -0,0 +1,90 @@ +// widgets.go + +/* + Source file auto-generated on Sat, 19 Oct 2019 22:06:16 using Gotk3ObjHandler v1.3.9 ©2018-19 H.F.M + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2019 H.F.M (github.com/hfmrow) + This program comes with absolutely no warranty. See the The MIT License (MIT) for details: + https://opensource.org/licenses/mit-license.php +*/ + +package gtk3Import + +import ( + "reflect" + + "github.com/gotk3/gotk3/gtk" +) + +// WidgetProperties: A convenient structure that implements +// methods to add multiple properties to an object at a time, +// considering a property restriction list that contains +// unauthorized properties for certain types of objects. +type WidgetProperties struct { + properties []widgetProperty + propRestrictions [][]interface{} // List of Property by object that not usable + initialized bool +} +type widgetProperty struct { + Name string + Value interface{} +} + +// PropsToWidget: Apply the properties to the object after filtering +// unauthorized ones. Can be used for independent objects, such as those +// built into an independant box that will be added as a container, to +// the Dialog's list of the main objects. +func (wp *WidgetProperties) PropsToWidget(wdg gtk.IWidget) { + wp.init() + for _, prop := range wp.properties { + for _, obj := range wp.propRestrictions { + if reflect.TypeOf(wdg) == reflect.TypeOf(obj[0]) { + for _, avoidProp := range obj[1:] { + if prop.Name == avoidProp.(string) { + return + } + } + } + } + wdg.Set(prop.Name, prop.Value) + } +} + +// AddPropertyUnallowed: add new unallowed property to the list +// i.e: []interface{}{new(gtk.Image), "justify", "wrap", "pattern", "relief"} +// means that the gtk.Image object cannot handle: +// "justify", "wrap", "pattern", "relief" properties. +func (wp *WidgetProperties) AddPropertyUnallowed(value []interface{}) { + wp.init() + // Add new property for an object to the list that will be applied during control' creation. + wp.propRestrictions = append(wp.propRestrictions, value) +} + +// AddProperty: add new property to the list, will be applied to all parent objects +func (wp *WidgetProperties) AddProperty(name string, value interface{}) { + wp.init() + // Add new property for an object to the list that will be applied during control' creation. + wp.properties = append(wp.properties, widgetProperty{Name: name, Value: value}) +} + +// Reset: user defined lists +func (wp *WidgetProperties) Reset(wdg gtk.IWidget) { + wp.properties = wp.properties[:0] + wp.propRestrictions = wp.propRestrictions[:0] + wp.initialized = false + wp.init() +} + +// init: default unallowed properties for objects +func (wp *WidgetProperties) init() { + if !wp.initialized { + wp.propRestrictions = [][]interface{}{ + {new(gtk.Image), "justify", "wrap", "pattern", "relief"}, + {new(gtk.Separator), "halign", "justify", "wrap", "pattern", "relief"}, + {new(gtk.Calendar), "wrap", "pattern", "relief"}, + {new(gtk.Box), "wrap", "pattern", "relief"}} + wp.initialized = true + } +} diff --git a/vendor/github.com/hfmrow/gtk3Import/treeview/treeView.go b/vendor/github.com/hfmrow/gtk3Import/treeview/treeView.go old mode 100644 new mode 100755 index 3b964b3..3a183f9 --- a/vendor/github.com/hfmrow/gtk3Import/treeview/treeView.go +++ b/vendor/github.com/hfmrow/gtk3Import/treeview/treeView.go @@ -1,12 +1,18 @@ // treeView.go /* - ©2019 H.F.M + Source file auto-generated on Tue, 12 Nov 2019 22:14:11 using Gotk3ObjHandler v1.5 ©2018-19 H.F.M + This software use gotk3 that is licensed under the ISC License: + https://github.com/gotk3/gotk3/blob/master/LICENSE + + Copyright ©2019 H.F.M - TreeView library This program comes with absolutely no warranty. See the The MIT License (MIT) for details: https://opensource.org/licenses/mit-license.php - This library allow to facilitate Treeview operations. + This library allow you to facilitate Treeview operations. Can manage ListView and TreeView, only one of them at a time. + This lib handle every kind of column type as defined in the gtk3 development manual. + Some conveignant functions are available to manage entries, columns, values, rows ... i.e: func exampleTreeViewStructure() { @@ -55,39 +61,128 @@ import ( "github.com/gotk3/gotk3/gtk" ) -// Notice: All options, functions, if they're needed, must be set before starting "StoreSetup" function. -// Otherwise, you can modify all of them at run time using Gtk3 objects -// (TreeView, ListStore, TreeStore, Columns, and so on). You can access it using the main structure. +// This library allow you to facilitate Treeview operations. +// Can manage ListView and TreeView, only one of them at a time. +// This lib handle every kind of column type as defined in the gtk3 +// development manual. Some conveignant functions are available to +// manage entries, columns, values, rows ... +// Notice: All options, functions, if they're needed, must be set +// before starting "StoreSetup" function. Otherwise, you can modify +// all of them at runtime using Gtk3 objects (TreeView, ListStore, +// TreeStore, Columns, and so on). You can access it using the main +// structure. type TreeViewStructure struct { - store gtk.ITreeModel // Used to determine wich TreeModel we work with. - Model *gtk.TreeModel // Actual TreeModel. Used in some functions to avoid use of (switch ... case) type selection. - TreeView *gtk.TreeView - ListStore *gtk.ListStore - TreeStore *gtk.TreeStore - Selection *gtk.TreeSelection - MultiSelection bool - ActivateSingleClick bool - Modified bool - Columns []column - SelectionChangedFunc func() // Function to call when the selection has (possibly) changed. - ForEachFunc func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter, userData interface{}) bool + + // Actual TreeModel. Used in some functions to avoid use of + // (switch ... case) type selection. + Model *gtk.TreeModel + + // Direct acces to implicated objects + TreeView *gtk.TreeView + ListStore *gtk.ListStore + TreeStore *gtk.TreeStore + Selection *gtk.TreeSelection + + // Basic options + MultiSelection bool + ActivateSingleClick bool + + // The model has been modified? + Modified bool + + // All columns option are available throught this structure + Columns []column + ColumnsMinWidth int // Set a minimum width to avoid a warning gtk + + // TODO MAY CAUSE WHOLE FREEZE SOMETIME (undefined) + // When "HasTooltip" is true, this function is launched, + // Case of use: display tooltip according to rows currently hovered. + // returned "bool" means display or not the tooltip. + CallbackTooltipFunc func(iter *gtk.TreeIter, path *gtk.TreePath, column *gtk.TreeViewColumn, tooltip *gtk.Tooltip) bool + HasTooltip, + // Signify that we will use 'query-tooltip' signal callback + UseQueryTooltip bool + + // Function to call when the selection has (possibly) changed. + SelectionChangedFunc func() + + // This function is called (if not nil) each time a column value is changed. + CallbackOnSetColValue func(iter *gtk.TreeIter, col int, value interface{}) + + // Used for gtk.Model.ForEach functions + ModelForEachFunc func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) bool + + // Used for gtk.TreeSelection.SetSelectFunction + SelectFunction func(selection *gtk.TreeSelection, model *gtk.TreeModel, path *gtk.TreePath, selected bool) bool + + // Used for gtk.TreeSelection.ForEachFunc + SelectionForEachFunc func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) + + // Used to substract from Y coordinates when using tooltip + headerHeight int + // Used to determine wich TreeModel we work with. + StoreType gtk.ITreeModel + + colTypeSl []glib.Type } type column struct { - Name string - Editable bool - ReadOnly bool - Sortable bool - Resizable bool - Expand bool - Visible bool - Attribute string // "text", "markup", "pixbuf", "progress", "spinner", "active" (toggle button) - Column *gtk.TreeViewColumn - EditTextFunc func(cellRendererText *gtk.CellRendererText, path, text string, col int) // "text" - EditActiveFunc func(cellRendererToggle *gtk.CellRendererToggle, path string, col int) // "active" (toggle button) -} - -// Create a new treeview structure (*TreeViewStructure) + Name string + Editable bool + ReadOnly bool + Sortable bool + Resizable bool + Expand bool + Visible bool + + // Attributes with layout: "text", "markup", "pixbuf", "combo", "progress", "spinner", "active" (toggle button) + // Attributes without layout: "pointer", "integer", "uint64", "int64" + Attribute string + + // Direct access to the GtkTreeViewColumn and his CellRenderer + Column *gtk.TreeViewColumn + ColType glib.Type + CellRenderer gtk.ICellRenderer + + // There is some default function defined for cell edition, normally, you don't have to define it yourself. + // But in the case where you need specific operations, you can build you own edition function. + EditTextFunc func(cellRendererText *gtk.CellRendererText, path, text string) // "text" + EditActiveFunc func(cellRendererToggle *gtk.CellRendererToggle, path string) // "active" (toggle button) + + // Functions below require a type assertion that the CellRenderer type comes from, + // e.g: cellRenderer.(*Gtk.CellRendererText). + // Generic conditional edition function. The 'values' can be nonexistant, unique or multiple and sometimes, + // require a type assertion in callback, that depend on which CellRenderer type the,'signal' come from. + EditConditionFunc func(cellRenderer interface{}, path string, col int, values ...interface{}) bool + + // Callback function and flag that permit to write cell on cancel 'text' + // both must be defined before 'store' initialisation. + WriteOnCancel bool + WriteOnCancelCallback func(text string) bool // Usually used for confirmation dialog +} + +// GetHeaderButton: Retrieve the button that assigned to the column header. +// May be used after "StoreSetup()" method. +func (col *column) GetHeaderButton() (button *gtk.Button, err error) { + // var iWdgt *gtk.IWidget + button = new(gtk.Button) + if iWdgt, err := col.Column.GetButton(); err == nil { + // Wrap button + wdgt := iWdgt.ToWidget() + actionable := >k.Actionable{wdgt.Object} + button = >k.Button{gtk.Bin{gtk.Container{*wdgt}}, actionable} + } + return +} + +/*********************\ +* Setup Functions * +* Func that applied to * +* buils and handle * +* treeview & models * +***********************/ + +// Create a new treeview structure. func TreeViewStructureNew(treeView *gtk.TreeView, multiselection, activateSingleClick bool) (tvs *TreeViewStructure, err error) { tvs = new(TreeViewStructure) // Store data @@ -95,69 +190,110 @@ func TreeViewStructureNew(treeView *gtk.TreeView, multiselection, activateSingle tvs.MultiSelection = multiselection tvs.TreeView = treeView tvs.ClearAll() + tvs.ColumnsMinWidth = 13 // Set a minimum width to avoid a warning gtk + + tvs.HasTooltip = true + + tvs.CallbackTooltipFunc = nil /*func(iter *gtk.TreeIter, path *gtk.TreePath, column *gtk.TreeViewColumn, tooltip *gtk.Tooltip) bool { + return false + }*/ + if tvs.Selection, err = tvs.TreeView.GetSelection(); err != nil { - return nil, errors.New(fmt.Sprintln("Unable to get gtk.TreeSelection: ", err)) + return nil, fmt.Errorf("Unable to get gtk.TreeSelection: %s\n", err.Error()) } return } -// StoreSetup: Configure the TreeView columns and build the *gtk.ListStore or -// *gtk.TreeStore object. The "store" argument must be *gtk.ListStore or -// *gtk.TreeStore to indicate with what kind of TreeModel we are working ... +// StoreSetup: Configure the TreeView columns and build the gtk.ListStore or +// gtk.TreeStore object. All parameters, personals or callback functions +// must be defined before calling StoreSetup in case you don't want to use +// the predefined ones and prefer to use your own (functions / callback). +// The "store" argument must be *gtk.ListStore or +// *gtk.TreeStore to indicate which kind of TreeModel we are working with ... // i.e: // StoreSetup(new(gtk.TreeStore)), configure struct to work with a TreeStore. // StoreSetup(new(gtk.ListStore)), configure struct to work with a ListStore. func (tvs *TreeViewStructure) StoreSetup(store gtk.ITreeModel) (err error) { - var colTypeSl []glib.Type var tmpColType glib.Type - tvs.store = store + tvs.StoreType = store + tvs.headerHeight = -1 + + // Removing existing columns if there is ... + for idx := int(tvs.TreeView.GetNColumns()) - 1; idx > -1; idx-- { + tvs.TreeView.RemoveColumn(tvs.TreeView.GetColumn(idx)) + } + + // Tooltip setup + if tvs.HasTooltip { + + tvs.TreeView.SetProperty("has-tooltip", true) + + if tvs.UseQueryTooltip { + // TODO Disabled to show if issue (freeze) with gdpf stop occuring + tvs.TreeView.Connect("query-tooltip", tvs.treeViewQueryTooltip) + } + + } else { + + tvs.TreeView.SetProperty("has-tooltip", false) + } + // Set options tvs.TreeView.SetActivateOnSingleClick(tvs.ActivateSingleClick) if tvs.MultiSelection { tvs.Selection.SetMode(gtk.SELECTION_MULTIPLE) } + // Build columns and his (default) edit function according to his type. for colIdx, _ := range tvs.Columns { if tmpColType, err = tvs.insertColumn(colIdx); err != nil { - return errors.New(fmt.Sprintf("Unable to insert column nb %d: %s", colIdx, err.Error())) + return fmt.Errorf("Unable to insert column nb %d: %s\n", colIdx, err.Error()) } else { - colTypeSl = append(colTypeSl, tmpColType) - } - } - if err == nil { - if err = tvs.buildStore(colTypeSl); err == nil { - // For replacment (In some cases) of typed methode assignation (switch ... case) - switch store.(type) { - case *gtk.ListStore: - tvs.Model = &tvs.ListStore.TreeModel - case *gtk.TreeStore: - tvs.Model = &tvs.TreeStore.TreeModel - } + tvs.Columns[colIdx].ColType = tmpColType + tvs.colTypeSl = append(tvs.colTypeSl, tmpColType) } } - return err -} -// StoreDetach: Unlink "TreeModel" from TreeView. Useful when lot of rows must be inserted. -// After insertion, StoreAttach() must be used to restore the link with the treeview. -// tips: must be used before gtk.ListStore.Clear(). -func (tvs *TreeViewStructure) StoreDetach() { - if tvs.store != nil { - tvs.Model.Ref() - tvs.TreeView.SetModel(nil) - } + return tvs.buildStore() } -// StoreAttach: To use after data insertion to restore the link with TreeView. -func (tvs *TreeViewStructure) StoreAttach() { - if tvs.store != nil { - tvs.TreeView.SetModel(tvs.Model) - tvs.Model.Unref() +// buildStore: Build ListStore or TreeStore object. Depending on provided +// object type in "StoreType" variable. +func (tvs *TreeViewStructure) buildStore() (err error) { + + switch tvs.StoreType.(type) { + case *gtk.ListStore: // Create the ListStore. + if tvs.ListStore, err = gtk.ListStoreNew(tvs.colTypeSl...); err != nil { + return fmt.Errorf("Unable to create ListStore: %v", err) + } + tvs.Model = &tvs.ListStore.TreeModel + tvs.TreeView.SetModel(tvs.ListStore) + + case *gtk.TreeStore: // Create the TreeStore. + if tvs.TreeStore, err = gtk.TreeStoreNew(tvs.colTypeSl...); err != nil { + return fmt.Errorf("Unable to create TreeStore: %v", err) + } + tvs.Model = &tvs.TreeStore.TreeModel + tvs.TreeView.SetModel(tvs.TreeStore) + } + // Emitted whenever the selection has (possibly, RTFM) changed. + if tvs.SelectionChangedFunc != nil { // link to callback function if exists. + tvs.Selection.Connect("changed", tvs.SelectionChangedFunc) + } + return err } -// RemoveColumns: Remove column from MainStructure and TreeView. +/*******************************\ +* Struct columns Functions * +* Funct that applied to columns * +* handled by the main structure * +* this is the step before cols * +* integration to the treeview * +*********************************/ + +// RemoveColumn: Remove column from MainStructure and TreeView. func (tvs *TreeViewStructure) RemoveColumn(col int) (columnCount int) { columnCount = tvs.TreeView.RemoveColumn(tvs.Columns[col].Column) tvs.Columns = append(tvs.Columns[:col], tvs.Columns[col+1:]...) @@ -165,266 +301,563 @@ func (tvs *TreeViewStructure) RemoveColumn(col int) (columnCount int) { return } -// InsertColumn: Insert new column to MainStructure. +// InsertColumn: Insert new column to MainStructure, StoreSetup method must be called after. func (tvs *TreeViewStructure) InsertColumn(name, attribute string, pos int, editable, readOnly, sortable, resizable, expand, visible bool) { newCol := []column{{Name: name, Attribute: attribute, Editable: editable, ReadOnly: readOnly, Sortable: sortable, Resizable: resizable, Expand: expand, Visible: visible}} tvs.Columns = append(tvs.Columns[:pos], append(newCol, tvs.Columns[pos:]...)...) + tvs.Modified = true } -// AddColumn: Add new column to MainStructure. -// attribute may be: text, pixbuf, progress, spinner, toggle +// AddColumn: Adds a single new column to MainStructure. +// attribute may be: text, markup, pixbuf, combo, progress, spinner, active ... +// see above for complete list. func (tvs *TreeViewStructure) AddColumn(name, attribute string, editable, readOnly, sortable, resizable, expand, visible bool) { + + // col := column{Name: name, Attribute: attrMap[attribute], Editable: editable, ReadOnly: readOnly, col := column{Name: name, Attribute: attribute, Editable: editable, ReadOnly: readOnly, Sortable: sortable, Resizable: resizable, Expand: expand, Visible: visible} - tvs.Columns = append(tvs.Columns, col) + tvs.Modified = true } -// RemoveColumns: Clear TreeView columns and ListStore or TreeStore object. -// Depending on provided object type in "store" variable. -func (tvs *TreeViewStructure) ClearAll( /**/ ) (err error) { - if tvs.TreeView != nil && len(tvs.Columns) != 0 { - tvs.TreeView.SetModel(nil) - for idx := len(tvs.Columns) - 1; idx > -1; idx-- { - tvs.RemoveColumn(idx) // Remove columns (from last to first) - } - switch tvs.store.(type) { - case *gtk.ListStore: - if tvs.ListStore != nil { - tvs.ListStore.Clear() - tvs.ListStore.Unref() - } - case *gtk.TreeStore: - if tvs.TreeStore != nil { - tvs.TreeStore.Clear() - tvs.TreeStore.Unref() - } - } +// AddColumns: Adds several new columns to MainStructure. +// attribute may be: text, markup, pixbuf, combo, progress, spinner, active +func (tvs *TreeViewStructure) AddColumns(nameAndAttribute [][]string, editable, readOnly, + sortable, resizable, expand, visible bool) { + for _, inCol := range nameAndAttribute { + tvs.AddColumn(inCol[0], inCol[1], editable, readOnly, sortable, resizable, expand, visible) } - return + tvs.Modified = true } +/**************************\ +* Building Functions * +* Make to create treemodel * +* and handle the differant * +* kind of columns with * +* predefined edit functions * +****************************/ + // insertColumn: Insert column at defined position func (tvs *TreeViewStructure) insertColumn(colIdx int) (colType glib.Type, err error) { // renderCell: Set cellRenderer type and column options var renderCell = func(cellRenderer gtk.ICellRenderer, colIdx int) (err error) { var column *gtk.TreeViewColumn + if column, err = gtk.TreeViewColumnNewWithAttribute(tvs.Columns[colIdx].Name, - cellRenderer, tvs.Columns[colIdx].Attribute, colIdx); err == nil { - tvs.Columns[colIdx].Column = column - column.SetExpand(tvs.Columns[colIdx].Expand) - column.SetResizable(tvs.Columns[colIdx].Resizable) // Set column resizable - column.SetVisible(tvs.Columns[colIdx].Visible) - if tvs.Columns[colIdx].Sortable { - column.SetSortColumnID(colIdx) // Set column sortable - } - // tvs.TreeView.AppendColumn(column) + cellRenderer, + tvs.Columns[colIdx].Attribute, + colIdx); err == nil { + tvs.Columns[colIdx].CellRenderer = cellRenderer // Store de CellRenderer used by this column + tvs.Columns[colIdx].Column = column // store column object to main struct. + column.SetMinWidth(tvs.ColumnsMinWidth) // Set a minimum width (13) to avoid a warning gtk + column.SetExpand(tvs.Columns[colIdx].Expand) // Set expand option + column.SetResizable(tvs.Columns[colIdx].Resizable) // Set resizable option + column.SetVisible(tvs.Columns[colIdx].Visible) // Set visible option + if tvs.Columns[colIdx].Sortable { // Set sortable option + column.SetSortColumnID(colIdx) + } tvs.TreeView.InsertColumn(column, colIdx) } return err } - atrribute := tvs.Columns[colIdx].Attribute + attribute := tvs.Columns[colIdx].Attribute switch { - case atrribute == "active": // "toggle" - var cellRenderer *gtk.CellRendererToggle - if cellRenderer, err = gtk.CellRendererToggleNew(); err == nil { - // Define an edit function if not previously given + case attribute == "active": // "toggle" + + var cellRendererToggle *gtk.CellRendererToggle + if cellRendererToggle, err = gtk.CellRendererToggleNew(); err == nil { + + // Define DEFAULT *conditional* function for checkbox edition if is not user defined + if tvs.Columns[colIdx].EditConditionFunc == nil { + tvs.Columns[colIdx].EditConditionFunc = func(cellRenderer interface{}, path string, col int, values ...interface{}) bool { + return true + } + } + + // An edit function may be user defined before structure initialisation, + // if not, this one, is set as the default edit function for checkboxes. if tvs.Columns[colIdx].EditActiveFunc == nil { - tvs.Columns[colIdx].EditActiveFunc = func(cellRendererToggle *gtk.CellRendererToggle, path string, col int) { - if !tvs.Columns[col].ReadOnly { - var iter /*parentIter,*/ *gtk.TreeIter - var childIter = new(gtk.TreeIter) - var gValue *glib.Value - var goValue interface{} - var ok bool - var changeValues = func(childIter *gtk.TreeIter, col int, goValue interface{}) (ok bool, err error) { - switch tvs.store.(type) { - case *gtk.ListStore: - if err = tvs.ListStore.SetValue(childIter, col, !goValue.(bool)); err == nil { - tvs.Modified = true - } - case *gtk.TreeStore: - if err = tvs.TreeStore.SetValue(childIter, col, !goValue.(bool)); err == nil { - tvs.Modified = true - } - } - if err == nil { - return tvs.Model.IterNext(childIter), nil - } - return ok, err - } - if iter, err = tvs.Model.GetIterFromString(path); err == nil { - if gValue, err = tvs.Model.GetValue(iter, col); err == nil { - if goValue, err = gValue.GoValue(); err == nil { - if tvs.Model.IterHasChild(iter) { // Change state of all childs if there exists - ok = tvs.Model.IterChildren(iter, childIter) - for ok { - if ok, err = changeValues(childIter, col, goValue); err != nil { - log.Fatalf("Unable to edit (toggle) cell col %d, path %s: %s\n", col, path, err.Error()) - } + tvs.Columns[colIdx].EditActiveFunc = func(cellRenderer *gtk.CellRendererToggle, path string) { + if !tvs.Columns[colIdx].ReadOnly { + // Conditional function: the "EditActiveFunc" is launched if condition is respected + if tvs.Columns[colIdx].EditConditionFunc(cellRendererToggle, path, colIdx) { + + var ( + err error + currState bool + currIter = new(gtk.TreeIter) + parentIter = new(gtk.TreeIter) + ) + + if currIter, err = tvs.Model.GetIterFromString(path); err == nil { + currState = tvs.GetColValue(currIter, colIdx).(bool) + if err = tvs.SetColValue(currIter, colIdx, !currState); err == nil { + // Change the state of the children if it exists + if tvs.Model.IterHasChild(currIter) { + tvs.changeChildrenTreeState(path, currIter, colIdx, !currState) + } + + // Get parent if exits + for tvs.Model.IterParent(parentIter, currIter) { + // if tvs.Model.IterParent(parentIter, currIter) { + // Change parent state if all child are checked, otherwise, uncheck it + if err = tvs.SetColValue(parentIter, colIdx, tvs.AllChildsCheckedState(parentIter, colIdx, false)); err == nil { + currIter = parentIter + parentIter = new(gtk.TreeIter) } } } } - _, err = changeValues(iter, col, goValue) - } - if err != nil { - log.Fatalf("Unable to edit (toggle) cell col %d, path %s: %s\n", col, path, err.Error()) + if err != nil { + log.Fatalf("Unable to edit (toggle) cell col %d, path %s: %s\n", colIdx, path, err.Error()) + } } } } } + if err == nil { - if _, err = cellRenderer.Connect("toggled", tvs.Columns[colIdx].EditActiveFunc, colIdx); err == nil { - if err = renderCell(cellRenderer, colIdx); err == nil { - colType = glib.TYPE_BOOLEAN - } + cellRendererToggle.Connect("toggled", tvs.Columns[colIdx].EditActiveFunc) + if err = renderCell(cellRendererToggle, colIdx); err == nil { + colType = glib.TYPE_BOOLEAN } + } } - case atrribute == "spinner": - var cellRenderer *gtk.CellRendererSpinner - if cellRenderer, err = gtk.CellRendererSpinnerNew(); err == nil { - cellRenderer.SetProperty("editable", tvs.Columns[colIdx].Editable) - if err = renderCell(cellRenderer, colIdx); err == nil { + case attribute == "spinner": + var cellRendererSpinner *gtk.CellRendererSpinner + if cellRendererSpinner, err = gtk.CellRendererSpinnerNew(); err == nil { + cellRendererSpinner.SetProperty("editable", tvs.Columns[colIdx].Editable) + if err = renderCell(cellRendererSpinner, colIdx); err == nil { colType = glib.TYPE_FLOAT } } - case atrribute == "progress": - var cellRenderer *gtk.CellRendererProgress - if cellRenderer, err = gtk.CellRendererProgressNew(); err == nil { - cellRenderer.SetProperty("editable", tvs.Columns[colIdx].Editable) - if err = renderCell(cellRenderer, colIdx); err == nil { + case attribute == "progress": + var cellRendererProgress *gtk.CellRendererProgress + if cellRendererProgress, err = gtk.CellRendererProgressNew(); err == nil { + cellRendererProgress.SetProperty("editable", tvs.Columns[colIdx].Editable) + if err = renderCell(cellRendererProgress, colIdx); err == nil { + colType = glib.TYPE_OBJECT + } + } + case attribute == "pixbuf": + var cellRendererPixbuf *gtk.CellRendererPixbuf + if cellRendererPixbuf, err = gtk.CellRendererPixbufNew(); err == nil { + if err = renderCell(cellRendererPixbuf, colIdx); err == nil { colType = glib.TYPE_OBJECT } } - case atrribute == "pixbuf": - var cellRenderer *gtk.CellRendererPixbuf - if cellRenderer, err = gtk.CellRendererPixbufNew(); err == nil { - if err = renderCell(cellRenderer, colIdx); err == nil { + case attribute == "combo": + var cellRendererCombo *gtk.CellRendererCombo + if cellRendererCombo, err = gtk.CellRendererComboNew(); err == nil { + cellRendererCombo.SetProperty("editable", tvs.Columns[colIdx].Editable) + if err = renderCell(cellRendererCombo, colIdx); err == nil { colType = glib.TYPE_OBJECT } } - case atrribute == "text" || atrribute == "markup": - var cellRenderer *gtk.CellRendererText - cellRenderer, err = gtk.CellRendererTextNew() - cellRenderer.SetProperty("editable", tvs.Columns[colIdx].Editable) - // Define an edit function if not previously given - if tvs.Columns[colIdx].EditTextFunc == nil { - tvs.Columns[colIdx].EditTextFunc = func(cellRendererText *gtk.CellRendererText, path, text string, col int) { - if !tvs.Columns[col].ReadOnly { - var iter *gtk.TreeIter - if iter, err = tvs.Model.GetIterFromString(path); err == nil { - switch tvs.store.(type) { - case *gtk.ListStore: - if err = tvs.ListStore.SetValue(iter, col, text); err == nil { - tvs.Modified = true + case attribute == "text" || attribute == "markup": + var cellRendererText *gtk.CellRendererText + if cellRendererText, err = gtk.CellRendererTextNew(); err == nil { + cellRendererText.SetProperty("editable", tvs.Columns[colIdx].Editable) + /* + * + */ + + if tvs.Columns[colIdx].WriteOnCancel { + // Ask to record entry if the 'editing-canceled' signal appear (like focus out treeview) + cellRendererText.Connect("editing-started", + func(cellRendererText *gtk.CellRendererText, editable gtk.ICellEditable, path string) { + var PreviousText string + // Transtype ICellEditable interface to GtkCellEditable object + cEditable, _ := editable.(*gtk.CellEditable) + // Retrieve a GtkEntry from GtkCellEditable + entry := cEditable.ToEntry() + PreviousText, _ = entry.GetText() + entry.Connect("editing-done", func() { + text, _ := entry.GetText() + entry.SetText(text) + // If there is no change in the cell, simply exit + if PreviousText == text { + return } - case *gtk.TreeStore: - if err = tvs.TreeStore.SetValue(iter, col, text); err == nil { - tvs.Modified = true + // On 'editing-canceled' signal, handling it to get Gtkentry content and write it to GtkListStore + if value, _ := cEditable.GetProperty("editing-canceled"); value.(bool) { + if tvs.Columns[colIdx].WriteOnCancelCallback != nil { + if !tvs.Columns[colIdx].WriteOnCancelCallback(text) { + return + } + } + + iter, _ := tvs.Model.GetIterFromString(path) + tvs.SetColValue(iter, colIdx, text) + } + }) + }) + } + + /* + * + */ + // Define DEFAULT *conditional* function for text edition if is not user defined + if tvs.Columns[colIdx].EditConditionFunc == nil { + tvs.Columns[colIdx].EditConditionFunc = func(cellRenderer interface{}, path string, col int, values ...interface{}) bool { + return true + } + } + + // An edit function may be user-defined before structure initialisation, + // if not, this one, is set as the DEFAULT edit function for text cells. + if tvs.Columns[colIdx].EditTextFunc == nil { + + tvs.Columns[colIdx].EditTextFunc = func(cellRenderer *gtk.CellRendererText, path string, text string) { + if !tvs.Columns[colIdx].ReadOnly { + + // Conditional function: the "EditTextFunc" is launched if condition is respected + if tvs.Columns[colIdx].EditConditionFunc(cellRendererText, path, colIdx, text) { + + var iter *gtk.TreeIter + if iter, err = tvs.Model.GetIterFromString(path); err == nil { + switch tvs.StoreType.(type) { + case *gtk.ListStore: + if err = tvs.ListStore.SetValue(iter, colIdx, text); err == nil { + tvs.Modified = true + } + case *gtk.TreeStore: + if err = tvs.TreeStore.SetValue(iter, colIdx, text); err == nil { + tvs.Modified = true + } + } + } + if err != nil { + log.Fatalf("Unable to edit (text) cell col %v, path %v, text %v: %v\n", colIdx, path, text, err) } } } - if err != nil { - log.Fatalf("Unable to edit (text) cell col %d, path %s, text %s: %s\n", col, path, text, err.Error()) - } } } - } - if err == nil { - if _, err = cellRenderer.Connect("edited", tvs.Columns[colIdx].EditTextFunc, colIdx); err == nil { - if err = renderCell(cellRenderer, colIdx); err == nil { + + if err == nil { + cellRendererText.Connect("edited", tvs.Columns[colIdx].EditTextFunc) + if err = renderCell(cellRendererText, colIdx); err == nil { colType = glib.TYPE_STRING } } } + + // For these Type, there is no layout + case attribute == "pointer": // Pointer + + colType = glib.TYPE_POINTER + + case attribute == "integer": // INT + + colType = glib.TYPE_INT + + case attribute == "uint64": // UINT64 + + colType = glib.TYPE_UINT64 + + case attribute == "int64": // INT64 + + colType = glib.TYPE_INT64 + default: - err = errors.New(fmt.Sprintf("Error on setting attribute: %s is not implemented or inexistent.\n", tvs.Columns[colIdx].Attribute)) + err = fmt.Errorf("Error on setting attribute: %s is not implemented or inexistent.\n", tvs.Columns[colIdx].Attribute) } if err != nil { - err = errors.New(fmt.Sprintf("Unable to Renderer Cell: %s\n", err.Error())) + err = fmt.Errorf("Unable to make Renderer Cell: %s\n", err.Error()) + } else { + // Add type to columns structure. + tvs.Columns[colIdx].ColType = colType } return colType, err } -// buildStore: Build ListStore or TreeStore object. Depending on provided object type in "store" variable. -func (tvs *TreeViewStructure) buildStore(colTypeSl []glib.Type) (err error) { - switch tvs.store.(type) { - case *gtk.ListStore: - // Creating a ListStore. This is what holds the data that will be shown on our TreeView. - if tvs.ListStore, err = gtk.ListStoreNew(colTypeSl...); err != nil { - return errors.New(fmt.Sprintf("Unable to create ListStore: %s\n", err.Error())) +/**********************\ +* Iters Functions * +* Func that * +* applied to Iters * +************************/ + +// GetSelectedIters: retrieve list of selected iters, +// return nil whether nothing selected. +func (tvs *TreeViewStructure) GetSelectedIters() (iters []*gtk.TreeIter) { + iters = make([]*gtk.TreeIter, tvs.Selection.CountSelectedRows()) + var count int + // tvs.Selection.SelectedForEach(func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter, userData interface{}) { + tvs.Selection.SelectedForEach(func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) { + iters[count] = iter + count++ + }) + if len(iters) == 0 { + iters = nil + } + return +} + +// GetSelectedPaths: retrieve list of selected paths, +// return nil whether nothing selected. +func (tvs *TreeViewStructure) GetSelectedPaths() (paths []*gtk.TreePath) { + paths = make([]*gtk.TreePath, tvs.Selection.CountSelectedRows()) + var count int + tvs.Selection.SelectedForEach(func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) { + paths[count] = path + count++ + }) + if len(paths) == 0 { + paths = nil + } + return +} + +// ItersSelect: Select provided Iters. +func (tvs *TreeViewStructure) ItersSelect(iters ...*gtk.TreeIter) { + for _, iter := range iters { + if !tvs.Selection.IterIsSelected(iter) { + tvs.Selection.SelectIter(iter) } - tvs.TreeView.SetModel(tvs.ListStore) - case *gtk.TreeStore: - // Creating a TreeStore. This is what holds the data that will be shown on our TreeView. - if tvs.TreeStore, err = gtk.TreeStoreNew(colTypeSl...); err != nil { - return errors.New(fmt.Sprintf("Unable to create TreeStore: %s\n", err.Error())) + } +} + +// ItersUnselectAll: Unselect all selected iters. +func (tvs *TreeViewStructure) ItersUnselectAll() { + tvs.Selection.UnselectAll() +} + +// ItersUnselect: Unselect provided Iters. +func (tvs *TreeViewStructure) ItersUnselect(iters ...*gtk.TreeIter) { + for _, iter := range iters { + if tvs.Selection.IterIsSelected(iter) { + tvs.Selection.UnselectIter(iter) } - tvs.TreeView.SetModel(tvs.TreeStore) } - // Emitted whenever the selection has (possibly) changed. - if tvs.SelectionChangedFunc != nil { - _, err = tvs.Selection.Connect("changed", tvs.SelectionChangedFunc) +} + +// ItersSelectRange: Select range between start and end iters. +func (tvs *TreeViewStructure) ItersSelectRange(startIter, endIter *gtk.TreeIter) (err error) { + var startPath, endPath *gtk.TreePath + + if startPath, err = tvs.Model.GetPath(startIter); err == nil { + if endPath, err = tvs.Model.GetPath(endIter); err == nil { + tvs.Selection.SelectRange(startPath, endPath) + } } return err } -// CountRows: Return the number of rows in treeview. -func (tvs *TreeViewStructure) CountRows() (count int) { +// ScrollToIter: scroll to iter, pointing to the column if it has been specified. +func (tvs *TreeViewStructure) IterScrollTo(iter *gtk.TreeIter, column ...int) (err error) { + var path *gtk.TreePath + var colNb int + if len(column) > 0 { + colNb = column[0] + } + if col := tvs.TreeView.GetColumn(colNb); col != nil { + if path, err = tvs.Model.GetPath(iter); err == nil { + if path != nil { + tvs.TreeView.ScrollToCell(path, col, true, 0.5, 0.5) + } else { + err = fmt.Errorf("IterScrollTo: Unable to get path from iter\n") + } + } + } else { + err = fmt.Errorf("IterScrollTo: Unable to get column %d\n", colNb) + } + return +} + +/*******************************\ +* Cols Functions * +* Funct that applied to Columns * +*********************************/ + +// GetColValue: Get value from iter of specific column as interface type. +func (tvs *TreeViewStructure) GetColValue(iter *gtk.TreeIter, col int) (value interface{}) { + var gValue *glib.Value var err error - var forEachFunc = func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter, userData interface{}) bool { - count++ - return false + if gValue, err = tvs.Model.GetValue(iter, col); err == nil { + if value, err = gValue.GoValue(); err == nil { + return + } } - switch tvs.store.(type) { + log.Fatalf("GetColValue: %s\n", err.Error()) + return +} + +// SetColValueWithCallback: set the value to iter for a specific column as an interface type. +// A callback function is called giving the possibility to perform interactive operations. +// func (tvs *TreeViewStructure) SetColValueWithCallback (iter *gtk.TreeIter, col int, value interface{}) (err error) { + +// var ( +// oldVal *glib.Value +// oldValue interface{} +// ) + +// switch tvs.StoreType.(type) { +// case *gtk.ListStore: +// if oldVal, err = tvs.ListStore.GetValue(iter, col); err == nil { +// if oldValue, err = oldVal.GoValue(); err == nil { +// err = tvs.ListStore.SetValue(iter, col, value) +// } +// } +// case *gtk.TreeStore: +// if oldVal, err = tvs.TreeStore.GetValue(iter, col); err == nil { +// if oldValue, err = oldVal.GoValue(); err == nil { +// err = tvs.TreeStore.SetValue(iter, col, value) +// } +// } +// } +// if err == nil { +// tvs.Modified = true +// if tvs.CallbackOnSetColValue != nil { +// tvs.CallbackOnSetColValue(iter, col, value, oldValue) +// return +// } +// } +// return +// } + +// SetColValue: Set value to iter for a specific column as interface type. +func (tvs *TreeViewStructure) SetColValue(iter *gtk.TreeIter, col int, value interface{}) (err error) { + + switch tvs.StoreType.(type) { case *gtk.ListStore: - err = tvs.ListStore.ForEach(forEachFunc) + + err = tvs.ListStore.SetValue(iter, col, value) case *gtk.TreeStore: - err = tvs.TreeStore.ForEach(forEachFunc) + + err = tvs.TreeStore.SetValue(iter, col, value) } - if err != nil { - fmt.Printf("Unable to retrieve the number of rows: %s", err.Error()) + if err == nil { + tvs.Modified = true + if tvs.CallbackOnSetColValue != nil { + tvs.CallbackOnSetColValue(iter, col, value) + } } return } -// AddRow: Append a row to the Store (defined by type of "store" variable). -// "parent" is useless for ListStore, if its set to nil on TreeStore, it will create a new parent -func (tvs *TreeViewStructure) AddRow(parent *gtk.TreeIter, row []interface{}) (iter *gtk.TreeIter, err error) { - var colIdx []int - switch tvs.store.(type) { +// GetColValueFromPath: Get value from path of specific column as interface type. +// Note: should be used only if there is no other choice, prefer using iter to get values. +func (tvs *TreeViewStructure) GetColValuePath(path *gtk.TreePath, col int) (value interface{}) { + var err error + var iter *gtk.TreeIter + + switch tvs.StoreType.(type) { case *gtk.ListStore: - for idx, _ := range row { - colIdx = append(colIdx, idx) - } - iter = tvs.ListStore.Append() // Get an iterator for a new row at the end of the ListStore - if err = tvs.ListStore.Set(iter, colIdx, row); err != nil { // Set the contents of the row that the iterator represents - return + iter, err = tvs.ListStore.GetIter(path) + case *gtk.TreeStore: + iter, err = tvs.TreeStore.GetIter(path) + } + if err != nil { + log.Fatalf("GetColValuePath: unable to get iter from path: %s\n", err.Error()) + return + } + return tvs.GetColValue(iter, col) +} + +// SetColValue: Set value to path for a specific column as interface type. +// Note: should be used only if there is no other choice, prefer using iter to set values. +func (tvs *TreeViewStructure) SetColValuePath(path *gtk.TreePath, col int, goValue interface{}) (err error) { + + var iter *gtk.TreeIter + + switch tvs.StoreType.(type) { + + case *gtk.ListStore: + if iter, err = tvs.ListStore.GetIter(path); err == nil { + err = tvs.ListStore.SetValue(iter, col, goValue) } case *gtk.TreeStore: - iter = tvs.TreeStore.Append(parent) // Get an iterator for a new row at the end of the TreeStore or under parent if not nil - for col, value := range row { - if err = tvs.TreeStore.SetValue(iter, col, value); err != nil { // Set the contents of the row that the iterator represents - return - } + if iter, err = tvs.TreeStore.GetIter(path); err == nil { + err = tvs.TreeStore.SetValue(iter, col, goValue) } } if err != nil { - return nil, errors.New(fmt.Sprintln("Unable to add row: %s", err.Error())) + return } tvs.Modified = true - return iter, err + return } -// AddRow: Insert a row after/before iter to "store": ListStore/Treestore. Parent may be nil for Liststore. -func (tvs *TreeViewStructure) InsertRow(inIter, parent *gtk.TreeIter, row []interface{}, before ...bool) (iter *gtk.TreeIter, err error) { +/***************************\ +* Rows Functions * +* Func that applied to rows * +*****************************/ + +// CountRows: Return the number of rows in treeview. +func (tvs *TreeViewStructure) CountRows() (count int) { + switch tvs.StoreType.(type) { + case *gtk.ListStore: + count = tvs.Model.IterNChildren(nil) + case *gtk.TreeStore: + // two different way because TreeStore return the number of toplevel nodes intead of ListStore + + // TODO May cause 'fatal error: invalid pointer found on stack' when used intensivly (querytooltip) + // Find another way to doing the same thing + tvs.Model.ForEach(func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) bool { + count++ + return false + }) + } + return +} + +// GetRowNbIter: Return the row number handled by the given iter, +// without any depth consideration. +func (tvs *TreeViewStructure) GetRowNbIter(iter *gtk.TreeIter) int { + path, err := tvs.Model.GetPath(iter) + if err != nil { + fmt.Printf("Unable to get row number: %s\n", err.Error()) + return -1 + } + ind := path.GetIndices() + return ind[len(ind)-1:][0] +} + +// AddRow: Append a row to the Store (defined by type of "StoreType" variable). +// "parent" is useless for ListStore, if its set to nil on TreeStore, +// it will create a new parent +func (tvs *TreeViewStructure) AddRow(parent *gtk.TreeIter, row ...interface{}) (iter *gtk.TreeIter, err error) { + return tvs.InsertRow(parent, -1, row...) +} + +// InsertRow: Insert a row to the Store (defined by type of "StoreType" variable). +// "parent" is useless for ListStore, if its set to nil on TreeStore, +// it will create a new parent otherwise the new iter will be a child of it. +// "insertPos" indicate row number for insertion, set to -1 means append at the end. +func (tvs *TreeViewStructure) InsertRow(parent *gtk.TreeIter, insertPos int, row ...interface{}) (iter *gtk.TreeIter, err error) { + + iter = new(gtk.TreeIter) + + var colIdx = make([]int, len(row)) + for idx := 0; idx < len(row); idx++ { + colIdx[idx] = idx + } + + switch tvs.StoreType.(type) { + case *gtk.ListStore: + err = tvs.ListStore.InsertWithValues(iter, insertPos, colIdx, row) + case *gtk.TreeStore: + err = tvs.TreeStore.InsertWithValues(iter, parent, insertPos, colIdx, row) + } + + if err != nil { + return nil, fmt.Errorf("Unable to add row %d: %s\n", insertPos, err.Error()) + } + tvs.Modified = true + return +} + +// InsertRowAtIter: Insert a row after/before iter to "StoreType": ListStore/Treestore. +// Parent may be nil for Liststore. +func (tvs *TreeViewStructure) InsertRowAtIterN(inIter, parent *gtk.TreeIter, row []interface{}, before ...bool) (iter *gtk.TreeIter, err error) { var tmpBefore bool var colIdx []int // var path *gtk.TreePath @@ -434,7 +867,7 @@ func (tvs *TreeViewStructure) InsertRow(inIter, parent *gtk.TreeIter, row []inte for idx, _ := range row { colIdx = append(colIdx, idx) } - switch tvs.store.(type) { + switch tvs.StoreType.(type) { case *gtk.ListStore: if tmpBefore { // Get the insertion iter iter = tvs.ListStore.InsertBefore(inIter) @@ -451,17 +884,27 @@ func (tvs *TreeViewStructure) InsertRow(inIter, parent *gtk.TreeIter, row []inte err = tvs.TreeStore.SetValue(iter, colIdx[0], row[0]) } if err != nil { - return nil, errors.New(fmt.Sprintln("Unable to insert row: %s", err.Error())) + return nil, errors.New(fmt.Sprintf("Unable to insert row: %s\n", err.Error())) } tvs.Modified = true return iter, err } +// InsertRowAtIter: Insert a row after/before iter to "StoreType": ListStore/Treestore. +// Parent may be nil for Liststore. +func (tvs *TreeViewStructure) InsertRowAtIter(inIter, parent *gtk.TreeIter, row ...interface{}) (iter *gtk.TreeIter, err error) { + if iter, err = tvs.InsertRow(parent, tvs.GetRowNbIter(inIter)+1, row...); err == nil { + tvs.Modified = true + } + return iter, err +} + +// TODO rewrite to be much faster // DuplicateRow: Copy a row after iter to the listStore func (tvs *TreeViewStructure) DuplicateRow(inIter, parent *gtk.TreeIter) (iter *gtk.TreeIter, err error) { var glibValue *glib.Value var goValue interface{} - switch tvs.store.(type) { + switch tvs.StoreType.(type) { case *gtk.ListStore: iter = tvs.ListStore.InsertAfter(inIter) for colIdx, _ := range tvs.Columns { @@ -482,7 +925,7 @@ func (tvs *TreeViewStructure) DuplicateRow(inIter, parent *gtk.TreeIter) (iter * } } if err != nil { - return nil, errors.New(fmt.Sprintln("Unable to duplicating row: %s", err.Error())) + return nil, fmt.Errorf("Unable to duplicating row: %s\n", err.Error()) } tvs.Modified = true tvs.ItersUnselect(inIter) @@ -491,149 +934,572 @@ func (tvs *TreeViewStructure) DuplicateRow(inIter, parent *gtk.TreeIter) (iter * } // RemoveSelectedRows: Delete entries from selected iters or from given iters. -func (tvs *TreeViewStructure) RemoveSelectedRows(iters ...*gtk.TreeIter) (err error) { - var ok bool +func (tvs *TreeViewStructure) RemoveSelectedRows(iters ...*gtk.TreeIter) (count int) { + if len(iters) == 0 { - if iters, err = tvs.GetSelectedIters(); err != nil { - return err + iters = tvs.GetSelectedIters() + } + + tmpIters := make([]*gtk.TreeIter, len(iters)) + // Reverse iters position to avoid error on remove. + // (when iter is removed, the next come to be invalid) + countIters := len(iters) - 1 + for idx := countIters; idx >= 0; idx-- { + tmpIters[countIters-idx] = iters[idx] + } + + return tvs.RemoveRows(tmpIters...) +} + +// RemoveRows: Unified remove iter(s) function +func (tvs *TreeViewStructure) RemoveRows(iters ...*gtk.TreeIter) (count int) { + + switch tvs.StoreType.(type) { + case *gtk.ListStore: + for _, iter := range iters { + if tvs.ListStore.Remove(iter) { + count++ + } + } + case *gtk.TreeStore: + for _, iter := range iters { + if tvs.TreeStore.Remove(iter) { + count++ + } + } + } + if count > 0 { + tvs.Modified = true + } + return +} + +// RemoveRowsPath: Unified remove path(s) function. accept '*gtk.TreePath' & 'TreePath' as string +func (tvs *TreeViewStructure) RemoveRowsPath(paths ...interface{}) (count int, err error) { + + var iter *gtk.TreeIter + + for _, p := range paths { + + switch path := p.(type) { + + case *gtk.TreePath: + iter, err = tvs.Model.GetIter(path) + case string: + iter, err = tvs.Model.GetIterFromString(path) + } + + if err != nil { + break + } + + switch tvs.StoreType.(type) { + + case *gtk.ListStore: + if tvs.ListStore.Remove(iter) { + count++ + } + case *gtk.TreeStore: + if tvs.TreeStore.Remove(iter) { + count++ + } + } + } + + if count > 0 { + tvs.Modified = true + } + return +} + +// GetSelectedRows: Get entries from selected iters as [][]string. +func (tvs *TreeViewStructure) GetSelectedRows() (outSlice [][]string, err error) { + outSlice = make([][]string, tvs.Selection.CountSelectedRows()) + var count int + tvs.Selection.SelectedForEach(func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) { + if outSlice[count], err = tvs.GetRow(iter); err != nil { + err = fmt.Errorf("Unable to get selected row: %d\n", count) + } + count++ + }) + return +} + +// getRow: Get row from iter as []string +func (tvs *TreeViewStructure) GetRow(iter *gtk.TreeIter) (outSlice []string, err error) { + var glibValue *glib.Value + var valueString string + + for colIdx := 0; colIdx < len(tvs.Columns); colIdx++ { + if glibValue, err = tvs.Model.GetValue(iter, colIdx); err == nil { + if valueString, err = tvs.getStringCellValueByType(glibValue); err == nil { + outSlice = append(outSlice, valueString) + } + } + if err != nil { + break + } + } + return outSlice, err +} + +// GetRowIface: Get row from iter as []interface{} +func (tvs *TreeViewStructure) GetRowIface(iter *gtk.TreeIter) (outIface []interface{}, err error) { + var glibValue *glib.Value + var value interface{} + + for colIdx := 0; colIdx < len(tvs.Columns); colIdx++ { + if glibValue, err = tvs.Model.GetValue(iter, colIdx); err == nil { + if value, err = glibValue.GoValue(); err == nil { + outIface = append(outIface, value) + } + } + if err != nil { + break + } + } + return outIface, err +} + +/*******************************\ +* Convenient Functions * +* Designed to make life easier * +********************************/ + +// GetColumns: Retieve columns available in the current TreeView. +func (tvs *TreeViewStructure) GetColumns() (out []*gtk.TreeViewColumn) { + glibList := tvs.TreeView.GetColumns() + glibList.Foreach(func(item interface{}) { + out = append(out, item.(*gtk.TreeViewColumn)) + }) + return +} + +// StoreDetach: Unlink "TreeModel" from TreeView. Useful when lot of rows need +// be inserted. After insertion, StoreAttach() must be used to restore the link +// with the treeview. tips: must be used before ListStore/TreeStore.Clear(). +func (tvs *TreeViewStructure) StoreDetach() { + if tvs.StoreType != nil { + tvs.Model.Ref() + tvs.TreeView.SetModel(nil) + } +} + +// StoreAttach: To use after data insertion to restore the link with TreeView. +func (tvs *TreeViewStructure) StoreAttach() { + if tvs.StoreType != nil { + tvs.TreeView.SetModel(tvs.Model) + tvs.Model.Unref() + } +} + +// Clear: Clear the current used Model: +// unified version of gtk.TreeStore.Clear() or gtk.ListStore.Clear() +func (tvs *TreeViewStructure) Clear() { + switch tvs.StoreType.(type) { + case *gtk.ListStore: + tvs.ListStore.Clear() + case *gtk.TreeStore: + tvs.TreeStore.Clear() + } +} + +// ClearAll: Clear TreeView's columns, ListStore / TreeStore object. +// Depending on provided object type into the "StoreType" variable. +// To reuse structure, you must execute StoreSetup() again after +// added new columns. +func (tvs *TreeViewStructure) ClearAll() (err error) { + if tvs.TreeView != nil { + // Removing existing columns if exists ... + for idx := int(tvs.TreeView.GetNColumns()) - 1; idx > -1; idx-- { + tvs.TreeView.RemoveColumn(tvs.TreeView.GetColumn(idx)) + } + tvs.Columns = tvs.Columns[:0] + tvs.TreeView.SetModel(nil) + switch tvs.StoreType.(type) { + case *gtk.ListStore: + if tvs.ListStore != nil { + tvs.ListStore.Clear() + tvs.ListStore.Unref() + } + case *gtk.TreeStore: + if tvs.TreeStore != nil { + tvs.TreeStore.Clear() + tvs.TreeStore.Unref() + } } + tvs.Modified = false } - tvs.StoreDetach() - switch tvs.store.(type) { - case *gtk.ListStore: - for idx := len(iters) - 1; idx > -1; idx-- { - ok = tvs.ListStore.Remove(iters[idx]) + return +} + +// StoreToStringSlice: Retrieve all the rows values from a 'StoreType' +// as [][]string +func (tvs *TreeViewStructure) StoreToStringSlice() (out [][]string, err error) { + var row []string + tvs.Model.ForEach(func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) bool { + if row, err = tvs.GetRow(iter); err == nil { + out = append(out, row) + } else { + return true } - case *gtk.TreeStore: - for idx := len(iters) - 1; idx > -1; idx-- { - ok = tvs.TreeStore.Remove(iters[idx]) + return false + }) + return +} + +// GetTreeViewIface: retrieve whole content of a TreeView as +// [][]interface +func (tvs *TreeViewStructure) StoreToIfaceSlice() (out [][]interface{}, err error) { + var row []interface{} + tvs.Model.ForEach(func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) bool { + if row, err = tvs.GetRowIface(iter); err == nil { + out = append(out, row) + } else { + return true } + return false + }) + return +} + +// ColNamesToStringSlice: Retrieve column names as string slice +func (tvs *TreeViewStructure) ColNamesToStringSlice() (outSlice []string) { + for _, col := range tvs.Columns { + outSlice = append(outSlice, col.Column.GetTitle()) } - tvs.StoreAttach() - if ok { - tvs.Modified = true - } - return err + return } -// GetSelectedRows: Retrieve rows from selected iters or from given iters. -func (tvs *TreeViewStructure) GetSelectedRows(iters ...*gtk.TreeIter) (outSlice [][]string, err error) { - var tmpSlice []string +// GetTreeCol: This method retrieve data from a [single column] of the current +// 'GtkTreeStore' as []string. Use GetTreeFullIface to retrieve multiple columns +// at once. +func (tvs *TreeViewStructure) GetTreeCol(toggleCol, dataCols int) (checked, unChecked []string, err error) { + var row []interface{} - if len(iters) == 0 { - if iters, err = tvs.GetSelectedIters(); err != nil { - return outSlice, err + tvs.TreeStore.ForEach(func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) bool { + + if row, err = tvs.GetRowIface(iter); err == nil { + + if row[toggleCol].(bool) { + checked = append(checked, row[dataCols].(string)) + } else { + unChecked = append(unChecked, row[dataCols].(string)) + } + } else { + + err = fmt.Errorf("GetTreeCol: %v", err) + return true } - } - for _, iter := range iters { - if tmpSlice, err = tvs.GetRow(iter); err == nil { - outSlice = append(outSlice, tmpSlice) - tvs.Selection.SelectIter(iter) // To keep iters selected + + return false + }) + return +} + +// GetTreeFullIface: Retrieve the whole content of the current 'GtkTreeStore'. +func (tvs *TreeViewStructure) GetTreeFullIface(toggleCol int) (checked, unChecked [][]interface{}, err error) { + var row []interface{} + + tvs.TreeStore.ForEach(func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) bool { + + if row, err = tvs.GetRowIface(iter); err == nil { + + if row[toggleCol].(bool) { + checked = append(checked, row) + } else { + unChecked = append(unChecked, row) + } + } else { + + err = fmt.Errorf("GetTreeFullIface: %v", err) + return true + } + + return false + }) + return +} + +// GetTreeParentIface: return the 'row' holded by the parent of 'iter' or from itself +// whether having children. After call with success, provided 'iter' argument points +// to the one the line came from. +func (tvs *TreeViewStructure) GetTreeParentIface(iter *gtk.TreeIter) ([]interface{}, error) { + + if !tvs.Model.IterHasChild(iter) { + + parent := new(gtk.TreeIter) + if !tvs.Model.IterParent(parent, iter) { + return nil, fmt.Errorf("Unable to get parent iter from child") } + iter = parent } - return outSlice, err + return tvs.GetRowIface(iter) } -// GetSelectedIters: retreve list of selected iters -func (tvs *TreeViewStructure) GetSelectedIters() (iters []*gtk.TreeIter, err error) { - var iter *gtk.TreeIter - var getIters = func(glist *glib.List) (iters []*gtk.TreeIter, err error) { - for row := glist; row != nil; row = row.Next() { - if iter, err = tvs.Model.GetIter(row.Data().(*gtk.TreePath)); err == nil { - iters = append(iters, iter) +// AddTree: This function, add a full tree to a TreeStore, childs will be added to +// parent's tree if exists or to a new created parent. +// Each entry handle a checkbox and a name only. +// +// e.g: in 3 calls to 'AddTree' +// 'iFace' = []interface{"github.com", "hfmrow", "gtk3Import", "pango.go"} +// 'iFace' = []interface{"github.com", "hfmrow", "gtk3Import", "main.go"} +// 'iFace' = []interface{"github.com", "hfmrow", "gtk3Import", "view.go"} +// add all nodes for this tree to column 'filepathCol' and checkbox at 'toggleCol' +// +// [] github.com +// [] ╰── hfmrow +// [] ╰── gtk3Import +// [] ├── pango.go +// [] ├── main.go +// [] ╰── view.go +// +// - 'stateDefault' default value for 'toggleCol'. +// - 'callbackParentCreation' can be 'nil', otherwise, this callback corresponds +// to the creation of the iter during the construction of the tree, allow to control +// (allows to manually add some usefull data to the row). +// - The returned 'outIter', target the iter used by the the last entry, useful for +// manually adding more entries to columns if needed. +func (tvs *TreeViewStructure) AddTree( + toggleCol, + filepathCol int, + stateDefault bool, + callbackParentCreation func(store *gtk.TreeStore, iter *gtk.TreeIter, currentAddIdx int, iRow *[]interface{}) bool, + iFace ...interface{}) (outIter *gtk.TreeIter, err error) { + + var ( + iterate, + childsCount int + tmpIter *gtk.TreeIter + ok bool + value string + pathSplitted []interface{} + ) + + // addItem: It only does what the name says. + var addItem = func(toAdd string, iter *gtk.TreeIter) (tmpIter *gtk.TreeIter) { + + var err error + tmpIter = tvs.TreeStore.Append(iter) + + if err = tvs.TreeStore.SetValue(tmpIter, toggleCol, stateDefault); err == nil { + if err = tvs.TreeStore.SetValue(tmpIter, filepathCol, toAdd); callbackParentCreation != nil && err == nil { + + if !callbackParentCreation(tvs.TreeStore, tmpIter, iterate, &pathSplitted) { + // remove created iter and quit if callback is not true + tvs.TreeStore.Remove(tmpIter) + err = fmt.Errorf("callbackParentCreation: has rejected the 'iter' creation") + } + // if iterate > len(pathSplitted)-1 { + // tmpIter = nil + // } } } + if err != nil { + log.Printf("AddTree: Unable to addItem. %s\n", err.Error()) + tmpIter = nil + } return } - switch tvs.store.(type) { - case *gtk.ListStore: - glist := tvs.Selection.GetSelectedRows(tvs.ListStore) - iters, err = getIters(glist) - case *gtk.TreeStore: // TODO make it to run through parents/child's nodes - glist := tvs.Selection.GetSelectedRows(tvs.TreeStore) - iters, err = getIters(glist) - } - if err != nil { - return iters, errors.New(fmt.Sprintln("Unable to retrieve selected iters: ", err)) - } - return iters, err -} -// ItersSelect: -func (tvs *TreeViewStructure) ItersSelect(iters ...*gtk.TreeIter) { - for _, iter := range iters { - if !tvs.Selection.IterIsSelected(iter) { - tvs.Selection.SelectIter(iter) + // findCreatFirstParent: Add or find first parent that match "name" and return it's iter. + var findCreatFirstParent = func(name string) (tmpIter *gtk.TreeIter, ok bool, err error) { + + if len(name) > 0 { + tmpIter, ok = tvs.TreeStore.GetIterFirst() + + for ok { + value := tvs.GetColValue(tmpIter, filepathCol).(string) + if value == name { + return + } + ok = tvs.TreeStore.IterNext(tmpIter) + } + + // Nothing found, then create it + tmpIter = addItem(pathSplitted[iterate].(string), outIter) + ok = tmpIter != nil + + } else { + err = errors.New("findCreatFirstParent: Could not proceed with empty parent.") } + return } -} -// ItersUnselect: -func (tvs *TreeViewStructure) ItersUnselect(iters ...*gtk.TreeIter) { - for _, iter := range iters { - if tvs.Selection.IterIsSelected(iter) { - tvs.Selection.UnselectIter(iter) + // searchMatch: Walk trought iter to retrieve the one matching "toMatch". + var searchMatch = func(toMatch string, outIter *gtk.TreeIter) (childIter *gtk.TreeIter, ok bool) { + + childIter = new(gtk.TreeIter) + ok = tvs.TreeStore.IterChildren(outIter, childIter) + for ok { + value = tvs.GetColValue(childIter, filepathCol).(string) + if value == toMatch { + return + } + ok = tvs.Model.IterNext(childIter) } + return } -} -// ItersSelectRange: -func (tvs *TreeViewStructure) ItersSelectRange(startIter, endIter *gtk.TreeIter) (err error) { - var startPath, endPath *gtk.TreePath + pathSplitted = iFace - if startPath, err = tvs.Model.GetPath(startIter); err == nil { - if endPath, err = tvs.Model.GetPath(endIter); err == nil { - tvs.Selection.SelectRange(startPath, endPath) + // parse "dirPath" entry into treestore. + if outIter, ok, err = findCreatFirstParent(pathSplitted[0].(string)); err == nil { + + for ok { + value = tvs.GetColValue(outIter, filepathCol).(string) + if value == pathSplitted[iterate] { + childsCount = tvs.Model.IterNChildren(outIter) + if childsCount > 0 { + iterate++ + if iterate >= len(pathSplitted) { + break + } + if tmpIter, ok = searchMatch(pathSplitted[iterate].(string), outIter); !ok { + outIter = addItem(pathSplitted[iterate].(string), outIter) + ok = outIter != nil + + // last := pathSplitted[len(pathSplitted)-1].(string) + // fmt.Printf("item: %v, last: %v\n", pathSplitted[iterate], pathSplitted[len(pathSplitted)-1]) + + } else { + outIter = tmpIter + } + continue + } else { + iterate++ + if iterate >= len(pathSplitted) { + break + } + outIter = addItem(pathSplitted[iterate].(string), outIter) + ok = outIter != nil + + // fmt.Println(pathSplitted[iterate].(string)) + + } + } else { + if tmpIter, ok = searchMatch(pathSplitted[iterate].(string), outIter); ok { + outIter = addItem(pathSplitted[iterate].(string), tmpIter) + ok = outIter != nil + // fmt.Println(pathSplitted[iterate].(string)) + } + } } } - return err + return } -// ScrollToCell: "column" argument set to nul, mean column 0, -func (tvs *TreeViewStructure) ScrollToCell(path *gtk.TreePath, column *gtk.TreeViewColumn, align bool, xalign, yalign float32) { - if column == nil { - column = tvs.Columns[0].Column +// ColValuesStringSliceToIfaceSlice: Convert string list to []interface, for simplify adding text rows +func (tvs *TreeViewStructure) ColValuesStringSliceToIfaceSlice(inSlice ...string) (outIface []interface{}) { + outIface = make([]interface{}, len(inSlice)) + for idx, data := range inSlice { + outIface[idx] = data } - tvs.TreeView.ScrollToCell(path, column, align, xalign, yalign) + return } -// ScrollToIter: -func (tvs *TreeViewStructure) ScrollToIter(iter *gtk.TreeIter) (err error) { - var path *gtk.TreePath - if path, err = tvs.Model.GetPath(iter); err == nil { - tvs.ScrollToCell(path, nil, true, 0.5, 0.5) - } - return +// glibType: glib value type List structure. +var glibType = map[glib.Type]string{ + 0: "glib.TYPE_INVALID", + 4: "glib.TYPE_NONE", + 8: "glib.TYPE_INTERFACE", + 12: "glib.TYPE_CHAR", + 16: "glib.TYPE_UCHAR", + 20: "glib.TYPE_BOOLEAN", + 24: "glib.TYPE_INT", + 28: "glib.TYPE_UINT", + 32: "glib.TYPE_LONG", + 36: "glib.TYPE_ULONG", + 40: "glib.TYPE_INT64", + 44: "glib.TYPE_UINT64", + 48: "glib.TYPE_ENUM", + 52: "glib.TYPE_FLAGS", + 56: "glib.TYPE_FLOAT", + 60: "glib.TYPE_DOUBLE", + 64: "glib.TYPE_STRING", + 68: "glib.TYPE_POINTER", + 72: "glib.TYPE_BOXED", + 76: "glib.TYPE_PARAM", + 80: "glib.TYPE_OBJECT", + 84: "glib.TYPE_VARIANT", } -// getRow: Get row from iter as []string -func (tvs *TreeViewStructure) GetRow(iter *gtk.TreeIter) (outSlice []string, err error) { - var glibValue *glib.Value - var valueString string +/************************\ +* Helpers Functions * +* Made to simplify some * +* more complex functions * +**************************/ - for colIdx := 0; colIdx < len(tvs.Columns); colIdx++ { - if glibValue, err = tvs.Model.GetValue(iter, colIdx); err == nil { - if valueString, err = tvs.getStringCellValueByType(glibValue); err == nil { - outSlice = append(outSlice, valueString) +// TODO MAY CAUSE WHOLE FREEZE SOMETIME (undefined) +// treeViewQueryTooltip: function to display tooltip according to rows currently hovered +// Note: return TRUE if tooltip should be shown right now, FALSE otherwise +func (tvs *TreeViewStructure) treeViewQueryTooltip(tw *gtk.TreeView, x, y int, KeyboardMode bool, tooltip *gtk.Tooltip) bool { + + if tvs.CallbackTooltipFunc != nil && tvs.HasTooltip { + + if tvs.CountRows() > 0 { + // we need to substract header height to "y" position to get the correct path. + if path, column, _, _, isBlank := tvs.TreeView.IsBlankAtPos(x, y-tvs.getHeaderHeight()); !isBlank { + if iter, err := tvs.Model.GetIter(path); err == nil { + + return tvs.CallbackTooltipFunc(iter, path, column, tooltip) + } else { + + log.Printf("treeViewQueryTooltip:GetIter: %s\n", err.Error()) + } } } - if err != nil { - break + } + return false +} + +// getHeaderHeight: Used to get height of header to use with [TreeView.IsBlankAtPos], +// It is needed to decrease y pos by height of cells to get a correct path value. +func (tvs *TreeViewStructure) getHeaderHeight() (height int) { + if tvs.headerHeight < 0 { // That means that is launched only at the first call. + for gtk.EventsPending() { + gtk.MainIteration() // Wait for pending events (until the widget is redrawn) } + // Getting header height + backupVisibleHeader := tvs.TreeView.GetHeadersVisible() + tvs.TreeView.SetHeadersVisible(true) + withHeader, _ := tvs.TreeView.GetPreferredHeight() + tvs.TreeView.SetHeadersVisible(false) + withoutHeader, _ := tvs.TreeView.GetPreferredHeight() + tvs.TreeView.SetHeadersVisible(backupVisibleHeader) + tvs.headerHeight = withHeader - withoutHeader } - return outSlice, err + return tvs.headerHeight } -// getCellValueByType: Retrieve cell value and convert it to string based on his type +// getCellValueByType: Retrieve cell value and convert it to string based on +// his type. Used by GetRow func. func (tvs *TreeViewStructure) getStringCellValueByType(glibValue *glib.Value) (valueString string, err error) { var actualType glib.Type var valueIface interface{} if actualType, _, err = glibValue.Type(); err == nil { switch actualType { - case glib.TYPE_STRING: // Strings - valueString, err = glibValue.GetString() - case glib.TYPE_BOOLEAN: // Boolean + + // String + case glib.TYPE_STRING: + valueString, _ = glibValue.GetString() + + // Numeric values: int, uint64, int64 + case glib.TYPE_INT64, glib.TYPE_UINT64, glib.TYPE_INT: + if valueIface, err = glibValue.GoValue(); err == nil { + switch val := valueIface.(type) { + case int, uint64, int64: + valueString = fmt.Sprintf("%d", val) + } + } + + // Pointer, just say that it's what's it ... + case glib.TYPE_POINTER: + valueString = fmt.Sprintf("%v", glibValue.GetPointer()) + + // Boolean + case glib.TYPE_BOOLEAN: if valueIface, err = glibValue.GoValue(); err == nil { if valueIface.(bool) { valueString = "true" @@ -641,116 +1507,143 @@ func (tvs *TreeViewStructure) getStringCellValueByType(glibValue *glib.Value) (v valueString = "false" } } - // case glib.TYPE_BOXED: + + // Need to be implemented default: - err = errors.New(fmt.Sprintf("Type %s: not yet implemented\n", tvs.getStringGlibType(actualType))) + err = fmt.Errorf("getStringCellValueByType: Type %s, not yet implemented\n", glibType[actualType]) } } return } -// GetRowIface: Get row from iter as []interface{} -func (tvs *TreeViewStructure) GetRowIface(iter *gtk.TreeIter) (outIface []interface{}, err error) { - var glibValue *glib.Value - var value interface{} - - for colIdx := 0; colIdx < len(tvs.Columns); colIdx++ { - if glibValue, err = tvs.Model.GetValue(iter, colIdx); err == nil { - if value, err = glibValue.GoValue(); err == nil { - outIface = append(outIface, value) +// changeTreeState: Modify the state of the entire tree starting at parent. +func (tvs *TreeViewStructure) changeChildrenTreeState(path string, parent *gtk.TreeIter, col int, goValue interface{}) { + var err error + var ok bool + childIter := new(gtk.TreeIter) + ok = parent != nil + for ok { + if err = tvs.SetColValue(parent, col, goValue); err == nil { + if ok = tvs.Model.IterHasChild(parent); ok { + if ok = tvs.Model.IterChildren(parent, childIter); ok { + for ok { + tvs.changeChildrenTreeState(path, childIter, col, goValue) + ok = tvs.Model.IterNext(childIter) + } + } } } - if err != nil { - break - } - } - return outIface, err -} - -// StoreToSlice: Retrieve all the rows values from a "store" as [][]string -func (tvs *TreeViewStructure) StoreToStringSlice() (outSlice [][]string, err error) { - var tmpSlice []string - // Foreach Function - var foreachFunc = func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter, userData interface{}) bool { - if tmpSlice, err = tvs.GetRow(iter); err == nil { - outSlice = append(outSlice, tmpSlice) - } else { - return true - } - return false } - // Gathering columns names - for _, col := range tvs.Columns { - tmpSlice = append(tmpSlice, col.Column.GetTitle()) + if err != nil { + fmt.Printf("Unable to changeChildrenTreeState (toggle) cell col: %d, path: %s, %s\n", col, path, err.Error()) } - outSlice = append(outSlice, tmpSlice) - // Retrieve values - tvs.Model.ForEach(foreachFunc) + return +} - return outSlice, err +// IsNotEmpty: Returns 'true' if the TreeView is not empty. +func (tvs *TreeViewStructure) IsNotEmpty() bool { + _, ok := tvs.Model.GetIterFirst() + return ok } -// StoreToIface: Retrieve all the rows values from a "store" as [][]interface{} -func (tvs *TreeViewStructure) StoreToIfaceSlice() (outIface [][]interface{}, err error) { - var tmpIface []interface{} - // Foreach Function - var retrieveValuesForeachFunc = func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter, userData interface{}) bool { - if tmpIface, err = tvs.GetRowIface(iter); err == nil { - outIface = append(outIface, tmpIface) - } else { - return true - } - return false - } - // Gathering columns names - for _, col := range tvs.Columns { // Gathering of columns names - tmpIface = append(tmpIface, col.Column.GetTitle()) - } - outIface = append(outIface, tmpIface) - // Retrieve values - tvs.Model.ForEach(retrieveValuesForeachFunc) +// AllChildsCheckedState: verify all childs and childs of childs then return false +// if one of them correspond to 'state' parameter. Otherwise, true is returned. +func (tvs *TreeViewStructure) AllChildsCheckedState(parentIter *gtk.TreeIter, col int, state bool) bool { - return outIface, err -} + nChilds := tvs.Model.IterNChildren(parentIter) + if nChilds > 0 { + newChild := new(gtk.TreeIter) + for idx := 0; idx < nChilds; idx++ { + if tvs.Model.IterNthChild(newChild, parentIter, idx) { -// StoreToIface: Retrieve all the rows values from a "store" as [][]interface{} -// The path to the iter is at start: [[0] [Parent 0]] [[0 0] [entry 0]] [[0 1] [entry 1]] -// [[1] [Parent 1]] [[1 0] [entry 0]] [[1 1] [entry 1]] [[1 2] [entry 2]] ... -// Thiw function does not retrieve the columns names ! -func (tvs *TreeViewStructure) StoreToIfaceSliceWithPaths() (outIface [][]interface{}, err error) { - var tmpIface []interface{} - // Foreach Function - var retrieveValuesForeachFunc = func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter, userData interface{}) bool { - if tmpIface, err = tvs.GetRowIface(iter); err == nil { - tmpIface = append([]interface{}{path.GetIndices()}, tmpIface) - outIface = append(outIface, tmpIface) - } else { - return true + // if tvs.Model.IterHasChild(newChild) { + // if !tvs.AllChildsCheckedState(newChild, col, state) { + // return true + // } else { + // return false + // } + // } + + if state == tvs.GetColValue(newChild, col).(bool) { + return false + } + } } - return false } - // Retrieve values - tvs.Model.ForEach(retrieveValuesForeachFunc) + return true - return outIface, err + // if tvs.Model.IterHasChild(parentIter) { + // if !tvs.AllChildsCheckedState(parentIter, col, state) { + // return true + // } + // } } -// ColValuesStringSliceToIfaceSlice: Convert string list to []interface, for simplify adding text rows -func (tvs *TreeViewStructure) ColValuesStringSliceToIfaceSlice(inSlice ...string) (outIface []interface{}) { - for _, value := range inSlice { - outIface = append(outIface, value) +/* Same as above but with recurse capabilities */ + +// // allChildsChecked: verify all childs and return false if one of them +// // is unchecked. Otherwise, true is returned +// func (tvs *TreeViewStructure) allChildsChecked(parentIter *gtk.TreeIter, col int) bool { +// nChilds := tvs.Model.IterNChildren(parentIter) +// if nChilds > 0 { +// newChild := new(gtk.TreeIter) +// for idx := 0; idx < nChilds; idx++ { +// if tvs.Model.IterNthChild(newChild, parentIter, idx) { +// if !tvs.GetColValue(newChild, col).(bool) { +// return false +// } +// } +// if tvs.Model.IterHasChild(newChild) { +// tvs.allChildsChecked(newChild, col) +// } +// } +// } +// return true +// } + +// ChildsPropagateColValue: Add value to parent and to all childs at specific column. +// If 'value' is nil, no modification will be done but all children are returned. +func (tvs *TreeViewStructure) ChildsPropagateColValue(parentIter *gtk.TreeIter, col int, value interface{}) (modifiedIters []*gtk.TreeIter, err error) { + + // Add value to parent if not nil + if value != nil { + if err = tvs.SetColValue(parentIter, col, value); err != nil { + return + } } - return -} + modifiedIters = append(modifiedIters, parentIter) -// ColValuesIfaceToIfaceSlice: Convert interface list to []interface, for simplify adding text rows -func (tvs *TreeViewStructure) ColValuesIfaceToIfaceSlice(inSlice ...interface{}) (outIface []interface{}) { - for _, value := range inSlice { - outIface = append(outIface, value) + nChilds := tvs.Model.IterNChildren(parentIter) + // Add value to his childs + if nChilds > 0 { + for idx := 0; idx < nChilds; idx++ { + newChild := new(gtk.TreeIter) + if tvs.Model.IterNthChild(newChild, parentIter, idx) { + if value != nil { + if err = tvs.SetColValue(newChild, col, value); err != nil { + return + } + } + if tvs.Model.IterHasChild(newChild) { + if mi, err := tvs.ChildsPropagateColValue(newChild, col, value); err == nil { + modifiedIters = append(modifiedIters, mi...) + } else { + return modifiedIters, err + } + } + modifiedIters = append(modifiedIters, newChild) + } + } } return } +/********************\ +* TEST Functions * +* Not designed to be * +* used as it !! * +**********************/ + // func (tvs *TreeViewStructure) getDecendants(iter *gtk.TreeIter) (descendants [][]interface{}, err error) { // // var parentPath, path *gtk.TreePath // var iterDesc *gtk.TreeIter @@ -766,7 +1659,6 @@ func (tvs *TreeViewStructure) ColValuesIfaceToIfaceSlice(inSlice ...interface{}) // return // } -// TEST function func (tvs *TreeViewStructure) selectRange(start, end *gtk.TreeIter) (err error) { var startPath, endPath *gtk.TreePath if startPath, err = tvs.ListStore.GetPath(start); err == nil { @@ -777,7 +1669,6 @@ func (tvs *TreeViewStructure) selectRange(start, end *gtk.TreeIter) (err error) return err } -// TEST function func (tvs *TreeViewStructure) pathSelected(start *gtk.TreeIter) (err error) { var startPath *gtk.TreePath if startPath, err = tvs.ListStore.GetPath(start); err == nil { @@ -787,13 +1678,12 @@ func (tvs *TreeViewStructure) pathSelected(start *gtk.TreeIter) (err error) { return err } -// TEST function func (tvs *TreeViewStructure) forEach() { var err error - var model *gtk.TreeModel + var model gtk.ITreeModel var ipath *gtk.TreePath var foreachFunc gtk.TreeModelForeachFunc - foreachFunc = func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter, userData interface{}) bool { + foreachFunc = func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) bool { if ipath, err = model.GetPath(iter); err == nil { fmt.Printf("path: %s, iter: %s\n", path.String(), ipath.String()) } else { @@ -803,14 +1693,13 @@ func (tvs *TreeViewStructure) forEach() { return false } if model, err = tvs.TreeView.GetModel(); err == nil { - err = model.ForEach(foreachFunc) + model.ToTreeModel().ForEach(foreachFunc) } if err != nil { fmt.Println("error occured outside func: " + err.Error()) } } -// TEST function func (tvs *TreeViewStructure) idx() { var err error // var model *gtk.TreeModel @@ -844,13 +1733,12 @@ func (tvs *TreeViewStructure) idx() { } } -// TEST function func (tvs *TreeViewStructure) indices() { var err error - var model *gtk.TreeModel + var model gtk.ITreeModel var ipath, jpath *gtk.TreePath var foreachFunc gtk.TreeModelForeachFunc - foreachFunc = func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter, userData interface{}) bool { + foreachFunc = func(model *gtk.TreeModel, path *gtk.TreePath, iter *gtk.TreeIter) bool { if ipath, err = model.GetPath(iter); err == nil { indices := ipath.GetIndices() jpath, _ = gtk.TreePathNewFromIndicesv(indices) @@ -863,14 +1751,13 @@ func (tvs *TreeViewStructure) indices() { return false } if model, err = tvs.TreeView.GetModel(); err == nil { - err = model.ForEach(foreachFunc) + model.ToTreeModel().ForEach(foreachFunc) } if err != nil { fmt.Println("error occured outside func: " + err.Error()) } } -// TEST function // func (tvs *TreeViewStructure) getColsNames() (err error) { // var glist *glib.List // if glist, err = tvs.TreeView.GetColumns(); err == nil { @@ -884,38 +1771,3 @@ func (tvs *TreeViewStructure) indices() { // } // return err // } - -var glibType = map[int]string{ - 0: "glib.TYPE_INVALID", - 4: "glib.TYPE_NONE", - 8: "glib.TYPE_INTERFACE", - 12: "glib.TYPE_CHAR", - 16: "glib.TYPE_UCHAR", - 20: "glib.TYPE_BOOLEAN", - 24: "glib.TYPE_INT", - 28: "glib.TYPE_UINT", - 32: "glib.TYPE_LONG", - 36: "glib.TYPE_ULONG", - 40: "glib.TYPE_INT64", - 44: "glib.TYPE_UINT64", - 48: "glib.TYPE_ENUM", - 52: "glib.TYPE_FLAGS", - 56: "glib.TYPE_FLOAT", - 60: "glib.TYPE_DOUBLE", - 64: "glib.TYPE_STRING", - 68: "glib.TYPE_POINTER", - 72: "glib.TYPE_BOXED", - 76: "glib.TYPE_PARAM", - 80: "glib.TYPE_OBJECT", - 84: "glib.TYPE_VARIANT", -} - -// getStringGlibType: Retrieve the string of glib value type. -func (tvs *TreeViewStructure) getStringGlibType(t glib.Type) string { - for val, str := range glibType { - if val == int(t) { - return str - } - } - return "Unnowen type" -} diff --git a/vendor/gopkg.in/djherbis/times.v1/bench_test.go b/vendor/gopkg.in/djherbis/times.v1/bench_test.go new file mode 100644 index 0000000..3afa3d6 --- /dev/null +++ b/vendor/gopkg.in/djherbis/times.v1/bench_test.go @@ -0,0 +1,56 @@ +package times + +import ( + "os" + "testing" +) + +func BenchmarkGet(t *testing.B) { + fileTest(t, func(f *os.File) { + fi, err := os.Stat(f.Name()) + if err != nil { + t.Error(err) + } + + for i := 0; i < t.N; i++ { + Get(fi) + } + }) + t.ReportAllocs() +} + +func BenchmarkStat(t *testing.B) { + fileTest(t, func(f *os.File) { + for i := 0; i < t.N; i++ { + Stat(f.Name()) + } + }) + t.ReportAllocs() +} + +func BenchmarkLstat(t *testing.B) { + fileTest(t, func(f *os.File) { + for i := 0; i < t.N; i++ { + Lstat(f.Name()) + } + }) + t.ReportAllocs() +} + +func BenchmarkOsStat(t *testing.B) { + fileTest(t, func(f *os.File) { + for i := 0; i < t.N; i++ { + os.Stat(f.Name()) + } + }) + t.ReportAllocs() +} + +func BenchmarkOsLstat(t *testing.B) { + fileTest(t, func(f *os.File) { + for i := 0; i < t.N; i++ { + os.Lstat(f.Name()) + } + }) + t.ReportAllocs() +} diff --git a/vendor/gopkg.in/djherbis/times.v1/times_test.go b/vendor/gopkg.in/djherbis/times.v1/times_test.go new file mode 100644 index 0000000..5861034 --- /dev/null +++ b/vendor/gopkg.in/djherbis/times.v1/times_test.go @@ -0,0 +1,125 @@ +package times + +import ( + "os" + "path/filepath" + "testing" + "time" +) + +func TestStat(t *testing.T) { + fileAndDirTest(t, func(name string) { + ts, err := Stat(name) + if err != nil { + t.Error(err.Error()) + } + timespecTest(ts, newInterval(time.Now(), time.Second), t) + }) +} + +func TestGet(t *testing.T) { + fileAndDirTest(t, func(name string) { + fi, err := os.Stat(name) + if err != nil { + t.Error(err.Error()) + } + timespecTest(Get(fi), newInterval(time.Now(), time.Second), t) + }) +} + +type tsFunc func(string) (Timespec, error) + +var offsetTime = -10 * time.Second + +func TestStatSymlink(t *testing.T) { + testStatSymlink(Stat, time.Now().Add(offsetTime), t) +} + +func TestLstatSymlink(t *testing.T) { + testStatSymlink(Lstat, time.Now(), t) +} + +func testStatSymlink(sf tsFunc, expectTime time.Time, t *testing.T) { + fileAndDirTest(t, func(name string) { + start := time.Now() + + symname := filepath.Join(filepath.Dir(name), "sym-"+filepath.Base(name)) + if err := os.Symlink(name, symname); err != nil { + t.Error(err.Error()) + } + defer os.Remove(symname) + + // modify the realFileTime so symlink and real file see diff values. + realFileTime := start.Add(offsetTime) + if err := os.Chtimes(name, realFileTime, realFileTime); err != nil { + t.Error(err.Error()) + } + + ts, err := sf(symname) + if err != nil { + t.Error(err.Error()) + } + timespecTest(ts, newInterval(expectTime, time.Second), t, Timespec.AccessTime, Timespec.ModTime) + }) +} + +func TestStatErr(t *testing.T) { + _, err := Stat("badfile?") + if err == nil { + t.Error("expected an error") + } +} + +func TestLstatErr(t *testing.T) { + _, err := Lstat("badfile?") + if err == nil { + t.Error("expected an error") + } +} + +func TestCheat(t *testing.T) { + // not all times are available for all platforms + // this allows us to get 100% test coverage for platforms which do not have + // ChangeTime/BirthTime + var c ctime + if c.HasChangeTime() { + c.ChangeTime() + } + + var b btime + if b.HasBirthTime() { + b.BirthTime() + } + + var paniced = false + var nc noctime + func() { + if !nc.HasChangeTime() { + defer func() { + recover() + paniced = true + }() + } + nc.ChangeTime() + }() + + if !paniced { + t.Error("expected panic") + } + + paniced = false + var nb nobtime + func() { + if !nb.HasBirthTime() { + defer func() { + recover() + paniced = true + }() + } + nb.BirthTime() + }() + + if !paniced { + t.Error("expected panic") + } +} diff --git a/vendor/gopkg.in/djherbis/times.v1/times_windows_test.go b/vendor/gopkg.in/djherbis/times.v1/times_windows_test.go new file mode 100644 index 0000000..6fe4ce9 --- /dev/null +++ b/vendor/gopkg.in/djherbis/times.v1/times_windows_test.go @@ -0,0 +1,75 @@ +package times + +import ( + "errors" + "os" + "syscall" + "testing" + "time" +) + +func TestStatFile(t *testing.T) { + fileTest(t, func(f *os.File) { + ts, err := StatFile(f) + if err != nil { + t.Error(err.Error()) + } + timespecTest(ts, newInterval(time.Now(), time.Second), t) + }) +} + +func TestStatFileErr(t *testing.T) { + fileTest(t, func(f *os.File) { + f.Close() + + _, err := StatFile(f) + if err == nil { + t.Error("got nil err, but err was expected!") + } + }) +} + +func TestStatFileProcErr(t *testing.T) { + fileTest(t, func(f *os.File) { + findProcErr = errors.New("fake error") + defer func() { findProcErr = nil }() + + _, err := StatFile(f) + if err == nil { + t.Error("got nil err, but err was expected!") + } + }) +} + +func TestStatBadNameErr(t *testing.T) { + _, err := platformSpecficStat(string([]byte{0})) + if err != syscall.EINVAL { + t.Error(err) + } +} + +func TestStatProcErrFallback(t *testing.T) { + fileAndDirTest(t, func(name string) { + findProcErr = errors.New("fake error") + defer func() { findProcErr = nil }() + + ts, err := Stat(name) + if err != nil { + t.Error(err.Error()) + } + timespecTest(ts, newInterval(time.Now(), time.Second), t) + }) +} + +func TestLstatProcErrFallback(t *testing.T) { + fileAndDirTest(t, func(name string) { + findProcErr = errors.New("fake error") + defer func() { findProcErr = nil }() + + ts, err := Lstat(name) + if err != nil { + t.Error(err.Error()) + } + timespecTest(ts, newInterval(time.Now(), time.Second), t) + }) +} diff --git a/vendor/gopkg.in/djherbis/times.v1/util_test.go b/vendor/gopkg.in/djherbis/times.v1/util_test.go new file mode 100644 index 0000000..fe42bc9 --- /dev/null +++ b/vendor/gopkg.in/djherbis/times.v1/util_test.go @@ -0,0 +1,81 @@ +package times + +import ( + "io/ioutil" + "os" + "reflect" + "runtime" + "testing" + "time" +) + +type timeRange struct { + start time.Time + end time.Time +} + +func newInterval(t time.Time, dur time.Duration) timeRange { + return timeRange{start: t.Add(-dur), end: t.Add(dur)} +} + +func (t timeRange) Contains(findTime time.Time) bool { + return !findTime.Before(t.start) && !findTime.After(t.end) +} + +func fileAndDirTest(t testing.TB, testFunc func(name string)) { + filenameTest(t, testFunc) + dirTest(t, testFunc) +} + +// creates a file and cleans it up after the test is run. +func fileTest(t testing.TB, testFunc func(f *os.File)) { + f, err := ioutil.TempFile("", "") + if err != nil { + t.Fatal(err) + } + defer os.Remove(f.Name()) + defer f.Close() + testFunc(f) +} + +func filenameTest(t testing.TB, testFunc func(filename string)) { + fileTest(t, func(f *os.File) { + testFunc(f.Name()) + }) +} + +// creates a dir and cleans it up after the test is run. +func dirTest(t testing.TB, testFunc func(dirname string)) { + dirname, err := ioutil.TempDir("", "") + if err != nil { + t.Fatal(err) + } + defer os.Remove(dirname) + testFunc(dirname) +} + +type timeFetcher func(Timespec) time.Time + +func timespecTest(ts Timespec, r timeRange, t testing.TB, getTimes ...timeFetcher) { + if len(getTimes) == 0 { + getTimes = append(getTimes, Timespec.AccessTime, Timespec.ModTime) + + if ts.HasChangeTime() { + getTimes = append(getTimes, Timespec.ChangeTime) + } + + if ts.HasBirthTime() { + getTimes = append(getTimes, Timespec.BirthTime) + } + } + + for _, getTime := range getTimes { + if !r.Contains(getTime(ts)) { + t.Errorf("expected %s=%s to be in range: \n[%s, %s]\n", GetFunctionName(getTime), getTime(ts), r.start, r.end) + } + } +} + +func GetFunctionName(i interface{}) string { + return runtime.FuncForPC(reflect.ValueOf(i).Pointer()).Name() +}