summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog19
-rw-r--r--ChangeLog.pre-2-019
-rw-r--r--ChangeLog.pre-2-1019
-rw-r--r--ChangeLog.pre-2-219
-rw-r--r--ChangeLog.pre-2-419
-rw-r--r--ChangeLog.pre-2-619
-rw-r--r--ChangeLog.pre-2-819
-rw-r--r--Makefile.am2
-rw-r--r--NEWS25
-rw-r--r--configure.in67
-rw-r--r--docs/reference/gtk/gtk.hierarchy1
-rw-r--r--docs/reference/gtk/tmpl/gtkrc.sgml1
-rw-r--r--docs/reference/gtk/tmpl/gtksignal.sgml165
-rw-r--r--docs/reference/gtk/tmpl/gtktypeutils.sgml20
-rw-r--r--gtk-2.0.m4189
-rw-r--r--gtk-config-2.0.in118
-rw-r--r--gtk/.cvsignore12
-rw-r--r--gtk/3DRings.xpm116
-rw-r--r--gtk/FilesQueue.xpm98
-rw-r--r--gtk/Makefile.am59
-rw-r--r--gtk/Modeller.xpm117
-rw-r--r--gtk/check-n.xpm21
-rw-r--r--gtk/check-y.xpm21
-rw-r--r--gtk/gtkdnd.c2
-rw-r--r--gtk/marble.xpm408
-rw-r--r--gtk/test.xpm92
-rw-r--r--gtk/testcalendar.c422
-rw-r--r--gtk/testdnd.c665
-rw-r--r--gtk/testgtk.c10352
-rw-r--r--gtk/testinput.c393
-rw-r--r--gtk/testrgb.c292
-rw-r--r--gtk/testselection.c490
-rw-r--r--gtk/testtext.c2287
-rw-r--r--gtk/testtextbuffer.c732
-rw-r--r--gtk/testthreads.c162
-rw-r--r--m4macros/gtk-2.0.m4189
-rw-r--r--modules/input/Makefile.am10
-rw-r--r--tests/.cvsignore8
-rw-r--r--tests/Makefile.am50
-rw-r--r--tests/testgtk.c2
-rw-r--r--tests/testinput.c2
-rw-r--r--tests/testrgb.c2
-rw-r--r--tests/testselection.c2
-rw-r--r--tests/testtextbuffer.c3
44 files changed, 522 insertions, 17208 deletions
diff --git a/ChangeLog b/ChangeLog
index 37c281cee4..440b90df18 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,22 @@
+Tue Apr 3 13:55:37 2001 Owen Taylor <otaylor@redhat.com>
+
+ * NEWS: Updated.
+
+ * configure.in: Remove support for uninstalled glib.
+
+ * gtk/gtkdnd.c (gtk_drag_highlight_expose): Return FALSE as
+ so as not to stop emission.
+
+ * gtk-config-2.0.in: Exit with an error message that gtk-config-2.0
+ is no longer supported.
+
+ * Makefile.am gtk/Makefile.am tests/*: Moved all tests
+ into tests, change build order to build modules before
+ gtk/.
+
+ * modules/input/Makefile.am: Move gtk-query-immodules-2.0 invocation
+ to here.
+
Tue Apr 3 13:52:57 2001 Tim Janik <timj@gtk.org>
* gtk/gtkitemfactory.[hc]: changed gtk_item_factory_dump_items()
diff --git a/ChangeLog.pre-2-0 b/ChangeLog.pre-2-0
index 37c281cee4..440b90df18 100644
--- a/ChangeLog.pre-2-0
+++ b/ChangeLog.pre-2-0
@@ -1,3 +1,22 @@
+Tue Apr 3 13:55:37 2001 Owen Taylor <otaylor@redhat.com>
+
+ * NEWS: Updated.
+
+ * configure.in: Remove support for uninstalled glib.
+
+ * gtk/gtkdnd.c (gtk_drag_highlight_expose): Return FALSE as
+ so as not to stop emission.
+
+ * gtk-config-2.0.in: Exit with an error message that gtk-config-2.0
+ is no longer supported.
+
+ * Makefile.am gtk/Makefile.am tests/*: Moved all tests
+ into tests, change build order to build modules before
+ gtk/.
+
+ * modules/input/Makefile.am: Move gtk-query-immodules-2.0 invocation
+ to here.
+
Tue Apr 3 13:52:57 2001 Tim Janik <timj@gtk.org>
* gtk/gtkitemfactory.[hc]: changed gtk_item_factory_dump_items()
diff --git a/ChangeLog.pre-2-10 b/ChangeLog.pre-2-10
index 37c281cee4..440b90df18 100644
--- a/ChangeLog.pre-2-10
+++ b/ChangeLog.pre-2-10
@@ -1,3 +1,22 @@
+Tue Apr 3 13:55:37 2001 Owen Taylor <otaylor@redhat.com>
+
+ * NEWS: Updated.
+
+ * configure.in: Remove support for uninstalled glib.
+
+ * gtk/gtkdnd.c (gtk_drag_highlight_expose): Return FALSE as
+ so as not to stop emission.
+
+ * gtk-config-2.0.in: Exit with an error message that gtk-config-2.0
+ is no longer supported.
+
+ * Makefile.am gtk/Makefile.am tests/*: Moved all tests
+ into tests, change build order to build modules before
+ gtk/.
+
+ * modules/input/Makefile.am: Move gtk-query-immodules-2.0 invocation
+ to here.
+
Tue Apr 3 13:52:57 2001 Tim Janik <timj@gtk.org>
* gtk/gtkitemfactory.[hc]: changed gtk_item_factory_dump_items()
diff --git a/ChangeLog.pre-2-2 b/ChangeLog.pre-2-2
index 37c281cee4..440b90df18 100644
--- a/ChangeLog.pre-2-2
+++ b/ChangeLog.pre-2-2
@@ -1,3 +1,22 @@
+Tue Apr 3 13:55:37 2001 Owen Taylor <otaylor@redhat.com>
+
+ * NEWS: Updated.
+
+ * configure.in: Remove support for uninstalled glib.
+
+ * gtk/gtkdnd.c (gtk_drag_highlight_expose): Return FALSE as
+ so as not to stop emission.
+
+ * gtk-config-2.0.in: Exit with an error message that gtk-config-2.0
+ is no longer supported.
+
+ * Makefile.am gtk/Makefile.am tests/*: Moved all tests
+ into tests, change build order to build modules before
+ gtk/.
+
+ * modules/input/Makefile.am: Move gtk-query-immodules-2.0 invocation
+ to here.
+
Tue Apr 3 13:52:57 2001 Tim Janik <timj@gtk.org>
* gtk/gtkitemfactory.[hc]: changed gtk_item_factory_dump_items()
diff --git a/ChangeLog.pre-2-4 b/ChangeLog.pre-2-4
index 37c281cee4..440b90df18 100644
--- a/ChangeLog.pre-2-4
+++ b/ChangeLog.pre-2-4
@@ -1,3 +1,22 @@
+Tue Apr 3 13:55:37 2001 Owen Taylor <otaylor@redhat.com>
+
+ * NEWS: Updated.
+
+ * configure.in: Remove support for uninstalled glib.
+
+ * gtk/gtkdnd.c (gtk_drag_highlight_expose): Return FALSE as
+ so as not to stop emission.
+
+ * gtk-config-2.0.in: Exit with an error message that gtk-config-2.0
+ is no longer supported.
+
+ * Makefile.am gtk/Makefile.am tests/*: Moved all tests
+ into tests, change build order to build modules before
+ gtk/.
+
+ * modules/input/Makefile.am: Move gtk-query-immodules-2.0 invocation
+ to here.
+
Tue Apr 3 13:52:57 2001 Tim Janik <timj@gtk.org>
* gtk/gtkitemfactory.[hc]: changed gtk_item_factory_dump_items()
diff --git a/ChangeLog.pre-2-6 b/ChangeLog.pre-2-6
index 37c281cee4..440b90df18 100644
--- a/ChangeLog.pre-2-6
+++ b/ChangeLog.pre-2-6
@@ -1,3 +1,22 @@
+Tue Apr 3 13:55:37 2001 Owen Taylor <otaylor@redhat.com>
+
+ * NEWS: Updated.
+
+ * configure.in: Remove support for uninstalled glib.
+
+ * gtk/gtkdnd.c (gtk_drag_highlight_expose): Return FALSE as
+ so as not to stop emission.
+
+ * gtk-config-2.0.in: Exit with an error message that gtk-config-2.0
+ is no longer supported.
+
+ * Makefile.am gtk/Makefile.am tests/*: Moved all tests
+ into tests, change build order to build modules before
+ gtk/.
+
+ * modules/input/Makefile.am: Move gtk-query-immodules-2.0 invocation
+ to here.
+
Tue Apr 3 13:52:57 2001 Tim Janik <timj@gtk.org>
* gtk/gtkitemfactory.[hc]: changed gtk_item_factory_dump_items()
diff --git a/ChangeLog.pre-2-8 b/ChangeLog.pre-2-8
index 37c281cee4..440b90df18 100644
--- a/ChangeLog.pre-2-8
+++ b/ChangeLog.pre-2-8
@@ -1,3 +1,22 @@
+Tue Apr 3 13:55:37 2001 Owen Taylor <otaylor@redhat.com>
+
+ * NEWS: Updated.
+
+ * configure.in: Remove support for uninstalled glib.
+
+ * gtk/gtkdnd.c (gtk_drag_highlight_expose): Return FALSE as
+ so as not to stop emission.
+
+ * gtk-config-2.0.in: Exit with an error message that gtk-config-2.0
+ is no longer supported.
+
+ * Makefile.am gtk/Makefile.am tests/*: Moved all tests
+ into tests, change build order to build modules before
+ gtk/.
+
+ * modules/input/Makefile.am: Move gtk-query-immodules-2.0 invocation
+ to here.
+
Tue Apr 3 13:52:57 2001 Tim Janik <timj@gtk.org>
* gtk/gtkitemfactory.[hc]: changed gtk_item_factory_dump_items()
diff --git a/Makefile.am b/Makefile.am
index 1ee167e411..2f9eaa6090 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -1,6 +1,6 @@
## Makefile.am for GTK+
-SRC_SUBDIRS = gdk-pixbuf gdk modules gtk demos contrib
+SRC_SUBDIRS = gdk-pixbuf gdk gtk modules demos tests contrib
SUBDIRS = po $(SRC_SUBDIRS) docs build
# require automake 1.4
diff --git a/NEWS b/NEWS
index 33ccbac0e5..dfbb474f4b 100644
--- a/NEWS
+++ b/NEWS
@@ -1,3 +1,28 @@
+Overview of Changes in GTK+ 1.3.3
+=================================
+
+[ 5600 lines of ChangeLog ]
+
+* API cleanups
+* Win32 work (Tor, Hans Breuer)
+* Focus improvements (Owen)
+* Frame buffer improvements (Alex)
+* Work on GtkTextView (Havoc)
+* Much work on GtkTreeView (Jonathan)
+* Selectable labels (Havoc)
+* Converted many arguments to properties (Lee Mallabone, John Margaglione)
+* Add exact regions to GdkExposeEvent, propagate it. (Alex)
+* Added ability to have resize grips in status bars (etc.) using
+ _NET_WM_MOVERESIZE protocol. (Havoc)
+* Added mnemnonic mechanism to make setting underline accelerators
+ much easier. (Alex)
+* Add per-style property mechanism to allow themes to change
+ geometry parameters. (Tim)
+* Added global settings mechanisms for settings such as double-click
+ time. (Tim, Owen)
+* Various support functions for new and old WM properties (Havoc, Alex)
+* Add TRUE-stops-returns for boolean-returning signals (Ron Steinke)
+
Overview of Changes in GTK+ 1.3.2
=================================
diff --git a/configure.in b/configure.in
index baabd25814..d43a5d2cef 100644
--- a/configure.in
+++ b/configure.in
@@ -109,7 +109,6 @@ AC_ARG_ENABLE(shm, [ --enable-shm support shared memory if available
echo $enable_shm, enable_shm="yes")
AC_ARG_ENABLE(ansi, [ --enable-ansi turn on strict ansi [default=no]],
, enable_ansi=no)
-AC_ARG_WITH(glib, [ --with-glib=DIR Use uninstalled copy of glib])
AC_ARG_ENABLE(xim, [ --enable-xim support XIM [default=yes]],
, enable_xim="yes")
AC_ARG_ENABLE(xim_inst, [ --disable-xim-inst does not use xim instantiate callback],
@@ -285,68 +284,20 @@ AC_TRY_COMPILE([#include <dirent.h>], [DIR *dir;],
CFLAGS="$gtk_save_CFLAGS"
AC_MSG_WARN([Could not determine POSIX flag. (-posix didn't work.)])))
-
-#
-# Find pkg-config
#
-AC_PATH_PROG(PKG_CONFIG, pkg-config, no)
-if test x$PKG_CONFIG = xno ; then
- AC_MSG_ERROR([*** pkg-config not found. See http://pkgconfig.sourceforge.net])
-fi
+# Run AM_PATH_GLIB_2_0 to make sure that GLib is installed and working
+#
-if ! pkg-config --atleast-pkgconfig-version 0.5 ; then
- AC_MSG_ERROR([*** pkg-config too old; version 0.5 or better required.])
-fi
+GLIB_PACKAGES="gobject-2.0 gmodule-2.0 gthread-2.0"
+GLIB_REQUIRED_VERSION=1.3.2
-if test x$with_glib = xyes ; then
+AM_PATH_GLIB_2_0($GLIB_REQUIRED_VERSION, :,
AC_MSG_ERROR([
-*** Directory must be specified for --with-glib])
-fi
-
-if test x$with_glib = x ; then
+*** GLIB $GLIB_REQUIRED_VERSION or better is required. The latest version of
+*** GLIB is always available from ftp://ftp.gtk.org/.]),
+ gobject gmodule gthread)
- # Look for separately installed glib
-
- GLIB_PACKAGES="gobject-2.0 gmodule-2.0 gthread-2.0"
- GLIB_REQUIRED_VERSION=1.3.2
-
- AC_MSG_CHECKING(GLib flags)
- if $PKG_CONFIG --atleast-version $GLIB_REQUIRED_VERSION glib-2.0 ; then
- GLIB_CFLAGS=`$PKG_CONFIG --cflags $GLIB_PACKAGES`
- GLIB_LIBS=`$PKG_CONFIG --libs $GLIB_PACKAGES`
- GLIB_DEPLIBS=$GLIB_LIBS
-
- AC_MSG_RESULT($GLIB_CFLAGS $GLIB_LIBS)
- else
- AC_MSG_ERROR([
-*** GLIB $GLIB_REQUIRED_VERSION or newer is required. The latest version of GLIB
-*** is always available from ftp://ftp.gtk.org/.
- ])
- fi
-
-else
- # Use uninstalled glib (assume they got the version right)
-
- if test -e glib-2.0.pc ; then
- :
- else
- AC_MSG_ERROR([GLIB directory ($with_glib) not present or not configured])
- fi
-
- # canonicalize relative paths
- case $with_glib in
- /*)
- glib_dir=$with_glib
- ;;
- *)
- glib_dir="\$(top_builddir)/$with_glib"
- ;;
- esac
-
- GLIB_CFLAGS="-I$glib_dir -I$glib_dir/gmodule"
- GLIB_LIBS="$glib_dir/libglib-1.3.la $glib_dir/gmodule/libgmodule-1.3.la"
- GLIB_DEPLIBS=
-fi
+GLIB_DEPLIBS=$GLIB_LIBS
CFLAGS="$CFLAGS $GLIB_CFLAGS"
AC_SUBST(GLIB_CFLAGS)
diff --git a/docs/reference/gtk/gtk.hierarchy b/docs/reference/gtk/gtk.hierarchy
index 4655ff729f..601aa73ff2 100644
--- a/docs/reference/gtk/gtk.hierarchy
+++ b/docs/reference/gtk/gtk.hierarchy
@@ -6,6 +6,7 @@ GObject
GdkPixmap
GdkColormap
GtkSettings
+ GtkRcStyle
GtkObject
GtkWidget
GtkMisc
diff --git a/docs/reference/gtk/tmpl/gtkrc.sgml b/docs/reference/gtk/tmpl/gtkrc.sgml
index 041bbddd55..fe52fbe8a2 100644
--- a/docs/reference/gtk/tmpl/gtkrc.sgml
+++ b/docs/reference/gtk/tmpl/gtkrc.sgml
@@ -496,7 +496,6 @@ This can later be composited together with other
#GtkRcStyle structures to form a #GtkStyle.
</para>
-@parent_instance:
@name:
@bg_pixmap_name:
@font_desc:
diff --git a/docs/reference/gtk/tmpl/gtksignal.sgml b/docs/reference/gtk/tmpl/gtksignal.sgml
index 1a5a4f3e27..1bb805c8ba 100644
--- a/docs/reference/gtk/tmpl/gtksignal.sgml
+++ b/docs/reference/gtk/tmpl/gtksignal.sgml
@@ -289,7 +289,7 @@ you don't want a return value.
the callbacks.
-<!-- ##### FUNCTION gtk_signal_lookup ##### -->
+<!-- ##### MACRO gtk_signal_lookup ##### -->
<para>
Given the name of the signal and the type of object it connects
to, get the signal's identifying integer. Emitting the signal
@@ -299,12 +299,13 @@ by number is somewhat faster than using the name each time.
It also tries the ancestors of the given type.
</para>
+@Returns: the signal's identifying number, or 0 if no signal was found.
+<!-- # Unused Parameters # -->
@name: the signal's name, e.g. clicked.
@object_type: the type that the signal operates on, e.g. #GTK_TYPE_BUTTON.
-@Returns: the signal's identifying number, or 0 if no signal was found.
-<!-- ##### FUNCTION gtk_signal_name ##### -->
+<!-- ##### MACRO gtk_signal_name ##### -->
<para>
Given the signal's identifier, find its name.
</para>
@@ -312,8 +313,9 @@ Given the signal's identifier, find its name.
Two different signals may have the same name, if they have differing types.
</para>
-@signal_id: the signal's identifying number.
@Returns: the signal name, or NULL if the signal number was invalid.
+<!-- # Unused Parameters # -->
+@signal_id: the signal's identifying number.
<!-- ##### FUNCTION gtk_signal_emit ##### -->
@@ -381,7 +383,7 @@ an array of GtkArgs instead of using C's varargs mechanism.
followed by one which is a pointer to the return type.
-<!-- ##### FUNCTION gtk_signal_emit_stop ##### -->
+<!-- ##### MACRO gtk_signal_emit_stop ##### -->
<para>
This function aborts a signal's current emission.
</para>
@@ -395,11 +397,11 @@ It will print a warning if used on a signal which
isn't being emitted.
</para>
-@object: the object whose signal handlers you wish to stop.
-@signal_id: the signal identifier, as returned by gtk_signal_lookup().
-<!-- # Unused Parameters # -->
@i:
@s:
+<!-- # Unused Parameters # -->
+@object: the object whose signal handlers you wish to stop.
+@signal_id: the signal identifier, as returned by gtk_signal_lookup().
<!-- ##### FUNCTION gtk_signal_emit_stop_by_name ##### -->
@@ -415,7 +417,7 @@ except it will lookup the signal id for you.
@name: the name of the signal you wish to stop.
-<!-- ##### FUNCTION gtk_signal_connect ##### -->
+<!-- ##### MACRO gtk_signal_connect ##### -->
<para>
Attach a function pointer and user data to a signal for
a particular object.
@@ -454,38 +456,38 @@ static void attach_print_signal(GtkButton* button, gint to_print)
</programlisting>
</informalexample>
+@o:
+@s:
+@f:
+@d:
+@Returns: the connection id.
+<!-- # Unused Parameters # -->
@object: the object associated with the signal, e.g. if a button
is getting pressed, this is that button.
@name: name of the signal.
@func: function pointer to attach to the signal.
@func_data: value to pass as to your function (through the marshaller).
-@Returns: the connection id.
-<!-- # Unused Parameters # -->
-@o:
-@s:
-@f:
-@d:
-<!-- ##### FUNCTION gtk_signal_connect_after ##### -->
+<!-- ##### MACRO gtk_signal_connect_after ##### -->
<para>
Attach a function pointer and user data to a signal
so that this handler will be called after the other handlers.
</para>
-@object: the object associated with the signal.
-@name: name of the signal.
-@func: function pointer to attach to the signal.
-@func_data: value to pass as to your function (through the marshaller).
-@Returns: the unique identifier for this attachment: the connection id.
-<!-- # Unused Parameters # -->
@o:
@s:
@f:
@d:
+@Returns: the unique identifier for this attachment: the connection id.
+<!-- # Unused Parameters # -->
+@object: the object associated with the signal.
+@name: name of the signal.
+@func: function pointer to attach to the signal.
+@func_data: value to pass as to your function (through the marshaller).
-<!-- ##### FUNCTION gtk_signal_connect_object ##### -->
+<!-- ##### MACRO gtk_signal_connect_object ##### -->
<para>
This function is for registering a callback that will
call another object's callback. That is,
@@ -506,21 +508,21 @@ gtk_signal_connect_object(button, "clicked", gtk_widget_show, window);
</programlisting>
</informalexample>
+@o:
+@s:
+@f:
+@d:
+@Returns: the connection id.
+<!-- # Unused Parameters # -->
@object: the object which emits the signal.
@name: the name of the signal.
@func: the function to callback.
@slot_object: the object to pass as the first parameter to func.
(Though it pretends to take an object, you can
really pass any gpointer as the #slot_object .)
-@Returns: the connection id.
-<!-- # Unused Parameters # -->
-@o:
-@s:
-@f:
-@d:
-<!-- ##### FUNCTION gtk_signal_connect_object_after ##### -->
+<!-- ##### MACRO gtk_signal_connect_object_after ##### -->
<para>
Attach a signal hook to a signal, passing in an alternate
object as the first parameter, and guaranteeing
@@ -528,16 +530,16 @@ that the default handler and all normal
handlers are called first.
</para>
-@object: the object associated with the signal.
-@name: name of the signal.
-@func: function pointer to attach to the signal.
-@slot_object: the object to pass as the first parameter to #func.
-@Returns: the connection id.
-<!-- # Unused Parameters # -->
@o:
@s:
@f:
@d:
+@Returns: the connection id.
+<!-- # Unused Parameters # -->
+@object: the object associated with the signal.
+@name: name of the signal.
+@func: function pointer to attach to the signal.
+@slot_object: the object to pass as the first parameter to #func.
<!-- ##### FUNCTION gtk_signal_connect_full ##### -->
@@ -626,95 +628,98 @@ should signal the removal of this signal.
@name: name of the signal.
-<!-- ##### FUNCTION gtk_signal_disconnect ##### -->
+<!-- ##### MACRO gtk_signal_disconnect ##### -->
<para>
Destroy a user-defined handler connection.
</para>
+<!-- # Unused Parameters # -->
@object: the object which the handler pertains to.
@handler_id: the connection id.
-<!-- ##### FUNCTION gtk_signal_disconnect_by_func ##### -->
+<!-- ##### MACRO gtk_signal_disconnect_by_func ##### -->
<para>
Destroy all connections for a particular object, with
the given function-pointer and user-data.
</para>
-@object: the object which emits the signal.
-@func: the function pointer to search for.
-@data: the user data to search for.
-<!-- # Unused Parameters # -->
@o:
@f:
@d:
+<!-- # Unused Parameters # -->
+@object: the object which emits the signal.
+@func: the function pointer to search for.
+@data: the user data to search for.
-<!-- ##### FUNCTION gtk_signal_disconnect_by_data ##### -->
+<!-- ##### MACRO gtk_signal_disconnect_by_data ##### -->
<para>
Destroy all connections for a particular object, with
the given user-data.
</para>
-@object: the object which emits the signal.
-@data: the user data to search for.
-<!-- # Unused Parameters # -->
@o:
@d:
+<!-- # Unused Parameters # -->
+@object: the object which emits the signal.
+@data: the user data to search for.
-<!-- ##### FUNCTION gtk_signal_handler_block ##### -->
+<!-- ##### MACRO gtk_signal_handler_block ##### -->
<para>
Prevent an user-defined handler from being invoked. All other
signal processing will go on as normal, but this particular
handler will ignore it.
</para>
+<!-- # Unused Parameters # -->
@object: the object which emits the signal to block.
@handler_id: the connection id.
-<!-- ##### FUNCTION gtk_signal_handler_block_by_func ##### -->
+<!-- ##### MACRO gtk_signal_handler_block_by_func ##### -->
<para>
Prevent a user-defined handler from being invoked, by reference to
the user-defined handler's function pointer and user data. (It may result in
multiple hooks being blocked, if you've called connect multiple times.)
</para>
-@object: the object which emits the signal to block.
-@func: the function pointer of the handler to block.
-@data: the user data of the handler to block.
-<!-- # Unused Parameters # -->
@o:
@f:
@d:
+<!-- # Unused Parameters # -->
+@object: the object which emits the signal to block.
+@func: the function pointer of the handler to block.
+@data: the user data of the handler to block.
-<!-- ##### FUNCTION gtk_signal_handler_block_by_data ##### -->
+<!-- ##### MACRO gtk_signal_handler_block_by_data ##### -->
<para>
Prevent all user-defined handlers with a certain user data from being invoked.
</para>
-@object: the object which emits the signal we want to block.
-@data: the user data of the handlers to block.
-<!-- # Unused Parameters # -->
@o:
@d:
+<!-- # Unused Parameters # -->
+@object: the object which emits the signal we want to block.
+@data: the user data of the handlers to block.
-<!-- ##### FUNCTION gtk_signal_handler_unblock ##### -->
+<!-- ##### MACRO gtk_signal_handler_unblock ##### -->
<para>
Undo a block, by connection id. Note that undoing a block doesn't
necessarily make the hook callable, because if you block a
hook twice, you must unblock it twice.
</para>
+<!-- # Unused Parameters # -->
@object: the object which emits the signal we want to unblock.
@handler_id: the emission handler identifier, as returned by
gtk_signal_connect(), etc.
-<!-- ##### FUNCTION gtk_signal_handler_unblock_by_func ##### -->
+<!-- ##### MACRO gtk_signal_handler_unblock_by_func ##### -->
<para>
Undo a block, by function pointer and data.
Note that undoing a block doesn't
@@ -722,29 +727,29 @@ necessarily make the hook callable, because if you block a
hook twice, you must unblock it twice.
</para>
-@object: the object which emits the signal we want to unblock.
-@func: the function pointer to search for.
-@data: the user data to search for.
-<!-- # Unused Parameters # -->
@o:
@f:
@d:
+<!-- # Unused Parameters # -->
+@object: the object which emits the signal we want to unblock.
+@func: the function pointer to search for.
+@data: the user data to search for.
-<!-- ##### FUNCTION gtk_signal_handler_unblock_by_data ##### -->
+<!-- ##### MACRO gtk_signal_handler_unblock_by_data ##### -->
<para>
Undo block(s), to all signals for a particular object
with a particular user-data pointer
</para>
-@object: the object which emits the signal we want to unblock.
-@data: the user data to search for.
-<!-- # Unused Parameters # -->
@o:
@d:
+<!-- # Unused Parameters # -->
+@object: the object which emits the signal we want to unblock.
+@data: the user data to search for.
-<!-- ##### FUNCTION gtk_signal_handler_pending ##### -->
+<!-- ##### MACRO gtk_signal_handler_pending ##### -->
<para>
Returns a connection id corresponding to a given signal id and object.
</para>
@@ -755,36 +760,36 @@ may opt to not emit the signal if no one is attached anyway,
thus saving the cost of building the arguments.
</para>
+@i:
+@s:
+@b:
+@Returns: the connection id, if a connection was found. 0 otherwise.
+<!-- # Unused Parameters # -->
@object: the object to search for the desired user-defined handler.
@signal_id: the number of the signal to search for.
@may_be_blocked: whether it is acceptable to return a blocked
handler.
-@Returns: the connection id, if a connection was found. 0 otherwise.
-<!-- # Unused Parameters # -->
-@i:
-@s:
-@b:
-<!-- ##### FUNCTION gtk_signal_handler_pending_by_func ##### -->
+<!-- ##### MACRO gtk_signal_handler_pending_by_func ##### -->
<para>
Returns a connection id corresponding to a given signal id, object, function
pointer and user data.
</para>
+@o:
+@s:
+@b:
+@f:
+@d:
+@Returns: the connection id, if a handler was found. 0 otherwise.
+<!-- # Unused Parameters # -->
@object: the object to search for the desired handler.
@signal_id: the number of the signal to search for.
@may_be_blocked: whether it is acceptable to return a blocked
handler.
@func: the function pointer to search for.
@data: the user data to search for.
-@Returns: the connection id, if a handler was found. 0 otherwise.
-<!-- # Unused Parameters # -->
-@o:
-@s:
-@b:
-@f:
-@d:
<!-- ##### MACRO gtk_signal_default_marshaller ##### -->
diff --git a/docs/reference/gtk/tmpl/gtktypeutils.sgml b/docs/reference/gtk/tmpl/gtktypeutils.sgml
index 6295e2dfa1..16a7e543fe 100644
--- a/docs/reference/gtk/tmpl/gtktypeutils.sgml
+++ b/docs/reference/gtk/tmpl/gtktypeutils.sgml
@@ -560,30 +560,33 @@ Create a new, unique type.
@type_info: must not be null, and @type_info->type_name must also not be null.
-<!-- ##### FUNCTION gtk_type_name ##### -->
+<!-- ##### MACRO gtk_type_name ##### -->
<para>
</para>
-@type: a GtkType
@Returns: a pointer to the name of a type, or NULL if it has none.
+<!-- # Unused Parameters # -->
+@type: a GtkType
-<!-- ##### FUNCTION gtk_type_from_name ##### -->
+<!-- ##### MACRO gtk_type_from_name ##### -->
<para>
Get the internal representation of a type given its name.
</para>
-@name: the name of a gtk type
@Returns: a GtkType
+<!-- # Unused Parameters # -->
+@name: the name of a gtk type
-<!-- ##### FUNCTION gtk_type_parent ##### -->
+<!-- ##### MACRO gtk_type_parent ##### -->
<para>
</para>
-@type: a GtkType
@Returns: the GtkType of the parent
+<!-- # Unused Parameters # -->
+@type: a GtkType
<!-- ##### FUNCTION gtk_type_class ##### -->
@@ -608,15 +611,16 @@ has all the proper initializers called.
@Returns: gpointer to a GtkTypeObject
-<!-- ##### FUNCTION gtk_type_is_a ##### -->
+<!-- ##### MACRO gtk_type_is_a ##### -->
<para>
Look in the type hierarchy to see if @type has @is_a_type among its
ancestors. Do so with a simple lookup, not a loop.
</para>
+@Returns:
+<!-- # Unused Parameters # -->
@type: GtkType
@is_a_type: GtkType
-@Returns:
<!-- ##### FUNCTION gtk_type_enum_get_values ##### -->
diff --git a/gtk-2.0.m4 b/gtk-2.0.m4
index 6b8d91e1b9..b3763444dc 100644
--- a/gtk-2.0.m4
+++ b/gtk-2.0.m4
@@ -1,69 +1,65 @@
-# Configure paths for GTK+
-# Owen Taylor 97-11-3
+# Configure paths for GLIB
+# Owen Taylor 1997-2001
-dnl AM_PATH_GTK_2_0([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND [, MODULES]]]])
-dnl Test for GTK, and define GTK_CFLAGS and GTK_LIBS
+dnl AM_PATH_GLIB_2_0([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND [, MODULES]]]])
+dnl Test for GLIB, and define GLIB_CFLAGS and GLIB_LIBS, if "gmodule" or
+dnl gthread is specified in MODULES, pass to glib-config
dnl
-AC_DEFUN(AM_PATH_GTK_2_0,
+AC_DEFUN(AM_PATH_GLIB_2_0,
[dnl
-dnl Get the cflags and libraries from the gtk-config-2.0 script
+dnl Get the cflags and libraries from the glib-config-2.0 script
dnl
-AC_ARG_WITH(gtk-prefix,[ --with-gtk-prefix=PFX Prefix where GTK is installed (optional)],
- gtk_config_prefix="$withval", gtk_config_prefix="")
-AC_ARG_WITH(gtk-exec-prefix,[ --with-gtk-exec-prefix=PFX Exec prefix where GTK is installed (optional)],
- gtk_config_exec_prefix="$withval", gtk_config_exec_prefix="")
-AC_ARG_ENABLE(gtktest, [ --disable-gtktest Do not try to compile and run a test GTK program],
- , enable_gtktest=yes)
+AC_ARG_ENABLE(glibtest, [ --disable-glibtest Do not try to compile and run a test GLIB program],
+ , enable_glibtest=yes)
+ pkg_config_args=gtk+-2.0
for module in . $4
do
case "$module" in
gthread)
- gtk_config_args="$gtk_config_args gthread"
+ pkg_config_args="$pkg_config_args gthread-2.0"
;;
esac
done
- if test x$gtk_config_exec_prefix != x ; then
- gtk_config_args="$gtk_config_args --exec-prefix=$gtk_config_exec_prefix"
- if test x${GTK_CONFIG_2_0+set} != xset ; then
- GTK_CONFIG_2_0=$gtk_config_exec_prefix/bin/gtk-config-2.0
- fi
- fi
- if test x$gtk_config_prefix != x ; then
- gtk_config_args="$gtk_config_args --prefix=$gtk_config_prefix"
- if test x${GTK_CONFIG_2_0+set} != xset ; then
- GTK_CONFIG_2_0=$gtk_config_prefix/bin/gtk-config-2.0
- fi
+ min_glib_version=ifelse([$1], ,1.3.3,$1)
+ AC_MSG_CHECKING(for GLIB - version >= $min_glib_version)
+
+ no_glib=""
+
+ AC_PATH_PROG(PKG_CONFIG, pkg-config, no)
+
+ if test x$PKG_CONFIG != xno ; then
+ if pkg-config --atleast-pkgconfig-version 0.5 ; then
+ :
+ else
+ echo *** pkg-config too old; version 0.5 or better required.
+ no_glib=yes
+ PKG_CONFIG=no
+ fi
fi
- AC_PATH_PROG(GTK_CONFIG_2_0, gtk-config-2.0, no)
- min_gtk_version=ifelse([$1], ,1.3.1,$1)
- AC_MSG_CHECKING(for GTK - version >= $min_gtk_version)
- no_gtk=""
- if test "$GTK_CONFIG_2_0" = "no" ; then
- no_gtk=yes
- else
- GTK_CFLAGS=`$GTK_CONFIG_2_0 $gtk_config_args --cflags`
- GTK_LIBS=`$GTK_CONFIG_2_0 $gtk_config_args --libs`
- gtk_config_major_version=`$GTK_CONFIG_2_0 $gtk_config_args --version | \
+ if test x"$no_glib" = x ; then
+ GLIB_CFLAGS=`$PKG_CONFIG $pkg_config_args --cflags`
+ GLIB_LIBS=`$PKG_CONFIG $pkg_config_args --libs`
+ glib_config_major_version=`$PKG_CONFIG glib-2.0 --modversion | \
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'`
- gtk_config_minor_version=`$GTK_CONFIG_2_0 $gtk_config_args --version | \
+ glib_config_minor_version=`$PKG_CONFIG glib-2.0 --modversion | \
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'`
- gtk_config_micro_version=`$GTK_CONFIG_2_0 $gtk_config_args --version | \
+ glib_config_micro_version=`$PKG_CONFIG glib-2.0 --modversion | \
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'`
- if test "x$enable_gtktest" = "xyes" ; then
+ if test "x$enable_glibtest" = "xyes" ; then
ac_save_CFLAGS="$CFLAGS"
ac_save_LIBS="$LIBS"
- CFLAGS="$CFLAGS $GTK_CFLAGS"
- LIBS="$GTK_LIBS $LIBS"
+ CFLAGS="$CFLAGS $GLIB_CFLAGS"
+ LIBS="$GLIB_LIBS $LIBS"
dnl
-dnl Now check if the installed GTK is sufficiently new. (Also sanity
-dnl checks the results of gtk-config-2.0 to some extent
+dnl Now check if the installed GLIB is sufficiently new. (Also sanity
+dnl checks the results of glib-config-2.0 to some extent
dnl
- rm -f conf.gtktest
+ rm -f conf.glibtest
AC_TRY_RUN([
-#include <gtk/gtk.h>
+#include <glib.h>
#include <stdio.h>
#include <stdlib.h>
@@ -73,98 +69,93 @@ main ()
int major, minor, micro;
char *tmp_version;
- system ("touch conf.gtktest");
+ system ("touch conf.glibtest");
/* HP/UX 9 (%@#!) writes to sscanf strings */
- tmp_version = g_strdup("$min_gtk_version");
+ tmp_version = g_strdup("$min_glib_version");
if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, &micro) != 3) {
- printf("%s, bad version string\n", "$min_gtk_version");
+ printf("%s, bad version string\n", "$min_glib_version");
exit(1);
}
- if ((gtk_major_version != $gtk_config_major_version) ||
- (gtk_minor_version != $gtk_config_minor_version) ||
- (gtk_micro_version != $gtk_config_micro_version))
+ if ((glib_major_version != $glib_config_major_version) ||
+ (glib_minor_version != $glib_config_minor_version) ||
+ (glib_micro_version != $glib_config_micro_version))
{
- printf("\n*** 'gtk-config-2.0 --version' returned %d.%d.%d, but GTK+ (%d.%d.%d)\n",
- $gtk_config_major_version, $gtk_config_minor_version, $gtk_config_micro_version,
- gtk_major_version, gtk_minor_version, gtk_micro_version);
- printf ("*** was found! If gtk-config-2.0 was correct, then it is best\n");
- printf ("*** to remove the old version of GTK+. You may also be able to fix the error\n");
+ printf("\n*** 'pkg-config --modversion glib-2.0' returned %d.%d.%d, but GLIB (%d.%d.%d)\n",
+ $glib_config_major_version, $glib_config_minor_version, $glib_config_micro_version,
+ glib_major_version, glib_minor_version, glib_micro_version);
+ printf ("*** was found! If pkg-config was correct, then it is best\n");
+ printf ("*** to remove the old version of GLib. You may also be able to fix the error\n");
printf("*** by modifying your LD_LIBRARY_PATH enviroment variable, or by editing\n");
printf("*** /etc/ld.so.conf. Make sure you have run ldconfig if that is\n");
printf("*** required on your system.\n");
- printf("*** If gtk-config-2.0 was wrong, set the environment variable GTK_CONFIG_2_0\n");
- printf("*** to point to the correct copy of gtk-config-2.0, and remove the file config.cache\n");
- printf("*** before re-running configure\n");
+ printf("*** If pkg-config was wrong, set the environment variable PKG_CONFIG_PATH\n");
+ printf("*** to point to the correct configuration files\n");
}
-#if defined (GTK_MAJOR_VERSION) && defined (GTK_MINOR_VERSION) && defined (GTK_MICRO_VERSION)
- else if ((gtk_major_version != GTK_MAJOR_VERSION) ||
- (gtk_minor_version != GTK_MINOR_VERSION) ||
- (gtk_micro_version != GTK_MICRO_VERSION))
+ else if ((glib_major_version != GLIB_MAJOR_VERSION) ||
+ (glib_minor_version != GLIB_MINOR_VERSION) ||
+ (glib_micro_version != GLIB_MICRO_VERSION))
{
- printf("*** GTK+ header files (version %d.%d.%d) do not match\n",
- GTK_MAJOR_VERSION, GTK_MINOR_VERSION, GTK_MICRO_VERSION);
+ printf("*** GLIB header files (version %d.%d.%d) do not match\n",
+ GLIB_MAJOR_VERSION, GLIB_MINOR_VERSION, GLIB_MICRO_VERSION);
printf("*** library (version %d.%d.%d)\n",
- gtk_major_version, gtk_minor_version, gtk_micro_version);
+ glib_major_version, glib_minor_version, glib_micro_version);
}
-#endif /* defined (GTK_MAJOR_VERSION) ... */
else
{
- if ((gtk_major_version > major) ||
- ((gtk_major_version == major) && (gtk_minor_version > minor)) ||
- ((gtk_major_version == major) && (gtk_minor_version == minor) && (gtk_micro_version >= micro)))
+ if ((glib_major_version > major) ||
+ ((glib_major_version == major) && (glib_minor_version > minor)) ||
+ ((glib_major_version == major) && (glib_minor_version == minor) && (glib_micro_version >= micro)))
{
return 0;
}
else
{
- printf("\n*** An old version of GTK+ (%d.%d.%d) was found.\n",
- gtk_major_version, gtk_minor_version, gtk_micro_version);
- printf("*** You need a version of GTK+ newer than %d.%d.%d. The latest version of\n",
+ printf("\n*** An old version of GLIB (%d.%d.%d) was found.\n",
+ glib_major_version, glib_minor_version, glib_micro_version);
+ printf("*** You need a version of GLIB newer than %d.%d.%d. The latest version of\n",
major, minor, micro);
- printf("*** GTK+ is always available from ftp://ftp.gtk.org.\n");
+ printf("*** GLIB is always available from ftp://ftp.gtk.org.\n");
printf("***\n");
printf("*** If you have already installed a sufficiently new version, this error\n");
- printf("*** probably means that the wrong copy of the gtk-config-2.0 shell script is\n");
+ printf("*** probably means that the wrong copy of the pkg-config shell script is\n");
printf("*** being found. The easiest way to fix this is to remove the old version\n");
- printf("*** of GTK+, but you can also set the GTK_CONFIG_2_0 environment to point to the\n");
- printf("*** correct copy of gtk-config-2.0. (In this case, you will have to\n");
+ printf("*** of GLIB, but you can also set the PKG_CONFIG environment to point to the\n");
+ printf("*** correct copy of pkg-config. (In this case, you will have to\n");
printf("*** modify your LD_LIBRARY_PATH enviroment variable, or edit /etc/ld.so.conf\n");
printf("*** so that the correct libraries are found at run-time))\n");
}
}
return 1;
}
-],, no_gtk=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
+],, no_glib=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
CFLAGS="$ac_save_CFLAGS"
LIBS="$ac_save_LIBS"
fi
fi
- if test "x$no_gtk" = x ; then
- AC_MSG_RESULT(yes (version $gtk_config_major_version.$gtk_config_minor_version.$gtk_config_micro_version))
+ if test "x$no_glib" = x ; then
+ AC_MSG_RESULT(yes (version $glib_config_major_version.$glib_config_minor_version.$glib_config_micro_version))
ifelse([$2], , :, [$2])
else
AC_MSG_RESULT(no)
- if test "$GTK_CONFIG_2_0" = "no" ; then
- echo "*** The gtk-config-2.0 script installed by GTK could not be found"
- echo "*** If GTK was installed in PREFIX, make sure PREFIX/bin is in"
- echo "*** your path, or set the GTK_CONFIG_2_0 environment variable to the"
- echo "*** full path to gtk-config-2.0."
+ if test "$PKG_CONFIG" = "no" ; then
+ echo "*** A new enough version of pkg-config was not found."
+ echo "*** See http://pkgconfig.sourceforge.net"
else
- if test -f conf.gtktest ; then
+ if test -f conf.glibtest ; then
:
else
- echo "*** Could not run GTK test program, checking why..."
- CFLAGS="$CFLAGS $GTK_CFLAGS"
- LIBS="$LIBS $GTK_LIBS"
+ echo "*** Could not run GLIB test program, checking why..."
+ CFLAGS="$CFLAGS $GLIB_CFLAGS"
+ LIBS="$LIBS $GLIB_LIBS"
AC_TRY_LINK([
-#include <gtk/gtk.h>
+#include <glib.h>
#include <stdio.h>
-], [ return ((gtk_major_version) || (gtk_minor_version) || (gtk_micro_version)); ],
+], [ return ((glib_major_version) || (glib_minor_version) || (glib_micro_version)); ],
[ echo "*** The test program compiled, but did not run. This usually means"
- echo "*** that the run-time linker is not finding GTK or finding the wrong"
- echo "*** version of GTK. If it is not finding GTK, you'll need to set your"
+ echo "*** that the run-time linker is not finding GLIB or finding the wrong"
+ echo "*** version of GLIB. If it is not finding GLIB, you'll need to set your"
echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
echo "*** to the installed location Also, make sure you have run ldconfig if that"
echo "*** is required on your system"
@@ -177,18 +168,18 @@ main ()
echo "***"
echo "*** rpm --erase --nodeps gtk gtk-devel" ],
[ echo "*** The test program failed to compile or link. See the file config.log for the"
- echo "*** exact error that occured. This usually means GTK was incorrectly installed"
- echo "*** or that you have moved GTK since it was installed. In the latter case, you"
- echo "*** may want to edit the gtk-config-2.0 script: $GTK_CONFIG_2_0" ])
+ echo "*** exact error that occured. This usually means GLIB was incorrectly installed"
+ echo "*** or that you have moved GLIB since it was installed. In the latter case, you"
+ echo "*** may want to edit the pkg-config script: $PKG_CONFIG" ])
CFLAGS="$ac_save_CFLAGS"
LIBS="$ac_save_LIBS"
fi
fi
- GTK_CFLAGS=""
- GTK_LIBS=""
+ GLIB_CFLAGS=""
+ GLIB_LIBS=""
ifelse([$3], , :, [$3])
fi
- AC_SUBST(GTK_CFLAGS)
- AC_SUBST(GTK_LIBS)
- rm -f conf.gtktest
+ AC_SUBST(GLIB_CFLAGS)
+ AC_SUBST(GLIB_LIBS)
+ rm -f conf.glibtest
])
diff --git a/gtk-config-2.0.in b/gtk-config-2.0.in
index 07e3a2dff9..4208248e0d 100644
--- a/gtk-config-2.0.in
+++ b/gtk-config-2.0.in
@@ -1,118 +1,4 @@
#!/bin/sh
-glib_libs="@glib_libs@"
-glib_cflags="@glib_cflags@"
-glib_thread_libs="@glib_thread_libs@"
-glib_thread_cflags="@glib_thread_cflags@"
-
-target=@gdktarget@
-prefix=@prefix@
-exec_prefix=@exec_prefix@
-exec_prefix_set=no
-
-usage()
-{
- cat <<EOF
-Usage: gtk-config-2.0 [OPTIONS] [LIBRARIES]
-Options:
- [--prefix[=DIR]]
- [--exec-prefix[=DIR]]
- [--target=gdktarget]
- [--version]
- [--libs]
- [--cflags]
-Libraries:
- gtk
- gthread
-EOF
- exit $1
-}
-
-if test $# -eq 0; then
- usage 1 1>&2
-fi
-
-lib_gtk=yes
-
-while test $# -gt 0; do
- case "$1" in
- -*=*) optarg=`echo "$1" | sed 's/[-_a-zA-Z0-9]*=//'` ;;
- *) optarg= ;;
- esac
-
- case $1 in
- --prefix=*)
- prefix=$optarg
- if test $exec_prefix_set = no ; then
- exec_prefix=$optarg
- fi
- ;;
- --prefix)
- echo_prefix=yes
- ;;
- --exec-prefix=*)
- exec_prefix=$optarg
- exec_prefix_set=yes
- ;;
- --target=*)
- target=$optarg
- ;;
- --exec-prefix)
- echo_exec_prefix=yes
- ;;
- --version)
- echo @GTK_MAJOR_VERSION@.@GTK_MINOR_VERSION@.@GTK_MICRO_VERSION@
- ;;
- --cflags)
- echo_cflags=yes
- ;;
- --libs)
- echo_libs=yes
- ;;
- gtk)
- lib_gtk=yes
- ;;
- gthread)
- lib_gthread=yes
- ;;
- *)
- usage 1 1>&2
- ;;
- esac
- shift
-done
-
-if test "$echo_prefix" = "yes"; then
- echo $prefix
-fi
-
-if test "$echo_exec_prefix" = "yes"; then
- echo $exec_prefix
-fi
-
-if test "$lib_gthread" = "yes"; then
- glib_cflags="$glib_thread_cflags"
- glib_libs="$glib_thread_libs"
-fi
-
-if test "$echo_cflags" = "yes"; then
- includes=-I@includedir@/gtk-2.0
- echo -I@libdir@/gtk-2.0/include $includes $glib_cflags @PANGO_CFLAGS@ @more_cflags@
-fi
-
-if test "$echo_libs" = "yes"; then
- my_glib_libs=
- libdirs=-L@libdir@
- for i in $glib_libs ; do
- if test $i != -L@libdir@ ; then
- if test -z "$my_glib_libs" ; then
- my_glib_libs="$i"
- else
- my_glib_libs="$my_glib_libs $i"
- fi
- fi
- done
-
- echo $libdirs @more_ldflags@ -lgtk-$target-1.3 -lgdk_pixbuf-1.3 -lgdk-$target-1.3 $my_glib_libs @INTLLIBS@ @PANGO_LIBS@ @more_libs@ @GDK_WLIBS@ @MATH_LIB@
-fi
-
+echo gtk-config-2.0 is no longer supported. Please use pkg-config instead 2>&1
+exit 1
diff --git a/gtk/.cvsignore b/gtk/.cvsignore
index f4b2056a6f..3a84e3c073 100644
--- a/gtk/.cvsignore
+++ b/gtk/.cvsignore
@@ -7,18 +7,7 @@ makefile.msc
_libs
.libs
libgtk-*.la
-testcalendar
-testgtk
-testinput
-testrgb
-testselection
-testtext
-testtextbuffer
-treestoretest
-simple
-testtree
gtkcompat.h
-testthreads
libgtk.la
gtkfeatures.h
gtkmarshal.h
@@ -34,5 +23,4 @@ stamp-gtktypebuiltins.h
stamp-gtkmarshal.h
stamp-gtk.defs
gtk-query-immodules-2.0
-gtk.immodules
.saved
diff --git a/gtk/3DRings.xpm b/gtk/3DRings.xpm
deleted file mode 100644
index 1ca75da752..0000000000
--- a/gtk/3DRings.xpm
+++ /dev/null
@@ -1,116 +0,0 @@
-/* XPM */
-static char * DRings_xpm[] = {
-"48 48 65 1",
-" c None",
-". c #104010404103",
-"X c #1040208130C2",
-"o c #104014515144",
-"O c #000010402081",
-"+ c #1040104030C2",
-"@ c #208120815144",
-"# c #28A241035965",
-"$ c #30C230C26185",
-"% c #208130C24103",
-"& c #104010402081",
-"* c #104000002081",
-"= c #000010401040",
-"- c #492441036185",
-"; c #596559659E79",
-": c #30C220815144",
-"> c #0820186128A2",
-", c #000000001040",
-"< c #2081104030C2",
-"1 c #514459659658",
-"2 c #514455556185",
-"3 c #104000001040",
-"4 c #000008200000",
-"5 c #618569A6AEBA",
-"6 c #618569A69658",
-"7 c #410345148E38",
-"8 c #104020814103",
-"9 c #79E782079658",
-"0 c #208120814103",
-"q c #596571C69E79",
-"w c #4103514471C6",
-"e c #2081208130C2",
-"r c #6185618571C6",
-"t c #28A228A25965",
-"y c #596561858617",
-"u c #96589E79BEFB",
-"i c #28A230C271C6",
-"p c #38E345145144",
-"a c #79E78207A699",
-"s c #30C2492469A6",
-"d c #410330C25965",
-"f c #410351446185",
-"g c #AEBAAAAAD75C",
-"h c #38E338E34103",
-"j c #EFBEEBADEFBE",
-"k c #208130C25144",
-"l c #9658A289DF7D",
-"z c #208110404103",
-"x c #28A228A26185",
-"c c #8E388A28BEFB",
-"v c #208118612081",
-"b c #38E3451479E7",
-"n c #4924618579E7",
-"m c #86178617B6DA",
-"M c #30C220814103",
-"N c #104030C25144",
-"B c #4103410371C6",
-"V c #86178A28D75C",
-"C c #DF7DDB6CE79D",
-"Z c #BEFBC30BD75C",
-"A c #410330C271C6",
-"S c #30C228A230C2",
-"D c #082008201861",
-"F c #186130C238E3",
-"G c #0000208130C2",
-" .Xo ",
-" O+O@#$% ",
-" &*=+X-;: ",
-" >&=,=<11#2 ",
-" +O34,X567& ",
-" 8X+=,90q9w. ",
-" +e<>3r tyu-& ",
-" Xi%.= paus+ ",
-" Od-@= fga$h ",
-" @y7X, Xrjak ",
-" 2:eaw+ $ag;@ ",
-" .X@8@k@o@X+ +pl9tO ",
-" +zX@x$$isikt8o02crv ",
-" 8@%ip7757ywbs$Ohn6#. ",
-" &0%$p7r215ybw1pzp2-0= ",
-" 8tk$#yw21665n;1+%-p$O ",
-" O<e7pbryq5am9ay6XMpM>3& ",
-" 9.NtpBw16amclVcm1t%kX*88 ",
-" +&etd7r6y9ulgglm6>e>3s@83 ",
-" +0k$y-y69cgCCCZVam%+#ik8X ",
-" O&oi$d725amgCjCZu962ybtx8+p ",
-" &X0x$sBym9VZCCCZca;yBbi%08& ",
-" =++@sApMy5muZZgum6y2wds:>+& ",
-" #tp;1;yB#i25cVucma5;w-pti@8& ",
-" .#2alumnBp:@1r59y9y6ywBS$%0X+= ",
-" %$wmZVu;#tX8X07r1656y2wbp$k@%@OD ",
-" 0Byc9a;h%0>&D&hBrr2r1bwB-AF:0<&*= ",
-" kBf;yr#@X+&<%MkhsBwBwpsB#Bktkt8+Oh ",
-" xt7B-t8*,3O.X00:$i#dBd#bptFek0X.+* ",
-" Xt#b#@=, =&O+X0Ft%ibsp$p$ki%l5sX&= ",
-" &<kvX&4 +O*&<X0e:%$pAti%:edugn0= ",
-" +X@&+, V,O&>+Xt>tktktv0%@k;Cls+ ",
-" =+O*4*X:p;9cy3&&8ve0FMtt$ee0>z7cZ6k ",
-" D=D4,=.k$sBs$ee=+X0Fk%-#t%0X&O0nu9bG ",
-" ,,434*&ze@F<eeeeee><tdhdSMe<&&XAaawx ",
-" 4,4,=+><peeeeee&=<%M%$hSF0X&O&kw5r%Z ",
-" D&vSFMF<>&D =0S-2i& ",
-" +>puB> >0h7s. ",
-" SM5VqM &0t#$8 ",
-" XpVV70 &0kMk. ",
-" XdyB%z *X<%@+ ",
-" &k$b0X+=8X08o ",
-" &e:e+=*X.X+& ",
-" +X.O+X0O.=, ",
-" +>&+0>3&* ",
-" &X0k+O, ",
-" >v,3 ",
-" "};
diff --git a/gtk/FilesQueue.xpm b/gtk/FilesQueue.xpm
deleted file mode 100644
index 586d27ec43..0000000000
--- a/gtk/FilesQueue.xpm
+++ /dev/null
@@ -1,98 +0,0 @@
-/* XPM */
-static char * FilesQueue_xpm[] = {
-"44 31 64 1",
-" c None",
-". c #E79DE38DDF7D",
-"X c #CF3CC71BCF3C",
-"o c #71C675D671C6",
-"O c #B6DAB2CAB6DA",
-"+ c #CF3CD34CCF3C",
-"@ c #DF7DE38DE79D",
-"# c #FFFFFBEEFFFF",
-"$ c #EFBEEFBEEFBE",
-"% c #DF7DDB6CDF7D",
-"& c #BEFBBAEAC71B",
-"* c #BEFBBAEABEFB",
-"= c #BEFBC30BC71B",
-"- c #71C66DB671C6",
-"; c #D75CD34CD75C",
-": c #9E799A699E79",
-"> c #E79DE38DE79D",
-", c #CF3CCB2BC71B",
-"< c #B6DAB2CABEFB",
-"1 c #BEFBBAEAB6DA",
-"2 c #B6DAB6DAB6DA",
-"3 c #618561856185",
-"4 c #C71BBAEABEFB",
-"5 c #AEBAAAAAAEBA",
-"6 c #965892488E38",
-"7 c #A699A699A699",
-"8 c #38E338E338E3",
-"9 c #F7DEF7DEF7DE",
-"0 c #E79DEFBEEFBE",
-"q c #DF7DE38DDF7D",
-"w c #C71BC71BC71B",
-"e c #C71BC30BBEFB",
-"r c #BEFBC30BBEFB",
-"t c #B6DAAAAAAEBA",
-"y c #410345144103",
-"u c #D75CDB6CD75C",
-"i c #C71BCB2BC71B",
-"p c #BEFBCB2BBEFB",
-"a c #9E79A289A699",
-"s c #86178E388E38",
-"d c #CF3CCF3CD75C",
-"f c #CF3CD75CCF3C",
-"g c #C71BC30BCF3C",
-"h c #28A22CB228A2",
-"j c #000000000000",
-"k c #D75CD34CDF7D",
-"l c #10400C300820",
-"z c #E79DEBADEFBE",
-"x c #DF7DDB6CD75C",
-"c c #514459655965",
-"v c #8617861779E7",
-"b c #DF7DD34CD75C",
-"n c #CF3CCB2BCF3C",
-"m c #618555555965",
-"M c #861786178617",
-"N c #30C234D330C2",
-"B c #EFBEEBADE79D",
-"V c #DF7DDB6CE79D",
-"C c #D75CE38DD75C",
-"Z c #514449245144",
-"A c #186120812081",
-"S c #79E77DF779E7",
-"D c #6185659569A6",
-"F c #9E7992489E79",
-" .XoOX+ ",
-" @#$%&*=-o;: ",
-" @>,=O<12*&:-<3X ",
-" >%&1*4*2*OO**56758790 ",
-" 9qX+we=r*&e<<<251t5555yu9 ",
-" $qu++;ipi=p*=p**2tOOO27a5s<- ",
-" #9udfXi;,gi&**4**4r*Ot5t55tehj ",
-" 0qku+u;+d,gg=*=r*&**&<255t<*yl1 ",
-" $$zq@%xk%uf;,w,i=i=e**r=12tO1=8cvj ",
-" $@%>.%.%%%xbkx,w+ni,wwrwe*4*1=;8mMNj ",
-" zz@Bz>>>V%%%C+u;;dfnnfwggi&=&X+yZsNll ",
-" af#9@B0>q>qqq>xk.;;;kfX+XnXw=g,fycMhhN5 ",
-" al5#9$$>qzBV.%x%%b;x+fnf+,X,iiqym6NAo-j ",
-" #roS%#$zz>>V%%xkk%f;;+df,XnwnVZD:8AS-j* ",
-" D-9Oy*9$Bz>q%qx%%u;x;;dknX+d>Zm:hhSDjr ",
-" a3o+>S3z#90@@z.%>qCC%uu;ff%@Zm:NhMoj= ",
-" wlvvo#:3599$>B>q>%%%%+f;fk$ymaalMvjr ",
-" 0.a--S49mct9$z@.qkkqC;xu%@Zm5AlvSj* ",
-" ohu%3:Z:9@y609q@@>..>Cx>$Zm5NhMvjr ",
-" -j797Zv5705y=#$0>>V.%>#Z378AMMj* ",
-" Zj9Xo-McBXDv%90.%%#9cc78AsMj* ",
-" 8hM#M-DSF96cvz0>z#c35Nhs6j1 ",
-" jl9#o63vx#-D###mmt8N66j* ",
-" 5jc@fZF3o%+ZFDm<8A6FjO ",
-" :j50sSay<$ss2Nh:FjO ",
-" 6880&SDMF.rNNFFj1 ",
-" 8jr#:SFScA6ajO ",
-" Alr$DSysajO ",
-" >jy#51:jO ",
-" %Dy*gjO ",
-" alla "};
diff --git a/gtk/Makefile.am b/gtk/Makefile.am
index 11c6174293..cbb5ef42b3 100644
--- a/gtk/Makefile.am
+++ b/gtk/Makefile.am
@@ -494,9 +494,6 @@ EXTRA_LTLIBRARIES = libgtk-x11-1.3.la libgtk-nanox-1.3.la libgtk-linux-fb-1.3.la
install-data-local:
$(mkinstalldirs) $(DESTDIR)$(datadir)/themes/Default/gtk-2.0
echo "# Empty gtkrc for default theme" > $(DESTDIR)$(datadir)/themes/Default/gtk-2.0/gtkrc
- $(mkinstalldirs) $(DESTDIR)$(sysconfdir)/gtk-2.0
- $(top_builddir)/gtk/gtk-query-immodules-2.0 > $(DESTDIR)$(sysconfdir)/gtk-2.0/gtk.immodules
-uninstall-local:
rm -f $(DESTDIR)$(datadir)/themes/Default/gtk-2.0/gtkrc
DEPS = @gtktargetlib@ $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-1.3.la $(top_builddir)/gdk/@gdktargetlib@
@@ -525,38 +522,6 @@ gtk_query_immodules_2_0_LDADD = $(LDADDS)
gtk_query_immodules_2_0_SOURCES = queryimmodules.c
-gtk.immodules: gtk-query-immodules-2.0 ../modules/input/Makefile.am
- ./gtk-query-immodules-2.0 ../modules/input/.libs/*.so > gtk.immodules
-
-#
-# test programs, not to be installed
-#
-noinst_PROGRAMS = testgtk testcalendar testinput testselection testrgb testdnd testtext simple treestoretest testtextbuffer # testthreads
-
-testcalendar_DEPENDENCIES = $(TEST_DEPS)
-testgtk_DEPENDENCIES = $(TEST_DEPS)
-testinput_DEPENDENCIES = $(TEST_DEPS)
-testrgb_DEPENDENCIES = $(TEST_DEPS)
-testselection_DEPENDENCIES = $(TEST_DEPS)
-testtext_DEPENDENCIES = $(TEST_DEPS)
-testtextbuffer_DEPENDENCIES = $(TEST_DEPS)
-treestoretest_DEPENDENCIES = $(TEST_DEPS)
-testdnd_DEPENDENCIES = $(TEST_DEPS)
-simple_DEPENDENCIES = $(TEST_DEPS)
-#testthreads_DEPENDENCIES = $(TEST_DEPS)
-
-testcalendar_LDADD = $(LDADDS)
-testgtk_LDADD = $(LDADDS)
-testinput_LDADD = $(LDADDS)
-testrgb_LDADD = $(LDADDS)
-testselection_LDADD = $(LDADDS)
-testtext_LDADD = $(LDADDS)
-testtextbuffer_LDADD = $(LDADDS)
-treestoretest_LDADD = $(LDADDS)
-testdnd_LDADD = $(LDADDS)
-simple_LDADD = $(LDADDS)
-#testthreads_LDADD = $(LDADDS)
-
.PHONY: files test test-debug
files:
@@ -564,38 +529,14 @@ files:
echo $$p; \
done
-test: testgtk
- builddir=`pwd`; cd $(top_builddir); top_builddir=`pwd`; \
- cd $$builddir; cd $(srcdir); \
- $(SHELL) $$top_builddir/libtool --mode=execute $$builddir/testgtk
-
-test-debug: testgtk
- builddir=`pwd`; cd $(top_builddir); top_builddir=`pwd`; \
- cd $$builddir; cd $(srcdir); \
- $(SHELL) $$top_builddir/libtool --mode=execute gdb $$builddir/testgtk
-
EXTRA_DIST += @STRIP_BEGIN@ \
oldest-source-stamp \
- testgtk.1 \
- testgtkrc \
- testgtkrc2 \
- circles.xbm \
line-arrow.xbm \
line-wrap.xbm \
tree_plus.xbm \
tree_minus.xbm \
- 3DRings.xpm \
- FilesQueue.xpm \
- Modeller.xpm \
- check-y.xpm \
- check-n.xpm \
- marble.xpm \
tree_minus.xpm \
tree_plus.xpm \
- test.xpm \
- check-y.xpm \
- check-n.xpm \
- test.xpm \
gtk.def \
gtk-win32.rc \
gtk-win32.rc.in \
diff --git a/gtk/Modeller.xpm b/gtk/Modeller.xpm
deleted file mode 100644
index 62e27f9853..0000000000
--- a/gtk/Modeller.xpm
+++ /dev/null
@@ -1,117 +0,0 @@
-/* XPM */
-static char * InterfaceModeller_app_2_Tile_xpm[] = {
-"48 48 66 1",
-" c None",
-". c #86174D344103",
-"X c #69A651445144",
-"o c #8617410330C2",
-"O c #69A6410338E3",
-"+ c #30C218611861",
-"@ c #AEBA6DB66185",
-"# c #71C638E328A2",
-"$ c #69A634D328A2",
-"% c #30C228A228A2",
-"& c #79E73CF330C2",
-"* c #BEFB9E799E79",
-"= c #8E3869A66185",
-"- c #514424921861",
-"; c #A699A289B6DA",
-": c #A6999E79A699",
-"> c #71C65D756185",
-", c #9E799A69A699",
-"< c #8E3882078E38",
-"1 c #861779E78617",
-"2 c #A6999A69AEBA",
-"3 c #8E388A289658",
-"4 c #71C675D679E7",
-"5 c #96588A289E79",
-"6 c #30C230C238E3",
-"7 c #C71BC71BC71B",
-"8 c #9E79A289AEBA",
-"9 c #AEBAAAAABEFB",
-"0 c #96589248A699",
-"q c #A699AAAAB6DA",
-"w c #AEBAAAAAB6DA",
-"e c #D75CD34CD75C",
-"r c #EFBEE79DEFBE",
-"t c #BEFBB6DABEFB",
-"y c #B6DABAEAC71B",
-"u c #AEBAAEBAB6DA",
-"i c #E79DDB6CDF7D",
-"p c #96588E389658",
-"a c #596559656185",
-"s c #AEBA8E388E38",
-"d c #CF3CCB2BCF3C",
-"f c #9E799A699E79",
-"g c #86177DF78E38",
-"h c #69A6659571C6",
-"j c #AEBAAEBABEFB",
-"k c #96589E799E79",
-"l c #B6DAA699A699",
-"z c #E79DC71BC71B",
-"x c #B6DAB6DAB6DA",
-"c c #861786179658",
-"v c #B6DAB2CABEFB",
-"b c #BEFBAAAAAEBA",
-"n c #C71BBEFBC71B",
-"m c #514441034103",
-"M c #41033CF34103",
-"N c #492428A228A2",
-"B c #AEBAA289B6DA",
-"V c #618530C22081",
-"C c #69A630C228A2",
-"Z c #69A630C22081",
-"A c #596528A22081",
-"S c #492428A22081",
-"D c #618528A22081",
-"F c #596520811861",
-"G c #69A628A22081",
-"H c #FFFF14514103",
-" .X ",
-" .oO+ ",
-" @.o#++ ",
-" @.o$%+ ",
-" @.&#++ ",
-" @.o#++ ",
-" @.o$++ ",
-" @.&#++ ",
-" .O#++ ",
-" *=-$++ ",
-" ;:>+++ ",
-" ;,<1% ",
-" 2,34 ",
-" 2;,51 ",
-" 2,,,,6 ",
-" 7777 28888,6 ",
-" 77777777 2829,,,06 ",
-" 9qwwe7rrrrr77rr 828,9tyt,6 ",
-" uuwriirrieiiieii77pa< 82,8,,,8,06 ",
-" s=1ttiieeeeded77eufgh>j,8,8,k,0,6 ",
-" =@lzieeeeee77eeex:fpcg4>9,,,,qjv6 ",
-" =O=blt7eeee7deenw:ffp<gha:t979;06 ",
-" =OO@=@zieeee7ex:::fffff0,v72444h6 ",
-" =OOo&Osst7iee7wkf:f:ff;t721444ham ",
-" =#&&&&OO@di7eu:ff:fferiv114444hmMX ",
-" =O&&&..o.sdp33fff:errrii7cc1hhh6mmNX= ",
-" =O&&&@.o.@sberrrrrriiuxuxnB;44aMmVCO#OX ",
-" =O&&o@..o.zrrrie777nnxtuxx:x;n:>mV##&&O$mX ",
-" =O&&o....zrrieieuxunx7txx:nnfwpMmVZ#$ZZZVVN ",
-" =O&oooo.*rrde77ewxnxxtnw:f4M%M%+NA#$Z$ZZVmN> ",
-" =Oo&ooo@iree7inxn7nnuuff4h%M>m%S-AZ$CCZDZmSX ",
-" =O&o.o.@rrn7eulun7xxuwp4mm6ahM%--AZCCZDDDANX ",
-" =Ooooo.*rixenuwwn7nxupph%M>>h6mAADVVZVVDDANX ",
-" =O&o.o.zrexwwnwuxxnughX%mahhmMN-AZCCVVDDAAN> ",
-" *XOoo.*iin7n777xxxtphaM+ama>MSNFVCZZVVDAAAS> ",
-" 1O..izewxux7nuuux4%++%hha>%N-DDCZZVDAAAASX ",
-" 1.=ituu:uButnxxuX%>hh>M%++NADZZZVDADAA--X ",
-" :e7f::lnn7*ppnx6ahm6++mNN-ADCZVDDAAAA-SX ",
-" 7nupp:wxxg%MMau6%++NmmmADADVVVVVDAA---NX ",
-" 7uBgh1wwxg6h>m%:MmmVNAVDZVZCVZZDAAAAF-S+X ",
-" nfgaM%pnwhX6%mXb6$DVVZC$C#C$ZZDVAAA---+NX ",
-" 27a%MaM47:mN.OoolmODGZ####$$ZZVDDA-----SSX ",
-" 2gmg<m6p7wmmOo...O$GZ####$$CZVVDAAA----++X ",
-" qBcaM <gxgmXmo.@.o&$$##$$$CZZZDADA-A-++-NX ",
-" M6> paMa HX.@@@oZ$###$$CZVDDAAAA---SS+X ",
-" 43 p=&@@&&$##$CCCVVVAAA--+S+S+%X ",
-" k =o@.##$VVmmmNNNSSSSSS%XXXX ",
-" s>OSSNmN>>aaa177777 "};
diff --git a/gtk/check-n.xpm b/gtk/check-n.xpm
deleted file mode 100644
index 417ae20911..0000000000
--- a/gtk/check-n.xpm
+++ /dev/null
@@ -1,21 +0,0 @@
-/* XPM */
-static char *openfile[] = {
-/* width height num_colors chars_per_pixel */
-" 10 9 5 1",
-/* colors */
-". c None",
-"# c #000000",
-"y c #666666",
-"i c #ff1f00",
-"# c #9f9f9f",
-/* pixels */
-"..........",
-"........yy",
-".......yy.",
-"......yy..",
-".yyy.yy...",
-"..yyyy....",
-"...yy.....",
-"..........",
-"..........",
-};
diff --git a/gtk/check-y.xpm b/gtk/check-y.xpm
deleted file mode 100644
index d82b48556a..0000000000
--- a/gtk/check-y.xpm
+++ /dev/null
@@ -1,21 +0,0 @@
-/* XPM */
-static char *openfile[] = {
-/* width height num_colors chars_per_pixel */
-" 10 9 5 1",
-/* colors */
-". c None",
-"# c #000000",
-"i c #ff0fff",
-"y c #ff1f00",
-"# c #9f9f9f",
-/* pixels */
-"..........",
-"........yy",
-".......yy.",
-"......yy..",
-".yyy.yy...",
-"..yyyy....",
-"...yy.....",
-"..........",
-"..........",
-};
diff --git a/gtk/gtkdnd.c b/gtk/gtkdnd.c
index 982facda47..f6af11f6cb 100644
--- a/gtk/gtkdnd.c
+++ b/gtk/gtkdnd.c
@@ -782,7 +782,7 @@ gtk_drag_highlight_expose (GtkWidget *widget,
x, y, width - 1, height - 1);
}
- return TRUE;
+ return FALSE;
}
/*************************************************************
diff --git a/gtk/marble.xpm b/gtk/marble.xpm
deleted file mode 100644
index 1ef2607610..0000000000
--- a/gtk/marble.xpm
+++ /dev/null
@@ -1,408 +0,0 @@
-/* XPM */
-static char *granite07[] = {
-/* width height num_colors chars_per_pixel */
-" 384 384 16 1",
-/* colors */
-". c #000000",
-"# c #111111",
-"a c #222222",
-"b c #333333",
-"c c #444444",
-"d c #555555",
-"e c #666666",
-"f c #777777",
-"g c #888888",
-"h c #999999",
-"i c #aaaaaa",
-"j c #bbbbbb",
-"k c #cccccc",
-"l c #dddddd",
-"m c #eeeeee",
-"n c #ffffff",
-/* pixels */
-"aacfedbbcbbaaaaaaaaabaabaaaaabcbcbbbabbchfdcccbbabbbaaabaabcbaa#aa#######a#aaaabcddeefhec##dgbabbaaadabbcfbaa##########aaabbaaa#a#####a#aa###a#aaabbbbcbbbccdedaaaaa#aaaaa#a#abaaabbabbbeddbbaaaaaca##a#aaaba########aaaadcababbabdehd.##.a######.cgdcb###b##.##.##aaaaa####abcba######a##aac#a##a####aa#aa##babbbcfccbbbcdccccecbbbcbbbcdccddcbcdfeecbhhjihhgffc.aaa####.#######aaaaaaaabbaaaaa",
-"aaacedccbbcbaaaaaa#bbaabbbaaaabcaabbbbbbafhfccbbbbbbabacbacbaaaaa##########a###abbcdeghhhcagb#ababaaccbacdfca#a####aa###aaaaabaaa#####aca#aabaababbcccccccbcdfdaaaa###aaaaaaaaaaabbbbbbccccccbbcbcaaa##aaaaabaaaa###abdaccceebaaaabehja####a######..#aeec#bb##########aa#####abba#########aaca########aa#aa###aaaabddbbbbbbbbbbccbbabbbbabbabbabcbcbcefhfeddccefhhijheecb#...a####aaaaaaaabaaaaa",
-"aaabccccccdbabcbaaa#aaaaaaaaaaabbabbbbbccabefdccabcbbabacccbaaabaa######a######aaabceiiiihije#bbabbaaeaabcedcaabaa########aaaabaa##a###ab#aabcababbccccccdeeeecc#a##a##aaaaaaaaaabbbbbbbcccbbbdcbbcdaa#a#aabbaaaaa###acbaa#bccaa#abcfig.#######.#######acddgefdda#######a########a#######aaaaaa#a######aaaa#####aaacdcbabbaaabbbcaaaaaaaaabbbaaabbaabbbcbcbabbabcdeefghjkjgc#..####aaaaaaaaaaaa#",
-"#aaaaaacbccbcabbbaaaaaabcaaaaabbbbbbabbbcbaabffccbccbccbbcbaaaabaaaa#aa#aa##a#aaaaabbikkjhijicabbbcc#faaacdebcbda#########aaaaaaaaa####aa##cacccabcccdccccdddfdcbaa##a##abbbabccbbcbbbccccaaa#abbaaba#a##abbbbbaaaaaaaaaaccaaca##aabcfic.###aa#######a####bddeeddb####.##.###aaa#########aaaa###aa####aaaa#######aabdbbbbcabbbaaaa#aaaaaaaaabaaabbbaabbbbdbbaaabccccccdcefhhkhda##aaaa#a#aaaaa##",
-"#aaabaabcecbaa##bcaaaaaaaababbabaaabbabbaabb#chhfdccccbcbecaaabaaaaaaaaaa####aaaaaaabdgjkkijijdabbdcabfaabcecbbec###########a#aaaabaa#######abbaaaadddedddeeefeccaa###a#aabcccdcbcbbbbccbbbbaaaaa#aabbaaaabbbbbbaaaaaaabbbbbaaa####acegha##a#aabbb####a##adccdedbcc#######.###a###a#######aaa#a#aa##..#aa#########abdbaabbabbbaa###aaaaaaaaaaaaacbaaababbdbabbabcbbcbcbccbbdegjkgb#aa#aa#aaaaaaa",
-"##aa#aabccccaaaaaaaa#aaaaaabbaabbbaaaaabbbcbbcfhhgfcccbbbbccbaabbaaaaaaabaa#aaaabaaaabbcehkljjdabacccbgbaaccdb#adea#########aa#abaaaaa#####ac#ba##accdedddefffeaba##a#aaaaacccccccbbbcccaabaaaaaaaaa#aaaaabcbbaaa#bbbbaaefccdbaaa#aaacdei##aa##aabbbaaa#a#cdcccccbcea.#########bbaaa######a###a#aaaa.#aaba####.###abcbaaabaabbbaa###aaaaaaaaaaaabbaaaaaaaaaaababcbbcbbaabbbdddeghheba##ab#abaa##",
-"#####bbaaaaabaaaaa##aa#adccaabaaabbbbabbabbbabccbccfdbccbbbbbcaabcaabaaabbaaaaaaaaaaaabbbcglli#accbbbddgabcddbbaacea#a##########aaa#aaa##aaaa####aabcddeeefffgdbbaaaa###baabbbbbbcdabdcbcaaabaaaaaaa#aaaaaabcbbbbadfbbbaejhhebbccaaaaaccfi.aba##abaaaba####ecbbccba#fc.####.##.bba#a#######aaaaaaaaaaa##aaaa######abcdaa#aaaabaaa###aaaaabaaabbbaaba##aaababcbbcbbbbbcbaaabbccccddgggeb#aadca###",
-"#####bcaaaaaabcbaaa#aaaabcccaaaaaaabaaabbbbbbbaacbabeeddddccbcbbcccbabaaaabaabaaaaaaaaabbbbglmdbcbaabebdgdbcecbbaabdbaa#########aabbaaaa#aa#a##a#aabbdceeedccdcbbaaaaa##aaabbcbbbabaaabbababbaaaa#aaaaaaaabcdccbbbabcbbbcfijfbcdcabb#abcbif#abb##aaabaaaa##fcccbbcaa#db#..##.##.aaa#########ab#aaaaaa#aabaaaaa#####abdbbaaaabbaaaa###b#a#aaaabaaaaaaaaaaaaaabbabbbbaabbbaaaabbbbbbbceffecccbaa##",
-"#####abaaaaa#accbbbbaaabaaaaaaaaaaadcbaabbabbbabbdcaacgfddddcdddcadfcaaaabcbbabaaaaaabcabbbdjliacbababcbdfcdeeaaaaaabba########a##aa#aabaa##a######abddeggca#bcbaaaaaa####aaaaaabbbbbcbbbbbaaa##a#aaaaaaaabcbccbbaaaabaabfgfiecccccbbaaaccicbbbcbaaabaaabb#ceccccdca##aacdb######aaa###a###aabaaaaaa#aabca#abba#####abca##aaaaaaaaa##a##aaaaaaabaaaaaaabaaaacbcbacdbaaabaaaaaabaaaaabbcddccbaa##",
-"####aa#aaaaaaabccbabbaaaaaaaaaaaaabfaaabbcbbbbbabdebaabdffddedefedccecccdcbbbbbccbccbbbbbbccekldaabaaabccbfaaaaaaaaaaaba########aaaaaaaaba##aaa###aabbccfgfaababbbaaaaa#aabbaabaaccaabcccbcbaa##aaaaaabaabbbccbbbaabbbbbbdddghdbbbcccb#abcdebcccbaabbbabbcbaecddddbaa##.#acdeca#######a#aaaaaaaaaaaaaaabba##abba####aacba##aaaaaaaaaaaaa##aba#abaaaaaaabaaaabbbbbbcbabbaabbaaaaabaaaaaaaaccbaa##",
-".####aa#aabaa##bccbaabbbba#aaaaabbaefdaabbbbccbbbaddaaabadeeffhhhffdedddeecbbbbcccbbabcbabbcfjjlkeaaaaacdadcaa#aaaaaaa#ab######ba#aaabbabcaa#aa###babcddcedba##acbaaaaaa#ababbbacbbbcccdfffbaa#aaaacbaabcbabccbbcbbbbbbcbbccedbbbccdccbaabcgb#bccbbbababbbcccdededcb#a####...addcba##aabbbbbbbbaaaaabba#aaa##abba####abbaa###a#aa#aa##aaa#a##abaaaaaaaaabababbcdbcb#baaaaaaaaaaaaaaaaaa#aaaaa###",
-"######a##aaaaaa#accbaaabbbaaa#aaababdcaaabbbbcccbbbdbabbbacdccgecadbbbcdccddeddcccccbaabcbbcgjhhjgeb#aacdcccaa#aa#aaa#a#aaa##aaaaa#aaabbaabb#aa###aabccddeccbbbaabcbbbcbbb#aacbbadbabcccddbaaa#aaaaabbbbabbbbcdbbbabbcddcbbbccaabbbccbbaaaadi##abbbbbbbaabbbacdeedbd######aa####bceda#aabbabaaaaaaaaba#aaaaa#aabaaa###acaaaa####aa##aaaaaaaa#aaaaaaaaaaababaaaaabcaaaaaaabbcbaaaaaaaaa###aaaa###",
-"##########aabaa#accbbabbbbbba##aaaabbcbbbbbbbbcbaaabdbbbbbbddccbbbbaaaabbabbbbcefefdcbaadbcddje#debgfbabecdc####aa##a###a#aa#aa##a##aaabbcabbaa###aabbcceedbcbaaaabdcccbabaaabbbbabbccbbaaaaaa#aaaaaaaabbbbbcbccabcccccdcccbbbbabbababbba#abfe#aaaaaaaabccbbaaaedddc######adcaaaa##dfcaaaaaaaaaa#aaaaa##aabcaaabbaa#aaab###aa###aaaaaaaaaaaa##aaaaaaaaaabaaabaaabcabaaaaaaabcbaabaaa##a###aa####",
-"#########aaaaaaabbcbbbbabcbaacbaa##aaabaaabccccccbaabecabbbcddbacdeba#aaaaabaaabbdfgedcbaccdcgica#aadghdbddd#aa#aaa#a###aaaabaa#####aaaaabbbbbba#aaabccceecbddbaa#bbccabcbbbbbacccdbbdabbaaaaaaa#aaaa#aabbbbcccdcbcbbccccccbcaababbdbabbba#bbgaabaaa#aaacccdcddbeedba#a##a#aba#aaaa##decbaaba#aaa###a#a###abba#bba###aaba####a####aaaaaaaaaaaa#aaabbbaaabbaabbaabbaaa#aa#a#abbaabbbaaa#aaaa#####",
-"############aaaaaaacbbbbbbbaa#aaa#a##aaaaaaaacbbbbbbabdcabbbcdbaccdba#aaaaaababbcbbdddedccddefihaa#aaahiiiffd#aaaa#abaa##aaaaacaa##a#bcaaaabbbcaaaabccdddecabaaaaacbbbabbccccccbbdbdfdaabbaaa###a#aaaaaaaabbbbbbbaaabdcddccbbbbabbbccaabbbaabfdaaabaa#aa##aabbbbbddba##aa#a#aa##aaaaaabcdbbaaa##aa#####a#aaabbaaaaa##abb######aa###aaaaaaaaaaaaaaaaabaaaaaaaabbbbaaabaaa#aaaaaaabbbaaaaaaaaa####",
-"###########aa#aa#aaaccabbaaaaaaabb#######a#aaabcbbbabbaeebbccbcbacdaaa##a#aabbbbccbbcbcdegifdfgifba##aaaagigha#aaaaabbaaaaaaaaabaaa##acaaaaabbbbbbabcdddefeba####abbaabccccbbbcbadcbcbaabba#aaaa#aaaaaababacccbaadbabbccedcccbbccbbabaaaaa##ade###abba#aa##abbba#cebb.#a####.#a#aaaaaaaaacfca#aaa###aa###abaabaaaaaaaabbaa#######aaaaa#aa#aaaaaaaaaaababdaaabbbbbababaaaaaa#aaaaaabbaaabaaaaa###",
-"##########a#aaabaaaaccaaaaaaabaaaaaaba###a##abaaabbababaccbcbbcccaaba#a###aaabbccdccccccdeegggfigaabb#aaa#fffcba#abbaaaaaaaaaaa#abba##aaa##aabbbcbbbbcdeegfeb####aabaabacbbbcbccaabbabaaaaaaa##aa#aaaaababbabbcbcdbbcccbddcdcccabcbbababba###afba#aabba#acaaabbbbaddb##aa####.####aabbaaaabffcaaaaaa##a##bcabbaaaaaaabbbc#a#a#######aaaaa#####a##ababbbbbaaaabbcbaaaaaaaaaaa#aaaaaabaaababaaaaa#",
-"#######a#####a#aaaaabcbaaaaaa#aabaaaaaa###abbabaaaaaccaaabdbccbccbaaca#####accddcccccccddeeefikjeabcca#a#abfifbaa#abbbbbaaaaaaaaa#bbba#bcaaaaaaaccbcccceffeccaa##aaabbbcabbacbddbbaabdbaaaaaaaaaaaaaaabbbaabbbbbbbbbcbbccccdcdcccabbbbbaaba###dcaaaabbaaabaabcbccaadba#aaa########aaaa##aaaacgdbaaaa####cfffda#a#aaaabbdbaa#aaa########aaaa#aa##aaabbabbbaaabbbaaaaaabaaaaaaaa#aaaaabaaaaaaaaa#a",
-"a###########aaaaaaaabbaabaaa###abaaa#a##a###a#aaaaabacaaabccbbbcbbbcbb####a#bdfbbccccccdefecdgiiddaabbaaaabacfeaaaaaabcccbaaaaaaabaaacaa##aaaaaaabccddcfgfgbabaaa#aaabbcccbccbcddbbacabbbbbbbbaaacbaaaabcbabbbbbcbbcbccbccdccdccdcbaabbbaabaaade#aa#baaabaa##abbcbacdb#.#abbccc#.##aaa####aa#aeeaaaaaaabbabddfgfba#aabcd#aaaa########aa##a##aaaaaababbaabbbbbabccbababaaaaaaa##a#aaaabbaaaaaaaa#",
-"#a###a######aaaaaaaacdaaaaaaaa#aaaaaaaaaa#####a###abbbbaaaaccbbbcbbbbaa#aaaaaeecabcccbccdedcdfgigeaaaacbaaabaacbaaaaaaabcbbbaaaaaaaaabccaaaaaaaaaacccceffffbabb#a####aaaabcccccddcdedbbbbaabcabbbccbccbcbcbbbbbbbbbcecbccccceccccdccbbaaaaaaabce#bbaaa###aaa##ababcacda#abb##a#######a#########bfdca#abcbaabaabcffddbabdc#aaaaa##########aa####aaaaaaabbabbbbbbbcbbbcbaaaaaaaa#aa#aaaaaabaa##b##",
-"##a#########aabaaaabcdbabaaaaa##aaaaabaaba######a##ababbbbbabbbbcbcdddbbaa#abceecabccccccdddfedgjgdbaaabaaabbbaaba#aabaabaccaaaaaaaabbccbbbaaabaaabcddefgfebbbb#aa####aaaabbcccccbbfeccbbbaaababbbbbbbccba#abbbabbcdccdcbddcddcccdcddcbaaaaaabcfbadaa#######a#abbacbbcc###a#a########a######a##aabdcabccbbababaaaacdfededbbaa#aa##aa######ba#aa#aaabbabaababcbbcbcbbbabbaaaaaaaa##aaabaaacba#a##",
-"##########a#abaaaaabbbcbbbcaa###a#aaaaa##aba#######aaaaaabbdccbaabccdddecaaaabccdbbacccddcdefdfgiifcba#bbaaabbaaaababbbbbbbabbaabaaaacbbbcbbaaaaaaaceeeefffbaaaa###a##aaaabbcbbbddcddddcbcbbaaabbbbababbabaaabababbbbcccdccddcddccccdecaaaa#abccfbbaaa#######aabbaacabe###a#aa#a#a##.aa#######a#aa#cfeecdcccccabbbabacggcabbaaabbaaaa####aabb#aaaabbababbbbbbcccbbbbbcccbbbaaaa#aaaaaababbaaaa##",
-"######a####abcbaaaaabbccbcbaa###a##aaa##a###aa######aaaaaabdgebaaabbbccacbaaaaabbbaaabccddcdeeffgigbaaaaaabaabcaaababbbbaabbacbaaabbaaaababccbabbabbdffefhdcaaa###aaabba#aababcbdeeccceccccbababbbbabbabbaaaaaabbaabbcbcccccdcddddccccdcaaaababcdeaba#####.###aaabaab#b####a####a##aa#b########aaaaabedddcccccaaaabbcabeaaaabbccbaaa#abbaaabbbaaaabbbaaacbcbcbbdccbaabbacbbbbbaaaaaaaaabbaa#####",
-"######aaa#abbcbaaaaabdccbbaaa#######aaa#####aaa##a#a##aaaababcbbaaaaabdebbbaaa##aaaaaaaabccddeefggieaaaaaaaacabaabbbabbbbaaaabbaaaaaaabbbabbccbaabbbdfgghebbbaa#####abba#aabbbcbccdcbbbcddcccbbbabbabbbabbabaaaaaaacbbabcbbccccddddccbcccaaaaaabbdcbc##########aaacbbaa####a####aa###a#aa###aaa###abbceddedcccbaaaacccdca##a#abbbabaaaabaaabbba#aabbbbbbccbbbbaaacccbbcbbaaabbbbbbabaaabaaaa####",
-"#######aa#aaccabbabaabdecbb#a########aaaa####aaa#aba##a#aaaaaaabbdcaabdcbcaacb####abb#abaabccdeffghfdabaaaa#acbbbbcbabcabcbaaaabbbabaaaabbbbbcccbbbccdfedccbbb#########aaaababbacccbcbbbddbdcccccbbbbaaaabbaabbaaaaabaabbbbccdcceedccccacbaaaabbbbddb####aa######aabbaa####a####aa#aa###a#####aa#aabbddeccddccbbbabbbbceb###aa#aaaaaa##aa####aaaa#abbbbbccacccbaa#accbbbbbaaababbabaaaaaaaaa####",
-"##a#####aaaaaabbbbabacdddccaa########aa#a#####aaa#aa#aaaaaaaaaaaabcabbcbbbbababa###baaaaaaabccdeeehifbabaaa###abbcbbcaccbcbbbaabbbbabaaabbbbbbbbcccccddbccbbbbba#######aaabbbaabbcccbdcbbdbbddcdcccbabaabaaaaaaaaaaaaaaaabbcccddecccbbacccbbbaabbbceca############aaaaa#############a#############aaaaabccddcbbbabbbbbbba#####a##a####aaa#######aaa#babaabbcbaaa##abbbaabbcbbbbaaaaaaaabbaaa####",
-"#########abaaabbabbbbbddeccca##aa######a#aa####bbaaaaaaaaaaaaaaaaaabccbcccebacfdb#####aaaaaaabcdddcfgfccbaa##a##abcbbcbbdcccccabbabaababbbbbbbbbbcdccddbabbbbbba########aaababbbacdccccaabcbbcabddddbbaaabbabbbaaaaaaaaabbbddcddecbccbbbdcbabbbaabbcda#############abaaaa############a####bb##a####aaaaabcffdcccbbbbbbbb#######aaa###aaaa#######aabaaaabbcbaaaaaaaa#aaaaaabbccbbaaaaaabbbaaa####",
-"#########aaabbabcbbbbbdddcbaaaaa###############aabaaaa#aaaaaaaaaaabbabbdefffccbba###aa##aaaaaabcdceecggdcbbaa##aa#aacbb#bcdddddabbbbbabbbabbbbbbbccfeedbbbbbbcbba#a#####a#acababbbdcbcbabbabaabaabeedcaaaaaaaabcbbaaaaaaabbcdfdddccbbbbcbccbabbbaaabcda########a#aaaaaaa#aa#####aaabaaaaaaacb##aaa#aaababbcdefddbbcbccbaa#####aaaaaaaab##a########aa#abbcccbaaaaaa###aaaaabaabccbbbaaaaaaaaa####",
-"########aaaaaaabbbbbbcdedbbbbabaa##########aa###bbb###a##aaaaaaabbaabbbdfeedb##a#a##aa###aaabbbbccdefbfecbbbaaa####a#adb#acdecdfcbaabcbbbbcbbbbbbcdeffbcccabbcdbbba#a###a#aabaaaaaccccbaaaaabbbbaabdfedaaaababbbbbaaaaaaababbcedcccbbbbaccccbaaaccbbabeb######aaaaa#aaa###a######aaaaaaabacbca#aaaaaabbbbccdegfeccccccbcbaaa#####aaaa#aaaaa###a###aaaabbbcccb##a#aaa#aaaaaaaabbdeddcbabaaaaa####",
-"#########a#aabbbbbbbbdddccbbba#aaaa##aa##a####a#bba#a#a#aaaabaabbbabbeedeeefdaaaa#####bb##aaabbabcddehgifffdcbaaaa#aa#aaaaaccdeddcabbbcbbbccbabbccdceeecdcaaaabbcccaaaaaaaaaaaaaabacdddbaabaabbbbcccccfdbaabbaabbcaaaaaaababbcccccbbbbbbbccbcca#acbbbbbda#####aaaa####ab##a######aaaaaaabaccbaaaaabbbbbbccceffcdeedcbbbbaaaa#aaaaaaaaa#aaabaaaaaa##aaaabbbcbbcbaa#####aaaaaabbbcccddcbbaaaaa####",
-"##########a#aabbcbcbbcecccbbbabaaaaaa#####a#aaaabbaa##ba#acaaababbbbbbbcdcfgdbbbaa####aba##aaaabbbccdfefhfgedecaaa##abaaaaacbabebbbbbbbbcccbcbbbbddbedbddcaaaaaabdccaaba#aaaaaa#bbbbbaddccaaabcbbdcbbcbddabbbbbbbccaaaaaaaaabcddcbbbbbbbbbbbbbbaaaabbaabe#########a####bb#aa#####aa#aaaabccdbbbbabbcbbbccccdccbaaeffdbca#aaaa#aaaaaaa#aaaaabaaaa#aaaabaabbccbbcceb#bcaaaaaaaabbbbcdcbbbaaaaa####",
-"#######aa#aaaaabbccbbcdccddcabaaaaaaaaa###aaa#aabcaaa#bba#aabaabbbbbbabcccdfedcaa##aaa######aaaabbbbcdddghhgfedcbaaaa#aaaaabcbbbccbbbbbbbcbccdcccccbeebccbbbaaaaaccccccba#aaaaaaabaaabbbddbbbbcccbcccbaceeacbbbcbccbaaabbabbbbceccbbbbbabbbbbbbab#aabbbbcc#.######a####.bcbcba####aaaa#bedccbbbbbbbaabccddedaaaaa##beeda#aaaaaaaaaaaaaaaaaaaaabba##babbabbbbcbbbccccbbaaaaabbabaabddcbbbaaaa####",
-"##########aaaabbbbccccbcddddbaaaa##a#a#a###aaaa#baabbaaaaaaaabbbabcbaabccbddfebaaba#ba######aaaabbbbbcddfiiigggedbaaaaaaaaaabcbabccbbbbbbbcccddddccceecccccbbaaaabccddbbba#aaaaaaaaabcbbbcccdccbcbabcbabceecbabbbbbbaaaabaabbbcddbbbbbbbbaabbbcbbbbaaabcbdc########..####ccccba#abbaaaabddbabbbcabbbbcccceeca###aaa##aaa##a#aaaaaaaaaaaaaaaaaaaaa##aabcbbbbbbbccbbbbcddaaaaacbaaaabddbbaaaaaa###",
-"############aaabbabcddccdbcdcbcbbbaaaaa##a##aaaa##abaaabaaaaaaabbaacaabddabcefc#aabaaa###a####aaabbbbbbddgihhfffgeaaaaaaaaaaaaabbbcbbbbbbbbbcddeeedceccdcccccaaaaabcbddbaa#a#ab#aaacbbbbbbddebbbbccbbbabbbedbaaaaaaaaaaaabbabbccecbbbbccbbbbaabbbbcc#aaabbcc######a#####.bccabbacbababaabdcabbbabbabbbcbdecabaa##aaaa####aaaaba##aaaaabaaababa##aa#aaabbbbbbbbcbbbbacbedbaaa#bbaaaabcbbbbaaaa#aa",
-"#######a####aaaaabaabbcccbabbbbbbbcbaaa######a#aa######aaaa#aaa#acbbbabeeebabddbaaabaa####aa#a#aababbbbbcehhgeeffdca##aaaaaaaaaabbbbabbbbbbcdcdddfgfhcbbcbbbcbaaaaabcccdbba###baaaabcbbaabcdeecaaabbbbbbaabddecaaaaaaaabbbbbbbccfcbcbbbbbbbaaaaabbbcca#aabacc#######a####acdcbbbbbbaaaabbccaabbbbbbbabbceecabb#aa#aaaa#######aaa##aaaaaaabbaaaaaaaaaaaabbbaabccbbcbaaacgdaaaa#aababbbabbbbaaaaa#",
-"###a#####a#aaaaaabcbacbbddcaaabbbbbbbaaaaaa##a#####a####aaaaa#aaabdbcbbedefcaaabaaaaabaaa#a##abaaaaababbbcfgggfeefea##aaaaaaaaaaabcbbbbbbbbcdcdddefgeabbbbaabccaabaaceddeeaaa##aaaaaabbbabbcdedbabbbaaaaaaaacfecaaaaabaabbbbbbcdfdbccbbbbbaaaaaabbbcdbaa#aabdb#########a#acdcccbaaab#aabccbbbbbbabbbceedccbcbbaaaa#baa#a###a#a##aa###aaaabaaaaaaaa##aaaabbaaabcbbbbbabbdfeaaaa#ababbcbbaabaaaaaa",
-"#####a#####aaaaaabbbbbbbcddcbabccaaabbaaaaa#a##a##a######aaaaaabaaaaacbbbffeaaaababbabbbbbaa##bbaaaabbbbcccghghgeffbaaabbaaaaaabbabccbbbbbbcdddefggecccbabaaabbbacbabbdddecbaa####aabaababbcccdcabaa#aaa###abceedcaaaaabbbbccddefdccdccbcbbaaaaabbccdccdb#abbd###a#####a#a#cddcccaaaaaaaaabccbbbbdeefbba##aabaaa#aaaaaa#aa###aaa##a####aaaaaaaaaaaa##aaaabacbabbbbbcbbbbcfgbaaa#aa#abbab#aaaabba",
-"##########abaaabbbbbcbcdcccdcbbbcbbbbbba#aaaaa#a############aa#aaaaaaababbdeaaaacbbbbbddcbaaa##abaaaabbbbcccghhhedecababcbaaaaaababcbbbbbccbddceggffecccbbbaaabca#aaaadddedcb#a##aaaabbbabbbbcccdd###aaaa#aa##bcefeddcddccefdddfdcccccccccbbaaaaaabccccdddaabbda########ab##bbbddcbbaa#aaaabcbbbcdddccaaaaa#abaaaaaaaaaa#aa#aaaabaa#####aaaaaaaa#######aabaacbabbbbbbcbbbbdfbbaaaa###baabaabaaba",
-"###########aaaabbcbbbcccbddbcdccbbbbcabbaaaaaaaaa###a##aa###aaaabaaababbccbbdb#abccabddbbbba#aaaabdbbaabbbbcdehihbaabbbbcdcbbbbaababbedcbbaccdddeeefedabbabaaa#aaa#aa#beeeeffca###aaabbbcbbbbbbcced#a###a##aaa#abffgfedcccfhcbdebcbccdccccbbaaaaaabbcccccddbaabdcb#.#aa#aaa##abdddcbbbaaababbbbbcbdbabbbbbb##ababbbaaaaa#aa#aa##aaa######ababaaa#####a#aabcbbbabbbbbbcccbbbeabcbba###aaaaaaaaaab",
-"b#########aaaaababbbbabbbbdebcccccbbbabaaaaaaaaaaaa########aa#abbaaabbabbdbcbbbaaadcbcbdbabba##aa##abcb#aaabcdcfhgdabbbccdcbcbbbbbbabcgdcbdbbdedeeehfgdbbbbbaaaa#aaa#abddddgeedcaaaaaabbbdccccccbceeaa###a###aaaacfghhgedccggefbccccccccccbbbbbbaabbcccccccdaabaaccb#aaa###a##adedccbcbaaabbbbcbbcddbaaabbbbaadbbaabbaaa##abaaa#aaaaaaaa#aaabaa########abbadccaaabbbcccccbbdcbcbbba###aaaaaaaabb",
-"aa##########aaabbbbbbbaabbaccbceeebbaabbaabaaabbbbaaa###aaaba#aabaaaaababbccggcbaabccbbbccbca##aaaabdbbabbabbcdddghbabbccddcbbbcbbbbbccgfcbccceddddeddedddcbababaaaaaa#accdeffedbaaaaaaaacccccbbbccffb#a#####aaaaabfhgghhhhgghecbccbccccccccbbbbaaabbbbcbbbcdcbbabbcb#####abca#abccccccabbbbbbbbbdddbaaaaabab#cdba#aabaaaaaaaa#aaa#a#aa#####aaaa#######aabbbbccbbbabbdeddcbbeaabbcb###aaaaaaaaab",
-"baaa######a#aaabaabdbbcbabbaccccedaaaaaaaaaaaaaaadbaa#aaaa##aaaaaaaaabbbcbcccdbaaaaabdcbacbcdcaaaaaaaabaaccbbccdddhgcabcccdecbcbbcbbabadedbbcdedcddeeccdddeeedcbbcbaabbbabbcddddec#aaaaaabbcccccbccdffc##a##a#aaaaaafheffhgeccefcbbcbcccccccbbbbaaabbbbccbbddedbabbcc.##a##abc###cdcccbcbbbabbbaddccababbbaaabaddba##aaaaaa#aaa#a#aaaaa##aa##aaaa#######abbbbccbcbbbbdefeeccecaaaaa####aabaaaaaa",
-"bb#a########aabbbaaababcccdaacdbbaba#aaaaaa#aaa##acaa###aa#aaaaaaaaaaabcdcccaaaaaaaaadbcbbbbacc###aaaaaaaacbbccdcdfggbbbcccdecccddcbbbacdfdbcdebbbcccdcccccdcbefccbaaaaabcbbccabdfcaaaaaaabbdddccccccefe##a##aaaaaaaadfghhhdbbcccccbcbbccdccbbbcaaaabbbbdccddeeba#bbda######.acabbddccabcbbbbbbbddccaaaaaaaaaaabdca#a#aaa#aaaaa##a#aaaaa##aa##aaa#a##a##abbbbccbbdbbccefffeccd#a########abaaaaaa",
-"aa##########aaaaabaabbaaccdcaacbbaab####aaaa#aaaaaa#a####abaaaaaaabcaaabddcacda#aaabacbbbbddddcbaaa##aaaaa#abbdcccdegfbbcdcdefccddccccbcbbfdccecabccbcbbbcdddcbffdcccb#aacbaabcbbeecaa#aaaabcedddccccddfeb#####aaaaaabbehhfcccbcccccbbccccccbcbcbbaaabbbcdcceddcbbabba########bcbbcdcbbbbbbbbaacccccaaaaaaaaaaaabcba####aba##aaaaaa#aaaaaa##a#aaaaaaa#aaabaabbcbbbbbbbdffffeeeaa########aabcaaaa",
-"aba#a#aa####aaaaabbabbabbaccaaabaaaa#######a####aaaaa####aaa#bbaaaabaaacbddcbccaaaaaaaaaaacdeabcbba#a###a#aaabccccdeegfcbcdddeedcdccddccccfedddcbbccbbbbbbccddedecccdca#aaaaaaabacedcddcbabaabccccccccceccd####aaaaaabaacdghhfecccccbbccccccccbcbbbaabbbcccccddcddceaca########cdccdccbbbbbbbbbccbcdcaaaaaaaaaaaaaaba#####aaaaaaa###aaaaa##a####aaaa###aabbbbbbccbdbbbcdefffgaa#a#######aabaaaaa",
-"aa#####aa###aaababbccccbbbbcbaaababa#######a#aabaaaaaa####aa#abbaaaabbaabbdcbbcdbbbbaaaaaabcddbcbba#####a#aaabcdccceefhgbbdcceeeeccccccddeefeeecccacccbcbabbccdefdbcebaaaabaababbbcdcdfffdabbbbbcccccccecade#aa#aabaaaabaackijkidbbbcbccccccccbcbbbbaabbccccccccddegfdaa#######ceedcbbcaacccccbcccccbaaaaaaaaaabaaaaaaaaa####aaa.baa######aaaa####baaa#aaaabbbbbccdcbbcddedfgfb##########abbaaa#",
-"#a########aaaaaaccbbcdcccbbbba#aaaaaa#####aa#aaab#aaaa#.###aa#aabababcbabaccbccdedaaaa#aaaaabccacbaa#a######aacbcccdffhigeccccdeedddccbcddffdefcbabbbcdecbabbbbcddecddbbaaabbabbbcccddeeffabbabbbbcccccdecdedb#a#aaabbaaaaahifgikfcbcccccccccccbbaaabbcbbbccbbbbcccdhea#a#####aedfebccccbbcbcccccccbaaaaaabaa#aaaaaaaaaba#b###aaa#b#######a####aa##abbbabaaabbbbbcdecbbcdedefghc#########abcedcb",
-"a############a#abcbbbcddccbbbcaaaaaa#a####a#a###ba#aa#######aaba#bbbbbccaabcccddeebaaaa##aaaabaaabaaaa#####a#aaaabcbdeggihfccccdddffdcbcccdfcbcbbbbbbccbbbbabaabcdfebcbbca##aabbbbcdcdfffeeaabbbccbbcccdeeddeed##aaabaaaaachgcccfijebbcccccccccbbaaaaabbbaabbaabbcbbcfecaaa#aaadcddbbdcccabbcccbbbabbaaaa#aaa###aaaaaaaaaaaaa##aaaaba######a######a#abbbbbbabbcbbbddcabcddddefgfa########aacedcc",
-"#######aaa#####aaaccccddcdcccbbaaaaa####a####a#aaaa#aa#######abaaabbccacdaadccdddccba#aa#bbaaabaaabaaaaaa#aaaaaababbbdeffiiebcccdddeedcccdcfbcbbbbaabcbbbbbbaaaabcdeefeeddedbaaabcbdccefffffabbbbbbbbbcdcdddddefbaabbbbabaeidccddcejgbbccccccccbbbbaaabaaaaabaaabccccdffebaabbaaddcc#cdccabcccccbbbbbaaaaa#aaaa##aa#aaaaaaaaabaaaba#b##a####a#a#a##a#aabbabbaabbbbddecbbdcccddeega.##.#a##aab###",
-"#########a#####ababccbbbdcccccabbb##aaaaaa#aaaaa##aaaaaa#..###aaaaaaccbbdcbbccdbccdaa##a#a#aaaaaa#ba###a#a#aaaaaaabbbcdeefhgeccedbbcdedeedgebbbbbbbbcdcbbbaabaaabacccddccccbdcaabbadddeefffgfbabbbbccccccccdddbggbaabbbbabhefcccddddihdccccccccbbbababaaa###aa#aabbbcdeeffa.##abcfedabccbcccabcbbbbbbabaaaaa###aaaaaaaabaaaaaaaaaaaaba#######aaab#####aaabaaaabbbaceffecbccddccdec#####.##aa#aa#",
-"#aa########a####abbccbbccdcccbbbbba#a##aaaaabaa#aa####aaba#.##baaaabccdabdbabbbbbcccbaa####aaaaaaa#aaaa######aaaabbabccdfeehihfggfdbceedddeddfdccbbcbbbbbbbbbbaaabaccccbbccdddecababedefffffhgdaaabccbcccccdddbfhfbbbcbbackdeeccdddccfhgbccccbbbaabaaabba#####a#aabbbdeddeda.###aeddcbaaccccccccbbbbbabaaaaaaaaaa##aba##abbaaaaaaaaaab######aa##aa###aaabbbaaaaabbbeffffdcdcdeffda######.###aaa#",
-"#aaa############aabcdcbcdcfedeecbbaba##aaaaabaa###b#a##aaaa####abaaacdcaacdaacbcaaaaaaaabc##aaaabaaaaaa######aaaaabbbdddeddfhhhhhhfcccffffdbaabcbdbabbbbbbbbbbaaaaabbcccbbbbcfdedbbadeddeefdefhffecbbcbcccccceddgibbbbbbdecccbbccccddddhidccccbbaacaaabba########aabccedddeda####cdcecbccccddddcbbbbbabbaaa#a#####a#######abaaaaaaa#aaaa#a##aaaa#a####aabaaaaaaaaabccddfgfddefge################",
-"##aaaaa#aa######aaabdccbccdeefebbaccb###aaabcbaa########aa######aaba#bdbbbcabbbbbbaaba##aba#####ababaaa##a#a##aaaabbcddedddeeefhghfddccdhecbbbaaaababbbabbabcbaaaaaabbccbbbbbbeefdbbbddbddffdggihiebbbcbbcccccedeicbcbbcdccccccccddddddcfifccbbbbabbabbbaaa####aa#aabcedddefeb##.bdcdeccbcccdddcbabbbbaaaaaa#aa############abaa#aaaaa#aaaaaaaaaa#######aabaaaaaaaabbabbcefgecbcc############a#a#",
-"##aaaa####aa##a##aaabcdcbbccdcdccbcaba##aaaabbbaa#aa#a####a######aabaaabaaaaaaaabbba#aa###a##a###abbbaa#aaaa#a##aabbcededddddeghggcdfedffddcbbbaaabbbbbccabbbbbcaaaaabccbbbbbbeccefdbcdbcbcefefhgghdbbcbcccccccdcefedbadccbbcccccddddddddeggcbbbaacaabbbaaa######aaaabdcdeedefbaa#deddcdcbbcdedccbbbcbaaaaaa##################aaaaa#aa##abaaaa#aaa#aa##aaaaaaaaaabaabbacdbacbaaba###############",
-"##a#aaa####aa##a##aaabbbbbcdeccbbaaaaabbaaabbaabaa###aaaa#########aaab#aaaaaaaaabbaaaa#a#a#aa#a#aabaaaa###abb##aaaaabcdeeddefghhhebbbfebbdddccbbbbbaaabdcbcbcbacbaaabbabcbbcccddbbcefecdcbbbcddehgggcbbcbcccccccdddffbbdbbbbbccccddddddddddegcbbaabaaabbbaaa######aaabbbcdefdeca#ddedcdddbacadedccbbbbbabaaaa###############.####aaa##a###a##aaa#aaa#abaabaaaaaaaaaaaaabcdbaaaa#a########a##a###",
-"a##a#aaaa#####aaaaaaabcccbbcdebbaaba#a#bbaaabbaaaa####aaa#####aa#abaaaaaaaabaaaaaabbbaaaaaa#aaaaaababaaa####aaaaaaaabcddddefedhhgbbbbcefbcdedcedabbbababbbcbbbbbbaaabbaabbbbbcbcddbbbcdcebbbbdcabehhebbbbcccccccceddhfddbbbbbccccddddddddddcdfdaaaaaababbaaaaaaaaaaabbbbccddcdfededffddddcbcabcddccbbcbbaaaaa#####################aa##a#a#######aa###aaaaaa###aaaaaaaaaabbccaabaaaa######a######",
-"aaaabaa##aa####aaaaaabbccccbcccaabbba#a##aaaabbb######aaaaba##aaaaababb##aaaaaa#aabaaaa#aaa#aabaaaaaacbaa####aaaaaaabcdeddefefhheabbbbbdfgfgedcfaaabbbbbbaaaaaacabaa#baaabbabaabbdeeeccabdccbbbcaachifbbbcccccbcccddejkeabbbbccccddddddddddccceebabbaabaaaaaaa#aaaabbbcbbcccddefgedfedddcccbaabcdcccbcbcaabaaaa########.##.########aa###a########aaaaa#a###a###aaaaaaaaababccaabaa#########aa#a#",
-"##aaaacb########aaaaabbbbcccbdcddbbcbc#aaaca##a#aba######abca#aaaa#aa###aa###aaaaaabbaaa#a###aaaaaaa##bcbba###a#aaaabbceedddehgfdaaabaccbfhiihffcaaaaccbaaaaaaacabaaabbaabcbbbbbbbcbdeffedfdb#acaabafjgbbcbcccbccccdefiicbbbbacccddddddddccccbbcfbbbbbabaaaaaaaaaabbbcbbbbccccdegfecfdbaabdabbbbcccdcccbbbbaaaa###################a#aa##a#a##a####a#aaaaa###########aaaaaabbbbbaabaa#######aa###",
-"###aaacba#######abaabbdcbbcdcbbefcbabcbbaaaaa####aa#a#a#a#a##aaab###a#aa####abb#a#aacbaa####aaaaaaa#aaabdcbaaaaaaaaabaceefeeffffbaaabbabccehigfeeddefdbabaaaaabbbabaabaaaaabbbbbbabccbabdedda##aaabbachhbbcbccccbbcccdeghebbbaccddddddddddccccbacecbabaaaaaa#aaaaabbbccbbbbcccdcdgfdfebbbbbcccbcbcddccccccbbaaaaa################aabbaaaa####aa###a##aba#############aaaaabbbddbbaba##########.#",
-"####aaaba#######aaaaabdfdbbcccbbdebbaaaab#aaa#a###aa###aaa###aba#####aaa#####aba#aaa#baaa#####aaaaa###aabcccaabbbbbcbbbdfffgeccebaaabbbbcbbeffedccfghhebaaaaaabbaaaaaaaabaabbabbbbbacbbbbcbdda####abbabghabbbccccbbccddddghdaabcddddeedddddcccbbabdfdaaaaa##aaaaaabccccccbbccddcbefdffdcbbbcdccbbccddcccccbbbaaaa################bbccbaabaa#aaaaaa#aabba##a#########a#aaaaabbccbcabaa###########",
-"#####aaaba#######aaacccefcccbcdccbcbbaaaaa#abcba#########aaaaaaa######aaaa####aa##aaa#aaaaaaa##aaaaa##aaaccddcccdddddcceeffdccdccbaaaaabbbbcfggdddfffggfebaaaaaaaaaabaaabccbbbbbbbabccbbbbbcbdb###aabbbbghbacccccccccccdddfigdbcddddddeddddcccbbbabbfeabaa#####aaaabcccccbcbdddecegfffcccabbccccbbccdcccccbbbbaaaa############a#aaaababaaaaaaa#aaa##aaaa#aaa##########aaaaaabbcccbbdba#########.",
-"#####aaaaa######aaabddefcccbabdccccbaaaaaa###aaa######aaabaabbba#######aaaa####a###aaaaaa#a##a#aaaaaaaaaabcddddcdeeedefgfefecdaabbaaaaabbbbbadfebcfdfgffeeecaaaaaaabaaacabdbaaabbbcdcbbbbbbbbccb#a###abbaegcabccccdcccccdddcfihfdccdddddddddcccbaaaaaddbaa######aaabccccbcbccdddhfcfgecccbbbbcbccbccbccbcccbbbbaaaa#a##########aaaaaabccbcba#aa#aa#aaaaa#aaaaa###########aaaabbaddedaa##a#.#####",
-"####aaaaaa#######cffdabcbcdcbbadfbcbbaa###a#aaa#aaaaaaabaaaababaa#######a##a#########aaa##aa##aa#aaaaaaaaabdeddccddddddffeeeec#a#aaabbbaaabbbcggdcfeeeeegfdccbabccbbaaabbbcaaaaabbbcdbbbbccbbbdbaaa###abbccebabbccccbcccccddcdfhjhedddddddddccbbaaaaaabdda#######aaabbddccbbdddedccdgeeedccbbccdccbccbcbccccbbbaaaaa#########.##aaabbaabbbcbaaa###aaaaaaa#a#a#a########aaaaabbaccddeb###########",
-"########aaa######acddbabcbbcccabcddcaabbaaa##aaaaaabbbcaaaabbaaaaaba########aaa#aa###aaa###aa##abaaaaaacbbbcdffeddeccdffffeddbaaaa#abbaaaabaabegebdfeddeffeddddcdddcabbacbcbccbaabbacccbcdbbbcdb#aa##aabbbbbffbbccccbccccccdddedfkkidddddddcccbbaaaaabbabdb#a#####abcccdbccccddfcccdfgeedccbbbcbccccbbabbcccbbbbbbaaa############a#a#aaaacacbaaa####aaa#aa###a##a######aaabaabbbbbbdfa##########",
-"#################abbcbaacccccbccaacbcaaaaaaaaaaaaaaabccabbbbaaab##bb######a#aba##aa##aaaaa##a#a#acabbbacdcbcddffffdgeefefeddcb#a##aaaaabaaaaaaddfdcfdccccccdcbcbcccecbbabccdddddcbbbbccccccbbbceb#aa###aaaabbfgbacccbcccdcdddeedgjkihccddcccccbbaaaabaabaadca####aabbcccbcddccefdcdeeeedddcacbccccccbabaaabbbbbbbaaaa###########.#####aaaabacbba##aaaaaaa####a####a######abbabbcbcbcdb###a##.##.",
-"###########aa#####bdbaaaaccddbbdcba#bbaa##aa#aaaabbbbbbaaabaaaaba##aa.####aaa##a#aaaaaabbbaa#####abaabbbbbccdddeefeffddefdccaa####aaaaaaaaaabaeefdedeccbabbbdddbbccccabbbbbbbbcdcccbcccccccccbaaaa#a####aaaabacgcabbcccdddefffedgijfehdcccccccbbbaa#aaaaaaabcbaaaaaabbccdcdddefgecddeefedccbbbabccbbbbaaaaaabbbbaaaaaa################aaabcbabbaa#aaaaa#aaa###a####a####aaabaabcbbbcbba###aa####",
-"############a#####abaaaaaabddccbcdddbaaaa###aaaabaaabbbaaaabbabba###b######aa######a##aacbcbba##a##babbccccdddddeeefgfeedccdb####a#aaaaaaaaaaadefedecbabbbbbcddddbcddcaabaaaaaabbbbbaabbccdcccbbbcb#a##aa#aaabbbfdbbccddddeffffefggeedjhedcdcccbbaaaaaaaaaaabbcaaaaabbcdcccdeefgdcccdefeccbbbbbbbccbbbbaaaaaaabbbaaaaa#######aa######aaabbbcab#a#aaaaaaaa#a##a#####abaaa#abaabbbbbbdccc####aa#.#",
-"###aaa###a#a#a####aabaaaaaabdbbbcecdcbaaaaaaaa#aaaaaaaaaaaaabccbb###a########a#a#aaaaa##aaaabca#a##aabbccccccdcccbbbbcbcabbbb#a#a#a#aaaabaaaabbeffddeabcbbbbcccccdccbbbaaaaa#abaaaaaaaaaababbbbbcbb#a##a##a#aaaabefcbdeeddeffffffeddfbchjieccccbbbaaaaaaaaaaaacfcabbbbcdddcdehggffeeddgfecbbccbbbccbcbbaaaaaaaaabaaa######a##aaa####aaaaaaabbaa##aaaaaaa#aaaa#####aabbaaaabbbbbbccccddbaaaa####.",
-"####aaaaa#aaaa#aaaaaaabbaaabccbbbcddbbdcbaaaaaabaaaaaabbbbaaaaabaaa###############aaaaa##a#aaaaaaaaaaabbccccdcbbbaaaaaaaabaaa#######aaaaabbbabaacffffbbbbbbbbbbbbccccbaaaaaaaaaaaa##aaaaaaabbccca#######aa###aaaabcgfcdeeefgggggggeffcbbehkjebbcbbaa##aaaa#aaaadheabbbcdddcegfbccdfffgggedccccbbbbbabbbaaaaaaaaabaaaaaa######aaaaa#aa##aaaabaaaaaaaaaaaaa##aaa##aaa#acbaaabababbcccdecbaaaa###a#",
-"#######a###abaaaaaaaaaaabbdccccbbbceefebcaaaaaa#aaaaaabbbcccaabaaa###aaa#######a###aaaba##aaaaaaa#aaaabccccccbbbaaaaaaaaabaa###a###a#aaaaacbababa#eeedbbbbcddbcbccbccccaaaaaaaa#a#aaaaaaaabbbbcba########aa####aabbbghdeeegggggghggfedbbbcdikgbbbbbaa#aaaaaaaaaabheaabccddegdccccdddccfffddbbabbbcbbbbbbbbbbbaaaaaaaa########a###aaaa#a#abaaaaaaaaaaabbabaaaaaaa#a##ccaaaaaaaaaabcccbacaaabaa###",
-"##a#aa#####aaaaaaaaaa#aabbbabbcbbabcdeedcbbbaaaaaaabbbccdddccccbbccbdcbcca########aa####aa##a#aaa###aabbccdccbbbaaaaaabaaaaa#########aaaaabcaaabaa#dfcccbcccbcccccdccccdbbaaaaaa###aaaaaaabbbcb######aa###aaaa###abbcfheeffghhghhijifcbbbbbehjhcbbba##aaaa##aaa##afgdbbcefecdcdccddddddeedcbabbcbbabbcbbbaaaaaaaabaa######a#a#a###aaaa#aaabaaaaa#aaaaaaaaaaaaaaaa#a#bcaaaaabaaaaabbcccbcabbbaaa#",
-"aaaaaaaaaa#aaaaaaaaaaaa#abaa#aaaaaaaaabcbbaabbbabbbbccddddddefdbcdccdecddcaa##aab######baaaa##ab###aaaabbbcccbbaaaaaaaaaaaaaa########aaaaaacdbaabaa#dcabccdddcccccdeeddddddbaaaaaa###aaaaabbbca#a#########a###a##aaabcegefgfhhggiiihddbbccbbfegihfb###aaaaa#aaaa##adgfefecbddccccddcedccefdcbabcdcaabbbbbbbaaaaaaaaaa#a####aaa#aa###aaaabaaaa#aaaaaaa#aaa##aaabaa##abcbaaa#aaaaaaabbbbdddbbbaaaa",
-"aaaabbabaaaaabaaaaa#a#aaa#abaaaaabaaaaaaaaababbbbccdddeeefdfffedccbbbbcccccaaaaacb#abaab#aaba#aaa###a#aaaabccbaaaa##aaa#abaa###a##a#aa#aaaaacca#abaaadbabddddfededcbbcaaabcddcaaaaaa###aabbbcdca######a####aa##aaaaabbcdkgghhhhhgiigecabbbccffedgiida#aaaaaaa#aaaaaabfecbccccbbbabbbddddddccbaaacdcbbcbbbbbbbaaaaaaaaa##################baaaaaaaa######aa#aaaaa#a##abbbbaaaaabbaaaababbddcbbbbaa",
-"aaaaabcccbbbaabaaaaa#aaaaa#aaaaaaaaaaaaabaaabaaabbbcdffefgffdcccdddcccccbaabaaacbab#aa##aaabb#a#a##aaaaaaabbbcaaa###aaaa#aaa#a###aaa#abaaaaaacccbaaaabcbaaccbbdccbbbababba#abccbaaaaaaaaaabdeabaa##########aa####aaaabbceghghhihiihhgcbbbbbbegdcdedhhdd#aaaaaaaaaaaaabdccccccaaabbbbcddddfeffdbbabcbbbbbbbbbaaaaaa###a#########aa#######acbaaa#####aaaa##aaaaaaaaa#a#aaaaaaaaaabbbbaabbccddbbbba",
-"aaaababbbccbbcbaaaaaa#aaabba#aaaaabaaaaababbbbbaaaaaa#aabbcaaabbbbbbbbbcbaaaaaabaaaa####a##aaaa######aaaaaabbbbb#######a#aaa#a###a##a#aaa#aaacbbcbabbabcabbbcddbaaabbaaaa##aaaabbaaaaaaaabbcdbaaa###########a####aaaaabbbcfihghhhihhhdabbbbbbeeccccbdehfaa##aaaa#aaaaaabedccbaaaabcdcddcbfeffddeedccbbbbbbabbaaaaa#############aa########ababaa###aaaaa###aaaaaaaaa##abaaaaabbbbbbbbbbbbcdffabaa",
-"aaaaabbacbbbabaaaa#aaa#aaaacba###aaabaaaaaababaaaaaaaaaa##aaaaaaaaababbccc###aabaaaa##a##aaaaa#aa##aa#abaaaacccb##a#a#a#aaaaa####aaaa###a#aa#ababdbbbabcbabbbbbbbbbcbbaaaaaaaaaaba#a###aaacbcdaaaa#########.#####aaaaaabbccfkjgfhhifdfdaaababbffcbbbbbacgda#aaaaaaaaaaaaaddcba#aabccccdbbdeefeddfdfecbbacaaaabbaa##############aaaaa#######a#aa###aaa####aaaaaabaaaaaaaba#aaababbbcccddddgihcabb",
-"baaaaababccccbbaaa##aaaaaaa#cddb#####aabbbbaaaaaaaaaaa#####aaa##aa#aabadedca#abbaaaaaa####aaaa#a#aaaaa##aababcbca#aaaa#####aa###a#aa##aaaaa#a#aaacbaabbbcbabcccbbbbcbabba#aaaaaaaa#bbaaaaabbadb###################aaaaaabacbgkkihhggfedaaaaaaaceecbaaaaabffgeca#aaaaaa###acdca#aaacbbccbcbeeefffdabdfecabaaababbaa#a##########aaaaaa#######abaa##aaaa#####aaaaaaaaaaaaaabaaabaabbbbbcdegghffdabb",
-"bbaaaaaabbcccccbbaaaaaaabaaaabccca###aabcceebaaaaaaaaaaa#a##a#####aa#aaaddbbaaabaaaaaaaaaaaaabb##abb#aaaaaaabcbba##aaa###aaa#########a#aaaaaaaaaaaaaabbbccbaabccbcbbbbbaaaaaaaaa##aaabaaaaccbed#################.##aaa#aaaaacekljihhhdbaaaaaaabdeedbaaaaaabceffdaaaaa#####abdd##abbbbccccbcedfeddbbbbdddbbaaababaaa#################aa#aa.###aa##ba##aa###aaaaaaabaaaaabaaaaababbabbbdfhjifeecba",
-"bbbaaababaabbcccbaaaaaa#aaaaa#aaba##aaabcbbccbaaaaaaaaaaaaa#aa####aaaaaabccbaaa#aaaabaabaaaa#abdca#acaaaaabaabbaba#aaaaaaabba##aaaaaaaaaaaa##a#aabbbbbbbccbbbacbcbabbbbbaaa#aaa##aaaaaacbccccdbbba#a########a#.####aaaaabaaaaafklljhfcaaaaaaaa#dcgfcbbaaabccccdggcbaaaaa#aaaacdaabbbbbbbbcbddeeddccccbbcecbaaaaaaaa#a##############aaa##a####aa##b###aa#aaaaaaaaaaaaaa#aabaaaaaabaabbdggghhfbdeb",
-"bbabbaaaaaabbcbccbabba#aaaa##a#aaa#a#aaabbabbbaaaaaabbabaaaa#a#####aaaaaadcba###aaaaaaaaaaaaaaabbaa#abaaaabbbcbaa#aaaaaaaaaaaa#aaaaaaaaaa#aaaaaaaabbbbbbbcbababbbcbbbbaaaa###a###aaaaaaaccddcddbaaba#aaaa####a#.#.#aaaaabbaaa##djlljc#aaaaaaaa#afdfebaaaabccccddegfdbaabbbbbbabddbbbbbbbbbadceedcdcccbbabdebaaaa#aaa#############aaaaaa#ab####a##ba#####aaaaaaaaaaaaaaaaaaaaaaaaaabcdfebbbabbbcc",
-"ecabbaaaaababcdcccbbbcdbaaaabbaa#aaaa##aabcbbbaabaaabbaabaaa#aa###aaaaaabecbaa#a#a#aaaaaaaaaa#aaaaaaaaaaaabbcbaa###aaaaabaaaaaaa#a####aaa#aabaaaaaabbbbbbdcbbabbbcbbaaaaa####aaa#aa###aaabcccccbaabbba##a####aa#####aaaabaaaaa##ahlkfa#aaaaaaa##fbbecaaaabccbcdddceghecbbccccbbbccddbbabaa#ccedddddccbbaaacfbaa#a##a############a##aaaaaaaaa##a###ca#aa###aaaaaaaaabaaaacabbaaabbbbddea###aaaabc",
-"abbcbbbbaaaabbccbbbbaaaa#a#aaaabcaaaaaa#aabbbbaabaaccbbabaaaaaaaaaaaabbabdcbaaaaa###aaaaaaaa#aaaaaabbbaabbbabaa#aaaaaa#aaacbbaaa##aa##aaaaabcbaaaaabacbccccabaabaacbcbaaa####aaaaa####aaaabdccdba#abbaaa#######a######aaaaaba#####dljfa#aaaaaaa#ddaadcbccbbbbccccdccehihfddccccccbbdfaaaabbbceefedddcbbbbaaaecaaaaa##a###a####a##a##aaaaaa####a###ba#aa###aaaaaaaaabbbbacbbbbbaaacccdd#####aaaab",
-"babbbcccbbbaacdbccbbbaaaaa######aaaaaaaa##abbbbabaaabbaaaaaaaaaaaa##abbbdcccbaa#aa#####aa#aaaaaaaaaaabcbabbabaa##aaaaaab#accbaaaaa#aaaaaaabcddbaaaaabbbccccbaabbbbaabbbbaa###aaaaa#####a#abceeeaaa#aaaaba#######a#######aaaaaaa###.cgjgb#aaaaaaaafcaacdcdcbcbbcbbccdeefeeghfeccccbcddc#aabaaaeffeccccbbbbbaaacdcaaba##aa##a#aa#aaaa#aa###a####a####b#a##aaaaaaaaaaaaabbbbcababbbbcdddeb#a#####aa",
-"bacbbcddcbbbbacddccbabbaaaaaa#a##aaaaaa####aabbaaaaaaabaaaaabaaaaaaaaabbcccbbabaaaaa#a#aaaaaaaaaaaaaaaabbccbbba##aaa#aaaaaabbbaaaa#aaa##abbaabbcbaabbcccccbbbbbabbbabbbbaa#############aaabbcedbaaaaaa#aaa######a########a#aaaa##a##adhjc#aaaaaaacdb##bddcbbbbaabbccefgecceffgfcbceccedabbaaacffdccbbbbbbbbbaabccbbaaa#aa####a###aaaaa#a##bb##a###ab##a###aaaaaaaaaaabaaabbbcbcbbbcefeb#####aa#a",
-"aaccbcddcbbabcbcddcbbbcbaaaaaaaa#aaaabaa##a#aaaa##aaaaaaaaaaaaaa#aaaaaaaaabbccaaaaaaa#aaabbaaaaaaaaaa##aabccccbaa#aaaa#abaaaaaaaaaaaaaabbbbaabbaccbddedcbbbbbabbbcbcbbcaaaa############a#aacbcba##aaaaaa#aaa#a###########a###aaaaa####adid#aaaaa##eca##addcbbaaaabbcddefddefddgiedccccffbaaaaaefeccbbbbbbbbbaabacdbbba####aa#a##a##aaaaaaccbba###.aa#aa#ba#a#aa#aaaaabbabcbccbcbcccegc######ba#a",
-"abcbbccdedcbbbabdddcbabbbbbaa##aa#aaabaa######aaaaaaaaaaaaaaa#aa#######aa#aabcbbaaaaaaaaabcaaa###abaaa#aaabcbcb#aa##aa#abbaaaaaaaabbcaaaaaabbgecbbbbccbbbbbabcabbcbbbbaaaaa##############aaabaaaa#aaba#######a###########ba#aaa#aaa###aabffcaaaaaabeb####cdcbaaaaaaabbccdeffeeegihfddddffcaaaabefeccaabbbbbbbaaaabdba#aa####aaaaa###aaaacccbbba#######aaaa#aa#a##aabbbbbbbccccccccddgf#aa##a#aaa",
-"aabcdddddddbbbccabcdccbaaaaaa#####bbaaaa#######aaaaaaa###a#####a#########aaaacbbbaaaa#accdddba#a#aaaaaaaaabbbcbaaaaa#aaaabaaaaabba#bdaaaaabeecbbcbcbccbbbbabbbbbbbabbbbaa#aa####a########aaaaacaabaabaa#######aa########abbbbaa##aaaa###aaegfb#aa##dcaaaabddbaaa##a##aaabcdfgffgiggfffedefea#aabffccbaaabbaaabaaaaacbaaaaaaa####a##aaaaaabbabaaa##aa##aaaaa######aabcbaabbccccbbddedeeaaaaa#baaa",
-"aabbdeedeedddaccbbbcbcccbaaaaaabbaccaaa#a#aa###aa#aaaa#########aa#a#####a##babbbbbcbbcfdccccbbaabaaaaabaabbbccbbaaaaaaaaaabaaaaaaaaacfcaaabcbbaaababbcaabbbabbbbbaaacbabaaa####a##.########a#abd##baaaaaa##.###aa#######abbadb#a#########aaeiib####bca#aabadcba########aabccdgghgfeddddeedegdaaabdedbbaaabbabbaaaaa#cbaaaaaaaa#a##a#aaa#abbbbaaa#aa##aaaaaaa#####aaabaabbbbccbbbcdecef######acaa",
-"baabcccddedddbacccbccdcbbbbaa####aa##aaa###a###aaaa#a#####aaaa#a#aaa###aaaaabbbbbabcgjfdccbbbaaaaaaaaaaaabbacccba###aaaaaaab##aaaabbbdfdbaabdecbbbabaabbbbbbbbbbbbababbaaaaaa######.########a#acdb#aaaaaaa######aa######abbccb####aa######afiifa###bca#aaaabcbba#a######aaabcdeefcbcedccccceffaaaaacdbaaabbbaabbabaaabcbbaaaaaaaaa##a#a##abbaaaa#ba##aaa###a####aaaaaaaaaaccbbbcccdeff.######aaa",
-"a#aabbbcdeddcccbcccccdcbbabaaaa##a###aa#a#a#####aa##a###a##aaa####aa#a#a#aaabbaabbbbbffdccbbbabbaaaabbbbbabcbbbaaa##aaaaaaaaa###aabcbbcdfdaacebbbbbaaabbbbbbbbbaaaaabbabaaaa###aa############abcdcaaaabbaaa######aa#####abbbdc#############adghf###cdaa##aaaabbaa##.##.##aaabcdecedbbcdecbbbccebaabacdaaaaabbbbbbbaaaaabdcbaaabaaaaa##aa#aaabaaa#bcaaaaaa###aa#a#a#aaaaaaaaababccdceec##########",
-"###bbbbcdeddddcccccbccbccbbbaaa#####.#a##aa######a##aaaa###aaaaa##a###aaaaaabbbbbbbccddcdcbbbbbcdbbbadecccccbcb###a###aaaabaaaa###accbbccfhcacbbbabbabbbbbbbbaaabbbaabbbaa####aa#########.####aabcbaaaabbaaaa#####a#####aabacfb###############dhhc.ddb###a###bbca#.#....##aaabcdccecbbccedbbcccedbabbdcbaaaaaaaabaaabaaaacccaabaaaaaaaaaaa#abaaabbcaaaaaa###########aaaaaaababbbceeda.#####a###a",
-"#baaabbcdeddddddddbbcccbcbbbbaaaa################aaababba####aaaaaa###aaaaaaabbaabbdecbccccccbbbccccbcbbbcbbddeeca###aaaabccaaaaaa##abbbbcdedbbabbaaaaabbbbbbbbaaaaaaabbaa#######aaa##########aabbbaaabbaabaaa########aaaaaabdfb####aa#########cghhceba###a##aabaa#.....###aaabcdceebbbbbddcbccbcdcabcedbbaaaaaaaabaaaaaa#cddbbbaaaaaaaaaaaaaaaaccbaaaaaba#a#a######a##a#aaaaaaccdeed####aa####a",
-"aaabaabccceeddeedcabbbcbbcbbbbbbaaaaa#########a##aaaaabbcbaa#aa#aaaaa#aaaaaaaaaaabbcddcbbbbbbbbbbbbbabbbbbbaabbdgfba#aaaaabbaaa##aaaaaabbbcceedaaaaabbabbbabbbbbbaaaaaabba#######aba#########a##abbcaabcbaabbba########aabbaabddca#aaaaa#########adjhaaa#aa#####aaa#...####aaabbcccfdabbbbbddcccbbccacffccbaaaaaaaaababaaa##bccccbabaaaaaa#aaaaabdcaabbaaaaa#########a#a#aaa###bcddhga####aa####",
-"##aabbbbcdffeddeebdcbbbbbcbbcbcbaaaaaa##.##aa######aabbbbaaaa#aaaaaaa##aaabb#aaaaacddfbcbabbccbccbbbaabbaaba#abadfdbbaaaabcaaaaaaaaabbbababbceedaaaabbabbbbbbbbbbaaaaaaaaa##.#####aa#########aaa#aacdabbbaaaaaaaa#######bbbbccdcddbaabbaaa####aa###bhgea#######.##aaa#####aaaababbbcebababbabdeccbbbceffeecbaaaaaaaaabaaaaaaa#bcccbbbbaaaaaaababbbbbaaaabaaa#######a##a#aa#aaaaabddhg###########",
-"#a#aaabcdddffdddeeedbbbbbcbbbbcbbbaabaaa#a##a##aacaaaaaaaaaa#a##aaaaacdaaaabaaaa#accdeaaaaabbbbccbbbbaaaaabbbababcdddcccbbaaaa#aaaabbbaaaaaabdeeeaaaaaababbbbbbaaaaaaaaaaaa###a####ba####a####aaaaaabecaa######aaa#####a#ababccccbcbabaaaaaaa###a####dijdb########a#a###aa##a#abbbbddbaaaaabbabdddcfeffffeccbbaaaaa#aaaaaaaaaa#abccbcabaaaaaaaabbaaababaaaaa#aaaa###aaa#aaaaaaaaabchga#####aaa##",
-"#a#a###abccdddefdeeecbbbbbbaabbbbbbbbba#########abaa#aaaaaaa##a#aaaaaccbaaabbabbcbbccfbcaaaababbbbbaaaaaaaaaaaabbbabbabaabaaa#aaaaaabbabaaa#abcdfea#aaaabbbbaaaaaaaaaaaaaaaa#######bba##########aaaabcedbb#######aa#####a##abdcbbccbaaaaaa#aaaaa#aa###bgjjga#######aba#aadba##aabbbccbaaaaabbaaabedffeffffdcbbaaaaaaaaaaaaaaaa#aaaccbbbaaaaaaaaaaaababbbaaaa#aaa#####aaaaaaaaaaabbbghc#####aaaaa",
-"a##a#aa#aabccbdfgeefeccababbbaabaabbbaa#a##.######aaaaaaabba##aa##abbbcbcbbccacbbdedgheccbbabbaaaaaaaaabbaaaaaaaaaaaaaaaaaacbbba#ababbbbaaaaaaabdeeca#aabcbaaaaaaaa#aaabaaaaa####.##ba###########aaabbceeba########a#########cbbbabbbaaa#aa#aaaaaaaaa###djkjb#b#..#abbcaaabcba##aaabbcaaa#aaaaabaacfffffedffccbaaaaaaaaaaaaaaaaaaaabcbbaaaaaa##aaaaabaaabaa#aaaaaaa#a#a#a#aaaabbbbccgc######aaa#",
-"##aaaaaa##aaccbaeihfgggcbabbbaaaaacbbceceeca########aaaaaabaaaaaaaabbbdcccdebbcbbabacedecbbbabaa#aaaaaabbbbaaaaaaaaaa#aaaaa#abbbbacbbbbbbaaaaaaaccddbbbbbbbaaaaaaaaa##aaa#a##a#####aa#############aaabbceeea########a########aaaaaaaabbaa###a###aaa######agjkhgfb.#aabddaaaaaaa###aabdb##b###aaaaa#cffffeeeeeccbaaaaa#aaaaaaaaaaaaaabcbaaaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaabbbbbdfeba####aaa#",
-"#a#aaaaa###aacca#cjjhhjebcbaa##a##acegebdcbdb#.#cbcaaaaaaaaaaaaaaaaaabbcdgiecbbaaabbbcbcdcbbbbbaaaa#aabaabcbaaaaa#aa#aa#aaa###aaaaaa####a###aaaabcddbcbbbaaaaaaa#aaaa#aaaaa##a#####baa#.#######a##aabbcdddffa##.####aa##.####aaaaaaaaaabaaa###########a####chhiihc..ceffbabaaabaaaaabccaacc###aaccbbegfffededdccbaa#a#aaaaaaaaaaaaaaaabcbbaaaaaaaaaaaaabaaaaaaaaaaaaaaaaaaaaaaabcccefeaaa###aa#a",
-"aaa#abaaaa##aaba##eiiikhccbddefeeffgecccdccdeffefddc#aaaba#aaabaabbaaaabcdhfbbbbaaacdecbbaabbbcbbbbaaaabbbbbbaaaaaa#######a###aaa#aaaaa######aaaaaccbcbaaaaaaa####aa##aaaaa#####a##############a##aaabcccccdfb##.#####a######aaa#aaaaaaaaaaa##########aaa##.#aejjifb#cffacbbbaaa#acbbcc##ddda##cddeefgfffeedddcabbaa#aaaaaaaaaaaaaaaaaaacbbaaaaaaabbabbbcaabaaaabbabbbbabbbbbbbbbbbdfc####a##aa#",
-"#aaa#a#a##a####b###dgkkjgccfiifdfdeeccddddcdcccccbca#aa##aa#aaaaabbbaababeggdbaaaaadfcbbbbbbcccbabcbaaaaabcabbbcbaaaaaa##########a#a########aa##a#accbbaaa#########aa###aaaa###aaa####.#########b##aabcbbcddfb###############aaaa###abbaaba#aaa#########aa#####djjjifbcebccdcba#bbacbcb##addccdcdeeefgfffeecbccbbbaaaaaaaa#aaaaaaaaaaaaaabbaaaaaaabaabbbbbaabababbbbbbbbbccccbbbbcced####a###aa#",
-"a##aaaaaaaaa#a#ba..#agkgfecfikgddcccdcccbcccbcbcbbdba##bccaaa#bbccccbaabbefffcaaaabdfbbbbbbbbccaaabaaaaaaabcbbbabbbbaaaa#######aaa############aa###abbaaa####a############a####a#######.#####a##aaa####aaaacfa#######..######aaaa###a#cdcbbbabcbaa#aab#########.chiiihfcddeghhgdccdabdaa#addcddceefeeffeeeedbbcccbbaaaaa#aaaaaaaaaaaaaaaaabbbbaaaaaaabaabbaaaababbbbbbbcccdccdcbbceea####aa###aa",
-"a####aaaabaaabbab#.#aaeecdhfijfcccddcccbbbbccbbbccaaa###.a#abccccbcbcbbbbbff#a###abcebabbbbccbcaabbaaaaabccbbbbbbbbbbbaaa#aa####aa##############aaaa#ababaa##############a#a######a####################aabbcacaaab#####.#.##abbaa###aaabcacbcaaaaaaa#aa#########.bgihiifcdgijjjiidaaabe#a#bdcbccccddddddecdecbbbccbbaaaaa##aabbaaaaaaaaaaabbbbbabbbaaaabbbbbaaabbbbbbbccdddedddefeffa####a#####a",
-"#######aaaaaaaaaa#.#abcdaahkkjgbbcccbbbbbcbbcbbbbaaaa#a######abddedccccbbacffcbb##acccacdcabbdccdbabaaaa#abbbbbaabbbbcba###a############.##.###########ababaa##################a##a###.################aaabcbcdbbbaa##.#.#.#aabaa###abcdcaabaa####aa#aabbb###a###.#bgjhacegijjjjjjhedfgea##cbbbccbbbcccccdcccbbbccaabaaaaaaaaaaaaaaaaaaaaaabcbabaaabaaabbbbbaababbbbbbccddddedffceedb######aa###",
-"aaa#a####a##aaa##a.##acda#cejjfdbbbbbabcbaabbcbbaa#aaa##a#a###baecbdfedddefhhgefea#cedbafecbbcbecbbccbbbbabbbbbbbccabbcdcaa####################.#######aaaaca##########################.########a######aaaaccccbbca#a########aaaa####bedcaabaa##aaaabaaabc########..#figefhikjihhhhiijiihd##bbcdbcccbcccddebcbbbbcdbaaaaaaaaaaaaaaaa#aaaaaabbcbbbbbbbabbbbbbbabbbbbccddedeedffa###a#####aaaaaaa#",
-"###aa############a#.##bccbbbbehhaabbbaaabbabbcbaba#aaa#######becdda#fgecddeehghegdabdecaabedbcaacbbddbbbbbbcbbbbbbdbaaccccba#########a################aaaaabcaba###############################a#####.###aaaabccbcb##a######aab##a###accbca#b#####aaaaaaaaa###.####...diihiiihfgeffeffhijid##ddcdccccccddddccbbaabddcaaaaaaabaaaaaaaaaaaaaaabbcbbabbababbbbbbbabbcbccdddedefc.##########aa#aaaa#",
-"#aaaaa#aaa##a######.#abbccaaaabgfb#ababa#aaaacbaaaaabbbab####edeefeccgedcddehhfacebadecaaaabcccbbbbcbabbbbbcbbcbccccccabccdb#######abb###a##############aaaacbccba##########a######.########a###a#########aabcceccb###a#####aaaa##aaaaacbb##ac######aaaaa##aaa#######..diihffffffdeddddefiigaaeddddbbcdddccdccbaaabcedbbbaababaaaaaaaaaaaaaaaabdcbaabbababbbbbbbbbbbbcceeegc.#############aaaaaa",
-"aabcbbaaaaaaaa########bbcdbaaaaaffa#aaaaa#aaabbaaaabcdeddabaefcdddefcgfddddeghcccffddbaaabbbbbccbccdbcbabbbbbbcbbbbbdcabbbddb########bca#a#######a##a###aaaaaaabdbaa#aaa####aca##...###aa####a##a########aaabbbdecc##aaa############aa#abba##a#########aa#aaaaa########.bgiedcccdccccccccdhigdeeeeedcdddccbcebaaaaaaceebbbbbbbababaaaaaaaaaaaabcccccfedcbbbbbbbbbbbbabcfffe############a###aaaaa",
-"a#aaedbbbbaaa#a#######abddca#aaaadcaa##aa####aabababbbccccfggcbcccccfgeccccdddffedfecddcbbbbccbbccdcddbbbbbbcbbbaabbcc#abaacba########aa##..#######aa####aaaaa###bbaaa#aaaaa#cc###a.####aa##aaa#########aaabbbbadcdaaabba##########a#aa#bbaa##a#######a#aa#aaaaaa#######.ageccbbbbbbbbbbbcbehigffeedddddccbcccbbaaa#accdcbbbbbbaaaaaaaaaaaaaabbcbccdbaadfdcbbbbbbbcbcefccba#################aaa#",
-"#aaacbaabbcbbbaa#######abcca##aaabbcba########abbaaabaabccdcbabbbccbcedccccccccccccedbbcdbbbccbcbbcbcbbbbbbbbbbabbbbcccbbaaaaaa##a####a#aa####.#####aa##a#aaaaa##abbcaaaabbbabcaaa#.#.###aa#a##a########aaabccabbddbaabaa####.##.aaaaaa##bba##############aaaa##a########.#bddbbbbbbbbbaaaaabfhhgfeedddccbccbdabaaabbbccddcbbbbbbaaaaaaaaaaabacbbcceb#a#babcbbbbbbcbce##.####################aa#",
-"aaaaaa#aaaababba#######abcccb#a#aaacddb######aaaaa#aaaaabbbbbbbcbbbbcdcbcbccbccccddbababcccccccccbbbbaaabbbbccbdcbbbbabcbbaa######aa#aaa############aa#####aaaaa#acbabaa#baabbcb#a##.#####baaa#########aaaabcdcccccbaaaa##########abaaa###aa##############a####aaa########.##dcbbbbbbbaaaaaaaabghgffedccccccbbcabbaaabbcbdedbbbbbbaaaaaaaaaabaaabccdecbcabbbcbbbbbcbeea###aa####################",
-"aaaaaaaaaaaaaa##########acceeba###bbbcda#######a####aaaaabbbabbabbbbbcccccccccbcbbcdcbaabbcbcccccbbbbbcabbbbddegebbbbbbbcaaaaa#########a######aba#####aa#####abaaaabcbb#aa##abaaba#####a##aaaaa######aaaaaaacccccbccaa##a#######aa#aabaa##aaa####aa########a#aaaaaa###########addcbbbaaaaaaaaaa#fieeeddcccbbbbbaaabaabbaaabdedcccbaaaabaaaaabbaabbbcdebaaccbbdddcbbcdc#aaaa###########.########b",
-"aaaaa#aaa#aa#############abcdfdaaaabcdf###aaaa##a#####aaaaabbccabbaaaabbbcccccbcbabbccbbbbbbbbbbbccbbcccbbbcdcdedecabbbbaaaaaaa########abb##aa#aaabaa#aba###a#aa#aabcccbabb###aa#aaa######aa##aa######aaaaaaaccccdaba###########aaa#aaba#aaaa#aa##a########aca##aaa######a######cffaaaaaaaaaaaaa#ehfeeedcbbbbbbcbaabbbbbbbaadeeefedcbaabbabbccbabbdcbcaabdcccccceedffb##aa####################a#",
-"aaaaa###aaaaaa#####.####aabccfgbaabbcfeda##aaabaaaaaa#aaaaaaaccbccbaaabcccbbccbbbbbbcbbbbbbbcbbbbbcabcccbababccdeccbabbbbaaaaa#aa########aaaaaaaabedaa##a#aaabaaaaabaccbaaaca###aaaaaa#####a###aa###a##aaa#aaaccbbabaa############aaaaaaaaaaaaa#########a##acdaabaaaa############acecaaaaaaaaaaaaafhffeddcbbabbcbbabbbbbbbbaabbdeddfeddbabbbdcabbabbababbbcbcbccddffcdaaaa##a###################",
-"aa#a#####aa#aaaa#########abcdcfeaaacbdccfcbbbdddbbbbbaaaaa#aaaabcbaabbbcccbbbcbbcccccccccbbcbcccbbbbbcccbbabbacddedcaabbabaaaaa##aa########cb##aa#cfdaa##aaababbbbaaaabbbbaabaaa#abaaa#####a#bbaaaa##a##aaaaaabbccdaaaaa#####bb#####aa##aaaaaaaa############aabbbbaaaa##aa##########deaaa###aaaaabcgiggddccccccccabbbbbabbaba#aabcaacccccbbcdbaacbbabbbbabcbcdddd####abaa#a##a#a#aa############a",
-"aaa#####aa#a#aaaaaaa######abccdfa#bbcddbcccdcdaaccdecbbbbbbbaabccbaaabbcccbbbccbccccddccccccddccbbbbbbcccbbbbbcccdddbabbbabaaaa########.####bba##a#aca###aaaaaaaaaaaaaabbbaabaabaaabba#######ababba.##aaaaaaaaabcdcb#aaaa#####a##########aaaaaa#a####aaaa##.##abbba#aab#aba#aa#a#####cgeaa####aa#aabfiigdccccbccccbbbbaabbbbaaaaaabccbbccccdabcbccaaaaabbbccdebdbaaaaaaaaa#a######aaaaa#########",
-"#aa#a###aaa####aa##a#####aabbbbeb#abbceeba#a####aaaba##cdbbbcccdccbbbbbbccbbabcbbbcbcddccccccddddddccdcabbbcbccbbbddcbbbbbbbaaaa#########.####aaa####a#a#aaaaaaaaaaaaaabbbbaaabaaaaaaba####a#.a##ab##.a##a##aaaabbddb##aa#####aa######.##aaaaaa#aa####a#aaa###abbb###acaacaaaa##a#####bff###a##aaa#aacghhfccbcbcbbcbbbbbbbcaaaabababbdccccddbbccccaaaaaabbccee##aaaabbacaaaa######aaa#aaaaaaa###",
-"#aaa##########aaaaa########bbbbbea#babcea#a######aaa####bccddcddedcccccccccbcbccbbbcbcddddcccbbbcccdefedcbaacbbcbbbbbbbbababaaaa############.###aa#a##aaa#aaaaaacbba##abbcbaaa#aaa#aa#########a#######a##aa#a#abbcbcc#a############aa####aaaaaaaaaa#######aa###aabaa##bbaaaa#a##aa######dea#####aaaaaa#behhdccbccacbbbbbbbcbbbaabbabbbcdcccdddbbbba#aaaaabbddb#######bcaaaaaa######aaaabbbaaaaaa",
-"aa#aa##########aaa########aabbbbbedbaabddcb#aaaa#aaaa####cccaacdeeggecccccccbbabbbbbbbbccddcccbbbbcbcddeedcbaaabbabbbbcbbbabaaaa###########.#####aba#######aaaaaabbba#aabbbbaa###aa##a#####.#a#.#.####aa##aa#aaabccbca#aa#..########a######aaa##aaa#########aaa#aaaaaabcaaaa##a##a###a#a#bdb#aaaaaaaaaaabcfhfccccabbcbbbbcbcbbbaabaabbabcddcdcccbba##a#a#abddb########aaaaa#aaa####aaaaaaaabbaaa",
-"aaa#aa##########aa#a#a#######abbabgebaabacca#ba#aaabaa#########a##bdeddeedddcbbbbbbbcbabacdddcccccbbbcdcdcdcabbbbbbababbbccbabaa###############aaabb####aa##aaaaabbbaaaa#abbbaa###aaaa###a###a##....###a##aa##aaabbbca##aa#.#######aaa##aa######aaa#########abaabaaaaaacbaaaaaa##a###a##a#afb##a##aabbbaaaaeggecebcbbbabbbcbbabaabbbbbbabbdddccccccabaaaaaaccc#####a#aaaa#a#####aaaaaaabbbaaabaa",
-"aaaaa############aa#a########.#abbcffcabbceccaaaaaaaaa###a###aa#######aaeebccccccbbbbcbbccbdddccccccbbbccbbbbbbbcbbabbbbbccbbbbaaa########.#aaa#a##aba#aa##aaabbbabbbaaa###abaaa#########aa##a############aa###aabcc#aa#aaa#######.##aaba#aaaaaa##aaaaa######baaaaaaa#aaaaaaaaaa###aaaaaa###ebaaaaaaaaaaaaabbfhgedbbbbbcbbbbbbabbbbbbbabbbbddecbcbbbbbbcbbbceaa#####aabca#a#a#a##a#aaaaaabbbbbaa",
-"aaaaaaa####aaaa#aa###########..#aabdddbbcccccaaaaaaaaaa##a##aaa###aa#####eddedddcddccbccbccccbbcbbcedbbcccccbbbbbbbbababbbcbbcbaaaaa############a#a#aa#aaaaabbaabaabaaa#aaa#abaaa#######aaaa#a###########.#aab##aacc#aa####a######..##aa#aaabbaaa##aaaaaaabbaabaccbaa###aaaaaaaaaa##aaaaa##a#ccbaaaaaa###aaaadgggfeababbcbcbcbbaabbbbaaabbbccddbcbbbbbcdccccca#a#a###aaaaaaaaaaaa#aaaaaaababccba",
-"aaabaaa#a#######a#aaa####aa###.###bcdcbcbabddbaacbbababaa#a##aaaa#aa#aacdccbddddddbbbbbaa#aaa######bfggfdcccbabbbbabaaabcbccabbaaaa#########a#aaaaa#######aabaaabbabbaa####aaaabaaa##aa##aaa#b####.#########abb#aaee##a###.##.##.###..####abccccbaaaaaaaaabcdaabbccba##a#aa#aaaaa#a#aa#aaaaaaaabebaaaaa#a##aabbfghhgedaaabbbccababcccbbbaabccbcccbbcbbcdcdcaaa########aaaaaaaaaaa#aaaaaaababbccb",
-"abaaaaaaaaaa######aaa########aa####bbccbbaabceaa#cbbbbbba#a##aaaa#aa###debacb#aacabaa##aa###########.#afhgeecbccbbbabaacbcccbbbbbbaa#a#########aa#aaaa####aaaaaabbbbbbbaa###aaabbba###a##aaa###.#######ba##aaadbaabeaa##aa#..###.##########abaaabdbaaababababbaabddbaa##aaaaaaaaaaa#aaaaaaaaaaa#aecaaaaa#aa#aaabdghhhfecccbcbbabbacccccbbbbbcbbbbbcbabbdcbcba########aaabaaaa##a###aaaaaaaaaabbb",
-"baaabbaaaaaaaaaaaa###########aaa####acccbaaaabcbcabbbbbbba#####aaaba#acbcaa#aaaa#abaa############.#####.dhihgeefccbbbbaabccbbbbbbaaaa##########a#aa#aa####aaa#aabaabcbbaa####a#aaaa###a#aaa################abbeebbbdd##a#######..####.######aaaaabcbbbbbbbbbbb#abcccbaaa#aaa#aaaaaa###aaabaaaaaaa#bcbaaaaaaaaaaaabehhhfedaaabaaabbccccbabbbbccbbabccbbbdcbbaaa#######a#aabaaaaa#aabaaaaaaaaaaabb",
-"bbaaaaaaaaaaaaaaaaaaa#########a#a####bbcbaaaaabeecbbaaabbaba###a#aaa##cedb#aaabaaaaa##a#########.##.###a#bfgedeffdccccbaaacdccccbbaa###########aaa######aaba###aabaabbbaaaa#####aa#a##abbaa####.##.####aaa#acbddddfega#a#######.######.##a#aaaa#aaaaaaaabccddebaba#bcba##aaaaaaaaab#aaaaabbbcaabaaaaccaaaaaaaabaabbehhfgebaaaaaaacdcccaabbcbbcbbbbbcdcbbcaaa#a######aa#abbaaaaaa#abbaaaaa#aaaaab",
-"bbbaaaaabbbaaabaa#aaaa###.#######a####abb#aa#a#cfecaabbaaaba#######aaa#bddcdaaabaaaa#a#aa######.########ba.a####bfddcccbbacdccccccaa############aaa######adb###aaaaaaabaaaaaa###aaaa##abaaa#####..#####aaaaabbcdeedfgd#aa########.#######a##aa#aaaa#a###a#abeedecc##aaba#aaaaaaaa#bbaaaaabbbbaaaaaaaaaccbaabaaababbadgggfdb#aaaaaabcbbbbbbccccdcaabbcdcccbaaa#######aaaaaaaa##aa###aaaaaaaaaaaba",
-"bbbbaa#aaaabaaaaaaaaaba#a######.#######abbbca##acdedcaabca#a#.###a######bddcfcaabaaa##a##a#####...##aa####a####a#abbccddcbbddedccccbaa####a######aaa#####acb###aaaaaaaaaaaaaa###########aaa####.####a##aaaaacdeceeeedc##aa########..#########aaaaa##a###aaaaaabcdedcb##aa#aaaaaaaaacbaaaaabbbbaaaaaaaaadfdaabaaaabbbbcdggfebaaaaaaacccbbbbbbccdcccbbbdcecba#####a####abbaaa#######a#aaabbaabaabb",
-"bbaacbabaabaaaabbaaabbaabb#.####.#######abbcba#aabecdbaccaa#a#.##aa##a###acacecbaaaaaa##########..######..abaa#aa####aceeddceggeddccbaa##########a#aaaa##aaa##a##aaaaaaaaaaaaa#########aaa####a#aaa####aaaabbdffffgebca#ab#######.#..#aa######aa###aa####aaaa#baabbdcc##b##aaaaaaaaabaaaaaabbbbaaaaaaaabcegcabaababbbbabgfgfdaaaaaabbabbbabbbcdddbcbccccdbaaa#a##a###aaaaaaa#########abbbbccbaab",
-"baaabbaaababaabbaaaaaaaaaaa##############abbaa##aadd##abbaaaa#.##aaa##a####aabcbaaa#aaa###a######..####.#..cdcbbbaa###abdcdedfghffddcbba###########aaaaaaaaaaaaaaaaaaaaaaa#aaaa########a#aaa#####aaa#a#aabbccddghhhfcca#aa##########...##########aa#aa###aaa##aaaa#a#bb####aaaaba#a#aaaaaaaabbcbbaaabaaabbefdabaabbbbbbbbfgggfdcaaaaabbbbbbbccdbdbcbcccbcbba##aaaaaa###aa#aaaa########bbabbbbaaa",
-"aa#a#aaaaaaaaaaaaaaaaaabbabaa#######.#.####aaaaaaabdeb#aababaa####aaa#abba#####aaaaa###a##bdba##a######....acdbabbaaaa#####cddaeggffedcba##########aaaa###aaa#abaaaababaaaaaaaaa##a###abaaaa###.#bbaaaaabdcddeefhhifdda#bb#aa##aa######..########ab##a###a##a#aaaa#abaabaaa#aaaaaaaaaaaa#aaaababbbbaaaaaaabcffbbbabaabbbaacefggdba#aabbbbcbacddccecbbbcccbba##aaaaaaaaaaa#a##a#a#######aaaabaa#a",
-"ba###aaaaa#cbaaaaa#abababa#a################aabbbbbbbea#aaabbaa#####a##adc##aaaaaaba##a####a########.#####...aca###########.####cffdcdecaaa#######aaabaa##aaaaaaa#aaabbbaaaaaabaaaba##babba######accbbbbbfccdeegdgfggeb#dc#####aaa#####...#######aaaa#aa##a#aaabaaa#bbaaaaa##aaaaaaaaaaaaaaabaabbbbbaaaaababbegdbbaaababbaabffffecb#aabbbbcbbcdddecbaabcbaaba#aaaaaaaaaaaaa###a########a#abbaabc",
-"a#######a###aa#abaaaabbccba###.##############abcbcbbcbea#aaaaaaa#######.##ba#a#aa#a#a#a##a####.###########..###ba##############a#aeedbadfcdddcbb##aaaaaaa#aa#aaaa#aaccbbbaabbbbbabcbbcdccb######abcdbddeeefddddb#afdcfebdca#####aaa######.#####aaca####abaa#aa#abcb#accaaaa##aa#aabbaaaaaaaaaaaabbbaaaaaaabbbbbgdbaaabbbbaaaccffgfdcaabbccccccddddfcbaaaaaaaaa#aaabbaaaaaa#a#aab####aa##aaa#bcc#",
-"aa###########aa#aaaaabbabbaaaa##..###########abdcccccbcdcaaaaaa#a##########aabb#abaa##########...#.########.######################.bfdaaccefddddbaaaaaaaaaaaaaa#aaababcccbbbbbccbbcddcabca####aaacdcabeggfdda.##.#cc#aefdbaaa###aaa###.##.####aaaaa#a###abd##a###ababbdc#aa#aaaaaaaabaaaaaaaaaaabbcbbaaaaaaabbbbgfbaaabbbbaabbbcefffddbabbcdccccedcabaaaaaaaaaaaaaaaaaaaaaaaaaaa#####aaa#aaaaaaa",
-"aaaa##########a######.#a#abbaa##########a####abdedcccccccba##########a######aaaa#abaaaaa#######..################aa#aa###############ddabedcgededbbbaabbabaaaaaaaaaaabbccccccbccdddba###abacbbcccba####aaaaaaaa##.###acfcaaa##aa#a############aa#####a#a##aea#aaa#aabbcda##aaa#aa#aaaaaaabaaaaaaababcbaaaaaaaabbbgfbabbbabaabcdcbdefffdbbcccccccdda#aaaaaaa##abaabbaaaaaaaabbbaaaa####a##aaaabaa",
-"aaaaabaa#######a###a##.###abbaa###############acdeccbbccdga##########a######.#aabaaaaaaaaa#a############.###aa###aaaaa###############.cdbbdefhhhfdccccbbbaaabaaaabbbbbccccdddcdccdb#####bbcbcddba####aa####a#a#####.##aedaaaa###aaa#######..#########a###a#bbbbbaaabbbbaba#aaaaaaa#aa#aaaabbaaababbabccbaaaabaabbbggdabbbbcbbbddcbcbdffdcaccccacccd#aaaaaaaaaa#abbbaaaaaaaabbabbabaa#aa####aabaa",
-"aaaa#aaa##########a###.##aaaaaaa####.##aa#####abccdcaabccffa##########a###aa####aabaaabaa#aaa####a######..###a#####aaa############aa###bdddeeddfgfeeeddcabaaabbbbbbbbbbcdddddeeeecaa####abbaaaa#######a#a########.###aaadaaaa#####aa########.#..##.##a######aaabbba#bbca##a###aaaaaaaaaaaabbaaaabbbaabddcaaaaaaaaabfgdaaabbbabdacdbcbdfffdbbdccbc#cbaa##aaaaaaa#aaaaaababaaaa#abbaaaaa#aaaaaaa#a",
-"###a#aaaaaaa######accbaaab#####aaaa####a#######accccabacccfe##.############aa####aa###aaa#aa####.#########.##########a############abca##bfcfabbbcaafffffdbbbbbbbbbabbcccdeeedefcaaaaaa##aaaaaaaa################a#.###abbcaa#aa#aaaaa#######....########aa####a#abba#bbbbaaaaaaaaaaaaaaaaaaabcabbbbbbabeedaaaaaaaaacfgecaabbabbacdbabcffffccccdda##aaaaaaaaababaaaaaaabaaaaaaaaaabaabaa##abb####",
-"a########aaa#######cddebba########aaaaaa#######abccccbabcdefea#.########aaaaabb##aaa#####aaa##.....#.##.##############a#####.#####aabcbaabfc######.afggggcbbbcbcccbbbccceeeeffhgccbaaa#aaabbaa#a######aaa########a#.##aacdba##ab#aabb##.#.####...########aa#####aaaaaaaabbaaaaaaaaaaaaaaaaaaccbabbbbbbabefdaaaaaaaaabeffabaaababdedabbcfffecccddaaaaaaaaababaaaa#aaaabbbaaaaaaaabbaaa#aa##ba###b",
-"#####aa#####aaaabbaaaacdb.#a#########aaa########abcbbbbbcdeeeefc.######aaaabaacbaaaaa##########..#..#....##############a###########abbbba#bd#a######aabbcfedccdddccccdddeeeeefgiedeebaaaaaabaaaa#aaaaa#aaaa###########aabcca##aabaaabba#....#....##.###.#aaa#######a#abaabbaaaaaaaaaaaaaaaaaaddbbbabaabbbddaaaaaaaa##adfecbbbbacddedbbccdffdccddaaa#aaa#bbaabca##a#aaabbaaaaaaaaaaaabb#aaaa###a#",
-"####aaba######aa#abbaaaba###aa#############.####aabcabcbbdegfebc.########abbbaaaaaaaaaa#########.....#.#.######.#######aa#####.#.##aaabbbbbc##a#######..##ehfeeeedddcedeffeeeeehf#abcecccbabbbbbaabaaaaaaaa########a###aacdba#aaaabaaaaa#..##..##.#..####aaa##a####aa#aaaabaaaaaaaaaaa#aaaaaabeeccbababbbbbaaaaaaaaaaaabcffbbbbcdccdcbbbcdfgfedcabaaaa##bbababa#####abbaaaaaaaaaaaaaaaa#aaaaaa##",
-"#a###aabaaaa###ba###ab##ba###a#############..###aaabcaabbdedefgb####aaa###aaaaaaaaabaaaa###########...#.############################aabbbadcaaa#####.######bfhhgggffffffffeeeefhhcaa##acfffeedddbaabaaaabaa########a####abebaaaa#a#a#aa############.###..#aa##a###aba##aaaaba#aaaaaaaaaaaaaaaaccdcdcbbbbabbbaaaaaaaaaaaaacfeaabbbbccdabccbdfffed#aaaaabaaaaaa#aa###aaaaabaaaaaaaaaaaaaaaaaaaaa##",
-"###aaa#aaaa#a##.a##a#aba#aa###########.#.#....####abcbbbbccdffegb...##aa###abaaaaaaaa#a#aa#######aaa###.####.#####################a##abbcfda#aaa###########.#acfhihhhijiiiihgfhhgcaaaa#..acccddccecccbaaabcb#######aa###abcdbaaaaa#aaa#aa##########.##########aa##aaa#aaaa########aaaaaabaaabbaaababaacbbabbbaaaaaabaaaaa#cefdabbbabbcbbbccdfggeb#aaaaaa###aaa#a###aabbaaaaaaaaa#aaaaaaaaaaaaaa#",
-"#aaaaaaaaaa##aaaaaaaa#aaaaaa##.###aa###.###...####aabdbbabbcfeced.#########aaaba#aaaaaa##ca#######aaaa######.########.########a#####aaabdhgfeaaaa#############.#aaba#addfghiiiiheb###aaaa###.####bdbcdcdcbbca##a##a##a##aabbdbaa####aaaaaaa#############a#.##aaaaaaaaa##aaa##a#a#acbaabbabbbaaaaaaaabbbbbaabbbaaaabaaaaa#a#bfgebaaababbbbbbbcggfeaaaaaaaaaaaaaaaa####aabaaaba###aaaabaaaaaaaaaaa",
-"a##ba#abaaaaaaaa####aa###bbaa##.#######b#####.#.###aacbbaabcdeccc##.########aabbba#a##aaa#bba######aaaaa#################.######aa##aabbfhhihdabaa##############aa######.##a#bgfb###aaaaaa########cbacccdfeecaa###aa##a#aaabcdbab##ababaaaaa##########aaa#####aaaaaaaa#a#aaba##aabfdaa#aaaaabbbabaaababdbbbbbbbbbbbbbaaaaaaa#dffcbaabbbbbbbbbcefgdba#abaaaaaaaaa#aa##abbbaaacba##a###aaaaaa##aaa",
-"aaaaaaaaaaaaaaaaaa#####a##aaaa########ab##.####..###aadccbbacdcaa###.######aabaaabb#aaaa###############aa#####a#####.##############aabbbehhhfcaaaa#####.########aaaa##aaa##a#.#caa####aa##########cdbbbbbcedefdcbbaa##aaaababbdbaaaaaaaaa#aba#########aa######aaaaaa#a#aa##aaa##addbbaaaaa#aaaaabaaaaaaccccdcbbabbbcbaabaaaaa#cfgdbabbbbabbbbbcfgedda#aaaaaaaaaab#a##aabbbaaaba#aa###a#aaaaaa#aa",
-"aaaaaabaaaaaaaa#accb#########babaa###aaa##.##a##.####abcbccabdeaaab#..######aaaaaaa#####################aaa####a#####.############aaaabdgihgcbaaa################aaaaaaaaa#aa###a######a##########dbaaaaaaaacbcefgfddcccddegdcbdbaabaaaaaaaaaaa######aaa####aaaaaaaaa#############aaaaaaaaaaaacaaaaaaaaabbbbdeccdccbbbbaabaaaaabefecbbbabbbbcbcegededcaabaaaabaaaaaa##aabbbaaaa#aa#aaa#bbaaaaa#a",
-"a##a#aaaaaa###aa#bbcbaa##aaa#aaaca##abb########a#####aacbbccbdeaaaba#########aaa##a#a####.################ba#########.##..######.bbabaaehhhgbaaaa#################aab#aabaa#aa###a##########a.###.ab#aa#abababbbcbcdcaacecccdefdc##abaaaaa##aa########aaba#aaa#a#aaaaba#a#aa#a##.##abaaaaaaaaabbabbaaaaaaaaaaccbbbcdbbbbaaabbbabbdgfdbbbabcbcccdddeeedcaaaaaaaabaaaaa##aabbaaaaa##aa####aaaaaaa#",
-"####aaaaaaa######abbcca##aaaaa##abbabba#a#####aaa######aabccedfaaaab#########aaa###.#######################b########.#ba#...##.#acbccccfgggebaaaa##a###############aababaaaa#a##a#a####a##a########c#aaaaaaaabbaaaaabccdebabbbdgeaaabbbaaaaa##a#######aaab##a##aaaaaabaaa###aaaa####ba#a##aaaaaabbaaaaabbaaaaacbbbcbbbcbbaaabbbbcbcfgecbcbbbccddccceddccaaaaaa#bbaaaaaaaaaaaa#aaa##a#aa#a#aa####",
-"##a###aaaaa#######aaaaaaaaaaaaa#aabbcaaaaa#a###aa########aabeeea###aaa#######aabb#####a######.#######aa##.######aaaabedccbbb##bbbbaabbbbccdeaa##a##a########aaa#####aabbbba#a#aaa#a####a###########caba###ababbbaabbabcdcddcbabehcaaaaaaaaaa############ab##aaaaaaaaaaaaaa#baaaaa###bb#a##aaaabbbbbaaaaabbbaabbbbcccbabbbaaaabbccccbfffcccbccccbccccddeedaab#aaaabaaabaaabaaa###aaa###bb##a#####",
-"aaaa##aaaaa#aa#######a#abbaaaab######aaaaa#aaaa#aa#######aabdefb#aaa#bc#######abcb#####a#################aa#a..###aabcdfffggfdcbbbbbaaaaaabdeaaa###########aaaa#####aabbbbbaaa#aaa#####aa#a##.#####aaaaaa##abaabcbbbaaabaabbbbcdefaaaabaaaaaa##a######aaa######aaaaa#aaaaaa##aaaa###aa#aaabbbabbaabbaaaaaaaabbbbbacccbaaaaaabbccdccdefegffdccecbccccdeeddcbaaaaaaabbbcbaaabaaaaaa#######aa######",
-"#aaaa##aaaa#############abaaaaaba##aaaaaaaabaaaaaba#####a##abdgca#aaadeb########bba#####aa#aaaaaa###aaa#ab#aa#.###.#acfhfddgccbaa#aaaaaa#abcfaaaa#######aaabbaaa#####aaaaaaaaa#aaaaa#aaaa##########aaaa#aa##aaa#acccabaaba#a###acdbaaaaaaaaaaa###a##.##aaaa###a###aaaaaaaaa###aaaa#abb#aaaabbbbbbbabaaaaaaaaaacbbbccbbbbaabaaacccccdfdbdfgeefcddabccbcedddccbbaaaaaabbbababbaa#aaaa#a##ab##a####",
-"##aaaa#############aa#####abaaabda##abaaaababbaaaaba####aa#abbdeaaaaaadf###############a#aaabbbbba#aa#aaaa#baba.#accbffffgddcbbaa#####aa##acfeabaaaaa###aabcdcbba######aaaaaaaaaaaaaaa#aaa##########dbaa########bbdcaab#abaaa##abceaaaa#a#aaaaaa#a###.######a#####aabaabb#aa#####a#bcbaaaaa#aaaabbbbbaaaaaaaaaaccccbccabacaaaabceeeeggdcdfffccccca#bbcbddeccccca#abbbbbbbaaabaaa#a#aaaaab#######",
-"##aaaa####.##########baaa##aaaaabda#aaaabbaaccbaaaa#####aaaaabbcbbaaabdgfe###aaa#######a##aaabbabbb#a#a#aabdceeedcabcaeddcfhecdb#########aacdhcbccbbbbbbbbdehhedba##aaaabbbbbaaaaaabbaaaaaaa########cba#######a#abbda#aabcbaa##aabceaaa######aaa##aa########aaa##aaaaaa#aaa###.###aabaaa#aaa#aa##abbbaa#baaaaaaabbbbbbdbbabaaaacaddacbbbbddccccbbda#cbbcdcddeccccbaabbbbca#aabaaaaaaaaaaaaa#####",
-"#aa###a####.##########aa#a##aaabaccaba#aabbaccbaaaaaaaaaaaaaabbccabaabeffeebbcb#.####.#aaabbaabbccccccccdddcec.#aaaaaaadccbbcccca.#######aabdhecdddeeeddeefecbbeedcaaaaabbbbbbabbbbcbbaaaaaaaaaba##aba####a####aacdccaa#ccbbaa##aabcdaa########a##aa########aaaa##aaaaa##aaa#########aaa##aa#aba#aabbbaaaaaa#aaaaaabaaaccbaaaaabccababbbb###bcbcbbecabbccdcddcdcccaaababbbbaaaaaaaa#aaaaaaaaa###",
-"#aa#aa##########a######a#####aaaaabc#abaaaabbcbbaa#a##aa#baaabbbbbabbcfffgghebdcbbacacbbbbbbbcbccdccfdaaabdedcaaabaaaaacccbbbbbbcb########abcfgedeffeeeegfcbbcbadgdddaabbbbbbbbbbcccccbbaabababbbaacbaa#########abcccbabccbbbaa##aabcb#a#######aa######a#a##abbbbabaa###a#aa########.bbaaa#aaaaaa#aaabbbccbaaaaabbbbbbbaaaaaaaaabbbccccaaa###bcdbabcbbbabcdddcbddccbbaaaabcccabaaaa#aabaaaaaaba#",
-"#aaaaa#######a####a###aa##.###aaaaabc#abaaabbcbba###aa####a#aaabbbaabcdcdeccdecccccba##aaabbaaaaaa##beaaabacfdeaabdecb#bdcbbbbbbaca#######abcdegeeeeffgfdabbccddeehhhfdbbbddeeccdcccdccbbbbbbcccbcca##a###a########aa#.aceccbbaa#aa#acb###.#####aa#####aba###abcdcbcbaaaaaaa#####a###bc#abaaaa#aaa#ababbbbccbaaaaabbcccbcbaaaaaabccdacccb#a###abddbbbbbbabbcebcbbdcccbbaabbabcabaaaaabcbaaaa#aaa",
-"aaaaaaaaaaa####aa#####aaaaa.###a#aaaccaaabaabccaa##aa#######aaaaaaaaadc##abaaaaa###a#######a#########cb#aaaacdddb#bbdda#becbbbbbbac#######abceffhffffda##babcccdeeddbddeecdcdebdeeccdddeddcccdeba#b###aa##a#########a###bedbbbbaa#a##aca###.#####aa####aaa####bbcdddbaaaaaaaaa#######adbbabaaa##aaaaaaacbabbccbaabaabbccccaaabbcbdcbcecccaa#a#a#adcabbbbbcbbcbccaabccdcbbbbcacbaabbaabcbaaaabaab",
-"bdbaaaabbaaaa#aa##a#aba#############abcaabababcba##aa#########aaaaaaabdb##aaaaaa###a##################b####aaccdeaabcbbaaeddbabbbabb#######bdfhghhgda###aabbcccecbbbdcccefdbbcbcb#eefgghggfeegdaa##a###aa#######aaa#####bedcabbaa#####acb##########a##aaaa####acbccccaaabaabbbba####a##dbba#aaaaa##aaaabdababbccbabaabbcddcbacbbccdacdbba#####aaaabcbbbbbbbccbbababbcddcbabbbabaaabcaaabaaacabaa",
-"aacdbaa##.##a##aa#aa#aba###.#########abca##aabbbca#..###########aaa##aab######aaaa#########aaa#a###aa#######aaccdfbabbaaaeeddbbcbbbdbaa#abcdfhjigca######abccbadb###cfbcbbecabbba#begfhggddcggdbbaaa##############a#aa#.cddccbaaaa#####ab##########aaaaaba####accbbbbaaabaabbbabb#######aba###aaa#aa#aaabcaaaaabccbabbcccdedcbdbbacdcdccaa##a#aaaaabcbbbbbacccbaaaabaccccbaaaaaaaabbbbaaaaababba",
-"aababbaa#####a##a##a###a####.##########aba###abbbbba####.#.#######a###aab######aa#a#########aaa#####aaaaa#####bbceebbbba#ceedccedcegdcbcddedbcbed#######aabccdbdda##adeeb##abbaaaaacbadeddfdghdcbbbaaa###########abbbcdbbdcbbca##aa#####bd###.#.###aaaaaaaba##abbbbbbbaaaaaaaabbaaa#######aa###aaa#aaaaaabcaabb##abcbbaabcedccdcbaaccccba####a#aaababcbaaaabbccbbaaababccbaa##aa##aaabaaaaaaabaa",
-"aabaaaaa#a#####a###aa##########..######aaba####aaaabb#.###############aaab##.###a#a#######aaaaaaaaa#a#aa###a##aacdceddfgfcfffgdccdeeefggdbaabbbbdcaa###aaabbcddeb##a#adfeaaaaaaaaa#bbaaccbeedhecbabbaaa#########.adccbcdbdbbcbba#######a#cda########abbaaaba##abbacbbaabaaaaabaaaaaa########aba##aaaaaaaaabcaaa#a##abca#aaabdefecbaadbbbaa##aa#aaaaaabdcbaaaaabcbaa#aaaabbbaaaaaaaaaaaaaaaaaaaaa",
-"aaabbaaa#########a##aaa###########.##.##aaaa#####aa#cba################abcb.####aaaaaa##aaaabbabaabbbaaa##aaaaaccgghggecdfihhg#a####a#a#abbccccacdcabbbbbacccdfeba#####aaaaaaa###a#ababbccadcgedccbaaa############ccbabccbcacabaa#####a#bacd###.####aaaaaaa###aaabbccaaaaaabbabbaaaa###.##..#bbb###aaaa#aaaaaaa########a#aabccceecbbdbbbbaa#aaaaaabbaadccbaabaabba#####aaaabaabaaa##aaba#aaa#aaa",
-"aaaa#aa##############bba##########..#.############aaaaaa#####.##########abca..####abaaaaabbbcccbbccddbbabbbbbcdefebdfd##a#.bedaa#########aabbbcbcddddcbbbcdeffd#########aaaaaaaa#aa#baaabcbacegedbbaaa##########bcdbaabbcccbbbaaaaa#####abbcca####.##aaa####aaabbcccdbaaaaaaabaaaaaaaa####.###abba##aaaa#aa##a############aaaa##cfebdcabcb###a##aaaabbabacbaaaaaba#a####aaa#aaaaaaa####aaaaaaaaa",
-"abbaaaa####a##########aa###################aaa####abaa#a################aabc#.#####aaaabbbcdddcdfffefgffeddfgdcdcb####aaaa###bb#######a##aabacdcddbdccacdefecc#a##a#####aaaaaaaaaa##aaaaabbbabfgdcbaa########aaacbbbbabbbbcdaba##a#####a#abccda####aaaaa#aaa#abaaaccbbbaaaababbaa##aaa#########bbba##abaa#####aa#a##aaa#a###aaa##defdcabbbaa##aa#aaaabbbaaccaaaaab######aaba#aaaaab####abaaaaaaa",
-"aaabaaa#################abba###############aaaaa##aaaaa#a###############aacaca.#####aabbbbccddfda#adeca#####b###aa#aa#aaaa##aaba#a####aa#aabccdccedebaacccb####aaaa###a###abaaabaaaaa#aaaaaababdgdbb##########cabbdbbbaaaaaccaaaaaaa##aaa##acdc#.#aaaaa##a##aabaa#ccaaabaabbaaacbb##abaa######..abca##aaaa#####aa#aaaaaa######abaabdggcaaa#aaaaaaaaaaacba##bbaaaabba#aa#aaaaa##aaaba###aa#aaaaa#",
-"#########.#################aaaa#.#.##aaa###aaa##aaa##a##aa###############abbbba#.##.#aabbbbcefc####...#####aa#####aa###aa####aa#######a#aaacbacbbdddbbccdfecbcc###aa####aa#aaaaaa###aaaaaaa##aaacfdaaa#####aaaabbabbbbaaabbabbaaa###aaaaaaa#abce..##ababc####aaaaabdaabbbbbbaaabbbaaa#a##.#######abaa#aaaba##aaaaa#a##aaa###aaa##ababehcaaaa##aaaaaaaadc####abaaaaaba###aaaaaaa###aaaaa#aaa#####",
-"####a######################aab#....##aacaaa#aabbaaaaa#####a##############aabbbcb##.###abbcceca###################aaaaaa#a#aa##a#aaaaaabaabbbbbacaaabbabaafddcbcb###aaa#aab##aaaa######a#######a##cfeaaa#####abcbbbbaaaaaabbabba###aaaaa#aaaabaaee#.##ddaaa####aaaaacaaabdcbbbbaabaaba#aa##.#######aaaa#aaabaaaaaaa##aaa#a##a#aaaaaaabbcgebbba#aaaaabaabbaba###aaaaabbaaaaaaaa#aaa##aa#a##baa#a##",
-"####a##aa##################aabda#.#####bcaa#abaabaaaaaa###################aaabcdb.####bbbdea##########.###########aaaaa##aaaaa##aaabbbbcbccbbaaaaaaaabbbaaaacdcbbbaaaaaaaabaa#aaa################abecaa####aadcabcaaaaaaabbaab#####aab#aaaaabaaade#..#ca.#a####abcbbb#abbccaaabbbabbbb#a############aa#aaaaaaaaaacaa##aaa##a#aaaaaacabccfebbbbaaaaabbbbaaba####ababacbaaabaaaa##a#aaaaaa##aaa###",
-"#####aaaa###.#a######a#######aab##..####abbbbbbbbaaa#aaa####aaaaa##########aabddea.###abda#################a#########a#####aaa###aaabbcdcbdbbaaaaaaaaabbbaaaaacddcbaaaa###abaa######..############abeda###ababbbccbaa#aaaaaabaa##a###ab#aa#aaaaaacec##ab.########babbaaaabbababababbcda###############a#aa###aaabcbbaaaaa###aaaa#ababbcdcdecaabaaababbaaa#######aaabbbbaaaaaabaaaa######a#aaaaa#",
-"a#######aa#a######aa#a#aaa###aaac#########abddccbbaaaaaaa####aa#aa########.abehghhc##abca##aaa##################################a#aabccb#aabaaaaaabbbaaaaaabaaabbbdba#aa###aaa##################aa#abefccaabbbcbabbaaaa#aaaaaaaa#aa###abaa##aaaabbcfdaba.#a######bacc##aaaabaababaabcbca##.#####a#####a#aaa#####aaaaab##aa##aaaa#aaaabccebbffbaaaaaabcaa###a#####bbbbbbbaaaaabaa#aa######aa#aa#a",
-"#baa#aaaaa###a#a#aaaaaaa####b#aaba#########aacbdcccaaa##a###aaa#aa##########bbfikjicacc###aa#aaaa#############a###################aaabccca##aaaaaabbaaaaabbbbaa#aabcbbaa####a#################a#aabaabdfbdcccbbbbbbbbaaaaaaaabbaaaaa#a#aaa#aaaaaabbcfdbb#######a#aaac##a#ababaaaabbcdaaaa##########a#aaaa#a#aa##a#aaaaaa#aaaaaaaaaaabbccdcaaegcbaaaaacaa#####a####bbbbbbbaaaabba##a###aaaaaa####",
-"####aa#aaaa##a#aaaaaaaaa##a#####aba##########aadcbbba####a####a#aa##########abcdfhiigc#a##aaaaaaaa#aa#####################a#######aadccccaba##aa#abaaaabbbcaabaaba#aaaaaa####a###a#a###.#####acbbcbaabcehfdccccbbbbbbbaaaaaaabaaaaaabaaaa###a#aaaabbcddca####.#####aa##aaacbabbbbaabcba#bc############aaa##aa##aaaaa#baaaaaa#aaaaaaaabccdeba#cgfbaaabca#a###aa#a###bcbbbbbbaabbba##b###aaaa#a###",
-"###a#aaaaa#aa######aaaaaaaa######aaaa#######a##aaaa####.###aaaaa#a###########abacdhiiga##abbaaaaaaaa##############a########a##a##abbcabc#abbaaaaaaaaaaaaaacaaabaa###a###aa###a###aaa########bbbbcbbbbddceihebbcbbbbbabbaaaaaaaa#aaaaaab#a#####aaaabbcccfb#.########aa##abaaaaaaabbaaaabbcbc#####a######ba##aaa###aa###aa##abbaa#aaaabbbdcccbbabdhebcbaaaaa####a#####accbbbbcbaacba#aa###a#aaa###",
-"#a####a#aaaaa#aaaaaaaaaaaaaa#######aba#######a####ab########aaaa##a#a##.#..#####aehhjihb#abacba#aaaaaa############a#a########aa#aabdcc####abaa##a##aaaaaa#ababa#a##aaaa#######a#aaaaaaaa##aacaabcccbcbabbcghgdbbabbbccba##aaaaaaaaaaaabaaa####aaaabcbcdccaa#########.##aaaaaaaaabababbabaa#######a#a##abbba#a######a###aa#aaaaaabbaabbcdbbbbabbadffbbaaaaaa#a##a####aabcbbbccabbabaaaba##baaaa##",
-"##aa###a#aaa#a##aaabbaaaaaaaaa##aa###a#############bba#.###aa#aaaaaa#######.####adfehjif###aaaaaaaabbaaa#a########aaa###a######abbbbcca.###a###########a###aa###a#############aaabbbbbaaceb#aaabbbccbaaabbbdggdcbbabbbbaa###aaaaaaaaaaba#aa#a###aabbbbcdc#####aa#######aaaabbbaaabbbbbbba#aa#######a##aabbaa#######aa###aa#aaaaaabbbbbccaaccbbbccdfgedaaaaaaaaaaaa##aaaccbcccbbccba##aa##abaaa##",
-"########a#aaaaa#aaaaaaaaaaaaa#aa#ba###########a####aaaaa#.##aaaaaaa##a#a########bbceeijfc####bbababaaaaaaa#########aa##a#aaaaabbadcccba####.############aaa#aa#############a##abbabbbaa##ceaaa#aaaabbbaaaaabbdgfbbbbbabba####aaaaaa#aaaaa#####a#aabbbccdccca#aaaa######aaaaababbaaabcabba##ba##a##a#aaaaaaaaa#######a#a##aaaaaaaabbbcccaabbddcaabbabdffdbbbaaa#aa####aabbccbbcbbddbaaa####acbaa#",
-"#######aa#a#aabbaaaaabaaaaaaaaaa##aa#a#############abaaaa####abb###aaa#a########babcfhiiea###acbbabbaaaaaaaaa####aaba#aaaaa#aaabaccbcbaa###############aaaa###a##############aabaaaaaa####bbbabaaaabbbbaaaabbbcffbbbbbbbbaa##aa##a###aaaa####aa##aabccefcadda##aaaabb#aaaaaaaaaabbbbbbbba##abb######aaaabbba###############aa#aabbcccbabbaabdccccaabacfggccbaaaaaa##a#aabccbbcaabdbacba####bbaaa",
-"aaa####aaaaaaaaaaaaababaaaaaaaaaaa#aa##############abbbbaaaaa##bbbaaaaaaa######ab#bccehiic###abcaabbbaaaa#aaaaaaaa#aaaaaaaaabcbccacba########.##########aa###############a#aaa#aa#a##a#####acbddcbaaabbbbbaaaabbefcbbbabaaaaaaaa######aaa###aa#####abcdghedcbbbbbcccdcbbaaaaaaaabbbbbbabaa#.acca#a###aaaaaaa########a##a###aaabbcdcaaaaaabbaccddaaaaacaadggfdbaaaaa#aaaaaabccbbaacbaababaaaabbaa",
-"aaa#a#####aaaaaabaaaabbbaaa#aaaaaaa###aa#######.#a###abbbaabbbbaaaaaaaaaaaa####a##ababchie###aabbbaaaaaa#aaaaa#aaaaaaaaaaaabccccbccb####a#############aa######.###########aa###aa#aaaa#a###abcccdbbbbaaaabbaaaabbceebbaabbaaaaa#########aaa##aa#####acdfdefebcddcbbdffdcbaabbaabbbbbcdbbaaa##abca#####aaaa#a##a#aa####a#a##aabbdedaaaaaa#aaccbeda#aabbaaaacefgfdbaaaa#aaaaabcccbccabaaabbaaaacc#",
-"##a##aa###aaabbbaaaaabcbaaa#aaaaaaa#a##########a#####aabbaaabaabaaaaaabcccca########aaacfhc##aaabccba#aaaaaabbaaa##abbababbcccbeecba#####a########a####a#a#####.##########b######a##a##aa###aababaaabbaaaaabaaaaaabdfcababbaaaa##############.#######bddcbdeffcbbba##dihdcbaaaaacaabbbdcaaabaa#aba#####aaa######aa##a###aa#abcdccdb#aa###aaaccdcbaaaaaaabbaaabehhebaaaaaaabaccbcbbbaaaaaaaaaaacb",
-"a##aa#####aaaabbbaaaaaababaaa#abaaa#############.###aaaabcaabaaaabbbbacdedaaaa######a##bccdccaaaaaacdcaaababbbaababbbccbcbbcdcceedc####a##a###########a#aaa######..####.####.###aa######abbaaaabaaaaaaaaaaaaaaaaaaaacfeedbbaa############.######aaaa#abbaaaaccbabaaa###igdccbbbaaaaaaabcbabcbcb##a######a####a#aaaaa####aaaacb#abdcaaa#a###a#acddcbaabaaaaaaaaadfhhedaaabbabbcccbbaaaaaaaaaaaaaa",
-"ba##a##a#aaaaa#aaabaaaaaaacaabcbaaaa#aa#########.#########aaaaaa##ababdefcab#aa########aabdfgbaaaaaacdcaaabaaaaabbbbabbcbbbcccddaaaa####aa#aa########a#aa#########..##.##..###.###aaba###aaaaa#abaaaaaaa#aa#aaaaaa#aaaegdcbbbaa###########.######aaa##aaaaab#abaaaaaa#.febaaabcccbcbbcbbaaadbcecbaa#####a#aaaaa###aaa#aaaaabaaaabccaaaaaa#aa###adbbbcbbaaaabaaaabbchifbabcccabbccaacbaaa##a#aaba",
-"#ba########a###aaaaaaa#a#aaa#abaaaaabaa##a#aa###############aab####aaaaabccaaa##a#.#####abcdfb#aaaaaaaaabaabbbcbbbbbababbcdddfedcb#a##aaa#aaaaa###aaaa##aaa##.######.###.###########a#########aaaabbaaaaaaa###aaa##a###bfedcbbaaa############a####a######a#aaabcbbbaaa#gdaaa###bcddcecccca#addefgfddca###a##aaaaaaa##aabaacb####bbdcaaaaaa#aa###ccbbbccbaaaaaaaaabaadhieabaabbccdcbabbaa#####aaa",
-"#aab####aa###aaaaaaaaaaaaaaaa#aaaaaaa#####aaa#a##.############aa#abaaaaaaabaaaaa########abccdfcaaaaaaabbbaa#abbcbbaacabbbbcddecdcc####aaa#aaaaa#aaaaaaa##aaaa###..######.#####a########aaa#a####aaaaa#aaaaa########aa####dedbbbaaa##############a###a#####ababccbaaaaa#gcaaaa####bdebbbbbca#bddcbaabccaa##a##aa#aaaaaaabbaca####abdbaaaaaaaaaa#a#ccbbbbbbbaaabbaabba#adhgcbaccccccdccba######aaa",
-"a##aa#a###aaaaaaaaaaaaaaaaaaaaaaaaa#aa###aaaaa###.#############a##abababbaaaaaba######aaabbcddhcaaab##baaababaabaaabbabbbbcdddffeeb###aaabcaaaaaaaa###aaa#aa####.######a#######b#####aaacb#######ababaa#aaa##aa########a#aaeecbbbaa##################a##a##bbaabb#aaaa#cd#aaaaaaaace.aaa#bdccdcaaabcacbaba###aaaaaaaabaabccaa#aaabbd#aaaaaaaaaaa#bcccbbbcbbaaaaaaabbaabbhidbbcccbdeddaaa#aa#aa#a",
-"aaaa#aaaa##aaaaaaaaaa#aaaaaaaaaaa######aa#aaa####..#########.###aaabbbcbbbaaaaaaba#####aabbcccegcbaaaaaaaacbaabbaaabaaaabcccdeeffddaaaaabcbbbcfffecdcba#abb#############aa#a##acbbcba#bbaa########aabba###a##########aa#aaa#eedccbaaa#####a#a###########aaa#aaa#bcaaaaaafaaaaaaaaacfa##a#aaaba#abaaccbcbbccbaaaaaaabbbbbbaaaa#a#abccc#aaaaabaaaaaadcbbbcbcabbbbaaaaabaaccfjgbccbcccccaa##aabaa#a",
-"#a#aa#aabbaa#aaaaaa##abaaaaaaaaa##aaabaa##aa#a###.#.##############aabbbcacbaca#aaca#####aabbccdeedbaabbaaaabbabababaaaabbccdddffedffb###bbccefebccbdeda#aaabbaaa#######aaaaa###aabcca#adaaa#####aba#aaaa##aa################.cedcbbbbaaaaaaaaa##a######aa####aa#bbaaaaaadc#aaaaaabbee####abaaa#aa##abaaabbabdcccdcbbaccbcb##aaaaabbcdbaaaaababaaaacbccbbccbaaabbbbaabababadjiedccccbbbaaaa#aa#a#",
-"aaaaa###aaaa##aaaaa####abaa#aaa#a###aaaa######aa#################a##abbbcccbbbaaabba##.#aabbbbddedd#aacb#aaaaaaaaaaaaabbbccdddggffghecbbaabbbddabaa#aaaabaaa#bbbaaaaa##a##aba###aaabb##bbaa####aaaa###########a########.#####aaeecbaabbaaaaaaaaaaaaaa###aaa##a##aa###aaabeabaaaaaabchca###a#aa#a###a##aa####bca#abdecbcdbaaba#aaabbdcaaaaaaaabbaaaaccbbbccdbabaaabbbabbbabacjkjgfdccbaaaabbaaa##",
-"#a#aaaa###caa#####aaadb#aaa#aaaa#aaa##aaa###aaaa#a####a##a######a#a##aabbbbabba##aabaa##aaaabacdececaaaba#aaaabaaaa#aaaaccdeeefgeeefbcbbbcbbbcbaaaaaaabaaaaaa##abba##a#####aaa###aaaa##.#ba##.###aa############.##.#############dedcbaabbaaaaaaabaa###a###aa##aa#aaaaaaa#dbbbbbbbaacgg#b####a####a##aaabaaabbcaa#abacdcaaaabaaaaabbccaaaaaaaabbbbcbabcacccccbabbaabbbabcbbaaejklhfcbcbbaaaa#aaaa",
-"####aaaaa##aaaaabaaaaabbaaa##aaaa###aabbaa###aa#aaaa###aa#######aa#a##bcccaaabbaa#acaa###aaaabbcdcdcbaabaaaaaabaa##aaaabbccdfffghffdaabbaabccddbabaaaaaaaaaaaaaaaaa##a#######a####aaa###.aba######a#################a############bfedbaabbbbbaaaaabaa##a#########abbbba##dcbabbbaaabcgdc#####aabaa###a#bbbbbbbbbbaaabbcbbabbbaaaabbbdebaabbbaabcbbbbacbabbabbbbabbbaababbbbbghillgcbbbbbaabbaaa#",
-"###aaaaaaccdcaaaaaaba##aaaaa##aabaabaaab########aaaba####a###a##aaaaaabccbba##bbba#bca###aaaaabdcddcda#abaaabaaaaccaaabbbccefgfghffaaaabbaaabefbcbaaaaaaaaaaaabaaaa##aa#########a########aaa###a##############.##.#.############a#abdebabcdcbbcbaabba############acdea#abecbaabbbaabbdfc##aaaa#a#aaa##abbbcaba#adebaecabbaccdcbbabbcbdddbabbbabccccbbacbbbbbabccbbbbbaaaabcbcfijjkjfddcbabdebaaa",
-"db#bdccbbcb##aabbbbaa###aaabbbbaccaaaabca####.#####baba##a#aaaaa#aba#accbbbbaaaaaaaacbaaaaaaaaacccdccc##abaabbaaabdbabbcccdffffhggbaaaaabdbaaaababbaaaaa#a#a#aaaaba#a#a################aabaaaaa###########.#####...#####.##.####aaaa#bedcccaaaaabbaaaaa##a#####aaaaddaabdebabbbbbabbbbgcaa#a#aaaa###aaabdaddabaadcfdfgdacbaabcbbbcccbdcdffdacdcedccbbbacbbbbcccccbbbbabacabbdgigbbgjjedcbbbccaaa",
-"#bbbaaaaaabaaabbbea#aaa#abbbbabaaaaaaaaba#############b####aaaaaabaa###abbbbbaaaaaaaacbaaaaaaabbcccccdd##cbcbcaaaaaaabcdeffgggiigabbbbbaabcaaaaaaaaaaaaaa#aaa##aaaaaaa################aaba###baaaa#######.#####....#########.#a##aa##a#adfca###abbaaaaaaa#####a####bdbacfdaaaaaabbaacedfa#aa#########abefeddcccdebccfggfedaaccbacddecdccdeddccefddcccccccabaabbabaabbaabacbbhijgdbacfkjeedcba#a#",
-"###aaaaa#abbaaaaaaa#a####bcaaaba###a#aaaa######a####aa######aaababaaaa##aabbaaaaaaaaabcaabbaaaaabcbccccbcbaaaaababbcccdefgfgghkgbaabbcbccbaaaaaabaaaaaaaa#aaaa#aaaaaaaaa####a########aaabba#aaaa#####a#.###.######.#####.####.##a#abaaa#aaddaaabbaaaaaaaa#########aabgggfbaaaaaabbbabbcfea#a#####aa##afghhfggghhgccddffhfffcccbccdfgeeeceec#aabcddcdddccebaaabaaabaaacbbbb#ejhjgbbceceikibbceba#",
-"aaa##a#aabbabbaaaaaaab####bc#aaaa#aaaaaa#ab##aaaa##a#aa######aa#baaaaaaaaaaaaaaaa#aaaaacbaabaaaabbcccccdbaaaabbbbccddeeefeegjheb#a#aabaccdcaaaaaaabbabaa#aa##aaaaaaaaaaaa#######a###aaaabba#abaa####..###.###.####..#####.#######aa##ba#####bcbaaabbaaaaaa########abdfggebabaaaaaabbbbbchfaaa######abbfegggefgghgffeecefggfhheecdddeeefdcefcabaabccbaabcbcbaaaaaaabbabbbbbbfghggdbcbcbbgkjfbbecb",
-"#aa#a###aababbbaaaaaaac###.acaaaba#aba####ac#aba###aaaaaaa#aa##a#a########aaaaa#aaaaabbbbbaabbaaabbbccccebaaaabbccddddedegggfhbaaa##aaabcccaaa#aaabbbbcbaaa#####aaaaaa#aaaaa#####a###aaaaaabbdaaa########...##.###..########.#####aa#aba###a#accbaaaaaaa#######aaaaabccdeeccbbaabaabbbbegfgeca#####adefffefgggfghggfeeccegihijigedbccfeceddfeaaabcacbbaaabbaaabaaaabbbbbcbchgghfgdabbaa#bgkjgcdd",
-"d#a#a####aaaabbbabaaaaaa####abaabaaaaaaa###acdbaa#a###aaaaaaaa###########aa#a####aaa#abbbbbaabaaaaaabcbccdaaaaabccddeefefhgefgbaaaaaaabaabbaa##ababbaaabcca#aa#aaaaaa##aabaaa####a####aacba#bcb#aa#.####.#...##.##..################a########a#adbaaaabaa#aa##aaaaabbbcdeddddcbabebbcbbffeefdec##adeeefeffefghgghghhgfedfheabfghhfdcegecbbbbccaaaabcaaaaaabaaabaabbbbabbcdfffgffffabbbbbcabgkjec",
-"cdaa##aa#aaababbbaabbaaaa####bbabcaaaaaaa##.acaaaaaaaa#aaaaa#ba###########aaa#a###aaaababbaabaaaaaaaabcccdgbbbccccddeffefgfeffbaa###a#aaaaaa#aaaaaaabbbccaaabaaaaa##a###aaabfd#####aaaabbaba#aa########.###.##.###############################bacedcbbbbabaaaaaaaaabcccccddedddbbdeecdefeededdeeffdegffeddefgfgggggcb##abbca###bbefeefeddcdcbeeaaaaab#a###babbbbbababcbccfgfeeefegcbaaabbca#afkh",
-"gdcbaaaaaabbbaaabaaabbbbaaa###bbcbaa#aaaa#####a###aaaaaa#aaa#aaaaa##a#####a#aa#aa#a#aaaabbaaacaaabaaaabccdfgddddddccdfhhffddfbaaa####aaaaaaa##a#aaaaaabbdb#aaaaba#a#######aacegdbaa#aaabaabbb########.#.##.##..#...####.#######################babedededcbaaaaaaaaabccddeedefecfffeeffddddddeddeeeddeggfddeeffbaaaaaaaabdb#baa#a##cbdfeaaabbcdfbaaaaa####a##abbbbaabbbbdcgfgeeedeefabba#aaaaaabg",
-"gjgccbaaaaabbbbbbbbaacbaaaaa###aaaaaaaaaaa####aaa#####aaa##aaa#a#a#######aaaaaa##aaaaaaaabba#acaacbaaa#acccfgdefefcdecfhhddbcaaa#a#####aaa#aa###aaaaaaabbeebaaaaaaa####.###aaacdcbaaaa#aaabba#############.#.#.#...###########..###############aacddeeededceeedccefggfgggfedggghfdfecdddccccddeeeeefddfffddddbabbbaaaaabefcdb#aa##aaabcaaaaa#bdgb#abaa#######ba#bbaabaaeegfgfeeeecfcaaa#aa#aaaa#",
-"#bgifcbaaabbbcbbbbaabbbaba#a#aa##aaaaaaaa######aaaa##a#aabaaaaaaaaabaaaba##aaba###aaaaaaaaabbabbabaa#a#abcceffeecb#cddeeggcdb##a##aa##aa#########aaaaaaa#bedaaaaaa##########abaa#aaaaaa#aaabaa#####a####################..######.#a##.#########aabcccbcda##afgggffdbbbabdhheghifedddeecbccdcdefffeeffdfggfdbaaaaa#aababbacdddb#bb#aaa#a####ababbdebbbaaa####a#babbaaacddfgffeefeeddcbabbaaaa#aaa",
-"a##ehiecbbbccdccbbbbaabbaaa#aaa##aabaaaaaaa####aaaa#####aaba#aabcbbbaabbba##abaaa######aa#abbacbaaaaaaaaabcccdfcaa##bbbbceabaa######aa##a##aa####aaaaaaaa#abaaaaaa###a######abbbaba##aaa#a####aaa###a############.########################a####aa#dcddcdb#a#dedeedcaa#baacgegiifedddddddcdddefeffggfgeedbba#aaaabbaabaaaaabceebbdaaaaa######aaaaabdddb#aaaaaabacbbbaabdfffgfgfeeeeddgcbaaaaa####",
-"#b##adiifdbcefedccccbaabaaaa#aaaaaaaaaaaaaaaa##abaa######aabbaabbcbbaaaaaaa#abaaa#######aaaaabcca#aaa##aaaabbccc#########a###aa##a###aa########aaa##aaa#aaa#aa#aba##a#######aabbabcaa#ababbca##aa####a#####a.#########################a###a##acba.ddeecccba#cfeeedcaaaaabccbaigfeeeddddcbcdcddfeffggeedaabaaaabaaabbabaaaaa##cffedeaa#a#aaa#aaaaaa#abfebabaaaaaacadcaaffecffffgfffeeggaaabaa####",
-"#caaa#.ahjgffefgggffecbbbabaaaaaaaa#aaaaaaaaababaa#aa#a#aaaabaaaacccaaaaaa#a#aaabaa######aaababaaaaaaaaa#aaaabccb####aaa##ab###aa#####a#a####.#aabaaaa########a##aba########acbbaaaaaaaaaabbbaaa################a###a####aa############aaccb#adcbbdddccbcdebdedccba#a#aabdcbaggeeddedcbbbccdeeffffhggfcbaaaabbbcaabaaaba####a#debceea#aaabaaaaaba#aaa#cfgcaa##aabcbcbdffedfeeeefefeedhcaaaa#a###",
-"####aa##.behhgfeeeddefedbbbbaaabaaaaabaaaaaaaabaaaa#aaaa#a#abbaaabbcbbaaaaaaaaaaaba####aa#aaabaaaa##a#aa#a#aaabbcc.##ab##aabca##aaaa############aabaaaaa#a#a#####aaa#bb#.####bccbaa##aaaa###aaaaa######a#######bbabba####bb###a#a###a###bcccccdcdccddcbbabcdcddccba####bdddb#bdcecdedcbbbbbcceeeeehhcdaaaababcbcaaaaabaaa#####ab#aabb###bb##abcaa###a##adfeba###aabaaefefffedddeedefefhbaaa###.#",
-"#####aaaa###chikjiigedcegcccbabbaaaaaabbaaaaabaa#aaa#a#a##aaaaaaaaabaa#aaaaaaabbbaa######aaaaabaaaaaa##aaba##aaabab.###aaaaaabaa#aa#a#############a###aaba########aa#cbb####abcbaaa##aaa#a######a#.####aa###bbccbbdccbaaabb###a#aaaaa###cbbbaccccbbcccaaaabbccccbbaaa#accdcb##bacgeeedccccbccdeeefggebdaaaaabbbbbbaaabaa#####a#a#aa#####aaaa##ca#####a####beeca#b#abadgefffedeedfdcffeff#a#a###.",
-"..######a#aaadd#acdhihecdgecbcaa#aa####ba#aaa##aa##aaa###aaaaaaa##ababaaa#aaaaabbbaa######aaaaaaaabaaaa##baa##a#a#b######aaaaaaaaa#################a#aa#bcb#####aba##a######bbbcbaabcaa#################a#abcdbdefededcbcbaa##aaa#a###bcbababbccbbbbbcaaaaabcccbaabaaaabcdbba###bhhfhgeddccbccddfhhhfbbaaaaaabbbccaaaabaa####aa#a#####b####aa#aa#ab###a##aaabefd#a#abbfgfeeeeeedeeddefggbaaa####",
-"##.######aaba#abaaaabeiiebceddcbaaaaa###aaba#########a##aaaaaaaa###aaaaaaaaabaabbbbaaa###aaaaabbbaaabbaaaaa###a###bb#####aa###########a######a#####aa#baaaba##abcedcbaa##a##bcccbaaaddccaa##############a##bbceffgfededdedcbaa#a#aaa#bcabaaabbbccbbbbbbaaaabbcbbbbaaaaabbcda#a##ehgfeeeeecddbcddfhhgcbbbbbbaaaabcbbbaaaaa###.#a#a#a####aaa###aa##a########aabbbedbacfegggfeeefeddccddgihdaaa####",
-"##.###a####aaaa#bacbaa#chidccdfdbbabaaa#ababaaa###a###aa#aaaaaaaaaba#aaaabccccbcccccabb###aabaabbbcbaabaa########aaab.####aaa##################a####b##aaaabb#aacdddcbb#######bccaaaabdbba#####aa#a#########abccccccddcffhigcbaaa#aa#acaabaabbbbaaabbbbbaaaabbbbaaaaaabcccdda#a#higheddefedeecdffffeeaaabbbbaaabcbaabaaaa#########a####aaaa######a#######aaabdcbadgfdeddegfgfeedcccccehigaaa####",
-"###########aa#####aacdb##ejgcbbfedcaaaaaacbabaa#####aaaa#aaaaaaaaaaa##abbbbbbaaabbcddddbccdcccbababaaaaaab#########aba..####aa###################aa########aa##aaaabbbba##a####ccaababdaa#aa#####aa##########aaaaabbccdfgjjihdcaa#aaaacbaabbababbaabbbabaabbbbbbbbbbbbbcccddebadhggfffeeffffeeeffdccddaaaabaaabbabbbbaaaa######..######aaaaaa#a###a#aaa###aaaccc#ceggedddcffffedcbabccdfgebaa###",
-"#########aabaaa####a#aabbachjgbacdedcccbabaaaaaaa#####aa#######aaaaaa#aaaaaaabaaaabbccdccddcbbbabaaaaaabbaa########aabb.#######a##################aaa##########aa##abaaaaa######bbaaaaba#a#a#.##.#a#aa###aa###aaaaaabcddgijijjigeba#abdcbbcdcabbbbaabbabaaabbbbaaabbbbbcacddee#dfeeeffeccdghhfffebccccaaaaababbbbaaabba#a########.###a##aaaa##aa##aaaaa####aababbddceggfedcdffedcbaabcdeeffaaaa#",
-"#######a#aaaaaa#a#####aaaabcdiibaaacecddcbaaaaaaaaaa##aaa########a#aa###aaaaaaaaaaaaabcccbbaaaaaaaaabaabbaaa######aaaaca.###.##a#a####a########aaaaaaa##...###a###a##a#aaaa#####bdaaaaaa########a########a##a##aaaaabbbbegfeedeghgeccddeeefgcbbaaaabbbbaaaabbbaababbbbcccbceeebegdddeffedbdeiihecbcbdbaabaaababcbbaaabaaa#a#.############aaaa##b#a##aaaaa##aabbbbccdceghgeddefedcaaaaccdedfaaaa#",
-"########bcaaaaa##########aaaa#gidaaabedcccbbbaabdbaa####aba#a#############aaaa###aaaaaaacbbaaaaabbabbbbbcbbabaa######aabb..##.####aa#aaa######aaaaaaa####a#.####aa##ba#aaaba#####dbaaaaa######aaa#aa######aa###aaa#aaabccebabaabbdfhhhgfghggdbaaabbcaaabbaaabaaaaaaabccccccedchigdcdddcedccabghdbaaabcaaabaaaaabbbbcbbaa##a########a##.#aaaaaaaaa#aaaaaaaca#acbbbbbcccdefeddeecdcbaababcfdfeaa##",
-"########baaaaba#aaaa#####a####aciib#aacdddbabbaabbb#aa#####aa#############aaaa##aaaabaaaabaa##aabababbbbccbbbcb#######aaaa#...##.#####aa########aaaaa######a############a#aaaab##abbaaaa#######cb############aa#aa#aaaaabaaa#######bfhigihhfbaabaaaaaabaaaabbaaaabaaaccbccdcchiihhdbcddcddccbbeeaaaabbbaaaababaabbbeeeaa#####.###.aaaa#aaaaaa#aaa#aaaaaa#bbadccbbbbccccbcddddcbcccbaaaaddddge###",
-"########a##abbaaa#########a#aaabcfjhaaabcdecaabaaaaaaa#######a########a#aa#abaa#####aaabaabaa##ba#abbccbaccaaca########abcb..######################aa###ceb#######aaa#####a#aaa###acaa#aa#######b############a#a##aaaaaabaa########abacfhhfcbbaaaabaaabaaaaccaaaaaaaacbcbbcffgfgcegeddeddcdccbcd#aaababbbaaababcaabaaccba########a#abaa##aaaa##aaaaaaaaaababcbbbaccbbcbccdddcbbbcbbcbbadcdeehd##",
-"########bb####aaba#########a####aabfjfbbcbcfdbabaaaaaaba######aa######aaaaaaaaa##a#####aaa######aaaabacbbaaabaa#########aadc...#######.##########aaaaaa#ddeb#a####aaaabeb######a###bbaaaa##b####aa#.##########a#a#a#aaaabaaa##b###.adbaabeecbaaaaaababaaaaabcabaaaabbbbbcdcfgeddgbbggeedddcccccc####aabaaaaabbaabaaa#acda############aaaaaa#aaabaaaaaaaaaabcbabbbabcbbbbcddccbcbbbabbbbccdfggf#a",
-"aaaa####bc##a#aaaaaaa###.#####.####aciiecccbceebaabbabbb######a#a####a##aaaaaaa########aaa#######aaabcbbabbaaaaa#########acfc..####.#.###.###aa###a#a#aaabcaaaa###aaaa##########a##bdcaaaa#ba###baa##########aaa####aaa#bbababdcbaacbbbaaaabbaaa##aaaaaaa#aabbbaaabbbbbbcdcccddcdec#adfedddcccbe#####aaaaaaaaaabbbaaa#bdb##.#######.####aaaaa###aaaaa##aaabccbbbaababbbbbcdccccbcbbbcbbbdcefghc#",
-"########a#####aa#bbaaaba######...####adhifegfddfdcabccbaa###aaaaaaa######aaaa##aa##a###b##########aa#aaaaaabaaa######a###abdfb..#######.##.#####aaa#a###baaa####aaa#########a####a#bddcbaaaa####aaaa####ad##aaaaaa#######abadddccccdcba##a#ababa###aaaaaaaaabaaabbbbbcbbcbbccdccbaba##afedddccbfa######a#aaaaaabbabaaaaab#####.##..#..a###aaaaa#aabbaaaaaabcccbbbabbbbbbbbddccbbcbbbcbbcfdeeffha",
-"##############aababaaaa##########.##.#..chjjhjifffdeccdbaa#aaa###aa#####.##aa#######.#######a#########aaaaaaaaaac########acchc.....#..###########aa##aa#abaaa##aba##a######aaaa##a##bdcbaaaa#####a#aa###bd###aaaa#aa##a####adgdcbbcddbb###aaa#a#####aaa##aaa##abbaabbbbcbbbcccddeccc#a#bhggfedaec##########aa#aaababaaaaaa#####.##.##.####aaaaaaaaaaaaaaaabdcbbbababbabbbabddcbbbbbbccbbdifdefge",
-"a###a##########abb#aaab#a#######...#####.##a#acgkigfeefdcaaa##aa#aaba####..######.#a###a#aa#aa##.#######aaaaaa##ba#####aaabbeha...###.###.#######a##aaa#aaa#a#aaaa###aa#a###aa###a###cdcaaa######a#####abb####aaaaa####a####deebbbccdbba##aaa#aa####aabaa#a#aabbbaaaaabcbcbbccbcedbba###cdffffeefba###########aaaaaabcaba#####.####.#######a#aaaaaaaaaaaaacdccabbababbabbaabcccbbbbbbbccdeeedefh",
-"f#######aa##a##aaa#aa#bba#########..############afkjgfgfeeeba#aaa##a#######.####.#.#####abbbaa##########aaaa##a#a#######abbcdhe#...######.##a####aa#a###aa#a#aaaaa######aaa###########bdbbaaa####a######aa##.##aaab####aabdecdcbaabbbaba##aaa#########abaaa##abbbaaaaabbbcdbaccbcebaa####adghfedeeba#############aaaaabbcb##########.######aa#aaaaaaa###bcdccbbabbbacbaabbbbbbdcccbbbbbcccccddeh",
-"hc#####aa######aa####aaaa#####a###.......##aa##a###gijhhhggeb##baaaa####...#####.#..a###acccaaa##########aa#####aaa####aacdddhf#..###.#..####aaaaaaaaaa###a#aa#aaaaa#####aabb##########cecaaa####a##############aabb##aabacddbcbbabbbaaaaaaaa##a#######baaaaa#abbaaa#abbbabcbbbcdgd####a##adcgfecdeb######a########aaaa#baaba########.######aaaaabbbbbbcbccbbbbbbbbbaaaaabbbbbbccbcbbbbcccccdeed",
-"egb##baaaaa####a##aa#aaa#a#######.#..###.###########adfilkhfca#abaaa#####..##....#....###bbccaa##a##aa####aaaaa##a##a##abbcfhjfb#..#####.######aaaaaaa######aa##a#abbbba###aba#aa#######cecaaaa###a#.#######aa##aa#aa###aaabcbcbbcbbaaabb##aaaaa#######abaaaaaabbaaa#abbbbbabbabdfeaaaa##a#ca#eecccfcaaaaaaaaa#a#a######aaaaabca########a####aaaabababbbbbbbbbbbbbbbaaaaaaabababccccbcccdccbdffd",
-"cfhd#acaaaa##a#######a#a##a###a##.....######.##########bddjkidca#########..###....######acaacbbb#a###ab##aaaaaaaaaaaaa#aabcfgejfa#.###a######a##aaaa#aaa#a###aa##a#abbcba#####aa####a###aeedbaaa##aa####...#aaaa#bcaccbaaaabcdccabcbbbaaca#aaaaa#########aaaaaaabaaaaabbbbbbbaaabbecbbcaaaaaa#adecccedcaaaaaaaaa##a###########abaa######a####aaaabdbbbbbbbaabbbbbabbaaaaaaaabbaabccbccbccdccdefg",
-"fedfea#a####a##a#a#######a####a#.##..#.####...########aaaaaeikhea#####################aaacbabbdfdbbaa#aaabbcbbaabaaaaaaabcdfbbeica..#a########aabaaaaaba#a###aa#######aaa#####aaa#.aa###adffdbaaa##ca####.#########abbcdeeeefcdcbabbbbbaacbbaaaaaa##a##a##baa##aa###aaaabbabbaabaadfb#bbbbbaa###feccbeecbbabaabaaaaaaa#aa###a####a########a##aaaaabbbbbbcbabbaaaaaabbbaaaaaaabbbabccccccddddeeee",
-"fggehdaaa######a##########aaaaa#.##.####..#..##.#######aabbaadjljgda.#################aaaccbccddcccccccccccccdcbbccbcbaabbcfdcbgf#...#aa######abcbaaaaabaaaaa############.##aa##a########dffedcbaa#cc##########a####bbbbcdffeedaaabbbbbcbabbaaaaaaa#######abaaaaaaaaaaaabbabbaa#a#bdcbbbaaaaa###cfeeehhecabbbbbbaaaaaa##aaa##a###a########aa#aaaa#bbcbbbabbbbaaaaabbbbbabaaaaaaaabbbbbcccddddeee",
-"edehhg#aaa######a#a#####a##abbaa###.###################aaabbcaacjllkhbaa#######a######bbaefddddcbbbaaaababefeedddccffdccdfgeeeefec#...#ab#.####abccbbba#aaaaaa###########..###a##########bfdfdccaaacfb.######aababaaaccccbdffebbbbcbbaacccbabbabaaaa######aaaaaaaaab#aaabaaaabaaaabbeffcaaaa####aeeeefiihfcabbbbbbabaaaaaaaa##a######aaaa####abbabbabcbaaaaccbbbbbbbbcbcaaaaaaaaaaaacbbcdddddede",
-"eefgghcaa#######a##aa######abbbcc#.############.###a#aaaaaaaaccbafjllkjecbaaaaaaaa##aabcccgefeecccbba#aaaa.acffffffcacdccbbbfffefda#.##########aabcedba##aa#a#####a#####..#####aa###.####bceecccbaabdfa##aabbbaabbbbdcbbccdcceebabbbaaabcdcbbbbbaaaa######a##aaaaaaacaaaaabbaba###acdeegcbbb#####aeffgfgijkgcbbbbbbbbabbaaaaa##a#aaa#abaaaa##aacdbabbccbaaa#bbbbaabaabccbaaaabbaaaaabbbccdeedddd",
-"deeffdfd#####a######a#######aaaca#a############bdca###aca##aaaceddfijjnligdcbbcbaaaaabcddchgedddbccaaa#aaaaa##accfbbbaa####bdhfedhd#.###########bbcccdba###aaa#####a##a#.#####a####.####.#abedebdcbbcfe#####adcbcddbbdbaaacbcbccbbbaaa#bbcbbbbbbaba#a############aaaaaaaaaabaaaaaaabdfcccbbba#####aceffgiijihedccbbbbbabbaaaaaaaaaaaaaaaaa#####aabaaabbbaaaaaabbaabbbbbcabaaaaaaaaabbbbcccdddddd",
-"ddddecbdca###a###a##baa#aa##abaaba#a###.#####.#aabaaa#aaa##aa#acdhilmklmlmkheegecbbbbccbcefgedcdcbbbbaaaaa#aba#a#cdabcbaaa#achihggfa############abdb#bcaa##aaa#########a###.######..########beddecbcdffc###.#acdfffdabcca#aabacbbbbbaa#abbbbbbbbbaa#############a#aaa#baaaaaba###aaadfd#babacababbbcegfhhiihgfdddcccbbbaabbaaaaaaaaaaba#aaa###a#aaaaaaaaaaaabbabbaabaaabcbbbaaaaaaababbccdddddcd",
-"deddddcacaba###a####aaaaaa#aaaa#aaa###aa#########a##aa#aaa##aba#.cfehhjkjllmllihfedcccbbdefgdcccecbbbccbaaaaaaaaabdbbbcbaaaabhjjhggea#.####a##a#accaa#cdaa#aaa#.#############a##a##.###a####.cedccccefbbaa#####deffeaacdaaaa#aabbbbbaaaaaabbaaabbaba#####a.###a###a#a#aaaaaaa#a##aaacdecaaaabaa#aa#bdgfeeefhhfdccccddcbbaaababaaa##aaaaaaaaa###aaaaaaaaaaaaaaaabbaaababbbbabbbaaaaaabbbbcdcdccdd",
-"dddcccdbbbcba#bb#aa###aa##a##a####a##.####aaa##a#aa##a#a#ba######.fffkjlhkkljmmmlieeddccefaeeeccdedbcdccbcbaaaaaabaccbccaaaabeijjigieba.#######aacbaa#accaaaaa##########a#a###aaa#############decabdeeeaba###..adeddcaabcbba##aabbbaaaaaaaaaaaaaaaaa#####a###########aa#abaaaa##a#abbcdeba#b#aa#####cefedcbbdeedcccdddcbbbaabbaaaaaaaaaaabaaa###aaaa#aaaaa###aaaaaaaaaabbbaabbcbaaaaaabcccccccdd",
-"ddccbcccbcedaddaaaaaaaaaa#aa#a######...###########aaaaaaaaaa####..cfhjjkmlmklkklmnjfeedeefebdeddegheeedddccbbbaaabbccbcbbaabbbgjkjjhifda.#######aaaaa###abaaaa####aaa###########aa##########..adccaddcecbabbaa##dedddcbabcbca#aaaabbaaaaaaaaaaaaaaaaaa###############aabaa##a####aacbcddebaaa########cffecdcbceeefdddddcbbbaabbbaaaabaaaaaaaaaa###aaa#a#aaaaaaaaaaaaaaaabbbaaaacbbaaabbbbcdcdccb",
-"cdcccccbbcdbaacbbbbbbaaa#aa#aaaa#####..#..##.#####a#aaa####aa######eigfcfgijjjlmmmmnlhfhiggdddeefgegfgffdeddcdcbaaccccbcbaaabbcfjkkkijgfb#######a#aa######a#############a###aaaaaba############abcc#ddcccbdecdcaddddddecbbbccaa###aabaaabaaaaaa#aaa#########.####a##a##a#aa#a######abccdgbb#ba#a######cffgfdefffehgdddeccccbaabbbaaabbabaaaaaaaaa###aa##aaaaaaaaaaaaaaaaaaaaaaaabbba#aabbacddccc",
-"cddcccbbcccaabbabaacbaaaaa#aa#aa#.#...#...#..###a###a#########aa##adeaaa#abedefijlkmnnlkkjdddfdcebb#degfaefgfeddcbdcddbacbbbbbbdjjklkkihgc#aa#####aa################aaa##a#aaabaaaaa###########aabdbedcabdddeeddddedcccddccbbbca###aaaaabba#a#####a#a###aaa###.###a#######aaaaa###aabbbbcdaaabaa##a####aeghhhggghhhfedddcccccbbbbbbbbbbbbbbaaaaaa####aaba#aca#aaaaaaaaaaaaaaaaaaaaabaaaaabbbcddd",
-"dddcccbbdedaabdaaaabbabbbbaaaaaa#.##.##.#.#####################aaaddbbaa#aa##a##aceejnllkkhfhfccfbbaaaabafabdeffgfcdddcabbbbabacgjkkllkhjhbaa#####aa############a##aaaa###aaa#aa#a#####.####a##aa#deedcabdeeeedeeddeedbccdcccdcb####aaabbbaaa#####a##a##a####################aa####aabbbcdea##a########aaabehiiiiiihfedfdccccccbacbbabbbcbbbbaaaaaaaa##ab##bbaaaaaaaaaabaaaaaaaabbbaaaaaabbbbbdd",
-"ddccdbcbedcaabbbbaaaaaabbababbaa#################a##########a###a#ecbaababaaaa#####abkllllljgbaaccbababbabaaaa#cedfheedcabbbbbbbchkkkklkhggeba###aba####.####a####a##aa##aaaaaaa##aa####.####a####dfdcba#bdeeeeeefedddcbbcdbbadcba###abaaacaaa###a##a###aa#####.####a######.##a####abbbbccbbc#ab##a#aa#ca###cfggihhihffffedcccccbbabccccdccbbbaaaaaaa#aa#aa#aaababaaabbaaaaaaaaaaaaaa#aa#abbcccc",
-"dedcccbcecaaacbababbbaabbbbbcbaaa#..###.#########a##############.cdabbbbbbbba###aabcddilmmljeaaabcbbbbbbbbbbbabaabcefgfecbbbbbbcdfjjkkkmkhfgecbaaabb########a######aaaaa####aaa###################befcbaabbadfeeeeffededcbbccabccccaa#aaa#abaa#######a########...###########.##..###abbbbcbbf#aa###abaa#a#####acfgffgfggefddcccccbbabcecbbbcbbaaaaaaaa##aa#aaaaababbbabbbbbcbbabaaaaa##aaaaabbcc",
-"cddecccccdcaaaaaabbbbaaaabbbbaaaa########.####################..aaababaaacbba#abddbcdfeejmllf#aabbbaabbbbbbaaaaaaa#afffdedcbbbddffjfijjkkkhgfed####aba#######a####aaaa#aa#####a######a############adffddcaa#befefedeeddccccbcbaacbaabbaa###aba####a###############.###########.######aabcddcefbb###bbaaaaaabba#cffffghhgfffedccccccbcbbebbbbbbbaaaaaaaa####aaba#aaaabbbbbbcbaaaaabbcbaaaaaaaabcc",
-"dddddfebdfeba##aaaaaaabbbbabaaaa####.#########################.abbaaaaaaaaabbaaabba##aceeilmme#aaaaaaaabbbbaaaaabbbbbefgeddcddddegiighiiggjggfdba##aaaa##############ba#b###aaaa#######a##a#aaa####dfgffgcaabefeeededccccdddcbbbbbaaacbab###aaaaaa########a#a########.#########..####aaabdcdecbdc#aa###aabbcccaacegggfgghggfeeeddddcccbccbbbbaaaaaaaaaaba#aaaabaaaaaaaaaaaaaaaaaaabbaaaaabbabbbc",
-"bcdeeeeedeeda##aaaaaaaccbbaaaaaaa####..##.#########a##########aaaaaaaaaaaaababba#aa####abbdhkmgbbbaaaaabbabaaaaababbbaehfcdeeeegghkkjjigdeehfeccaaaabcba########a####aaa#####aa####a####aa###baba##adfgfffdeeffdcddddddbcccdccbbbbbbb##bdb###aadb#a##############.##.######.##########abcdcedecegdb#a#aaabbcddaa#adfghfghgffefeefeeddcccccbbcbaaaaaaaaaaa#aa###aaaaaa#aaaab##aaaabbbabaaaabaaabb",
-"cbceeeefffffd#aaaaaaaaaddbaaaaaaaa#############.#############cbbaabaaaaaaabaaaaaaaaa###aaa#achlkigdaabbabbbbaabcaacaababccdbbdedcdfehkkjgeceheccda#aabbba###.######a#aaa#####aa######.#a#aa##aa#aa##adgggfeeggffdcccddcccbbcbccbbbaaa####ca##abcba#aa##########.#####a######.#.#######abbcbddbdfhgeaaa##abbcdcaaa##aaceghdfgffffffeeddddcccbbbaaaaaaaaaaaa##aa#aaaaaaaaaaab##a#baabbabbbaaaababb",
-"ccddefgfefffd#a##aaaaaabccbabaabaaa##########...############acbaabaabaaaaaaa#aaa#aabaaaa#aaaabgkjiifbabbabbaaaabaaabbabaaaaaaabcc#####cgkmjgfhfcbcaaaabcbaa########a#aa###a###########.####a######aa##bghfefgeddeccbbbccccccbcdcaaa#a##a#aa#a#aaaacbaa##.############aa########.#######bbbccddddggfbaa###abbcbaaaa#aaabeeeeggghgggffeedcccbbbbbcbaaaaaaaaaa###aaaba#aaaabbaa#a#abbbbbbabdbbaaaab",
-"bcceddefhgfcbaa#a#aaa###aaabbbaaaaa#######################aababaaaaa#aaaaaaaaaaa#aaaaaaaa#aa###cefllgabaaaaabbbaaaaabaaabbabaaa#ba######bfjljhghcac##aaacaa########a###############aa#.##a#############afgfgfedcccccbbccccccddcccaa##a####aa#aaaaaabaa#################a#a##.#########aaabccccddeegfbaa###abbaaa#aaaaaabdfceghhhhhhgfedddcbbbbbbbbaaaaaaaaaa###a##aaaaaaabbbaaacbbabbbbbcccdaaaa",
-"bbcccdefhiea###a##aaa######aaaa#aacb##############a####aaabcbbabbaaaaabaaaaaaaaa##a#aaabaaaaaaaaabekljbaaabbaabaabaaaaaaaabbaaaa#a#aa#####aekkhhiba###aabbbb#####a.#########a#a#####a#######aa####.#aba##gggfeedccbbbbbbcbaabccbcbaa##a###aa##abaaa#aa###..###########.###a##.#######aaaabbbcdddcefgaaaaa##abaabaaaabbaabdeffghighhgfffeeccbababbbbbaaaaa#aaaa#a####aaaaaabbaabbbbbbbcccbcccdbaa",
-"bcccccdefgeaaaaaaaaa#a#a#a##aaa#a#aba#######a#.###aa######bcaaaaaaaaaaabaaaaaaaa###aaaaaabbaa#aaabbchkkc#aaaaaaaaaaaaaaaaaaaaa#a#aaa#a#######dkklibca#aaabcdca#a#aa#################a######aaaa######aab#cghhgfddcbbbbaabaaaaabbca##a##abaaa##abaaba#a#aa############...##.###.#..####aaacbbcdccdcdedbaaa#a#acbaaa#aaaaaaabcffffghhhfggfeddbcbbbaaaabbaaaaaaaaaaa#aa#aa#aaabbbcccbbbbbbbbbbcdccb",
-"bbbccccdfcec##aaaaaa####a####aa#aa#aca##a####baa#######a##bbbaaaaaaaabbbbbaaaa#aaaa##aaaaabbba#aaaaaadijgaabaabbaaaaaa###aaaaaaaaaaaaaa#######behlidcdbaaabbcecaa######a###aaa###########a####a#######aaacghihgfedcbaaaaaaaaaababbbaa###aaa####a#aba##a#a#####..######......#...#.#.####aaccbcccdcdehhdaa####bcba###aaaaaaabaaadfeeegihgecdedcbcbaaaabbaaabaaaaaaa##aaaa#aaabcbbbccbbbbbbbbbcbbb",
-"babbcdddddde######aaa###########aaaabda##a####abaaa#####abbaaaaaaaaaaaaaaabbbaaa#aa##aaaaaaaaabaaaaaabcdkib#aaaabbaaaaaa####aaaaa#aaaaaa##a##a##acgjhfgefcbbacccbaa####a######aaaa########a#############bfffhjigedddbaaaaaabaabbbbccaa####aa###a##aa#################a##.....#..#########aabbbbcccddfheaaa####bba####abba#aaaa##bca.#bghfedecbccbbbaaaaaabaaaaaaaaa#a#aaaaabbbbbbbbbbbbbbbbbbaba",
-"bbabbdcdddcec#####aaaa#a####a###abaaaaaa##bda##aaa######aaaaa#######aabbbaaaaaa##a##aa#a#aaaaaaaabaabacbdjjbaaaaaabaaaaaa##########a#aa##aaa##a#a##cfhhededabbdcbcca##########aaaaa############a######a##dffgjiiheedcbaa###bbaabbbddba#########aaa####################a###..###..##..###aaaabbbbcbcfffebaaaa#aabaa##a#aaaaaaa#####aa#.bdegfeccbbaabbaaaaaaaaaaaaaa#aaaaaaaababccbcbaabbbbbbcbbab",
-"dbbbbcdcdcdcea###a####a#aab#aaaa##aaaaaaa##a####aaa###.##aa###########aaaabaa#aaaaaaaaaaaaa#aaaaaaabbaabbbhkfcaaaaabbaaaaa##########aaa###aaba######.ekjgddbabbaabccbba########aaa####.#######aa##aaa#####dgfgghgggedcbbaaa#aabbbcbedba#######aaa#a####################aa#.......##..####aabbbbcbcdefeebb#aaa#aaa##ab###aaa#######a###.##cgefdccbbabbbaaaaaaa#aaaa#a#aaaabbccbbcbbbaabbbbcbccbbb",
-"bcabbcceffabbc########aaa#aaaaaaba#aaaaaaaa########.#####aa######aa####aabbbaaaaaaa##aaaaaa###aa#aa#aaaaabbfkjhdaaaabaaa#aa##aa#####aa#a#a#aaaa######aikjjhbaaabbaacbaaa###############.###################bfhggggggfedcabaaaaabbcdeccaa########aa##########aa######a#a##a##..#.#...#####aabbbbbcccecdgccb##a####a##a############aaa######agfedccccbbaaaababaaaaaaa####aabbaaaaabbababbbccccbbcb",
-"ababbccdffdbbbba###aa#aaaaaaa#baaaaaaaaaaaa#########.####ab###########aaaaaaabcbbbaa###aaaa#ba###aaa###abbbbflljeaaaaaaaaa###########aa##aaaaa#######.afikkiba#abbaaba##########a############################ehffgggfeedcccbaabababcccbaa######aa##aa###.###aa####...#########...########abbbbcbbbcdecfgdaa#######################aa##a####bfeeddccbbbbbaaaaaabaaa#abaaaaaaaaabaaaabbbbbbccccccc",
-"adbbbbcdddecbaba#a#######a#a##aaaaaaaaa#aa##########.###aac##########a##aa#aaaabcbbaaaa##aaa####aa#aaba#abbbbdillhcaaaaa####aa####aa#aaaa##aa#########.#chkli#aaaaabbaaa########a#aa###a###############.###aa#fggffgffedeecbbbaaabbbbcbaaa#####aa###a############################.######aababbcbbbccedcfccaaaaaaaa###############.####a#####bffeddccbbaaaaaaaabaaa###aabaaaaaaaaaaababbbbbbbcccc",
-"ccbbccddeeeccaaca##a####aaaaaa##aaaaa#a#aaaa#########.###ab####.#a###aaa##aaa#aaaabbaaaaaaaaaaba#abaaaaaaaaaaachkklfbaaaa##########a##abaaa############..#bimiaaaaaabaaba##########aa#babaa##############.##a##aegfcbdeedfedbbbabbabbcbbbaa#####a#####aa######################.#########aabbbbbcbbacddddccaaa#aaaaaa###a#####################afgeecdccbaaaaaaa#abccbaaaaaaa#aaaaaaaaaaaabbbccbcc",
-"ccedcdddeeeccbbbcba#a###aaa#a#a#aaa#####aa#a#############ab#####.#####aa#a#aabaaaabbbbabbba##aa###acb#aaaaaaaaacfihkida##a#a###.####aaaaaaaa##a###aa######.ahljc#abaaaaaaa###.####a######abaaa############.#####.bababeedegdcbccbcbabaaabba#a##aa####aba#aba#a###################.####a##ababbbcbbbcdddedea#aaa#a####aa#######.###.######a##a##fgfedddbbaaaa#bcdccbbba####aaaaaaaabbabbbbbbbcbbc",
-"cddeddddeefddcbbcc#a#aa#aaaaaaa#aaaa####aaa######aa######ab#a########aa#a#aaaaaaaaaaabbaabba#aab###abb######aaabbcfheihc######a#####aa#aaaaaaa####aaaaaa###.aikjcaaaaaaaa#################aaccbaa#a################aaaaaaabdddcbccbaaaaaaaaaaa##b####abbcccb##.###a#############..###aaaaaabbbbbccbbccccddecaaa#aaaa###a########################effedccaabbaccbbaaaacc####a#aaaa#aabbbbbbbbbbbcc",
-"dcdcdcdeddfecdcbcdaa#aaa##a###a###aa##############aaaa###aba#############aaaabaaabaaaabbabbaaa#aba####a##a###aaabccefadhhb##aaa#####aaaaa#aa#a##aaa#aaa#####.aflkcaaaabaa####################ddcbaaa#################a#aaa#bdddbbcbaaaabaaaaaaa#a####a#baa####a###a###aa#############aaaabccccbcccbbcdcdedefb##a###aa##aa###############a##aa####efddcbcecbccabbaa#aacc###a##aa#aaaabbababbbbccc",
-"ccdddcbcfhfddcdcbbc#####a#aaa##a########a#a#aaa#####aaa##abaaa##.#######aabbaabbaaaaaaaababbaaa#aaaaa###a#a#a#aaabccdha#diga##aba#####ca##aa####aaaaa#a#######acildaababbaa###########a#######abccbaa#########.#########a###cdedbbdcbbabba#aaa###a####aaaa#aab###a##a#aa######aaa######aabbccccccccccddddeddfca#aa##aaa#aaa#####a####.###aa#a##a#cfeddedacaaabcaa###aacc###########aaaaaabbbbbcc",
-"ccccddccdeffdcccdccb########aa##########a#aaabaa#####aa##ab#aa###########aaaaaaababaaaaaaaabaabcabba############aaabcffb.afjfa#aba####a#a########a#a########aa#abhjb#aaaba#a##########a#######aabcccbb####.#..###aba#########abddbcecbbcbba#aaa########aaaa#a#a###aaa########aaaaa#####aabccdcddccccccccddedcec###ba#a####a#a##########.######aa#adedcbbaabaaabbaa###aabca##aaa#a##aaaaaaabbbbbc",
-"cccccdcedcddfebbdcbdb#######################abcbba#######bbaa######.######aaaaaabbabaaaa##aaabababaaaaa########aaaabbcfiea#bgjeaaa######aa#a#############a####a#acgigaaabb##########.##a#######aaa#adcba##########ba#a#a#####a#adfcddbcccbaa#aaa######aaaaaa##aa#aabbab#aa####aaaa#####aaabbccdddcdcbbbbcccddegd##baaaaa#########a################abbcccbbbbabbbba#####abca##aaa####aa#aaabbbbbb",
-"bbbccddcdcddefdbcdadcaaa#####################aabbbba#a#aabba#aa##########aaaaaabbaaaaaaaaa#a#aaabbbbbaaaa###a#aaaaaaaabfifa##ejgbaaa########a##################acbcfigba#aa###########a#########a#aaabbbba#######.#a#a#######aaaaffddccbccba##aaa##########a######aabaaa#.####aa######aaabbbccdeeefggecdedcdfedcbaacbaaaa##a#a####a############a##aa#accdcbcbbbbbba#####aaca#aaaaaaa###a#aaabaab",
-"bbbbcccccddddfecbccbdc#a############a###aaaa#aaa#aa##aabcccc###########aa#aaaaaabaaaaaaaaaa#aaa#aaabbbbbbaa###a#aabaaabbbhie#.bfhfbaaaa###aaaaaaaaa#######a####aaabdhifbaa########aabaa###a######aa#####bccaa#####.#####a########afgeddccdcba###aa########a#a#######aa######.##########aabcbcccdffghihgdcddcbacbbeabaaaaaa#a###################a##aaaa#bcddcdcbbbab##a##aaaba#aabcaa####a#aaaaba",
-"bbbbbbcccccdefedbbcacdc####aa##a#.##a#.##abb######a##aabbccc###########aa#aaaabbbbaaabaaaaaaaaaaaaaaabbbccbaa##aaabaabba##diic##adhebaaaa#aaa#aa##aa##########aabaaagjjf#a######a#aaaaaaa#a#######aa#a###bdddaa#a###.#a###########adcdddddcba#aaaaa#a###a##a##ba#b###aa####.###aa#####a#abcdcbbcdghihhgdcaaaaaabcfdccaaaaa#aa###################a##a#a##acbcdcbbcba#a#####aaba##abaaaa###aaaaaaa",
-"aaaaabbbbbcddeedccebaccb###a####a####a#..aba##########aaaaccb.############aaaabbaabbaabbaaaaaaaaaa#baaaccbbaaaa#aaaaaaaa####fjfb###egebaabcb##aaa##############aaa#achkjbaa######aaaaaba#a#aa###a###########abba###################abaceddcbaaaaaaaa#####a#####a####a##a######.###a##abaaccddedeeffdghfaaaaaaaabbdfcabbaaaaa###############.#########a###bccbedcbdaa######a#abaaaba########a#aaa",
-"#a#aaaabbbbbbcdedcccbabbb##aa######.######ba#############abcc##############aaaaababaaaaabbaaaaaaaaaaaaabbcbbccba#aaaaaaaaaaa#beihb##afgdbbcba#aaaaa######a######aa#abcilheba#####aaaaabaaaaaa#########a####a##a#aaa###############a#aaadedbbaaaaaaaaa##aa##a#######a##aab######.##aaaababceefcddcb#.#gfaaa#aaaaabcfgcaaaaaba########.#####################aabddcbcabaa##a##aaabaaaa######a######",
-"##a#aaaabbaabbccdcbcbbbacb###a###########.aba#######aa###aacf#######.#######aaaaaabcaaa#acaabbaaaaaaaaabababbbcdcbaabba#abaaaaabfje#a#aehdaaaaaaaaba#####ab#a####aabaabijiebaa##aaaaaabaaaba##aa#####a#a###########a###a###########aaaaaabbbaaaaaabaaa#aaaaa#####a##abaaaaaa########abbabcdgeba##.##.bdaaa#a#aaaacfgcaaaaaa########.a########.#######a#aa###abccbbbaaaa#aa#abbab#abaa####aa#####",
-"#####aaabbaaaabcbccccbbbcca###a############a#########aa##aaacb###.#.########aaaaaaaaabcbaaabaaaaaaaabaaaaaaaaaabcaaaaabaaaaabaabaejhbaa#aggcaaaaaaaaa####abb#a###aa##aabhigddbababba#acbabaaa###aa####a#c#a#############a#a########aaaaaaaabbaaaaaaaaaa#aa##a#####aaaaaa###aaa######aabbabege##b#######aa#a##aaaaaceecbaaa############################aaaa##aaacbbbaaa##aaa#aaaaa##aa#####a#####",
-"####aaaaaaaabbabbdcbcdccbbba#aa####a##a####a######..##aaaaabab###.###########aaaaaaabbbbbbaaaaa#aaaabcbaabaaabbaaaaaaabbaaabbabab#bghcaba#dhfaabaaaaaa#aa###aa##aaaaaaaabeegbccbaaabcbbbaababa######aa#aaaaa##aa#.######aaa#########b#aaaaaabaaaaaaaaaaa#a##aa#aaa#aaabbab##a####ab#aabbbbcfhaaca##############abbabddbbaa####################.###a##a#aaaaa#aabbbbbaaaaaa###aaaaaaaa#######a###",
-"#####aaaaaabbbbbccdbccdcbcca##########a#####aa##a######a#aaaabc###############aaacaabbabbbbbaaaaaaabccbbaaaaaaababcaa#bbaaaaaaaa#ba#eiebabaafhb#aaa###a#a####aaabbaa#baabbbigcebaaabcbbcdbbbcca#a##a###acbbaa#ab##########aaaa########aababbbaaaaabaaaaa##a###a#aa###aaaca##a#aa.bc#abbdccbdga#####.###########abbbbcdebaa##a##a##########a####.###a#aa###aaa##aabbabbba#a#####aaaaaa########aa#",
-"#####bbbabbbabbcddddcccbbbcca#a##aa###a#################aaaaabb#a####.########aaaacaaaaaacaaaaabcaaabbcdcbbbcbabbbabbaaaaaaaaa####aa#cijdbababhfa#aa###aa##a##a#aaaaa#aabbbflggfaabacbaabbbaacbba##aa#abccbbaa###aaa#####a#aaaba###a#aaaaabbacbaaaaaaaaaaaa###aaaaaaaaaacaaaa#bbab#abbcccccbdc#################aabdceedebaa#########################b#####aa#####bbbabbaa#a####a#aa##ba########a",
-"aa##aaabbbbccbbcccddcdccabbdfa####a###########aa######a#a#aacc#######.#########aaabababbaaaabbaaaaaaaabbbbaaaaaaabaabbbaaabaaaaacba#a#beijbaaaaehfa###########aa#abaaaabbbbdhjghffedccaaabaabaabbaaaacbcbcccbaa#aaaaaaaa#aaaaaaaa####aaaabbaadebbaaaaaaaaaaa###aaabaa#a#aaaaabbbbbbbabcdcccefe####.##.#######.##a#aacccccaa#aa#####.###############aaa###.#a###a##bbbbbaa#a########aaaaa##a#####",
-"###ab#ababbccbcbccdddccccbbbeda##aaa######aa###abaa####a###abdb#a###.######aaa#aaabbbaaaaaa#abbbaa#aaaaabdaabbcbabb#aaaaaaaabaaacbcba####ejdbbbacgjd##aa#aa#####aaabbaabaabbejiiiihhggfbaabbbaabcba#bcdcdddddcaabbbbcbaaaaabaaaaaaa##aaabbbbcdedbcbaaaaabbaa#aa#aabbaaaaaaabccbbbbbcdccddffebb####################aabccccca###########.#########a####aaa####a##aa#abbaaaaaa########aaa####a#####",
-"#aaaaabbbabbcccccdedccccedccdebabaa#aa###########baa##.##aaa#aca#######.#####aaa#aaabaaaaaabaaaacbaaaaaaabaaaabcbaabaa##aaabaaaaabaaaa###.cjgcbbbadiib##aaaaa####aaabbaaaaabdhlijjiiihfefcbaabbbbbbababdedfddedccbccdccbccdccccbaa#aaaaababcccdddcccbaaabbaaba#aaaabbaabbaccdddcdefffedeeed..################.######abcbdfbab#a###########################a#a#####aaaaaaaa##aaaa######a##.#a####",
-"###aaaaabcbabccccdcddcccccbbccebaaaa##############a#a####aaa##abb##############aabaaababaaabaaaabbaaaaaaaaaaaaaabbcbabbaabaaaaaaaaaaaa####.afhdbbaabfihb.#aa###aa###aaba#aaacclljjiijigddecbaabccbabbbdbadcbeffffeffgghhhighgfhgffcaaababdbbbbcfddddcbbbbbccabaaaaaaababddehggfegjiedaaaa#a####a##############.######bcdcddbaaa##a###################a#a#####aa####aaaa#aaa#a########a#######aaa",
-"aa##aaaabaaabbbdddccdbcddcccccdd##a#aa##aa########a######aaba###ab##############abaaaaacbaaaabaaaaaaaaaaaaaabbaabbaccbaaaaaaaaaaaaaa#########bfgbaabbdije.######aa#abbaaaaaaabellkkkkllkiiigfdcdcbabbcbcdcbcgijkjhhhhijjic#dcbcbddghffeeeihiggfgddedcccbcdcdcbcbcbabadeeffghhhebegdddb#########a#a####################babbbcbbb##a##################aa##a####aa#a###aa#a#aaa##a#######aaaaa##aa#",
-"a#aaaaabaaaaaabcdcceccefcadgeceebba###a#aaa########a#####aabaa#aabda########a####aaaaaaabbaaaabaaaaaabbaaaabbbbaaaaaabbcbaaaabaaaaaaa#aa######.eiebbbbcfihc#.###abaaa#aa##aaaabellkjlkjklmnnmlkgfccbbdddeefghjijkkllkhd#cfeabcbbcbbdgjjhgecccehieeededccceeedddddefcdffcedbacdec#bbaba#########aaaba#########.#######aaaacccdbbaa####################aa##a####aaaaa#aaaaa#a####aa######aa#aa##aa",
-"a#aaaabaaaaaaaabcccdddggedbdfccecaaa###aaba#a#######aa#.##aabba#aabc###########aaaaabcbaaaabaabaabbbabaaaaaabbcccaaaabbbbbbaaabaaaaaa#aa#aba###.bigbbbccdilid.##aaaaaa####aabbbcekmljgdfiijikmlmnkgdeefeeegieeddgdcghgdbabcfdebcccceffggfcbbbbbcefgedddcceeefdedcbccefgb####babedcaa##aa#######aabcda##.#############aaaaabcdcdbaa#########a########a###a###aabbbbaa#aa#aaaaa##aa######aaa##aaa#",
-"##aaaaabbaaaaaaabcdceeffedccfgedcaaa##aaaa###a#a#####aa..##abaaaabbd#########aaaaa#a#bbbbbbaaaaaaabbbbbaaaaaabccbbaaabaabbbbab#aaaaaaaaa#aaaaa###ahibbcdccgjkg####a#aa####aabbcddegkhddgihhghiibdilmljjjjiiihfaaa##aeeedcbbdghfdbbdfedfedccbbbbdbffhfededeefhhfc#####cea#####aaabdfda.a######.##abdfb##########.###a##aaaabadefecb#a##########aaa####a##aa####acbbbaa##aaaaaaaaaaa#####a######a#",
-"a##aaaaaabaaaaaabacddeddfdccefffd#aaaaabbaa#a#####a#.aaa###aaaa#abbdb########aaaaba#aaaaababbaabbbbbbbbbaaaaaaa#abcbaaababbbbcb#aa#abaaa###########fhdcccdcehihb###aa######a#bccdefggiglkjjhiihba#cglkjhiihgebcaaaaaa#aacdbbdefhfdbbeedbccbbbabdcbgjifefedeggfgfa#aa#a.aa######aaaacffba####.###abdeca######a###########aabbegffgedaaa##########aa####a##aaa#####aaaab#aaa##aaa#aa######a#######",
-"##aaaaa#aaaaaaaaabbcdddceddeeecdfbaaaaabbbaa#####ab#########aaaaaabbc########aababbaaaaaaaabbbaaaabcbbabbaaabaaaaaaabbbbaaabaabbbcaaaaaaa##########.bhfcccdddefigc#abaa#aaaaaacccdegeiihkihhjhbbaa#.#a##a#..##aaaaaaaaaaaacaabaacefedefbbedcbaccdbcfgiihhfdec.addb#ba###aa######aaaaadgeca#######aceaaa#################aaabdgeeghffb########a######aa####abaa#####a#aaaaaaa#aa###a#.######aaaa#",
-"a##a####aa#aaaaaaabccbccdedefebbef#baaaaaabaa#####a#aaa####aaa##aaaada########aaabbbaaaaabbaaaaccbbcabbbbaaaabaaaaaaaabbbbabbbbaabcb#a##a#########a##bifdccdddefgjeaaabaaaa##accbbcddfhehijhdb#aaaaa#a####a#abaa#aa##aa#aaaaaabbbaabefigffefdbcccdcbaacbbdhhfeaacbabb##a##########aaaaadhgb#####aabecaa########a###########baegfefgfeca##a#######a##aaaaa#aaaaa####aa#aabbaa#aaa###a#.#####a#aaa",
-"#aa#####a#a#aaaaaaacccbbccdcdedbcfcaaabbbaaaaa####a###a###abdb####aaeda######a#aa#aabbbabbaaaaacddbaaaaabaaaaaaabcbaabbbaabbbbbbababa####aa###aaa#####dihecccdedeejgaabcbaaaaabcbbbcdeheggeabaaa####aa########aa###aaaaaaaaaaaaaaccbaabdegedddddddccbbbba#abaabcbbaaaa##a##.#.#####a#a#abefb#####abdfaaa#####aaaa#a########aaadfeeffffc#######a######aa#aaaaaaa#aa##aa#aaabaaaaaa#######.###a#aa",
-"aaaaaa#aaaaaabaaaaabbcbbabbbcceedffdbaabcaaaa##abaa##aa###acefa####abdaa###.####a##aabbbcbcbaaaaabba##aaabaaaabaabbbaabbbaabbbbabbcbba#a##aa###aaa#####bhjgccdddefdhheabbaaababcbbabcdehfcaaaaaaaaa#aaaa#######aa###a##aaaaaabcdaabbbbabbbefedeccddcbbbaababbbcccca#a####aa#############aaceda###aabfebaa####aaaaa##########aaadefedegca########aaa##aaa#aaaaaaa##aaa##aaaaaaa#bcba#########aa##",
-"#aaa#aaa#aaaababcbbbbccbaaabbbbdgffgbaabbbaaaa#aaa####a##abbgea##aa##bca#########a#a#bcbabbbbaaaaaaaa##aabaababbbaabaabbbbbbbbbaaaabbaa##a#####aaa######adhidddddfhdfigbcba#aaaaaaaacbcfdabaaaaaa#aaaaaaa#######bb#####aaa##aabccaaabdcaaaeeefeddefcbbbbaaaabcbbbcdba#####a####..#######a##abdb#aabcefdaa####a#aaaaa#######aaaaaabacefc#########a###aaaaaa##aaaaaaaaaaaaabaaaa##aaaa###.#####aa#",
-"#############aabaaaabcbbaaaabbcceeeeeaaabbaa##a###ab#####abddb#####a##cb#######aa#a##aabbbbbbbaaaaabaaa##bbabbbaaabaabbbacbcbbbcbbbbaaa###a######aa##a#baaagkecdeegfeehfcbba##aaaaaaaaccdcbaccbaaaa#aaa##aaa#########a##a###aaabcaaaadeddbbdcdeigfdbcccbaa##cbabcbcdaaa####aaa######.######aa#debaacfdcaa#####aaaabaa########a##aabccdd#############aaaaaaa###aaaaaaaaaaaaaa###aaaaaa#########aa",
-"#############aabbbcbbccbaaaabbccddeedca#abaaa#aa###a##.##aaaa#######aaaca############aaaaaabaabaaaaaa##a#aaaaabbaaaaabbbabbbcbbccbccbaba##########a##aaabaabejfddddehddhgdbbba##aaaaabbbcccaabaaaaa#a#a##a#aaa###############aabcaaaaaegeddcecacdghfdccbaaa#cbabcbac#######bba#################bcdcbeebaaa###aaaa#aa#a###a####abaabdcdcba#a##a####aa###aaaaa##aaaa#aaaaaaaaaaa#aaa##aa#########a",
-"aca##########a#aaabdbcccbaaaabbccddeedbaaaaaa#aa#########abca#######a#aca############aaaaaaaaaaaaaaaaaaaaaaaaabbabaabbbbbabbbcbbbbcabbbba##########aa###aabbbeidbbccehefhhcbbaaa#aaabbaaabbcaaa#abcaaaaaaaaaaaaa#####.########aaabaacbedfdbbbdccccfhebaabaaa##a#acaba######daa###.######a####aa##acfdfdaa####aaaaaaaa###aca#aaaabaabccdeaaa###aa#aaaa##a#aaaaaa#abaaaaaaaabaaa##############.aab",
-"aa#bb#####.######aaabcccbbaaaabbbcddeebaaaa########.#####abca##########abaa####a#####aaaaaaaaaaaaaa#aaaaaaaaabcbbaaaaaaaabbbbbbbbbccabbaa#a#########a#####aaaachdbccdefehgiebbbaaaaabaaabccacbaaaacbaaaaaaa#aaaaaa#############a#baaaaceddbaabcbebbefdcaaaaa###ba#baa#####.aba##############a#a##aacfghdcaaaa#abaaaaaa######acbababbbdbaa###aaa#aaaa#a#aa#aa#aa##abaaaaaaabaaaaa##############ba",
-"a#aa#a#####.###a#aaabbcccbbbaabbbccccge#aa#######.#######abbba#######aaabbaa####bba###aaaaaaaaaaaaa#######aaaaabbbbabaabbaabbbbcbbbcbabbbaaa#a##a##########aaaabeccccddfgefhgaccaa#abbabbbbabbbba#aa#aaaaaaaaaaaaa#######a#####aaaaaabacdccabbbcecaacdfecbbaaaa#aaabaaa#####aa########aaab####a###aabeggbaaaaaaaaaaaaa#a##a###aaaabcccccaa###aaaaaaa#aa#aaaaaaaa#abaaaabaaaaaaa#a###########a#aa",
-"###aaaa###a######aaaacccbbbbbbbabccccehb#a########..#####abbca#######aaaacaa####cca###aaaaaaaaaaaaa#######aaaabaaaacdbaaabbbbbbbaabbbbcbccaa############a#aaaaabaccbdccegeccffbbaa######.#abaabbbaaaaaaaa#aaa#aaaaaaa#a##########aaaabbcc#abbabaabaddcbceebbba#aaaaaba######a############aba###a##aaaccggbaaaaaaabaaaaabaaaaa#a#bbabbccdb#aa###aa#aa#aaa#a#aaabaaaaab###abbabaaa###a#a########aa",
-"###aa#a######.######aacccbbbbbabbbccccfheaaaa#############bbcaa#######aaabcaa#####aa####aaaaaabaaaaa#aaa##aaabaaaaaacdcbaabcbbcbbbabbaabbbbca#a######aaa##a##a#aaacabccdeggacge.#aa####a#baaaabbabaaaaababbaaaaaaaaaaaa#########aaaaaaabda#aaabbbacbcdbbcdeca#a#aaaaa#a#aa#aa#############aa#####a#aaabcfgcabaaaaabaaaa#aaa#####babbbcccc##aa#a#aa#aaaa###aa#aaaaaaaaaaa#aabbaaaa###a#a#####abba",
-"###aa##aa##########a#acbcccbbbbbbbbbcceffebaa#############accbaaa######a#bdcaaa####aa##aaaaaaaaabaaaaaaaa#abbbaaaababcddccbcccccbaabaaabbbbbca####a######aaaaa##a##bbabcbdgefeed########a#a###ab#aabbbaaaaaaaaaaabaaabba#####a#.#a##aaaabca##abbbaccbbdcbcdedb#aaaaabaaa###aaa#########aa#aaaaaaaaaaaaabceecc##aaaaaa#a#aa########abbacccc##aaa#aa##aaaa###aabaaaaabaaaaaaabaaaa####aa#####a#a#a",
-"b###aaaaa#######.##a##abbdcbaabbbbaabccdegea########a#####abcbba###aa####acccaa######a#####aaaacbbbabbccbbaaccaaaaabbbcccbcbccbbaaaababaaaaabc###a#aa#####a#aa#a#aabdaaacbbafhgbfa.#####aaaaaaaaa#aabaaaaaaaaaaaabbbaaba###a###########baba##aaaabacaabccbccdeeaaaa#aaab####.########.##aabbbaaaaaaaaaaabccaccba##abbaa###a##a###a#aabbccca#aaa#a#abaaaaaaaaacaaaa#aaaabbaaaaa#aaaa#a#######a##a",
-"baabaa#######aaa#####aabbccbbaaabbaaabccdfeba#######aaa###abcabbaa##aaa####ddbaa######a###aaaaaaaaaabbcbbbbbccaaaaaabbbbbcccccbbbaaaaaaaaaa#abca##a#aaaaaa##aaaaaaabcaaaabaabgicce##.#a##aa#a#aaaaabaccbaabaaaaaaaaabbbaaa#aabb##########aa#aaaaaaaaaaabccccddfebaaaaabbaa################bbbbbbaaaaaaaabbbc##acbbaaaaaa####a#####aabbbcccb###aaaaaabbaaaa#a##aa####aba#bbaaaaaaabaaa#######a##a",
-"baaaaa#######aa#######aabccbabaabbbaabbbcdgdb#a########a##abdbbaaaa##aaa##abdcbaa#############aaaabbbbbbbbbabccaaaaaaaacbbbcccbccccbbaaaaaaaabbca#aaa#a#aaaaaacbabaa#aaaaaccbbjgabc###bb######abaaabbcccbabbbaaaaaaaaaaaaa##aaaaaa#######aa###aabcbaaaabbbccdeeefebaccbbbbb#.####a####.###abaabbbbbcbaa#aaabca.##acccbaaaa########aaababbcba##abaaaaaaaaaaaaaaaa#aaa#baaababa#bbaaaaaaa#######aa",
-"aa##aaa###############a#abcbabbaaaabaabbbcffcaa##aa##aaaa#abbbbaaaaaaa##a##abdbaa##############aaaaabbaacbabbbcaaaaaaaabbbaaabacbccbbbaaa#aaa#aabb#aaaaaaaaaaabbbbaaaa##aabbbadiabbc.##c#######aaaaaabbccbbabbaaababaaaaaaaaaa##aa#######a#####aabbaaaabcbbbcddcefhgceeaabba##############abbbbbbcbaa###.###aca####aacdba#a#a######aaaabbcbbaa##aaaaaaaaaaaa#aaaaaaaaaaaaaa#bababaaaabaaaaaaa#ab",
-"cb####aa################abcbbbaaaaabbaabbbdgdb##a#aa#aaaaa#abaabaaa#bba####aaddba#######a#########a#abbaaccccccbaaaaabaabccbbabaabcbbbbaaa#aa###acda####aaaabaaabbcbbaaaaa#bcbcebbccd#.aba######aaa#a#acbaaabbbbbaaabbdbbca##ba###abc.#.####.##a#bbaaaaaaccccdecdefghgfccccb#.####.#...###aaaabbabddba###...##bb#####a#bcba##########aaabbccaa###aaaaaaaaaaaaa##a#aa#aaaaaaaa##ababbaabaaaaaaaab",
-"ec##########a##aa#.#####abbcbbaaa#aa#ababccfffcaaa#aabaaaaaabbaaaaa#aba###aabbfdaa###.#############a#aaabbccbbccaabbaabbbbbbbbabaaabbbbbaaa#a###aacdba##aa#abbacbbcbbbaabaaabbceabccde.#c#aa######aaa#aaa#aaababbabaabbdefecd#aaaaaaec#.#########aaaaaa#aacdcbdbabdfegddffdba##.#.###.###aabbbbabbccbba###.#.##bc#######abbba########aaabbbddcaa##aaa##aaaaaaaaaa#aaa#aaaa#aaaaaababaabbaaaa##ab",
-"bca######.#####aa#######abbbbac#a##aa##abcdcehfaaaabbbaa#abcbbbaaa#aaba#####acegdaa####.############aaaaabbbbccccbabababcbbbbbaabbcbbabaa##aaa###aacebba###bffcdbcbbcbbcaaaabbbhbabbcee.##aa##aaa#acaabbaaaaaaabccaaaaaabdefge##aaaacea###########a######abdfdabaaaaababaceeb###.#...#.##aaabbbabbbaabaaa###..##bea###a##a#aca#a#a#####aaababb####aaaa##aaaaaaaaaaaabaaaaa#aaaaaababaaaaaaa###ab",
-".#a###########.b########aacaaaacaaaaaaa##acdffgbaaabaaa##aaehdbaaaa#aaaa#####acfgbaa#########.########aaaabbabcdecbaabbabbbbbbbaaababaaaa######a##aaddbaaaaab##a##abccccccbbaabfhaababgd.######aa#aaaaaaaaaaaaabacdddbaaaaaaddeda#aa#ba######..##a########abdcaaaaababcabbbcddb#a###..#.##aaabccbbaaaaa#########abed#########cb#a#a####a#aaaaacb###a#aaa##aaaaaaaaaaaabaa#aaaaabaaaababaaa######",
-"#########aaa###a########abbaaaaaaa#a#aaaaaacdegeaabaaccbaa#acefcaa###aabba###aadfdbbaa####.#############ababaaabcccaaaaabbbbbbbabaaabbbbaaa#####aaaabdeaabbba########aabdedcbabbffaababhd########a#aaaaaaaaaaaaaaacedbabaaba#bfggcaaa#########..#.########aabcb#aaaaaabaababccddba#..##.####aaabbaaaaaa##...#####acecb########abba#aa#a#aaaaabbca##aa#aa#aabbaaaaaaaaaaaaaaaaaaabaaaaaabaaa#aa##",
-"##########aa###a#####aaaaaaa##aaaacc#a###aabbcefbabbcfcddddbabgfa#a#aaaadbaa##abdedcaaaaaa#############a#aaaabbbbaacbbabbaabbaaababbaabababa##a##aaaaaccbbbb########.###abbacdcccgbabbbcida####aa#a#baaaaaaaa##aaabccaaaaaacbbabggb#a#####aa##..##aa######aabbcbaaaaaaaba#aabbcccca#.########aaaaaaaaa###...#######abdec########abb#aaaaaaaaaaabcbaaa#####aabbbb#aaaaaa#abba#aaaaaabaaaaaaaaabb#",
-"###########aaaaba###aaaaaa####aaabdebca###aabbcfgfbacdccdeheaadgea###a##dcabaaaabdedcbaa##################aaaaabbbccbaabcbaabbbbabbabbbaaabaa#####aa#abddbcb##a########a##.##accdeedbcccejcbaa####aaaaaa#a#aaaa###aabbbbaa#bdbb#chfa####a########.###########babbaaaaaabaa#aaaaabbcdc#..######aa#aaaaaa###.#..#####a#abdeba#######bbbbaaa#aaaaaabcca#aaaa#aaaabbbaabaaaaaaaba#aa#bbaabbaaaa#####",
-"######a##a###a#aaaaa#aabaaa##aaacddbbcaa##aaaabdifdadeeddfffaabdddbaaaaabd#aaaaaacfedcaa#################aa###aaaacccbbabbbbaaabbbbbbbbbaaaaa######a#aaacdddaaa#########a######aabbicceedghcbb##aa#aaaaaa#aaa#a####aaabbaa#adffbafgd####aa###################aaaaaaaaaaaaa#ababaaabbbcb#.####aaaa#a#a#a##..########a#aabbcdd#.###a##bbaaaaaaaaabbbbba######aaaacbb#abaaabaa#a#aaaabaabbbabaa####",
-"######aaaaa####aaaaba#abaaa###a#bddccaaa######abcfgghhhfdfffcacbabdecca#bca#aba##aeffeba##############.########aaaaccbbbabcbbbaaaababbbbbbbaaaa######aaaabeeaa#aaa######a###a#aaaabfgdbbddhhccb###aaaaaabaaa###aa##aaaaaaaa#bffgd#cda##a#a######a#a###########aaaa#aaaaabb#abaaaa#aaaabbca####aa#aaaa####.#############aaabcdc#####a#abba###aaabababc#aaa##aaabcaaaaabaaaaaaacaaaabaabbbbbaaa###",
-"a######aaaa##a#aabbaaaaacba##a##acccddbaa#a##aaaaacccdefefefdacaaaacgebcdb#a##aacbbegfdba#aba##############aa###aaabcdbccbbabcbbbbbbbaabbabaaa###a###aaaabcdb#baa#a###########aaabddgcdcbbcfidbcb#aaaaabaaa#a#a#abaa###a#aa##dfffeaa#####a#####aa##b.######.###aaaaaaaaaacbacaabaaaa#aaaacccaa####################a########abceca###aa#abaa#aaabaaaacda#aa###aacaaaaaabaaa#aaabaaaacbbbbacaaaaaa",
-"aa##a###aaaa#a##aaaaabbbbbbba####bbbacbaaaa##aaaaaabccbdedcefaccaaa#accccaa##aaabcddfgefeeffea################aaaaaabbcbcbbcbabbbaabbaacaaaa#a#######a#aaaacfcaaa##a############aacdee#a####eifccc#aaa#ccaa###aaa#ba###a###a#befffd######aaab###aa############aaaaaaaaaabbcbcdbbaa###abbaaabccdca...#######aa#a####a######aaaabcdc######aaaaaaaaaaabbcdbaaa##aababaa##aabaaaaaabaa#abbbbaaba#aaa",
-"#aaaaa##a#.###a#aaaaaceccbbbab##aaaaaaaaaba#aaaa#aaabccbcdddgfdaaaa######aa##a#aaaeggihgeefeddeca###############aaaaababcbbbbaabaaaaabacbaaa##a#####ba#aaabadgeaa#a##a####a##a##aabbeeaa#####bhibaca##aadbaaaaaca###########aadfddfda###abaabb#aaba#####a######baa#aaaa#abdc#bccbaaaa###ba#aaabdfeec#########aa#aaaa####aa#aaaaabde###a###aaaaba#aaaabbccbaaaaaaaaaa#a#aaabaaabbaaaababbbbaabaaa",
-"##aa####a#####aaaaabcccbbbcbbaa##aaaaaaaaabb#baa##aaabbcccdefgiecbaaa##aabba###a#affghihfccdddddeca################aaabaaaabaaaaaaaaa#aaaabaa########aaaabaabcgcaaaadda#aa#######aacdde#######aegbbdbaa#adbbaabcaa#aa#########acfeeecaaaaaaaabbaaaba###########aaaaaaaaabddfbaaababaaaaaaa##aba#acefgca###aa#####abb######aaaaaaabcfa##a###aaaabdaaaabbbbdb###aa#aaaaaaaaaabcbbbbbbabaabbbbbbaa#",
-"####aaaa#a#####aaabccccbaabcbcca##aaababbabbabaaaaaabcccbacddefffdccabccdedaaaabdeeffgggeccddccdcdca#a##############aaacaaaabaabaaaaaaaaaaaaaaaa###aa###aaaaacdgcaaabaaa#######a##abdchaa######.cfcbcb#a.bffcbbbab###aaaa###a###ceedddabcbaaaabbabbaaaa##..#####aa##aaaa#acecbbcbaaaaabaaaa##aba#aecbccdcabaaa##abbaa#a##aaaa##aaaabdd##aa##aaa#aaababbbbbdb#a##aabaaaaaaaaaaaaabbbbbbcbbbbcbbaa",
-"aaabaaaa####aaaacccbbcbbbaaaabdaaaaabcaabcbbbbbaa##abcddcbcdefedffedbdccdeec#aafffdddeffcccbcdcccccccaa#############aaaab##aacaaaaaaaaaaaaaaaaaaa###aba#aaababdefaaaaaaa##a###aaaaabccgcaa#######bgcdeca##bhgbabaac##a#aaa##a###befddfdddbddbaacabbbbaa####.#######a#aaaaaacbaabbbaa##ababa##aa##acaaaabbcb#aa#a#aaa##aa#####a#a#aaaabeca#aaaaaaaaabaabbbbbdb#aaa#abaaaaaaaaaaaaaaaaaabcbaababaa",
-"aaaaaa#aa#####abbbcbbabcccbbaaabbccccdbabccbbbbbaaabbcddcbceeeddeggddfbcdeec###dffedddeddcccedccccbbcdb#################aa#aaabaaaa#baabaaa#aaa######aaaaaaaabbcdfaaaaaaa#a####a#aaaabge##########bhcbccaabdeeaaaa###a###aaaaaabceedefeeedeeccabbabcbbaaaaa##.#.#######aaaabbb#aaaaaaaaaabaa##a##aaa#acbcabca###aa####aa#########a##aaaedb#abaaaaaaabbabababccb#aaaaba#aaaaaaaaaaaaaaaaabbbbbaaa",
-"aaabaaaaaa###aaabbbbbaaaacbbbbbcccddefdaabbbbccbbbbabbccbcdddddeeeffefcedffedbabeeecddcbcccbdbbbabbbabba#aaaaa##a######aa#a##aaaaa#a##aaaaaaaaa###aa##aa###aaabbdedaaaaab#a####aaaaabbgha#a########becaccdfgddda#aa#aaaabaaa#a#addeecdcdfeeeddcacbbbcbbaaaaaa###########aabacbaaaaabaaba#baba#aa##bbbdbacaabcb##aaaaaaaaaa#########a#aaabddbaaaaababbbbbaaabcccbabaaaabaaaaaaaaaabaaabaaaabbbbaa",
-"abbabbaaaaaaaaaaaabbabaaaaabbcbbcdedfggccbaaabbbbccccbccddeddccdddcddecddeffddecddccacbaacbbbbaabaabaaaaaaaaaaaaaba####a###ba#ba#aa#####aa#aaaaa############aabbcdebbbaaaa########ababdhf#a#########afecfffebceaa###aaa#aaaaa##abeeddddeegffdcfdbbabcccbaaaaba###########aaaabaaaabbaaabbbaabbaaaaacdcaacaaaabca##aaa#aa#aa#aa#######aaaaacee#bbaababbbbbbbbbccdcaaaabbaaaabbbaaaaaaaaaabaaaaaab",
-"babbaaabaaa#aaa#aaaaaaaaaaaabbbbcdbadccdbbbaabbbbbcbbccdeeedeabcccccccccdeedfddcccdbcbaaaaaaabbbaaaaaaaaaccaaa#aa##aaaabbaab#a####aa####aa##aaa###############abcdedbcba#####aaaa#aabbdhie.#####a#####fgffececeda###aaa#aaaaaa#cddecddcddefeegefeccbccccbaa##aaa#.#####.##aaaabaa#aaaaa#aab#bcccbbccbbaab#aaaabcbbaa#aaaa#a#a######aaa##aaabdfdbbbbabbbbbbbbbbccccaaaaaaaaaaabbbbbaaaaaaaaaaba#b",
-"bbaaabbaaaaaaaaaaabaabbbaaaabbabcedcbbabccaaaaabbbaabbceffcccbbcbbbbbbbbddcdddbbbabbbbaa####aaabaaaaa##aacfeaa######a##aaabbbaaa##aa#a#####bcca#a##aab##aaa#aaaacccgdbbb#######aaaaabbbdhhb###########aeifddbbceda#aaa##aaabaabefffcdddccdeeeedeffefeddccbaa##aaa###.###..aa##aba##aaa#aaabaaabccddcccaabaababaabcca###aa#aaaaa####aa#####aaacffbbbbbbbbbbbbbbbbcdcaaaabbaaaaaabbaacbaaaaaabbbab",
-"babbbabbaaaaaaaaaaaaabbbaaaaabbbceddcbaaabbbbbaaaaaaabcdffdcabbccbbaaaabbbbbbbbaaaaaabaaa#a##aaaaaaa####aadd######a########abbaaaa##a#####a#aa########aaaaaa#aabbbbdgcaaa###aa##aaaaabadfgb######aa###aadidcdbaceca#aaaaaa#abcdeeeccdeddccddeadeefffffffecbaba#######.###.##aa#abaaaaaaaaabcaaabaabcbd#abaabbbbaaabdba#a#a##a###aaaa#########aacefdbbbbbbbbbbbbcbcccaaaabaaabbaabaaccaaabbaabbaa",
-"baababbbbabaaaa#a##aaabbbaaaaabccehdbaaaaaaabbaaaa##aabdgieccccbcbaaaaabaaaaaaaaaabaaaaaaaaabaaaaa###a###aaa################aaaaaacba######a#a##########aaaa#abbbbbcdhb##a####aaaaaaaacbfe.##aaaaa#####aadhcbbaaefbdb##aaccddfgedbddccccbbcdedceceggfeefefdcbaaaa#####.###.###aaaaaaaaa##aba#aaaaababdb#aa#aaabaa###bcbaa#######aa#############abdffcabbbabbcbbcbcbcdcbbaaabbbbbbbaacabaaaaaaaaa",
-"bbbbabbbbbbbaaaaabdcabdcaaaaaabbcdffcbaabaaabbbaaaaa##bcgjfbbbcdddcbbbbbbbbbaaabaabbbaaaaaaaaaaaba#########a#a###############aaaaaabaa#######a######aa#a##aaaabcbabbcceda#aaaaaaaaaaabbbec.a#aaaaaaa####aadhcabbbeecbaaadefggfeddcddcccccbccdccdddeghggeeeddcbaaaaa############abbaabaa#aaaaaaaaba#ba#aaaa#abaaaaa##aabbb###aa#a#a##a##########abbcffdcabbcbbbcccbbccccbaaaaaabbbbaabbabaaaaabba",
-"bbbbbbbbbbbbbbaaabfdcccbcbaaaaacdceebaa####aaabbbbaa##bdghfcbaaacdddccccccccccbbababbbaaaaaaabbbaa#a##aa#a#b##a#aa###a#######abaa###aaaa##a################aaaaabbbcbbcffaaa#cbaaaaaaaacec.#####aadea##a#aabgdababdfda#adfggeddccccbbbaccbbcbcddddgghigffffbabbaaaa##########ab#aaaaaaaaaaaaa####aaaabaaaaaaaaaa####a##aaca##a######a#########acbbbbcdefdabbaabccbbbbccccbcbaaabbbaaaababaaaabcc",
-"bcbbbbbbbbbcbbbbbcecccbaccedaaabddcaaa#######aabcbbbaabdfhfdcaa###acdcabdfeeedcccccbbcbbaaaaaaacbaa###aaaa#aaa#####a#aa##aa###ba###aaaaaaaba############aa#aaaaaaaaaabbbfgaa#adbaaa#aaaaehaa###aa#adea#a#aaabgbabacefdb#dfffedccbbaaaaaaccbbcdecdggihihhfdffcbbaaaa###aa###..#aa####baaabaaaaaa#####aaaaaaaa#aba#a###abaa#cbaa##.##aa####aa##aa#baaaacccefdbbabbcccbbbdccdbaabbbbbbbaaabbaaaaabc",
-"cabaabbbbbbcbcccccddb##abaccbabbdbcaa#a##a####aabdcdbbcdddghcbaaa####bcacigggecbbbcbcbbabcaaaaaabaaa#a##abb#########a##aaaaaaaaaa###aaaaaaa########aa##aaaa#####aaaaa#acegfaaa#aac##aaaachfc###aa###aabb###a#bbabccddefdceffedbcaaaaa#aaabbbbcdegihhhhgggdcffecabaaaa##a##.###abca#aaa##aaaaaaaa######a###b###baa####aaaaaaaaabca###############aaaabbbbbbdfebbabcccbcdcbbdcbbaababbabaabaaaabbb",
-"febaaaabbbbcdcccccb#####abbabbcccbbaaa####aa#a#abdeccbddeeehgcaa#a#aa#addhifdddbbccbcccbbbbaaaaaababaaa#aaba####a##a#a##aaaa#aaaaa#a##baaaaaaa#####b###aaaaaa##a##aaaabcefihefc##aaaaaabbdha####aaaa#ab######aaaabbccdefegffdcccaa#a##aaaaaabbehhhhffffcddbdcdbbba#ac######..###bb###a#abaaaaaabba#####aaa######a#aa#####a#####bbca###########a##aaabbbaaaabdfdbaccbccbcbbccdcbbbbaaaabaaaaaaabb",
-"dedbbbbbbccbcdccddb#####bbbaacccacbaaaa###aaaaaaacfdcbcdegghigbaa#aaaaaadfhgedcccccbbbbbbbbbbbbbbbbaaaaaabbba########aa#aaaa#abaaa####aaaaaa############aaaaaaa###aaaabcfghgihfbcb#abaaabbge####aaaaab######a#aaaaaaccdeeddfdbcbaaa##a##aabaafhgggfedccccdccbaaabaaaaaa#########a#####a##aabaabcaa#aaa#a#####.####a###########a#aaaba##a####a#aba#aaaabbaaaaabdeecccbbcbbccccdcbabaaabbbaaaabbba",
-"bccdcbbbcccccbcdfda#####acbabcbaabaaa#a###aa#aabbbefedcdffiihhcaaaaaaaabacfffefedcbbbbbaaaabbbbbbbbcaaaaaabaaa####a###a##aaaaaaaaba#####aabaa###########a#a####a###baabccghfhiieaa##aaaaabdga##a#a#aaaa######aabbaaabbbcddegdcbbaa##aaaaaaabbfedfddecbbbbbbaabbabbaaaaaaaaaa####aa####a#a#aaaabcbaaaaaaaa##############.######a#a#aabbba#a####a#aaaabaaabaaabbabcfedcbbbcbccccccbabbabaaaaabbccb",
-"bbccccbbcccccdddeca####aabbccca##aaaa##a#####abbbbeeffeeccfjjifbaabaaabbbcdecdeffdbcbbbaabbbccccbbdcbaaaaa###########a#a#aaaaaba#a######aaabcaaabaa###aa#aaa######acedbcdfihfhifba####aaaadhc###aaa###########a#bbaaabbccccfecaaacca##aaaaaccffdfccedbbab#a#aaaabbaaabababaa###########aaa###bbaa#aaa#abaa##########.########aa####a#aabba#a###a###aaaaabaabaaabbbcdfedbcccbcccccabbbbbbabbbbbbc",
-"bcdcbbcccccddddddba####abbbbdca#a###a###aa####aaabcededcbbgiijjhcabbaaaaaccddddcceedddddddeeefedbbcbcccbbbbaaa#a###aaaaa###aaaacaaa##a###a##acca############acaaaaa#abbccdghccggfcaba#aaaacggdaaa###############abbbaabbdeefedbaaaadda##aabbchedeefedbaaab#####aabbaabacbabaaaa########aa#a###aa####aaabba##a##.#############a#a####aaa##abdba#########aabbaabbabbaabdeddcbbbcccccbbbbaabbbccbba",
-"bbddccbccdccdcebcbb#####abccbcd######aa##a######abcddcdddeggiihhhdaaaabcccceedccbbcbbccbccdeeeggfeddccdeccbbaaaaaaa#a##aaa###aaaba#a##aa######a#####a######aaaaaaabaaababcehb#adcbdbba#aaabdceaa#################abbbbbacgeeecca###bedcaa#adfhccdffbbbba###a####aaaaabbbbaaaba###aaaa##########aa#.##aaaaa#aa#b######a#######aaaa##aaaa###abcdb######a#aabcbaabaabbaaabcdedbbbcddcbbbbcabbbccbbb",
-"bcdfdddcccdddcecbb####a#aabccabaa#####aaaaa#####abbccdedeedcijfggfabaabbbbccddccbbbabaaaaaaaaabbbgihihffedccbbbbbbbba#a#aa####aaaaaaa##aa#######a###aaaa########abaabbbbaccega#cdaaabaaaaabbfea#a#################abbbbbaeedddcbaaabacceccefihdccedcbaa##########aaaaaaabbbaaaa#####aaa##a############aa####aaaa######a#####aa##a##aaa###aaa#a#abc#aa###aabcaaaabbbbbbbbbbcddcbccddcbbbbabcccdcc",
-"ccbcffhfdddddccadbaa#####aabbaaba##########a##aaabbaacdddfeehjifgha#aabcbacddccbbbbbabbaaa#aabcccefgdddeffeecdedbbbbcba###aa####a##aaaaa##a###aa###aba#aa######a#aaabbba#abbfcbcccccbaaa#abbfjg#aa###########aaabbaaabbcbdedcdbbaaabbbcceghhiiedcedbbaa######a###aaaa#abaaaaaaaa##aaa##a##############aa####aaaaa#####ab#####aa##a###aa#aa#a#####aaaa##aaaaabbbbabbbbbbbbbbbbdddccddccbcbbbcccdd",
-"eecbdggfdddedcacda####a###abbaaca######aa##aaa#aabcababcdeeedgigdfgbbcbbbbbcccbbbbbaaaaaaaaaccddddefdecccbbcbbddcbccddedcaaa#a#aa##########a########adbaa#########aabbbcbcabbdcdcbbbcbaa##abbfiaaa##############baaabbbbccedcccbaa#abbbbbefgihfdcccbaaaa###a######aaba#abaaaaaabaa#aaaaaa######...#a#.#####aa#aaaa########a##aaa###a###aa#aa#aaaa#aabbabaaaaabcbbbbbbbbbbbbbbbccdeddcccbdccccdde",
-"eedfhhfcba#abb##a#####a#aabcaaccbc#####a#aa#aa###ccbbbabcdfffhgifehfebbbabbcccbbbbbbbbaaaa#ccdcddfghfeccccbbbbabcddegcbccdcaaaaaa###a###a######a#a##accba#########aaaabbccbbcbcehb###cbba##bdehe###############aa##aabbbccdcbccba##aacccbcceffedcbbaaa#####a######aaba##aaaa#ababcbbbbcbaa########.#.##a####a####aa######aaa###aa####a###a##a#aaa####aaadbbaaacccbbbbbbccbcbcccbcceeeeededcdbccd",
-"dgghigdb##a#a########baaa#abbcbdbbb#####aa#aaaaaaabaababcdegiihdggffdcbaabbbbabbbbbabaaaaa#ccdccdegedccbbbbbbcbbbbaadbabaacdb###aa###############aaaab#aa##a#######aaaaababbbabbfieaaaa#aaa#chke.#########..#aaaaaaaaababbccbbcbaa#aabbcbabcdeedcba###a#####a#a##.###baabbaaaaaaaabbaaba#########....#.#######ab#a#######a######a#########a##aabba###aaabbbbbbacdcbbbbcbcccccbdddeededegeddddcdc",
-"dhghhfa##a######a######aabaacccedaaa#######aaaaaaaababbbccdghgfedgfgcabaaaaaaabababaabaaaaabdcceeeecdbbbababbbbccbbbbbabdbabcba#a############aa##aaaaab#aa###########aababcbbaabeggh######aaagj##############aa#####abbaabbbbbabbbabcabbaaaabcddccba#######.###########ccaaa###aa##aaaa###a###..##....#.aa##a############aaa#####a#####a###aaa#aaaa#aaacaabbbbbbeccccbbccddccdegghhgfeegd#bddccc",
-"ffhhhe###########a#####b#bcadddcbaaaa#####abcca#aaaaaaaaabdhihgddfgfgcaaaaaaabbbabbbaabaaaabedcefecbbbbbbabbbaaabbacdca#aaa#bbdb#aaa#########aa####aa#a###a#####.###aaaaadbbaabaddcggbaaaa#bbdia#a##########aaa###aaabaaaabbbbbbaacefebaa#aaaabcccbaaaa###########.#.##ad#####.##aaa#aa#aa#####...#...###ab#ba######a###a##ab#####a###aaa##aa#aaaaaaaabbbbbbbbbbceddeeccbccccddfhijjhggghb#bba##",
-"#afhgcaa###########a#a##aabcddca###aa######abbbabaaaaabaaaeiiihgbbgeddaaaaaaaaabbaabbbaaaaabdcccddddccabbbbacaaaaabbbaaabaa##acdd###a######..a#a#####a#aa##a########a##aaecb#abbbcccfgaaaaaaaeia#a#a##############aabbaaaababbababdgeca####aaaaabcbbba#####a####.#######da##############aaaa#######.##.#.#ba########.#a#aa##abba##aa#aa#aa###aaaaaaaaaabbbbbcbccccefgeeccbccbbbbdfiihgggeb#aaaa#",
-"##bhgd###############ab#ababcdd###aaaa####aaaaaaaaababaaaadhhigebabfddcaaaaaaaaaaaabaaaaaaabcbbbcbbcecbbbabbbaaaabbaaaaaba###abadea#########.#a##########aa#a###a###a####aabbabbaadccghbbbaaabfi#a##a###aa####a##a#aaabaaaaaaaabbacfdba##a#aaa#aaaabbb######a######.##a#######aa#a##a#a####aa#####a#.#a####aa#########aaaaa##aaa###aa#aaaaa#aaaaabaaaabcbbbbccccceeceeeefedddcbbceeffhgfebaa####",
-"##.dhdb#########ab###bdababaddc######a###.#a######aabacaaaadghfdbbabecdba###aaa#aaaaccabaaacababbbbbbbcbcbbcbaaaaababaaaba####abbcfbaa#aaa###.###ab#####aaaa##a######aa#ba#aabbbabdcabefbcaababhe#a##aa##aa###a#####aabba#aaaaabbbefcba###aaaa#aaaaaaaa#########a#.##############aa#bb#aaa##a####.###########aaaaa#######aaaa###a####a##aabaabaaaaaaaaaabbbcccddebbbbdedefdcccccbceeghgfdaaba#aa",
-"aa#aeea##########c####ba###aca#####aba#############abcabaa#acdefccbacdbdc##aaaaa###aabdbaaabbcccbbbbbbbccbabcabaabbabbaaaaa###addbcdba#a################a####aaaa#aaaaaaaa#aaacbabdcbbbehca#abbeh#aa######aa######aa#aacfbaaaaaabbdgdbaa###aaaa#aaaa########.###aa#a.###########aaa#bbaaaaaa####a#.##.#######aba#####a#############a#aaaaabbba#bbbbaaaaabbcddddddbaabcedccbaadfdcceeggdbaaaaaaa#",
-"aa##ada#a########aaaa###a###a######abaa#########aa#abbbaaaabbcddeeebcdbabb#aaaaaa####aaaabcccbccbaabbbabccbaaaaaaaabbaaaaaaa##aabcccfeb##############a####ab#aaa##aaabbaacababaaaabcdbccffc##abeh.##aa###a#########aaaaacbabaaaccddfgdbaaa##aaaaaaa#######.##.#######.#########aaabaab########a#a##.#########aaa#####aa##a#aa###bdaaba#aa#aabaaaabbbabbbbcddefecbcbaabbdcbaabcecccefgcaaaaaaaaa#",
-"aaa#aaaa#aaaaa#####aaaaaa###########a#####a##ab#a##aacabaaabcccbdhedfdbbabc#aaaaaaaba##aaaeheaaaaaaabbbacddbbaaabbbaaaaaaabc#aa#a###cfgb#a#########aa###aaaccaaaaaaaacbabcdaacbaaabcddcccgfcaabeg.#a#aa#a###aaaa####aaaaabaaaaaaceefhfdbaa###aaaaaa########.####.###.####.####aa#abcbaaa####aaa#############aaaaaaaa#aaaa#ba#babffb#acb#aaaabaaabbccabbcccfgdaa##bcbbaaacbcbacebbbcddbbaaa#a####",
-"accccedaa#aa#aaa##a#aabda#################a#a#a##aaaabbbabbcccdcccfcfecbaaceca#aacdbcccba#ahgabaaaaababbbccccbaabbbbbbbaaabcb###aca#aabcc##a##########a###a#abaaa#aaabbddddbbbcbaaaaabcdddhecccg######ba#a##.#a###aaceca#cbaaaaacdefhgfcaaa#aaaabba#########..#####...#.#######aaabccbaaa####aa########.####abb##aa#aaa#a#ba#abbefba##bbbaaaaaabbccc#ccddeffcaaaa#baaaaabebbbbcbbbbcbbbbbaa##a##",
-"#abeeebaaa###aa###aa###aaa###################aa###a#aabbbbcddddccefegfcca#adhbaacccaaabcbcdecaaa##aaacabdabdcbaabbabbaaababbcb#aabb#aa##dea##aa#######aaa##a##aabaaaacacdfebbbbbbabccccfeddfgfed...#a##aa###########acdbabbb#aa#acddegfecbaaaaaaabaa#########...#####.#########a#abbbabba##aa#####.##....#####a##aaaaaaaa#baaaceeebaaaaeedbbbabbbccb#cedddcccbaaaaaaabaa#bebbbbbbbbbbbbbaaaa####",
-"##aadba#aa##a#######abbda################a#######aaaa#ababccdeeddffhhgccbaabefdbbaaa#aabcbbabca#aaaababbbbcccbaaacaabaaabaaaabbaaaab#aaaaefaaaaaaa#.###a#a#a######bbbaabccabbdcbabbcbcdbbaaaefeiiffa####a#######a##aaaaabbcba#baabdddefffdcaaaaaaaaaa##########...##############aabbbbbdabaaa###.....########aaaaaaaaaaaaabcccbdfebaaaaaacfdccbcddc##baabcbabaaaaaaaaabaaaedbcbcccccbbccbaaaaaaa",
-"a##aba#a####.######a##bgb#######a########aa#######aaa##aabbcceedddeghiebaaabccebaaaaaaaabaabaaabbaaabbaaabbbbbaaabbaaaaaaaaabbccbbcba#####cfebbabbbacaaaaaa#aaaa###acbbbbbbbbcbaabbbccbaaab#.aceffdfghfa#a####aa#aa##acbacbbbaaaaabcedcddedbaaabaaaaaa#######..#.################aabccccdbbb####.#..#..#.#..########aa#aaa#aaabdddbcababbbdeddedeeb####aaaaaa#ba#aababcbbbaeccbcbcbcbbbbaaaa###a",
-"ba#a#####a#############cb#########aa##a###a####ab#aabaaaabbbbedcdccehihcbbbbbbccaaa#a#aaaaabbaaaabbbcbbaaabbbccaaabbaaaaaaaaaabbbbacda####aaedbaaabddba#aaab###aa####aaddcceebabbbcbcdca#aaba#aaabaabfmka##aabaaaaaa#abbabbbbaaa#acccdddccedbbbbaaaaaaaa##a####.#.###############aabddcbbcaaa####.#......aa###aa####aaaa#aa##aacccccbbbabbcdedddea####a##aa#a#bccbccbcbbaaaadddccbbbbbbaa#aa####",
-"ab##aaaa######a##########aa###b##aaaaa##a#a#####ababbbaababbbccccdcdgjifbbabbcccca#aaaaaaaaacaaaaabcccbaaa#bbbcaaaaaaaaaaaaaaaaccbaabbaa#a#a#bcbbaa##a###aaba######aaaaaaddfhgccddddacacaaaaa#aaaaaaabhnk.aabbb##aa####aa#acaabb#aabccddeecccbbbabaa##aa###aa#######.######a###aaaabdddcdedda#########...#####aaaaaaaaa##a###aabcbbccbbbbcddeeefc##a####aaaaaacdccbbaababaaabccdccccbbbbaa#a####",
-"#####a#aaaaa###aaa######ba###aa#bba#aa#abca##bb#abaabbbbbbaabbbbdccceihgecbcdccbcd#ababa##aaabaaaaaabccbaabbddbbaa#aaaaaaaaaaaaaccbaaa#a######aabdcb##aaa##a#a#####aaaa##aabffebccddcb#aa#######aaaaaadlnd#aabbabaaaaa##aaaa####aaaabccdeedbb#aa##a###############.##..#.#####aaaaabccdeecdaa#####.########.###aaa#aa###aaaa#aaabcbccccbbccddeef##aaaaa####aaaccbaabaaaaaaaaba#bcddcbbbbbb#aaa#a",
-"abaa###aaaaa##a#a##a#############a#a#ababda#aaaaaaaabbaabbbbcbbbddbddgifhedbcccbbcc##aabbaa#aaaaaaabaabbbccccdebaa##aa#aaaaaaaaaabedaaaa##########becaaaaa#a#########aaa##abceffdccb##aa########a#abbabilk#a#a######ab#aa#aa#####aaabbcddedbaa#a######a#####################a#aaaaaabdddfgfc##########...a#a###aaa#a#aa##a###aaaabbbbbcbbbcceghfaaaaaaaabbabccbbbaaaaaaaa#abba#aacedcccbaaaaa#aa",
-"bbaa##aa#aaaa#aaaaaaaaa#aaa##########abaaaa#baaaaabbbbbabbbbccccddbddggghhfdbbcaabbbbbaabbaaaa#aaabbaaabbb#bbbaaa#####a#aaaaaaaaaabb##aa##########aabdcbabaaaa####aa###aa#abbcdhhcaba#baaa#######aaaaabhlmc#a#####aaaaa#a##abba#aabaaabcdgfbb################################aabbaabbccdhigca#########.########aaa########aa#a##aaabbbbccbccdgfha#caaa.##fedbbcbaaaaaaaaa#aaa###aaadecccbbaaaaaa",
-"#aa###aaa#a#aaabbbbbcbaa##a#######aaabaababaa#aaaaabbbbbaaababccdecdfhhiihgfdbccbbcbabaaaaaadca##abbaaaaaaa#bb##aaa####aa#aaa#aaaabbda.##########aaaabddcbbaa#a##aa#aaa##aaabbdecca#a#aa#a########aaaaaeili##a######abaa###aaaaaacfeaabddcdbaa##############################aaabbbbbbcdfgjieba####.#####aa#aa############aaaaa###aaabcbbcbbcefggcbbfeedbedbcbabbaaaaaaaaaaaaaaa#aaa#cdcddcbbaaaa",
-"aa#a###aa#a##a#aaaabbccaa#aaa########bacbaaaaaaaaaaaabcbbbbbbcedcdccfhfhkhggfdbbccbbabaabaabdda###aaa#aaaaaaacb#########aaaaaa#aaaabec##########aaaaaaabddcbaaaaaaaaaaaa##aabacbaaaba#####a##a######aaabgklbaaa#####aaaaaaaaaaabbbfdaacddeddcbaaa#########aaab##########a##aaaabbcbbbbeffhjifdcb#####.##acbb#aaaa###########aaaa#aaacbcbbcbcegfaccgghgffdcbbaabbbaaa#aaaaaaaaaba#aaaabeecccbaaaa",
-"aaaa########aaaabbabbbbcbbbaaaa#####.##aaaaaaaaaaaaabbbbaaaaadedcdccegijkifddebccbbccaabaaa##aa######aaaaaaba#aa#########aaaaaaaaa#bccda#######aaaaabbaaabddcba#aaaaaaaaaaaaabcdaaaaa##abaaa#a#a#a##aaaafhlg.aa#a#a###ba##b#acaabcdfaaaccdccedba##########adcbca#########a#aaabbcddccbdefggiigecb########aaaa#abba###########aaaaaa#bdbccbccef#abdeddeeddccba#bbbbbaaaaaaaaaaabcaaaaaa#eedccbbba",
-"aa#aaaaa###aaaaaaaaabbbbbbbbaaaa#######aabaaaaaaaaaabbaaaaabbbfeccccdfiljigcdeccccbccbccbbaaaa#######a#aa##aaa#####..#..#aaabaaaaaaabacb######aaaaaaabbaaaacddcbaaa##cbabaaaaabcbaaaaa###a##a####a##aababchl#.###a#####aaaaaa#aabbdeaaacbbbbdfdccbabb####a#ddbbbba##########abbbccdcccddefghhfcaaa######aab#abaaddaa########ab###aaaacccccdefd#dbgebcccdcaabbbaaaaaaababbbaaabacaaaaaba#eeddcbba",
-"aa#aaaaba#a#a##aaababbccbabbbbba########aa#a#aaaaaaaababbaaaaadcccaddfhkjigdcdecccbbcdcecbaaaa######aca####aa#####a#####.#aaaaa#aabababb######aaaaaabbabaaaaabcdcbaaaaaaaaaabbbcaaaa#a####aa####a#aaaaaababjh.####a#####aaa##aaaabdabaaaabbabdeeeddddcb#.##debaaabaaaba####aaabbccdcccddeffgfgcaa##aa###aaaaaccaddca########a#a###aaaccbbceffbaacgeaabbbbabaaaaaaaaaaabaaaabbcaaabaaaabbbccdedcb",
-"ba#a#aaaaa####aaaaaaaaaaccbcbbaa#######aaaa###aa##aaaaaaaabbbabbcbbefffhjihfcbfcbcbbbcfhgcaaa#####a#deaa##aaaa###############a##a###aaaaa###aaaabbaaaababbbbbbbbedcbaa#abbbbbcccaa##a######aa##aaa##abaa#aabja##.#######a#a###aaabecaaaaaaacccbcaaaabbdddefedcbaa###aaaa#aaaabbbcccccccddfggghdba####aababababcbbddba###a###a#aaa##aabbcccegfbaabcaaaaaaabbaaaaabbaabaacaabbbabbadbaaaaabba#aefc",
-"ba#a#aa#######aaaaaaabaabbebdbbb######aa####a###a####aaaabbaabcabcccddffjhfdbaefcdbbbbdjkjebaa#####bccb##baba#####aa######a###a#a####aaaaa##a##aabaaaaaaabbbbbbabefdbbcbbbcbbbcbaa####aa#######aaaaadaaaaabbdg###a#a####a#aa#aabccccaaaaaabcdbccaaaaabbdeeedcdcba###aa#aabaaabbbcbcccddddeffffdbaa####abccbb#bbccdbccaa###a#aaaa#a#aabbdcdfgdaaaccaaaaaa#aaaaababbaaabbbbbabbbbbcbcbaaaabaa###be",
-"fcb#############aa#aaaaaaadegdacbaa###aa####aaa#a####aaaabbaaabaabddccehieabaabecccbbbbbikkgca####acbb###baba#####aa####aaaaaaaa######aa###aaaaaaabaaaaaaaacbbbbbbeffedccbcddddbaaa##aaaa###a##aaa#adba#aaabbie.#.#aa##aaaaaaacecaaaba###a##aabdb#a#aaccccccccbbba###aaa###aaabbbbcccdddedegcddcbbaaaabbabbabbaabbaaddbaa#####aa##aaabbddefgcabagbaaaaaaaaaaaabbaaacabaaaaabbbbabbaaaaaaaaaaaa#a",
-"bdeba#########aaaaa###aaaaacfebbbbaa###aa#####aa########aaababaacbdeccehhbaaaaaddcbbbbbcgijhea####acb########a##aa#a##a#aaaaabaaaa####aaab###aaaaaaaaaababbccbbbbacbedffedcdeeaaaab#aaa#aa##a##aa#a###aa#aabackc.#.##aaaaaabdefb#a#aaaaa#a####abc####abcbbeecbbaaabb#aaaaaaaabbbbcbcdededdefdcaccbca##aaaa###aaaaabaaeccaaa###aaa#aaabcccdffbbacfc#a#a#aaaaaaabbaaaaeabcbbabbbbcbbabb#aaaaaaa#aa",
-"##aba######aaaaaaaa##a#aaa#fdaabbccb###################a#aaaabbabccccdehibabbbbcfdcbbbabgihc#a####abbaa##a###aa##a#aaaa##aaa##aaaaba###daaa###abcaaabaaabbbbbccbcbcdcdddggfedbcbaaaaa##a#####aaaa#aa#####abbbbdjb.a##aaaaabeecabba##aabda######aa####aaabbdcdcbaa#bcbbaaaaaaaabbbcccddedefffdcbccbab####a#####a#aaabaabeeba######aaacbcddegebbacccba##a#aaaaaaaaaaaaccbbbbbabaaa#aaabbaaaaaaaaaa",
-"aa##baa####aaabaaaaa#####aacaababbccbaa##################aaaaaaaabbccbegifaaaabbcecbbbbaadgb#####aeeabc#.######aa##aaaaa#aaaaa###abaa##edaaaa##aabbaaaabbbbbbbccbbdccccdddehhdabbaaaaaa##a###aaaabb######cebcbcgj#aa##abdfggcbbbaaaabdfea####aaaaa##aa###aaa#aaaa#aaabbaaaaaaaabbccddeeddeffeeeefcabaa#aa#####aa#aabbbacccbaaaaaaaabcccdegfbbbceaacb#####aaaaaaaaaaaacccabaaaaa#a#abbccaabbaaaa#",
-"#aaa#daaaaaaaabbbaaaa####abbaabaabcbbbbb##aa################aaaaabbbddehecacbaaaabecbbbbabaa#####adcca#########a#a##daaaaacaaaaaa###aa#aca#aa##aaaabbbaabccbbbbcddaccdeddecfhgcabaaa#ab#a####a####aaa#aaaabbbcbcijdchihgighedbcbbcdfdabbbbccaaaaaa###caa#aaaa#a#a##aaaaaaaaaaaaabcccdddddeeedeeeffbaaaaaa##aa###aaabbbabcdeabaaaabbbbcdegibabbfaabca####a#acca#aaaaaaababbbaaaa##aaababbaaabaaaa",
-"#####adcbbbaabbbaaaa#a#a#####aaaabbaaabcbaa#################aa#aaaaabddgeadbcaaaaabccbbbbba#####a#a##aaaaa###aa#aa#bccaabaac#aaa#####a#..#####aaaaaabcbaaabbbbcdccdcddedceefgfccbaaaaaa#aa###aa##accaaaaaaaabbbbdjkfdfgjjhgfeeeeeedcaabaabaaaaa#####ab#a#aaaa###a####aaaaaaaaaaabbccddccccdccdeeegfbcbcaaa#aaba#aaabdcbbbababbbaabbcccdghg#aadbaabbaa###a##acdaaa#a#aa#baaaaaaaaa#a#aaaccbaabaaa",
-"a##a#aaedbbcbabaaaa##a##aa####aaaababbaabacaaa###a#######a####aaaaaaaccehbbbbcbaaaaacdbbbcb#a#a#a#.####aaa##a#aaaaaaabaaaaab##aaaaaaaa#####aaa##aa##abbaaabbbccbccbcdcdcddeffcaabaaaabba#aa####a##bcbaaaabababbbbejib#abccdcbbccba##a##aaaa##a######a##aaaaa#a###a#####aaaaaaaaabbccccccccccccdeegfcdabbaaaaaaa#aaaabccbbbaccbabbbcddefedea#cd##a#aaab#aaa##bcb###aaa##abaaaa#####aaaaabbcbaabbb",
-"aa##aa#bhgccbbccbbaaaaa########aaaaabcbaaaabbaaaa###aa#####a#a#aaaabbbbcega##acbabababecccdabaa##########aaaaaaaaaaaaaabaaa####aaaaaaaa##.##abaaa#aaaaabbbbbbbbcdbbccddcdcegeaaaab#aaaaaaaaa####aabbabbcbbbcaaabbcegiaaaaaa##abbcbca##.###aaaaa####aaa##abbaa#aaaaa####aaaabbaaabbbbccccbcccdddedfddcaaaaaaaaaaaaabbccdbbbcecbbccdefged#a###fa######aaaaaaaabaa#######aab#aaaa#aa#aaaaaabcccabaa",
-"aa##aadafhhfeccbbbaa#aaa##a####a#aaaaaaaaaaaaaaaaabaaaabaa#aa###aaaaaabbcfd#a#acbaaaaabeecdcc#############abbaaaaaaaababbba###aaaaaaa#a#####aa#aaaaaa#aaaabbbabcccehgeecdegebaaaaaaaaa#aaa#aa###aaaaababccbbaa#aabceggaaaaaa#aaaabcb####a###aaba######a#a#####aaaaba#####aabbaaaabcbbbbcbbacceeddeebabdbabbaaaaaababcdccdccdcbbccefecb#####cc#########aaaaaaaaaa##ba#aaaaabbbbaaa#aaaaaabcccdgdb",
-"##aaacdggggghgdbbbbbaaaaa#aa###a###aa##aaaaaaaaaaaaabcbbaaaaaa#aaaaaaabbbdfd#aaacdaaaaaadgefc#######a#a###abb##a#aaabaaaaaa#######aaa#a########aaaaa##aabbbbbbbbccefhfeeegfbbba#aaaaaaaaaaaa####aa##abbcdacbaa##aabcehfaaaa###aaababa##.##a#aaaca#a#aaaaaa#aaaa#aabcc#####aaaabbbbbadcabbbbbbceedefcaabcecaaabaaababccdcdddccbbcceda#####baeaa#aaa#####ab##aaaaa##aaa##abbbbbbbbaaaaaaaaabbbagig",
-"f#aaaehhfffeffhfbccbbaaaaaaa####a#aaaaa###aaa#a#abaabccabcbabbbbabbaabbbbcehdaaaaaaaaaab#dgeaa##a###########aa####aaaaaaa######a####aaaa###a###aaaaa###aabbbbbacccdedddfgebcbaaaaabbbaabaaba#########abcbdabaaa#aabcdeibaaa######aaaca######aabbb####aaaaaaaaaaa##bbdb####aabbbbaaaacdcaabbbbcceddeccccaba#aaabaaaabccddddddceddeec#aca#aabebaaa#######aaaba#######aaaaabbbabbbbbaaaaaaaaaba#dii",
-"hd#aaejiedefeeddedccbaaaaaa########aaa#######a#a#aaaabbaacbbababccbbabbbbbceidbaaaaaaaacbcgeca#############aaaaaaaaaaaba######.a############a##aaaaaaaaaaaacbbbccccedbcfcbbbbaaabbbbaaaaaaababaaa#baaaabababbabaaaaabdfhaaaaa#aa##b#bbaa#####abb##a##aaaabbba#aaaaaacda#####abbbbaa####a#abaabccbdecdbbaaaaaaaaaaaabccceeedcdfgffeba#aa#aa#bcaaa##########aa##a####aaaaa#aaabbbbaaaaabbbcbbbeefh",
-"ggecdhjkiefeeddcdefdababaaa########aa##a########abaabaabcdabbcdccbcbabbbbccchiecaa#abbbaaaadeca#####a#######aabaaaaaabba###a##.#############a##aaaaaaaaaaabbbccdddbbeccdbbcbbbabbbbbbcbbaaaabccaaaabaabcabbabaaaabaabcefeabaaaaa####aaccb####aaa###a###aabbab#a#aaa##aaa#####acbba#a######aaaabbbbfefdaaaacaaaaaaaabbbcefffeefbed########a##dbaaa#######a#############a########aaaaaaaaaccfgfhdf",
-"efddegijmkfeeeddccdgdbcccbaaa####a#aaa#####a####a###aabbcbabacccdccbbbbbcbbdfijhbaaaaabb###cedbaa###aaa#####aabbccbaaaaa###accb###a##########aaaaaaaaaaaabcbbccddddcddaaaabbbabbbbbbcbaabbbbbaaaabbaaaaabbbbaaa#ccaabbddheabaaaaa####abca#####ba##a####abcaaaaaaaaaa#aaaa#####bbaaa##aaaa##aaabbaaadfdbaabcbaaaaaaabbacehhhhcaaaa#####a#ab##ccaa########aa#############ba#a#aaaa#aaabdaaeffghgff",
-"eddcbcdefijgeedcccbbdeccccbaaaaaaaaaa#a#########aaa##a#abcaacccccccbcbbccccdefikibaaaaaaaabbdddca#a#a#aa####aaabbbaaaa##a##aaaba##aa##a######aaaaaaaaaaabbbbbccccddddaabbaabcdbbbccbacbabcbbccbaa#aaaa###baaaaa#a#aaabcdfjb#aaaaaa####abaa.####a##aa####bcbbaaaaaaaa#####aa##abaaa#a##aaaaaaaaaaaaabecbaababaaaaabbbcbcehhcaaa##aaa#######b#.cbabaa#####aa##a#####a#########aa#a#aaabdefffggfefe",
-"ddcaaabdefhihecdbbbbacdecccbbaaaaaaaa############aa##aa#ababbcbcbbbababccdceeegijgaaaaaba###bfcdc##aaaaa######aaaaaaaaa#aaaaaacba#aaa#a#ba#aa#aaaaaaaababcbbbbbcedabbaabbaaabbbabbdccbbbaabbbbbaaa#aaaaa##aaaaaa#####abcehka##aaa#####aaaa###..a#aba#####abcaaaaaaa#a##a##a###ba########aaaa####aa#deaaa#aaaaaaabbbbbccefcbaba##abaaaa.#a#ba##dc#a#a####abaabb#a##aa##a###a###aaaaabaceecddhhedd",
-"cccbabbcdfffhheccbbbbbcdfccbbbbaaaaaa###############a##aaaabacbbbbaaaacccddcdefhjjhbaaaabaa##dfbbc###aa#aa######aabaabaabbbbbabdb#aa#a###bba#a##aaaabbabbbbbcbbcedbaaaaaaaaabbbbbcbccbcebbbbaaaaaaaaaa#####aaa####aa#aabdegj.############a##a##a#aba####a##baaaaaa#a###aa#aa########a##a#aaaa####a#eeaa###aaaaaaaaabbcdgfdbaa####aabbcb#aabc###cda#aa##aababcbb#a#aa###a##aab#aaaaababdecbcdheed",
-"cbbaccbcddeffeedcbbbbbbccffdbbcbabbaaa#aa########a###ca#abaabbbabaaaaabcccddcdgiikjgbaaaaba##afcacba###aa########abbbbaabbbbbbbcbbbb#aa#a###aa##aaaaababbbbcbccdca#a##aaaaabaaabcccbbcbcbaabba##aaaaaba#####aa####aabbbddcdjd.#########.#..#######aba######aaaaaba########aa#######aaa#aba#aaa###aacaaaa##aabaaaaaaabbcefcbbaaaaa##aaacabaaaa###bca#####aaaaacaa#a###a##a#aaa#a#aabbbbcddcccegdd",
-"cbbabbbbccddeedddcbbbbbbbbdfheccccbaaaa###########aa#bd##baaaabaaaaaababcddcccggijjjbaaabbaa##bcbabba##aa#######aaaaaaabbbbbbbbbcccaaaa##a##aaa##aaaabbbdbcbbcdfbaaa#aaabbbbbbbbbcccbccdedaaa#aaaabbaaaa#a#aa####a#abcccdccfi###########....#######aa##aaaaaaaaaaa##########a###a##aa#aa#aaa#####aaa#aaaa##abbbaaaaabcdefbbaaaaabaa####aa####a#a#dba#####bb##b###########aaaaa#aaabbaabbbccddede",
-"baabbbbbccccdeedcccbbccbcbbcdiheccbbbaaaaa#aab##aa###aa###aaaacbaaaaaababccccdfhjjjl#abbbaaba#abeaabb######a#####bbaa#aaaabbbcbbabbaa###aa####a###aaaabacdcccdceaaaaaaaaaababbbbbbbcbbbcbdba###aabbbaaa#aa##########aabbabccgb.###.#########.########a#aaaa#abaa#########a##aa#####bcaabaaba###aaaaaaaa#####aaaaaabbbdhidabaaaaaaaa###########a###ebbb###aaa####a###aa#aabcaabbaaababaaabbbbbdcb",
-"abcbbbbbbbccbbcddbcbbbbbbbbbcfeghfccbbabaaaaabaaaa####a#b##aaaabbaa#aaaaabccbceefhegdedaaaaaaa#abdaaba#aa##a#####aaaabaaaaaaabbbaacc###aa#aa####a#aaaaaaabcccddfbba#aaaaaabbbbabbccccccbcbdaa#####ac#####a##########aa#aabcbdh..#########.#####.####aaa#aaa###abb###########accaa###a##aaabbbba#a##a#abba####aaaaaccegcbbaaaaaaa#aa###.##a########aeaaaa###a#a######aaa##aaaaaaaabbaabbaacaacced",
-"cadbbbbbbcbccbbacbbbbbbbbabccdeehgffccbcbaaabaaaaaa###a####aaa#aaaaaaaaaaabccbdeeffeehgcaabaaa##adb#aca##aaa#####aaabaaaaaaaaaabaacdb##aaaaaaa#abbaaabbbabbdecffbaaaaaaaaaaaaaabbaccbcbcccdcaa#############aabb######aaaaabbbehd..###d#.#.######.####adbaaaa##abba########aaaaaaaaaaaaa#aaaaaaa#a#aa#abaaa####aaacdeheaaaaaaaaa##aa#aa#####a####a#.cdaa######a##a###########aa##aabb#aabaaabbadf",
-"cabdabbbabcccdccbccbbbbbbaabdcdefdcfgccbbbbaabcbaaa###aa##aca####aaa##aabbbccccddffhihhfbaba#c###bdaaagaaa#a######aabaabaaaaaaaa#a#aa####aaaa#aabbaaaabbbbbcddfeca###aaaaabbaabbabbcbccbbbccdada###aa######aaba####a###abaabcafjlf..defe##...#########bbaaa###aab#a#######aaabcb#aaaaaca##aaaa####a##aab###a##aabdfiida###aaaaa##ca#aa#####a####a###ecaaa########a##a#####a####a###aaaaaaaaaabab",
-"ccbbbbabbaaabccdcbbbbbbaaaabcdbbbeeadgeccbbbbabbbaaa##aa#abedbaa####a####bbbcbccddehhhfdaa###da#a#ddaabhaa###########a#abaabbaa######a####aaaaaaaaaabbbbbbcbdeefcb###aaaaaaaaaabbbbccccbbaabbcaaa############aacbaabaaaaaaabccbdejkbd..bgccdcba########aa######aaa#a#######aaaccaba#bcaaba#a##aaa#####abba#aa#aabdgkjkihgdb#.cedcbb#.###dc########b##ebaaaa#########################aaa#aaaaaaba",
-"abeecbbaababbbabbdbabbbbbaaabcccbdcb#ehedccbbaabbbaaa#abaaaedba###########acbbbcceeeggdaaa#bacaa#aadabbdf#######.#######aaaaaa######bca###aaaaaaaaaabbbbbbbccfffbaaaa#aaaaa#aaaabbccabbcccbbbbaaaaa#######a#aa#acaaaaaaaaaaaabccceglh.#....#baacca..####ab########aaa####a##ababbbba#ceaaaaaa###a######aa##acbbbbchgcddfgjihddigefegfffba#affeecbbaaabda#aa######a#a################aaaa#aaaaaab",
-"babfdcbcbabaabababbbaaaaaaaabcccdbaaaacifddcbbbbbbbabaabaacecabaaaaa######aaabbcdeeedifba#adcbaaba#bcabbfe#aa####aaa###a#abaaaa######aaaac#aaaaaaaabbbdbbbbcceebbba##aaaaaaa#aaabbbbbbcccdcabaaaaab##a#aaaaaaa######abaaaaa#abbbbddei#####a####.#ee######aa######aaaba######abaaaa#a##bc##aa#a####a###a#aaaabcbbbceecbbcbdeffgfdccccdefeefgffedcefeb##cdbcba########a###########a###aaaabaaaaaaa"
-};
-SIMPLE = T BITPIX = 8 NAXIS = 2 NAXIS1 = 384 NAXIS2 = 384 HISTORY Written by XV 3.10a END 3"3wUD3D3"3""3"3"333""""""""3DDDU3""""DwUUD3333333"3""3""DfD"3""""""""33DUfffUw3""UD3""3"3D"33wf"""""""3""""""""D""""""""333U3333DDff333"""""""""""333333DDDUD"3"""""3"""""""""3""""""3333UUf"
diff --git a/gtk/test.xpm b/gtk/test.xpm
deleted file mode 100644
index 9b0d2efdb2..0000000000
--- a/gtk/test.xpm
+++ /dev/null
@@ -1,92 +0,0 @@
-/* XPM */
-static char *openfile[] = {
-/* width height num_colors chars_per_pixel */
-" 20 19 66 2",
-/* colors */
-".. c None",
-".# c #000000",
-".a c #dfdfdf",
-".b c #7f7f7f",
-".c c #006f6f",
-".d c #00efef",
-".e c #009f9f",
-".f c #004040",
-".g c #00bfbf",
-".h c #ff0000",
-".i c #ffffff",
-".j c #7f0000",
-".k c #007070",
-".l c #00ffff",
-".m c #00a0a0",
-".n c #004f4f",
-".o c #00cfcf",
-".p c #8f8f8f",
-".q c #6f6f6f",
-".r c #a0a0a0",
-".s c #7f7f00",
-".t c #007f7f",
-".u c #5f5f5f",
-".v c #707070",
-".w c #00f0f0",
-".x c #009090",
-".y c #ffff00",
-".z c #0000ff",
-".A c #00afaf",
-".B c #00d0d0",
-".C c #00dfdf",
-".D c #005f5f",
-".E c #00b0b0",
-".F c #001010",
-".G c #00c0c0",
-".H c #000f0f",
-".I c #00007f",
-".J c #005050",
-".K c #002f2f",
-".L c #dfcfcf",
-".M c #dfd0d0",
-".N c #006060",
-".O c #00e0e0",
-".P c #00ff00",
-".Q c #002020",
-".R c #dfc0c0",
-".S c #008080",
-".T c #001f1f",
-".U c #003f3f",
-".V c #007f00",
-".W c #00000f",
-".X c #000010",
-".Y c #00001f",
-".Z c #000020",
-".0 c #00002f",
-".1 c #000030",
-".2 c #00003f",
-".3 c #000040",
-".4 c #00004f",
-".5 c #000050",
-".6 c #00005f",
-".7 c #000060",
-".8 c #00006f",
-".9 c #000070",
-"#. c #7f7f80",
-"## c #9f9f9f",
-/* pixels */
-"........................................",
-"........................................",
-"........................................",
-".......................#.#.#............",
-".....................#.......#...#......",
-"...............................#.#......",
-".......#.#.#.................#.#.#......",
-".....#.y.i.y.#.#.#.#.#.#.#..............",
-".....#.i.y.i.y.i.y.i.y.i.#..............",
-".....#.y.i.y.i.y.i.y.i.y.#..............",
-".....#.i.y.i.y.#.#.#.#.#.#.#.#.#.#.#....",
-".....#.y.i.y.#.s.s.s.s.s.s.s.s.s.#......",
-".....#.i.y.#.s.s.s.s.s.s.s.s.s.#........",
-".....#.y.#.s.s.s.s.s.s.s.s.s.#..........",
-".....#.#.s.s.s.s.s.s.s.s.s.#............",
-".....#.#.#.#.#.#.#.#.#.#.#..............",
-"........................................",
-"........................................",
-"........................................"
-};
diff --git a/gtk/testcalendar.c b/gtk/testcalendar.c
deleted file mode 100644
index d870890c80..0000000000
--- a/gtk/testcalendar.c
+++ /dev/null
@@ -1,422 +0,0 @@
-/* example-start calendar calendar.c */
-/*
- * Copyright (C) 1998 Cesar Miquel, Shawn T. Amundson, Mattias Grnlund
- * Copyright (C) 2000 Tony Gale
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- */
-
-#include <gtk/gtk.h>
-#include <stdio.h>
-#include <string.h>
-#include <time.h>
-
-#define DEF_PAD 10
-#define DEF_PAD_SMALL 5
-
-#define TM_YEAR_BASE 1900
-
-typedef struct _CalendarData {
- GtkWidget *flag_checkboxes[5];
- gboolean settings[5];
- GtkWidget *font_dialog;
- GtkWidget *window;
- GtkWidget *prev2_sig;
- GtkWidget *prev_sig;
- GtkWidget *last_sig;
- GtkWidget *month;
-} CalendarData;
-
-enum {
- calendar_show_header,
- calendar_show_days,
- calendar_month_change,
- calendar_show_week,
- calendar_monday_first
-};
-
-/*
- * GtkCalendar
- */
-
-void calendar_date_to_string( CalendarData *data,
- char *buffer,
- gint buff_len )
-{
- struct tm tm;
- time_t time;
-
- memset (&tm, 0, sizeof (tm));
- gtk_calendar_get_date (GTK_CALENDAR(data->window),
- &tm.tm_year, &tm.tm_mon, &tm.tm_mday);
- tm.tm_year -= TM_YEAR_BASE;
- time = mktime(&tm);
- strftime (buffer, buff_len-1, "%x", gmtime(&time));
-}
-
-void calendar_set_signal_strings (char *sig_str,
- CalendarData *data)
-{
- gchar *prev_sig;
-
- gtk_label_get (GTK_LABEL (data->prev_sig), &prev_sig);
- gtk_label_set_text (GTK_LABEL (data->prev2_sig), prev_sig);
-
- gtk_label_get (GTK_LABEL (data->last_sig), &prev_sig);
- gtk_label_set_text (GTK_LABEL (data->prev_sig), prev_sig);
- gtk_label_set_text (GTK_LABEL (data->last_sig), sig_str);
-}
-
-void calendar_month_changed( GtkWidget *widget,
- CalendarData *data )
-{
- char buffer[256] = "month_changed: ";
-
- calendar_date_to_string (data, buffer+15, 256-15);
- calendar_set_signal_strings (buffer, data);
-}
-
-void calendar_day_selected( GtkWidget *widget,
- CalendarData *data )
-{
- char buffer[256] = "day_selected: ";
-
- calendar_date_to_string (data, buffer+14, 256-14);
- calendar_set_signal_strings (buffer, data);
-}
-
-void calendar_day_selected_double_click( GtkWidget *widget,
- CalendarData *data )
-{
- struct tm tm;
- char buffer[256] = "day_selected_double_click: ";
-
- calendar_date_to_string (data, buffer+27, 256-27);
- calendar_set_signal_strings (buffer, data);
-
- memset (&tm, 0, sizeof (tm));
- gtk_calendar_get_date (GTK_CALENDAR(data->window),
- &tm.tm_year, &tm.tm_mon, &tm.tm_mday);
- tm.tm_year -= TM_YEAR_BASE;
-
- if(GTK_CALENDAR(data->window)->marked_date[tm.tm_mday-1] == 0) {
- gtk_calendar_mark_day(GTK_CALENDAR(data->window),tm.tm_mday);
- } else {
- gtk_calendar_unmark_day(GTK_CALENDAR(data->window),tm.tm_mday);
- }
-}
-
-void calendar_prev_month( GtkWidget *widget,
- CalendarData *data )
-{
- char buffer[256] = "prev_month: ";
-
- calendar_date_to_string (data, buffer+12, 256-12);
- calendar_set_signal_strings (buffer, data);
-}
-
-void calendar_next_month( GtkWidget *widget,
- CalendarData *data )
-{
- char buffer[256] = "next_month: ";
-
- calendar_date_to_string (data, buffer+12, 256-12);
- calendar_set_signal_strings (buffer, data);
-}
-
-void calendar_prev_year( GtkWidget *widget,
- CalendarData *data )
-{
- char buffer[256] = "prev_year: ";
-
- calendar_date_to_string (data, buffer+11, 256-11);
- calendar_set_signal_strings (buffer, data);
-}
-
-void calendar_next_year( GtkWidget *widget,
- CalendarData *data )
-{
- char buffer[256] = "next_year: ";
-
- calendar_date_to_string (data, buffer+11, 256-11);
- calendar_set_signal_strings (buffer, data);
-}
-
-
-void calendar_set_flags( CalendarData *calendar )
-{
- gint i;
- gint options=0;
- for (i=0;i<5;i++)
- if (calendar->settings[i])
- {
- options=options + (1<<i);
- }
- if (calendar->window)
- gtk_calendar_display_options (GTK_CALENDAR (calendar->window), options);
-}
-
-void calendar_toggle_flag( GtkWidget *toggle,
- CalendarData *calendar )
-{
- gint i;
- gint j;
- j=0;
- for (i=0; i<5; i++)
- if (calendar->flag_checkboxes[i] == toggle)
- j = i;
-
- calendar->settings[j]=!calendar->settings[j];
- calendar_set_flags(calendar);
-
-}
-
-void calendar_font_selection_ok (GtkWidget *button,
- CalendarData *calendar)
-{
- GtkRcStyle *style;
- char *font_name;
-
- if (calendar->window)
- {
- font_name = gtk_font_selection_dialog_get_font_name (GTK_FONT_SELECTION_DIALOG(calendar->font_dialog));
- if (font_name)
- {
- style = gtk_rc_style_new ();
- pango_font_description_free (style->font_desc);
- style->font_desc = pango_font_description_from_string (font_name);
- gtk_widget_modify_style (calendar->window, style);
- g_free (font_name);
- }
- }
-
- gtk_widget_destroy (calendar->font_dialog);
-}
-
-void calendar_select_font( GtkWidget *button,
- CalendarData *calendar )
-{
- GtkWidget *window;
-
- if (!calendar->font_dialog) {
- window = gtk_font_selection_dialog_new ("Font Selection Dialog");
- g_return_if_fail(GTK_IS_FONT_SELECTION_DIALOG(window));
- calendar->font_dialog = window;
-
- gtk_window_set_position (GTK_WINDOW (window), GTK_WIN_POS_MOUSE);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &calendar->font_dialog);
-
- gtk_signal_connect (GTK_OBJECT (GTK_FONT_SELECTION_DIALOG (window)->ok_button),
- "clicked", GTK_SIGNAL_FUNC(calendar_font_selection_ok),
- calendar);
- gtk_signal_connect_object (GTK_OBJECT (GTK_FONT_SELECTION_DIALOG (window)->cancel_button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (calendar->font_dialog));
- }
- window=calendar->font_dialog;
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-
-}
-
-void create_calendar()
-{
- GtkWidget *window;
- GtkWidget *vbox, *vbox2, *vbox3;
- GtkWidget *hbox;
- GtkWidget *hbbox;
- GtkWidget *calendar;
- GtkWidget *toggle;
- GtkWidget *button;
- GtkWidget *frame;
- GtkWidget *separator;
- GtkWidget *label;
- GtkWidget *bbox;
- static CalendarData calendar_data;
- gint i;
-
- struct {
- char *label;
- } flags[] =
- {
- { "Show Heading" },
- { "Show Day Names" },
- { "No Month Change" },
- { "Show Week Numbers" },
- { "Week Start Monday" }
- };
-
-
- calendar_data.window = NULL;
- calendar_data.font_dialog = NULL;
-
- for (i=0; i<5; i++) {
- calendar_data.settings[i]=0;
- }
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title(GTK_WINDOW(window), "GtkCalendar Example");
- gtk_container_set_border_width (GTK_CONTAINER (window), 5);
- gtk_signal_connect(GTK_OBJECT(window), "destroy",
- GTK_SIGNAL_FUNC(gtk_main_quit),
- NULL);
- gtk_signal_connect(GTK_OBJECT(window), "delete-event",
- GTK_SIGNAL_FUNC(gtk_false),
- NULL);
-
- gtk_window_set_policy(GTK_WINDOW(window), FALSE, FALSE, TRUE);
-
- vbox = gtk_vbox_new(FALSE, DEF_PAD);
- gtk_container_add (GTK_CONTAINER (window), vbox);
-
- /*
- * The top part of the window, Calendar, flags and fontsel.
- */
-
- hbox = gtk_hbox_new(FALSE, DEF_PAD);
- gtk_box_pack_start (GTK_BOX(vbox), hbox, TRUE, TRUE, DEF_PAD);
- hbbox = gtk_hbutton_box_new();
- gtk_box_pack_start(GTK_BOX(hbox), hbbox, FALSE, FALSE, DEF_PAD);
- gtk_button_box_set_layout(GTK_BUTTON_BOX(hbbox), GTK_BUTTONBOX_SPREAD);
- gtk_box_set_spacing(GTK_BOX(hbbox), 5);
-
- /* Calendar widget */
- frame = gtk_frame_new("Calendar");
- gtk_box_pack_start(GTK_BOX(hbbox), frame, FALSE, TRUE, DEF_PAD);
- calendar=gtk_calendar_new();
- calendar_data.window = calendar;
- calendar_set_flags(&calendar_data);
- gtk_calendar_mark_day ( GTK_CALENDAR(calendar), 19);
- gtk_container_add( GTK_CONTAINER( frame), calendar);
- gtk_signal_connect (GTK_OBJECT (calendar), "month_changed",
- GTK_SIGNAL_FUNC (calendar_month_changed),
- &calendar_data);
- gtk_signal_connect (GTK_OBJECT (calendar), "day_selected",
- GTK_SIGNAL_FUNC (calendar_day_selected),
- &calendar_data);
- gtk_signal_connect (GTK_OBJECT (calendar), "day_selected_double_click",
- GTK_SIGNAL_FUNC (calendar_day_selected_double_click),
- &calendar_data);
- gtk_signal_connect (GTK_OBJECT (calendar), "prev_month",
- GTK_SIGNAL_FUNC (calendar_prev_month),
- &calendar_data);
- gtk_signal_connect (GTK_OBJECT (calendar), "next_month",
- GTK_SIGNAL_FUNC (calendar_next_month),
- &calendar_data);
- gtk_signal_connect (GTK_OBJECT (calendar), "prev_year",
- GTK_SIGNAL_FUNC (calendar_prev_year),
- &calendar_data);
- gtk_signal_connect (GTK_OBJECT (calendar), "next_year",
- GTK_SIGNAL_FUNC (calendar_next_year),
- &calendar_data);
-
-
- separator = gtk_vseparator_new ();
- gtk_box_pack_start (GTK_BOX (hbox), separator, FALSE, TRUE, 0);
-
- vbox2 = gtk_vbox_new(FALSE, DEF_PAD);
- gtk_box_pack_start(GTK_BOX(hbox), vbox2, FALSE, FALSE, DEF_PAD);
-
- /* Build the Right frame with the flags in */
-
- frame = gtk_frame_new("Flags");
- gtk_box_pack_start(GTK_BOX(vbox2), frame, TRUE, TRUE, DEF_PAD);
- vbox3 = gtk_vbox_new(TRUE, DEF_PAD_SMALL);
- gtk_container_add(GTK_CONTAINER(frame), vbox3);
-
- for (i = 0; i < 5; i++)
- {
- toggle = gtk_check_button_new_with_label(flags[i].label);
- gtk_signal_connect (GTK_OBJECT (toggle),
- "toggled",
- GTK_SIGNAL_FUNC(calendar_toggle_flag),
- &calendar_data);
- gtk_box_pack_start (GTK_BOX (vbox3), toggle, TRUE, TRUE, 0);
- calendar_data.flag_checkboxes[i]=toggle;
- }
- /* Build the right font-button */
- button = gtk_button_new_with_label("Font...");
- gtk_signal_connect (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC(calendar_select_font),
- &calendar_data);
- gtk_box_pack_start (GTK_BOX (vbox2), button, FALSE, FALSE, 0);
-
- /*
- * Build the Signal-event part.
- */
-
- frame = gtk_frame_new("Signal events");
- gtk_box_pack_start(GTK_BOX(vbox), frame, TRUE, TRUE, DEF_PAD);
-
- vbox2 = gtk_vbox_new(TRUE, DEF_PAD_SMALL);
- gtk_container_add(GTK_CONTAINER(frame), vbox2);
-
- hbox = gtk_hbox_new (FALSE, 3);
- gtk_box_pack_start (GTK_BOX (vbox2), hbox, FALSE, TRUE, 0);
- label = gtk_label_new ("Signal:");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
- calendar_data.last_sig = gtk_label_new ("");
- gtk_box_pack_start (GTK_BOX (hbox), calendar_data.last_sig, FALSE, TRUE, 0);
-
- hbox = gtk_hbox_new (FALSE, 3);
- gtk_box_pack_start (GTK_BOX (vbox2), hbox, FALSE, TRUE, 0);
- label = gtk_label_new ("Previous signal:");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
- calendar_data.prev_sig = gtk_label_new ("");
- gtk_box_pack_start (GTK_BOX (hbox), calendar_data.prev_sig, FALSE, TRUE, 0);
-
- hbox = gtk_hbox_new (FALSE, 3);
- gtk_box_pack_start (GTK_BOX (vbox2), hbox, FALSE, TRUE, 0);
- label = gtk_label_new ("Second previous signal:");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
- calendar_data.prev2_sig = gtk_label_new ("");
- gtk_box_pack_start (GTK_BOX (hbox), calendar_data.prev2_sig, FALSE, TRUE, 0);
-
- bbox = gtk_hbutton_box_new ();
- gtk_box_pack_start (GTK_BOX (vbox), bbox, FALSE, FALSE, 0);
- gtk_button_box_set_layout(GTK_BUTTON_BOX(bbox), GTK_BUTTONBOX_END);
-
- button = gtk_button_new_with_label ("Close");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_main_quit),
- NULL);
- gtk_container_add (GTK_CONTAINER (bbox), button);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
-
- gtk_widget_show_all(window);
-}
-
-
-int main(int argc,
- char *argv[] )
-{
- gtk_set_locale ();
- gtk_init (&argc, &argv);
-
- create_calendar();
-
- gtk_main();
-
- return(0);
-}
-/* example-end */
diff --git a/gtk/testdnd.c b/gtk/testdnd.c
deleted file mode 100644
index a35115fec1..0000000000
--- a/gtk/testdnd.c
+++ /dev/null
@@ -1,665 +0,0 @@
-#include "gtk/gtk.h"
-
-/* Target side drag signals */
-
-/* XPM */
-static char * drag_icon_xpm[] = {
-"36 48 9 1",
-" c None",
-". c #020204",
-"+ c #8F8F90",
-"@ c #D3D3D2",
-"# c #AEAEAC",
-"$ c #ECECEC",
-"% c #A2A2A4",
-"& c #FEFEFC",
-"* c #BEBEBC",
-" .....................",
-" ..&&&&&&&&&&&&&&&&&&&.",
-" ...&&&&&&&&&&&&&&&&&&&.",
-" ..&.&&&&&&&&&&&&&&&&&&&.",
-" ..&&.&&&&&&&&&&&&&&&&&&&.",
-" ..&&&.&&&&&&&&&&&&&&&&&&&.",
-" ..&&&&.&&&&&&&&&&&&&&&&&&&.",
-" ..&&&&&.&&&@&&&&&&&&&&&&&&&.",
-" ..&&&&&&.*$%$+$&&&&&&&&&&&&&.",
-" ..&&&&&&&.%$%$+&&&&&&&&&&&&&&.",
-" ..&&&&&&&&.#&#@$&&&&&&&&&&&&&&.",
-" ..&&&&&&&&&.#$**#$&&&&&&&&&&&&&.",
-" ..&&&&&&&&&&.&@%&%$&&&&&&&&&&&&&.",
-" ..&&&&&&&&&&&.&&&&&&&&&&&&&&&&&&&.",
-" ..&&&&&&&&&&&&.&&&&&&&&&&&&&&&&&&&.",
-"................&$@&&&@&&&&&&&&&&&&.",
-".&&&&&&&+&&#@%#+@#@*$%$+$&&&&&&&&&&.",
-".&&&&&&&+&&#@#@&&@*%$%$+&&&&&&&&&&&.",
-".&&&&&&&+&$%&#@&#@@#&#@$&&&&&&&&&&&.",
-".&&&&&&@#@@$&*@&@#@#$**#$&&&&&&&&&&.",
-".&&&&&&&&&&&&&&&&&&&@%&%$&&&&&&&&&&.",
-".&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&.",
-".&&&&&&&&$#@@$&&&&&&&&&&&&&&&&&&&&&.",
-".&&&&&&&&&+&$+&$&@&$@&&$@&&&&&&&&&&.",
-".&&&&&&&&&+&&#@%#+@#@*$%&+$&&&&&&&&.",
-".&&&&&&&&&+&&#@#@&&@*%$%$+&&&&&&&&&.",
-".&&&&&&&&&+&$%&#@&#@@#&#@$&&&&&&&&&.",
-".&&&&&&&&@#@@$&*@&@#@#$#*#$&&&&&&&&.",
-".&&&&&&&&&&&&&&&&&&&&&$%&%$&&&&&&&&.",
-".&&&&&&&&&&$#@@$&&&&&&&&&&&&&&&&&&&.",
-".&&&&&&&&&&&+&$%&$$@&$@&&$@&&&&&&&&.",
-".&&&&&&&&&&&+&&#@%#+@#@*$%$+$&&&&&&.",
-".&&&&&&&&&&&+&&#@#@&&@*#$%$+&&&&&&&.",
-".&&&&&&&&&&&+&$+&*@&#@@#&#@$&&&&&&&.",
-".&&&&&&&&&&$%@@&&*@&@#@#$#*#&&&&&&&.",
-".&&&&&&&&&&&&&&&&&&&&&&&$%&%$&&&&&&.",
-".&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&.",
-".&&&&&&&&&&&&&&$#@@$&&&&&&&&&&&&&&&.",
-".&&&&&&&&&&&&&&&+&$%&$$@&$@&&$@&&&&.",
-".&&&&&&&&&&&&&&&+&&#@%#+@#@*$%$+$&&.",
-".&&&&&&&&&&&&&&&+&&#@#@&&@*#$%$+&&&.",
-".&&&&&&&&&&&&&&&+&$+&*@&#@@#&#@$&&&.",
-".&&&&&&&&&&&&&&$%@@&&*@&@#@#$#*#&&&.",
-".&&&&&&&&&&&&&&&&&&&&&&&&&&&$%&%$&&.",
-".&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&.",
-".&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&.",
-".&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&.",
-"...................................."};
-
-/* XPM */
-static char * trashcan_closed_xpm[] = {
-"64 80 17 1",
-" c None",
-". c #030304",
-"+ c #5A5A5C",
-"@ c #323231",
-"# c #888888",
-"$ c #1E1E1F",
-"% c #767677",
-"& c #494949",
-"* c #9E9E9C",
-"= c #111111",
-"- c #3C3C3D",
-"; c #6B6B6B",
-"> c #949494",
-", c #282828",
-"' c #808080",
-") c #545454",
-"! c #AEAEAC",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ==......=$$...=== ",
-" ..$------)+++++++++++++@$$... ",
-" ..=@@-------&+++++++++++++++++++-.... ",
-" =.$$@@@-&&)++++)-,$$$$=@@&+++++++++++++,..$ ",
-" .$$$$@@&+++++++&$$$@@@@-&,$,-++++++++++;;;&.. ",
-" $$$$,@--&++++++&$$)++++++++-,$&++++++;%%'%%;;$@ ",
-" .-@@-@-&++++++++-@++++++++++++,-++++++;''%;;;%*-$ ",
-" +------++++++++++++++++++++++++++++++;;%%%;;##*!. ",
-" =+----+++++++++++++++++++++++;;;;;;;;;;;;%'>>). ",
-" .=)&+++++++++++++++++;;;;;;;;;;;;;;%''>>#>#@. ",
-" =..=&++++++++++++;;;;;;;;;;;;;%###>>###+%== ",
-" .&....=-+++++%;;####''''''''''##'%%%)..#. ",
-" .+-++@....=,+%#####'%%%%%%%%%;@$-@-@*++!. ",
-" .+-++-+++-&-@$$=$=......$,,,@;&)+!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" =+-++-+++-+++++++++!++++!++++!+++!++!+++= ",
-" $.++-+++-+++++++++!++++!++++!+++!++!+.$ ",
-" =.++++++++++++++!++++!++++!+++!++.= ",
-" $..+++++++++++++++!++++++...$ ",
-" $$=.............=$$ ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" "};
-
-/* XPM */
-static char * trashcan_open_xpm[] = {
-"64 80 17 1",
-" c None",
-". c #030304",
-"+ c #5A5A5C",
-"@ c #323231",
-"# c #888888",
-"$ c #1E1E1F",
-"% c #767677",
-"& c #494949",
-"* c #9E9E9C",
-"= c #111111",
-"- c #3C3C3D",
-"; c #6B6B6B",
-"> c #949494",
-", c #282828",
-"' c #808080",
-") c #545454",
-"! c #AEAEAC",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" .=.==.,@ ",
-" ==.,@-&&&)-= ",
-" .$@,&++;;;%>*- ",
-" $,-+)+++%%;;'#+. ",
-" =---+++++;%%%;%##@. ",
-" @)++++++++;%%%%'#%$ ",
-" $&++++++++++;%%;%##@= ",
-" ,-++++)+++++++;;;'#%) ",
-" @+++&&--&)++++;;%'#'-. ",
-" ,&++-@@,,,,-)++;;;'>'+, ",
-" =-++&@$@&&&&-&+;;;%##%+@ ",
-" =,)+)-,@@&+++++;;;;%##%&@ ",
-" @--&&,,@&)++++++;;;;'#)@ ",
-" ---&)-,@)+++++++;;;%''+, ",
-" $--&)+&$-+++++++;;;%%'';- ",
-" .,-&+++-$&++++++;;;%''%&= ",
-" $,-&)++)-@++++++;;%''%), ",
-" =,@&)++++&&+++++;%'''+$@&++++++ ",
-" .$@-++++++++++++;'#';,........=$@&++++ ",
-" =$@@&)+++++++++++'##-.................=&++ ",
-" .$$@-&)+++++++++;%#+$.....................=)+ ",
-" $$,@-)+++++++++;%;@=........................,+ ",
-" .$$@@-++++++++)-)@=............................ ",
-" $,@---)++++&)@===............................,. ",
-" $-@---&)))-$$=..............................=)!. ",
-" --&-&&,,$=,==...........................=&+++!. ",
-" =,=$..=$+)+++++&@$=.............=$@&+++++!++!. ",
-" .)-++-+++++++++++++++++++++++++++!++!++!. ",
-" .+-++-+++++++++++++++++++++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!+++!!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" .+-++-+++-+++++++++!++++!++++!+++!++!++!. ",
-" =+-++-+++-+++++++++!++++!++++!+++!++!+++= ",
-" $.++-+++-+++++++++!++++!++++!+++!++!+.$ ",
-" =.++++++++++++++!++++!++++!+++!++.= ",
-" $..+++++++++++++++!++++++...$ ",
-" $$==...........==$$ ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" ",
-" "};
-
-GdkPixmap *trashcan_open;
-GdkPixmap *trashcan_open_mask;
-GdkPixmap *trashcan_closed;
-GdkPixmap *trashcan_closed_mask;
-
-gboolean have_drag;
-
-enum {
- TARGET_STRING,
- TARGET_ROOTWIN
-};
-
-static GtkTargetEntry target_table[] = {
- { "STRING", 0, TARGET_STRING },
- { "text/plain", 0, TARGET_STRING },
- { "application/x-rootwin-drop", 0, TARGET_ROOTWIN }
-};
-
-static guint n_targets = sizeof(target_table) / sizeof(target_table[0]);
-
-void
-target_drag_leave (GtkWidget *widget,
- GdkDragContext *context,
- guint time)
-{
- g_print("leave\n");
- have_drag = FALSE;
- gtk_pixmap_set (GTK_PIXMAP (widget), trashcan_closed, trashcan_closed_mask);
-}
-
-gboolean
-target_drag_motion (GtkWidget *widget,
- GdkDragContext *context,
- gint x,
- gint y,
- guint time)
-{
- GtkWidget *source_widget;
- GList *tmp_list;
-
- if (!have_drag)
- {
- have_drag = TRUE;
- gtk_pixmap_set (GTK_PIXMAP (widget), trashcan_open, trashcan_open_mask);
- }
-
- source_widget = gtk_drag_get_source_widget (context);
- g_print ("motion, source %s\n", source_widget ?
- GTK_OBJECT_TYPE_NAME (source_widget) :
- "NULL");
-
- tmp_list = context->targets;
- while (tmp_list)
- {
- char *name = gdk_atom_name (GPOINTER_TO_UINT (tmp_list->data));
- g_print ("%s\n", name);
- g_free (name);
-
- tmp_list = tmp_list->next;
- }
-
- gdk_drag_status (context, context->suggested_action, time);
- return TRUE;
-}
-
-gboolean
-target_drag_drop (GtkWidget *widget,
- GdkDragContext *context,
- gint x,
- gint y,
- guint time)
-{
- g_print("drop\n");
- have_drag = FALSE;
-
- gtk_pixmap_set (GTK_PIXMAP (widget), trashcan_closed, trashcan_closed_mask);
-
- if (context->targets)
- {
- gtk_drag_get_data (widget, context,
- GPOINTER_TO_INT (context->targets->data),
- time);
- return TRUE;
- }
-
- return FALSE;
-}
-
-void
-target_drag_data_received (GtkWidget *widget,
- GdkDragContext *context,
- gint x,
- gint y,
- GtkSelectionData *data,
- guint info,
- guint time)
-{
- if ((data->length >= 0) && (data->format == 8))
- {
- g_print ("Received \"%s\" in trashcan\n", (gchar *)data->data);
- gtk_drag_finish (context, TRUE, FALSE, time);
- return;
- }
-
- gtk_drag_finish (context, FALSE, FALSE, time);
-}
-
-void
-label_drag_data_received (GtkWidget *widget,
- GdkDragContext *context,
- gint x,
- gint y,
- GtkSelectionData *data,
- guint info,
- guint time)
-{
- if ((data->length >= 0) && (data->format == 8))
- {
- g_print ("Received \"%s\" in label\n", (gchar *)data->data);
- gtk_drag_finish (context, TRUE, FALSE, time);
- return;
- }
-
- gtk_drag_finish (context, FALSE, FALSE, time);
-}
-
-void
-source_drag_data_get (GtkWidget *widget,
- GdkDragContext *context,
- GtkSelectionData *selection_data,
- guint info,
- guint time,
- gpointer data)
-{
- if (info == TARGET_ROOTWIN)
- g_print ("I was dropped on the rootwin\n");
- else
- gtk_selection_data_set (selection_data,
- selection_data->target,
- 8, "I'm Data!", 9);
-}
-
-/* The following is a rather elaborate example demonstrating/testing
- * changing of the window heirarchy during a drag - in this case,
- * via a "spring-loaded" popup window.
- */
-static GtkWidget *popup_window = NULL;
-
-static gboolean popped_up = FALSE;
-static gboolean in_popup = FALSE;
-static guint popdown_timer = 0;
-static guint popup_timer = 0;
-
-gint
-popdown_cb (gpointer data)
-{
- popdown_timer = 0;
-
- gtk_widget_hide (popup_window);
- popped_up = FALSE;
-
- return FALSE;
-}
-
-gboolean
-popup_motion (GtkWidget *widget,
- GdkDragContext *context,
- gint x,
- gint y,
- guint time)
-{
- if (!in_popup)
- {
- in_popup = TRUE;
- if (popdown_timer)
- {
- g_print ("removed popdown\n");
- gtk_timeout_remove (popdown_timer);
- popdown_timer = 0;
- }
- }
-
- return TRUE;
-}
-
-void
-popup_leave (GtkWidget *widget,
- GdkDragContext *context,
- guint time)
-{
- if (in_popup)
- {
- in_popup = FALSE;
- if (!popdown_timer)
- {
- g_print ("added popdown\n");
- popdown_timer = gtk_timeout_add (500, popdown_cb, NULL);
- }
- }
-}
-
-gint
-popup_cb (gpointer data)
-{
- if (!popped_up)
- {
- if (!popup_window)
- {
- GtkWidget *button;
- GtkWidget *table;
- int i, j;
-
- popup_window = gtk_window_new (GTK_WINDOW_POPUP);
- gtk_window_set_position (GTK_WINDOW (popup_window), GTK_WIN_POS_MOUSE);
-
- table = gtk_table_new (3,3, FALSE);
-
- for (i=0; i<3; i++)
- for (j=0; j<3; j++)
- {
- char buffer[128];
- g_snprintf(buffer, sizeof(buffer), "%d,%d", i, j);
- button = gtk_button_new_with_label (buffer);
- gtk_table_attach (GTK_TABLE (table), button, i, i+1, j, j+1,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 0, 0);
-
- gtk_drag_dest_set (button,
- GTK_DEST_DEFAULT_ALL,
- target_table, n_targets - 1, /* no rootwin */
- GDK_ACTION_COPY | GDK_ACTION_MOVE);
- gtk_signal_connect (GTK_OBJECT (button), "drag_motion",
- GTK_SIGNAL_FUNC (popup_motion), NULL);
- gtk_signal_connect (GTK_OBJECT (button), "drag_leave",
- GTK_SIGNAL_FUNC (popup_leave), NULL);
- }
-
- gtk_widget_show_all (table);
- gtk_container_add (GTK_CONTAINER (popup_window), table);
-
- }
- gtk_widget_show (popup_window);
- popped_up = TRUE;
- }
-
- popdown_timer = gtk_timeout_add (500, popdown_cb, NULL);
- g_print ("added popdown\n");
-
- popup_timer = FALSE;
-
- return FALSE;
-}
-
-gboolean
-popsite_motion (GtkWidget *widget,
- GdkDragContext *context,
- gint x,
- gint y,
- guint time)
-{
- if (!popup_timer)
- popup_timer = gtk_timeout_add (500, popup_cb, NULL);
-
- return TRUE;
-}
-
-void
-popsite_leave (GtkWidget *widget,
- GdkDragContext *context,
- guint time)
-{
- if (popup_timer)
- {
- gtk_timeout_remove (popup_timer);
- popup_timer = 0;
- }
-}
-
-void
-source_drag_data_delete (GtkWidget *widget,
- GdkDragContext *context,
- gpointer data)
-{
- g_print ("Delete the data!\n");
-}
-
-int
-main (int argc, char **argv)
-{
- GtkWidget *window;
- GtkWidget *table;
- GtkWidget *label;
- GtkWidget *pixmap;
- GtkWidget *button;
- GdkPixmap *drag_icon;
- GdkPixmap *drag_mask;
-
- gtk_init (&argc, &argv);
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_signal_connect (GTK_OBJECT(window), "destroy",
- GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
-
-
- table = gtk_table_new (2, 2, FALSE);
- gtk_container_add (GTK_CONTAINER (window), table);
-
- drag_icon = gdk_pixmap_colormap_create_from_xpm_d (NULL,
- gtk_widget_get_colormap (window),
- &drag_mask,
- NULL, drag_icon_xpm);
-
- trashcan_open = gdk_pixmap_colormap_create_from_xpm_d (NULL,
- gtk_widget_get_colormap (window),
- &trashcan_open_mask,
- NULL, trashcan_open_xpm);
- trashcan_closed = gdk_pixmap_colormap_create_from_xpm_d (NULL,
- gtk_widget_get_colormap (window),
- &trashcan_closed_mask,
- NULL, trashcan_closed_xpm);
-
- label = gtk_label_new ("Drop Here\n");
-
- gtk_drag_dest_set (label,
- GTK_DEST_DEFAULT_ALL,
- target_table, n_targets - 1, /* no rootwin */
- GDK_ACTION_COPY | GDK_ACTION_MOVE);
-
- gtk_signal_connect( GTK_OBJECT(label), "drag_data_received",
- GTK_SIGNAL_FUNC( label_drag_data_received), NULL);
-
- gtk_table_attach (GTK_TABLE (table), label, 0, 1, 0, 1,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 0, 0);
-
- label = gtk_label_new ("Popup\n");
-
- gtk_drag_dest_set (label,
- GTK_DEST_DEFAULT_ALL,
- target_table, n_targets - 1, /* no rootwin */
- GDK_ACTION_COPY | GDK_ACTION_MOVE);
-
- gtk_table_attach (GTK_TABLE (table), label, 1, 2, 1, 2,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 0, 0);
-
- gtk_signal_connect (GTK_OBJECT (label), "drag_motion",
- GTK_SIGNAL_FUNC (popsite_motion), NULL);
- gtk_signal_connect (GTK_OBJECT (label), "drag_leave",
- GTK_SIGNAL_FUNC (popsite_leave), NULL);
-
- pixmap = gtk_pixmap_new (trashcan_closed, trashcan_closed_mask);
- gtk_drag_dest_set (pixmap, 0, NULL, 0, 0);
- gtk_table_attach (GTK_TABLE (table), pixmap, 1, 2, 0, 1,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 0, 0);
-
- gtk_signal_connect (GTK_OBJECT (pixmap), "drag_leave",
- GTK_SIGNAL_FUNC (target_drag_leave), NULL);
-
- gtk_signal_connect (GTK_OBJECT (pixmap), "drag_motion",
- GTK_SIGNAL_FUNC (target_drag_motion), NULL);
-
- gtk_signal_connect (GTK_OBJECT (pixmap), "drag_drop",
- GTK_SIGNAL_FUNC (target_drag_drop), NULL);
-
- gtk_signal_connect (GTK_OBJECT (pixmap), "drag_data_received",
- GTK_SIGNAL_FUNC (target_drag_data_received), NULL);
-
- /* Drag site */
-
- button = gtk_button_new_with_label ("Drag Here\n");
-
- gtk_drag_source_set (button, GDK_BUTTON1_MASK | GDK_BUTTON3_MASK,
- target_table, n_targets,
- GDK_ACTION_COPY | GDK_ACTION_MOVE);
- gtk_drag_source_set_icon (button,
- gtk_widget_get_colormap (window),
- drag_icon, drag_mask);
-
- gdk_pixmap_unref (drag_icon);
- gdk_pixmap_unref (drag_mask);
-
- gtk_table_attach (GTK_TABLE (table), button, 0, 1, 1, 2,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 0, 0);
-
- gtk_signal_connect (GTK_OBJECT (button), "drag_data_get",
- GTK_SIGNAL_FUNC (source_drag_data_get), NULL);
- gtk_signal_connect (GTK_OBJECT (button), "drag_data_delete",
- GTK_SIGNAL_FUNC (source_drag_data_delete), NULL);
-
- gtk_widget_show_all (window);
-
- gtk_main ();
-
- return 0;
-}
diff --git a/gtk/testgtk.c b/gtk/testgtk.c
deleted file mode 100644
index f1cfb011a7..0000000000
--- a/gtk/testgtk.c
+++ /dev/null
@@ -1,10352 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-/*
- * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
- * file for a list of people on the GTK+ Team. See the ChangeLog
- * files for a list of changes. These files are distributed with
- * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
- */
-
-#include "config.h"
-
-#undef G_LOG_DOMAIN
-
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include <sys/stat.h>
-#include <math.h>
-#include <time.h>
-#ifdef HAVE_UNISTD_H
-#include <unistd.h>
-#endif
-
-#define GTK_ENABLE_BROKEN
-#include "gtk.h"
-#include "gdk/gdk.h"
-#include "gdk/gdkkeysyms.h"
-
-#ifdef G_OS_WIN32
-#define sleep(n) _sleep(n)
-#endif
-
-#include "circles.xbm"
-#include "test.xpm"
-
-typedef struct _OptionMenuItem
-{
- gchar *name;
- GtkSignalFunc func;
-} OptionMenuItem;
-
-gboolean
-file_exists (const char *filename)
-{
- struct stat statbuf;
-
- return stat (filename, &statbuf) == 0;
-}
-
-GtkWidget *
-shape_create_icon (char *xpm_file,
- gint x,
- gint y,
- gint px,
- gint py,
- gint window_type);
-
-static GtkWidget *
-build_option_menu (OptionMenuItem items[],
- gint num_items,
- gint history,
- gpointer data);
-
-/* macro, structure and variables used by tree window demos */
-#define DEFAULT_NUMBER_OF_ITEM 3
-#define DEFAULT_RECURSION_LEVEL 3
-
-struct {
- GSList* selection_mode_group;
- GtkWidget* single_button;
- GtkWidget* browse_button;
- GtkWidget* multiple_button;
- GtkWidget* draw_line_button;
- GtkWidget* view_line_button;
- GtkWidget* no_root_item_button;
- GtkWidget* nb_item_spinner;
- GtkWidget* recursion_spinner;
-} sTreeSampleSelection;
-
-typedef struct sTreeButtons {
- guint nb_item_add;
- GtkWidget* add_button;
- GtkWidget* remove_button;
- GtkWidget* subtree_button;
-} sTreeButtons;
-/* end of tree section */
-
-static GtkWidget *
-build_option_menu (OptionMenuItem items[],
- gint num_items,
- gint history,
- gpointer data)
-{
- GtkWidget *omenu;
- GtkWidget *menu;
- GtkWidget *menu_item;
- gint i;
-
- omenu = gtk_option_menu_new ();
-
- menu = gtk_menu_new ();
-
- for (i = 0; i < num_items; i++)
- {
- menu_item = gtk_menu_item_new_with_label (items[i].name);
- gtk_signal_connect (GTK_OBJECT (menu_item), "activate",
- (GtkSignalFunc) items[i].func, data);
- gtk_menu_shell_append (GTK_MENU_SHELL (menu), menu_item);
- gtk_widget_show (menu_item);
- }
-
- gtk_option_menu_set_menu (GTK_OPTION_MENU (omenu), menu);
- gtk_option_menu_set_history (GTK_OPTION_MENU (omenu), history);
-
- return omenu;
-}
-
-static void
-destroy_tooltips (GtkWidget *widget, GtkWindow **window)
-{
- GtkTooltips *tt = gtk_object_get_data (GTK_OBJECT (*window), "tooltips");
- gtk_object_unref (GTK_OBJECT (tt));
- *window = NULL;
-}
-
-/*
- * GtkButton
- */
-
-static void
-button_window (GtkWidget *widget,
- GtkWidget *button)
-{
- if (!GTK_WIDGET_VISIBLE (button))
- gtk_widget_show (button);
- else
- gtk_widget_hide (button);
-}
-
-static void
-create_buttons (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *table;
- GtkWidget *button[10];
- GtkWidget *separator;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "GtkButton");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- table = gtk_table_new (3, 3, FALSE);
- gtk_table_set_row_spacings (GTK_TABLE (table), 5);
- gtk_table_set_col_spacings (GTK_TABLE (table), 5);
- gtk_container_set_border_width (GTK_CONTAINER (table), 10);
- gtk_box_pack_start (GTK_BOX (box1), table, TRUE, TRUE, 0);
-
- button[0] = gtk_button_new_with_label ("button1");
- button[1] = gtk_button_new_with_mnemonic ("_button2");
- button[2] = gtk_button_new_with_mnemonic ("_button3");
- button[3] = gtk_button_new_from_stock (GTK_STOCK_BUTTON_OK);
- button[4] = gtk_button_new_with_label ("button5");
- button[5] = gtk_button_new_with_label ("button6");
- button[6] = gtk_button_new_with_label ("button7");
- button[7] = gtk_button_new_from_stock (GTK_STOCK_BUTTON_CLOSE);
- button[8] = gtk_button_new_with_label ("button9");
-
- gtk_signal_connect (GTK_OBJECT (button[0]), "clicked",
- GTK_SIGNAL_FUNC(button_window),
- button[1]);
-
- gtk_table_attach (GTK_TABLE (table), button[0], 0, 1, 0, 1,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
-
- gtk_signal_connect (GTK_OBJECT (button[1]), "clicked",
- GTK_SIGNAL_FUNC(button_window),
- button[2]);
-
- gtk_table_attach (GTK_TABLE (table), button[1], 1, 2, 1, 2,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
-
- gtk_signal_connect (GTK_OBJECT (button[2]), "clicked",
- GTK_SIGNAL_FUNC(button_window),
- button[3]);
- gtk_table_attach (GTK_TABLE (table), button[2], 2, 3, 2, 3,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
-
- gtk_signal_connect (GTK_OBJECT (button[3]), "clicked",
- GTK_SIGNAL_FUNC(button_window),
- button[4]);
- gtk_table_attach (GTK_TABLE (table), button[3], 0, 1, 2, 3,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
-
- gtk_signal_connect (GTK_OBJECT (button[4]), "clicked",
- GTK_SIGNAL_FUNC(button_window),
- button[5]);
- gtk_table_attach (GTK_TABLE (table), button[4], 2, 3, 0, 1,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
-
- gtk_signal_connect (GTK_OBJECT (button[5]), "clicked",
- GTK_SIGNAL_FUNC(button_window),
- button[6]);
- gtk_table_attach (GTK_TABLE (table), button[5], 1, 2, 2, 3,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
-
- gtk_signal_connect (GTK_OBJECT (button[6]), "clicked",
- GTK_SIGNAL_FUNC(button_window),
- button[7]);
- gtk_table_attach (GTK_TABLE (table), button[6], 1, 2, 0, 1,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
-
- gtk_signal_connect (GTK_OBJECT (button[7]), "clicked",
- GTK_SIGNAL_FUNC(button_window),
- button[8]);
- gtk_table_attach (GTK_TABLE (table), button[7], 2, 3, 1, 2,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
-
- gtk_signal_connect (GTK_OBJECT (button[8]), "clicked",
- GTK_SIGNAL_FUNC(button_window),
- button[0]);
- gtk_table_attach (GTK_TABLE (table), button[8], 0, 1, 1, 2,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button[9] = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button[9]), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button[9], TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button[9], GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button[9]);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_hide (window);
-}
-
-/*
- * GtkToggleButton
- */
-
-static void
-create_toggle_buttons (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *button;
- GtkWidget *separator;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "GtkToggleButton");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
-
- button = gtk_toggle_button_new_with_label ("button1");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- button = gtk_toggle_button_new_with_label ("button2");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- button = gtk_toggle_button_new_with_label ("button3");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- button = gtk_toggle_button_new_with_label ("inconsistent");
- gtk_toggle_button_set_inconsistent (GTK_TOGGLE_BUTTON (button), TRUE);
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkCheckButton
- */
-
-static void
-create_check_buttons (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *button;
- GtkWidget *separator;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "GtkCheckButton");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
-
- button = gtk_check_button_new_with_mnemonic ("_button1");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- button = gtk_check_button_new_with_label ("button2");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- button = gtk_check_button_new_with_label ("button3");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- button = gtk_check_button_new_with_label ("inconsistent");
- gtk_toggle_button_set_inconsistent (GTK_TOGGLE_BUTTON (button), TRUE);
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkRadioButton
- */
-
-static void
-create_radio_buttons (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *button;
- GtkWidget *separator;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "radio buttons");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
-
- button = gtk_radio_button_new_with_label (NULL, "button1");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- button = gtk_radio_button_new_with_label (
- gtk_radio_button_group (GTK_RADIO_BUTTON (button)),
- "button2");
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), TRUE);
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- button = gtk_radio_button_new_with_label (
- gtk_radio_button_group (GTK_RADIO_BUTTON (button)),
- "button3");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- button = gtk_radio_button_new_with_label (
- gtk_radio_button_group (GTK_RADIO_BUTTON (button)),
- "inconsistent");
- gtk_toggle_button_set_inconsistent (GTK_TOGGLE_BUTTON (button), TRUE);
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkButtonBox
- */
-
-static GtkWidget *
-create_bbox (gint horizontal,
- char* title,
- gint spacing,
- gint child_w,
- gint child_h,
- gint layout)
-{
- GtkWidget *frame;
- GtkWidget *bbox;
- GtkWidget *button;
-
- frame = gtk_frame_new (title);
-
- if (horizontal)
- bbox = gtk_hbutton_box_new ();
- else
- bbox = gtk_vbutton_box_new ();
-
- gtk_container_set_border_width (GTK_CONTAINER (bbox), 5);
- gtk_container_add (GTK_CONTAINER (frame), bbox);
-
- gtk_button_box_set_layout (GTK_BUTTON_BOX (bbox), layout);
- gtk_box_set_spacing (GTK_BOX (bbox), spacing);
- gtk_button_box_set_child_size (GTK_BUTTON_BOX (bbox), child_w, child_h);
-
- button = gtk_button_new_with_label ("OK");
- gtk_container_add (GTK_CONTAINER (bbox), button);
-
- button = gtk_button_new_with_label ("Cancel");
- gtk_container_add (GTK_CONTAINER (bbox), button);
-
- button = gtk_button_new_with_label ("Help");
- gtk_container_add (GTK_CONTAINER (bbox), button);
-
- return frame;
-}
-
-static void
-create_button_box (void)
-{
- static GtkWidget* window = NULL;
- GtkWidget *main_vbox;
- GtkWidget *vbox;
- GtkWidget *hbox;
- GtkWidget *frame_horz;
- GtkWidget *frame_vert;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title (GTK_WINDOW (window), "Button Boxes");
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_container_set_border_width (GTK_CONTAINER (window), 10);
-
- main_vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), main_vbox);
-
- frame_horz = gtk_frame_new ("Horizontal Button Boxes");
- gtk_box_pack_start (GTK_BOX (main_vbox), frame_horz, TRUE, TRUE, 10);
-
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (vbox), 10);
- gtk_container_add (GTK_CONTAINER (frame_horz), vbox);
-
- gtk_box_pack_start (GTK_BOX (vbox),
- create_bbox (TRUE, "Spread", 40, 85, 20, GTK_BUTTONBOX_SPREAD),
- TRUE, TRUE, 0);
-
- gtk_box_pack_start (GTK_BOX (vbox),
- create_bbox (TRUE, "Edge", 40, 85, 20, GTK_BUTTONBOX_EDGE),
- TRUE, TRUE, 5);
-
- gtk_box_pack_start (GTK_BOX (vbox),
- create_bbox (TRUE, "Start", 40, 85, 20, GTK_BUTTONBOX_START),
- TRUE, TRUE, 5);
-
- gtk_box_pack_start (GTK_BOX (vbox),
- create_bbox (TRUE, "End", 40, 85, 20, GTK_BUTTONBOX_END),
- TRUE, TRUE, 5);
-
- frame_vert = gtk_frame_new ("Vertical Button Boxes");
- gtk_box_pack_start (GTK_BOX (main_vbox), frame_vert, TRUE, TRUE, 10);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 10);
- gtk_container_add (GTK_CONTAINER (frame_vert), hbox);
-
- gtk_box_pack_start (GTK_BOX (hbox),
- create_bbox (FALSE, "Spread", 30, 85, 20, GTK_BUTTONBOX_SPREAD),
- TRUE, TRUE, 0);
-
- gtk_box_pack_start (GTK_BOX (hbox),
- create_bbox (FALSE, "Edge", 30, 85, 20, GTK_BUTTONBOX_EDGE),
- TRUE, TRUE, 5);
-
- gtk_box_pack_start (GTK_BOX (hbox),
- create_bbox (FALSE, "Start", 30, 85, 20, GTK_BUTTONBOX_START),
- TRUE, TRUE, 5);
-
- gtk_box_pack_start (GTK_BOX (hbox),
- create_bbox (FALSE, "End", 30, 85, 20, GTK_BUTTONBOX_END),
- TRUE, TRUE, 5);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkToolBar
- */
-
-static GtkWidget*
-new_pixmap (char *filename,
- GdkWindow *window,
- GdkColor *background)
-{
- GtkWidget *wpixmap;
- GdkPixmap *pixmap;
- GdkBitmap *mask;
-
- if (strcmp (filename, "test.xpm") == 0 ||
- !file_exists (filename))
- {
- pixmap = gdk_pixmap_create_from_xpm_d (window, &mask,
- background,
- openfile);
- }
- else
- pixmap = gdk_pixmap_create_from_xpm (window, &mask,
- background,
- filename);
-
- wpixmap = gtk_pixmap_new (pixmap, mask);
-
- return wpixmap;
-}
-
-
-static void
-set_toolbar_small_stock (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_icon_size (GTK_TOOLBAR (data), GTK_ICON_SIZE_SMALL_TOOLBAR);
-}
-
-static void
-set_toolbar_large_stock (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_icon_size (GTK_TOOLBAR (data), GTK_ICON_SIZE_LARGE_TOOLBAR);
-}
-
-static void
-set_toolbar_horizontal (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_orientation (GTK_TOOLBAR (data), GTK_ORIENTATION_HORIZONTAL);
-}
-
-static void
-set_toolbar_vertical (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_orientation (GTK_TOOLBAR (data), GTK_ORIENTATION_VERTICAL);
-}
-
-static void
-set_toolbar_icons (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_style (GTK_TOOLBAR (data), GTK_TOOLBAR_ICONS);
-}
-
-static void
-set_toolbar_text (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_style (GTK_TOOLBAR (data), GTK_TOOLBAR_TEXT);
-}
-
-static void
-set_toolbar_both (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_style (GTK_TOOLBAR (data), GTK_TOOLBAR_BOTH);
-}
-
-static void
-set_toolbar_both_horiz (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_style (GTK_TOOLBAR (data), GTK_TOOLBAR_BOTH_HORIZ);
-}
-
-static void
-set_toolbar_small_space (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_space_size (GTK_TOOLBAR (data), 5);
-}
-
-static void
-set_toolbar_big_space (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_space_size (GTK_TOOLBAR (data), 10);
-}
-
-static void
-set_toolbar_enable (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_tooltips (GTK_TOOLBAR (data), TRUE);
-}
-
-static void
-set_toolbar_disable (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_tooltips (GTK_TOOLBAR (data), FALSE);
-}
-
-static void
-set_toolbar_borders (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_button_relief (GTK_TOOLBAR (data), GTK_RELIEF_NORMAL);
-}
-
-static void
-set_toolbar_borderless (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_button_relief (GTK_TOOLBAR (data), GTK_RELIEF_NONE);
-}
-
-static void
-set_toolbar_space_style_empty (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_space_style (GTK_TOOLBAR (data), GTK_TOOLBAR_SPACE_EMPTY);
-}
-
-static void
-set_toolbar_space_style_line (GtkWidget *widget,
- gpointer data)
-{
- gtk_toolbar_set_space_style (GTK_TOOLBAR (data), GTK_TOOLBAR_SPACE_LINE);
-}
-
-static void
-create_toolbar (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *toolbar;
- GtkWidget *entry;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title (GTK_WINDOW (window), "Toolbar test");
- gtk_window_set_policy (GTK_WINDOW (window), FALSE, TRUE, TRUE);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &window);
-
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
- gtk_widget_realize (window);
-
- toolbar = gtk_toolbar_new (GTK_ORIENTATION_HORIZONTAL, GTK_TOOLBAR_BOTH);
- gtk_toolbar_set_button_relief (GTK_TOOLBAR (toolbar), GTK_RELIEF_NONE);
-
- gtk_toolbar_insert_stock (GTK_TOOLBAR (toolbar),
- GTK_STOCK_NEW,
- "Stock icon: New", "Toolbar/New",
- (GtkSignalFunc) set_toolbar_small_stock, toolbar, -1);
-
- gtk_toolbar_insert_stock (GTK_TOOLBAR (toolbar),
- GTK_STOCK_OPEN,
- "Stock icon: Open", "Toolbar/Open",
- (GtkSignalFunc) set_toolbar_large_stock, toolbar, -1);
-
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Horizontal", "Horizontal toolbar layout", "Toolbar/Horizontal",
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_horizontal, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Vertical", "Vertical toolbar layout", "Toolbar/Vertical",
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_vertical, toolbar);
-
- gtk_toolbar_append_space (GTK_TOOLBAR(toolbar));
-
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Icons", "Only show toolbar icons", "Toolbar/IconsOnly",
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_icons, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Text", "Only show toolbar text", "Toolbar/TextOnly",
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_text, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Both", "Show toolbar icons and text", "Toolbar/Both",
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_both, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Both (horizontal)",
- "Show toolbar icons and text in a horizontal fashion",
- "Toolbar/BothHoriz",
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_both_horiz, toolbar);
-
- gtk_toolbar_append_space (GTK_TOOLBAR (toolbar));
-
- entry = gtk_entry_new ();
-
- gtk_toolbar_append_widget (GTK_TOOLBAR (toolbar), entry, "This is an unusable GtkEntry ;)", "Hey don't click me!!!");
-
- gtk_toolbar_append_space (GTK_TOOLBAR (toolbar));
-
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Small", "Use small spaces", "Toolbar/Small",
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_small_space, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Big", "Use big spaces", "Toolbar/Big",
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_big_space, toolbar);
-
- gtk_toolbar_append_space (GTK_TOOLBAR (toolbar));
-
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Enable", "Enable tooltips", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_enable, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Disable", "Disable tooltips", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_disable, toolbar);
-
- gtk_toolbar_append_space (GTK_TOOLBAR (toolbar));
-
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Borders", "Show Borders", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_borders, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Borderless", "Hide Borders", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_borderless, toolbar);
-
- gtk_toolbar_append_space (GTK_TOOLBAR (toolbar));
-
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Empty", "Empty spaces", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_space_style_empty, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Lines", "Lines in spaces", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_space_style_line, toolbar);
-
- gtk_container_add (GTK_CONTAINER (window), toolbar);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-static GtkWidget*
-make_toolbar (GtkWidget *window)
-{
- GtkWidget *toolbar;
-
- if (!GTK_WIDGET_REALIZED (window))
- gtk_widget_realize (window);
-
- toolbar = gtk_toolbar_new (GTK_ORIENTATION_HORIZONTAL, GTK_TOOLBAR_BOTH);
- gtk_toolbar_set_button_relief (GTK_TOOLBAR (toolbar), GTK_RELIEF_NONE);
-
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Horizontal", "Horizontal toolbar layout", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_horizontal, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Vertical", "Vertical toolbar layout", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_vertical, toolbar);
-
- gtk_toolbar_append_space (GTK_TOOLBAR(toolbar));
-
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Icons", "Only show toolbar icons", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_icons, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Text", "Only show toolbar text", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_text, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Both", "Show toolbar icons and text", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_both, toolbar);
-
- gtk_toolbar_append_space (GTK_TOOLBAR (toolbar));
-
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Small", "Use small spaces", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_small_space, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Big", "Use big spaces", "Toolbar/Big",
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_big_space, toolbar);
-
- gtk_toolbar_append_space (GTK_TOOLBAR (toolbar));
-
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Enable", "Enable tooltips", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_enable, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Disable", "Disable tooltips", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_disable, toolbar);
-
- gtk_toolbar_append_space (GTK_TOOLBAR (toolbar));
-
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Borders", "Show Borders", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_borders, toolbar);
- gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
- "Borderless", "Hide Borders", NULL,
- new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
- (GtkSignalFunc) set_toolbar_borderless, toolbar);
-
- return toolbar;
-}
-
-/*
- * GtkStatusBar
- */
-
-static guint statusbar_counter = 1;
-
-static void
-statusbar_push (GtkWidget *button,
- GtkStatusbar *statusbar)
-{
- gchar text[1024];
-
- sprintf (text, "something %d", statusbar_counter++);
-
- gtk_statusbar_push (statusbar, 1, text);
-}
-
-static void
-statusbar_pop (GtkWidget *button,
- GtkStatusbar *statusbar)
-{
- gtk_statusbar_pop (statusbar, 1);
-}
-
-static void
-statusbar_steal (GtkWidget *button,
- GtkStatusbar *statusbar)
-{
- gtk_statusbar_remove (statusbar, 1, 4);
-}
-
-static void
-statusbar_popped (GtkStatusbar *statusbar,
- guint context_id,
- const gchar *text)
-{
- if (!statusbar->messages)
- statusbar_counter = 1;
-}
-
-static void
-statusbar_contexts (GtkStatusbar *statusbar)
-{
- gchar *string;
-
- string = "any context";
- g_print ("GtkStatusBar: context=\"%s\", context_id=%d\n",
- string,
- gtk_statusbar_get_context_id (statusbar, string));
-
- string = "idle messages";
- g_print ("GtkStatusBar: context=\"%s\", context_id=%d\n",
- string,
- gtk_statusbar_get_context_id (statusbar, string));
-
- string = "some text";
- g_print ("GtkStatusBar: context=\"%s\", context_id=%d\n",
- string,
- gtk_statusbar_get_context_id (statusbar, string));
-
- string = "hit the mouse";
- g_print ("GtkStatusBar: context=\"%s\", context_id=%d\n",
- string,
- gtk_statusbar_get_context_id (statusbar, string));
-
- string = "hit the mouse2";
- g_print ("GtkStatusBar: context=\"%s\", context_id=%d\n",
- string,
- gtk_statusbar_get_context_id (statusbar, string));
-}
-
-static void
-create_statusbar (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *button;
- GtkWidget *separator;
- GtkWidget *statusbar;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "statusbar");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
-
- statusbar = gtk_statusbar_new ();
- gtk_box_pack_end (GTK_BOX (box1), statusbar, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (statusbar),
- "text_popped",
- GTK_SIGNAL_FUNC (statusbar_popped),
- NULL);
-
- button = gtk_widget_new (gtk_button_get_type (),
- "label", "push something",
- "visible", TRUE,
- "parent", box2,
- NULL);
- g_object_connect (G_OBJECT (button),
- "signal::clicked", statusbar_push, statusbar,
- NULL);
-
- button = g_object_connect (gtk_widget_new (gtk_button_get_type (),
- "label", "pop",
- "visible", TRUE,
- "parent", box2,
- NULL),
- "signal_after::clicked", statusbar_pop, statusbar,
- NULL);
-
- button = g_object_connect (gtk_widget_new (gtk_button_get_type (),
- "label", "steal #4",
- "visible", TRUE,
- "parent", box2,
- NULL),
- "signal_after::clicked", statusbar_steal, statusbar,
- NULL);
-
- button = g_object_connect (gtk_widget_new (gtk_button_get_type (),
- "label", "test contexts",
- "visible", TRUE,
- "parent", box2,
- NULL),
- "swapped_signal_after::clicked", statusbar_contexts, statusbar,
- NULL);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkTree
- */
-
-static void
-cb_tree_destroy_event(GtkWidget* w)
-{
- sTreeButtons* tree_buttons;
-
- /* free buttons structure associate at this tree */
- tree_buttons = gtk_object_get_user_data (GTK_OBJECT (w));
- g_free (tree_buttons);
-}
-
-static void
-cb_add_new_item(GtkWidget* w, GtkTree* tree)
-{
- sTreeButtons* tree_buttons;
- GList* selected_list;
- GtkWidget* selected_item;
- GtkWidget* subtree;
- GtkWidget* item_new;
- char buffer[255];
-
- tree_buttons = gtk_object_get_user_data(GTK_OBJECT(tree));
-
- selected_list = GTK_TREE_SELECTION_OLD(tree);
-
- if(selected_list == NULL)
- {
- /* there is no item in tree */
- subtree = GTK_WIDGET(tree);
- }
- else
- {
- /* list can have only one element */
- selected_item = GTK_WIDGET(selected_list->data);
-
- subtree = GTK_TREE_ITEM_SUBTREE(selected_item);
-
- if(subtree == NULL)
- {
- /* current selected item have not subtree ... create it */
- subtree = gtk_tree_new();
- gtk_tree_item_set_subtree(GTK_TREE_ITEM(selected_item),
- subtree);
- }
- }
-
- /* at this point, we know which subtree will be used to add new item */
- /* create a new item */
- sprintf(buffer, "item add %d", tree_buttons->nb_item_add);
- item_new = gtk_tree_item_new_with_label(buffer);
- gtk_tree_append(GTK_TREE(subtree), item_new);
- gtk_widget_show(item_new);
-
- tree_buttons->nb_item_add++;
-}
-
-static void
-cb_remove_item(GtkWidget*w, GtkTree* tree)
-{
- GList* selected_list;
- GList* clear_list;
-
- selected_list = GTK_TREE_SELECTION_OLD(tree);
-
- clear_list = NULL;
-
- while (selected_list)
- {
- clear_list = g_list_prepend (clear_list, selected_list->data);
- selected_list = selected_list->next;
- }
-
- clear_list = g_list_reverse (clear_list);
- gtk_tree_remove_items(tree, clear_list);
-
- g_list_free (clear_list);
-}
-
-static void
-cb_remove_subtree(GtkWidget*w, GtkTree* tree)
-{
- GList* selected_list;
- GtkTreeItem *item;
-
- selected_list = GTK_TREE_SELECTION_OLD(tree);
-
- if (selected_list)
- {
- item = GTK_TREE_ITEM (selected_list->data);
- if (item->subtree)
- gtk_tree_item_remove_subtree (item);
- }
-}
-
-static void
-cb_tree_changed(GtkTree* tree)
-{
- sTreeButtons* tree_buttons;
- GList* selected_list;
- guint nb_selected;
-
- tree_buttons = gtk_object_get_user_data(GTK_OBJECT(tree));
-
- selected_list = GTK_TREE_SELECTION_OLD(tree);
- nb_selected = g_list_length(selected_list);
-
- if(nb_selected == 0)
- {
- if(tree->children == NULL)
- gtk_widget_set_sensitive(tree_buttons->add_button, TRUE);
- else
- gtk_widget_set_sensitive(tree_buttons->add_button, FALSE);
- gtk_widget_set_sensitive(tree_buttons->remove_button, FALSE);
- gtk_widget_set_sensitive(tree_buttons->subtree_button, FALSE);
- }
- else
- {
- gtk_widget_set_sensitive(tree_buttons->remove_button, TRUE);
- gtk_widget_set_sensitive(tree_buttons->add_button, (nb_selected == 1));
- gtk_widget_set_sensitive(tree_buttons->subtree_button, (nb_selected == 1));
- }
-}
-
-static void
-create_subtree(GtkWidget* item, guint level, guint nb_item_max, guint recursion_level_max)
-{
- GtkWidget* item_subtree;
- GtkWidget* item_new;
- guint nb_item;
- char buffer[255];
- int no_root_item;
-
- if(level == recursion_level_max) return;
-
- if(level == -1)
- {
- /* query with no root item */
- level = 0;
- item_subtree = item;
- no_root_item = 1;
- }
- else
- {
- /* query with no root item */
- /* create subtree and associate it with current item */
- item_subtree = gtk_tree_new();
- no_root_item = 0;
- }
-
- for(nb_item = 0; nb_item < nb_item_max; nb_item++)
- {
- sprintf(buffer, "item %d-%d", level, nb_item);
- item_new = gtk_tree_item_new_with_label(buffer);
- gtk_tree_append(GTK_TREE(item_subtree), item_new);
- create_subtree(item_new, level+1, nb_item_max, recursion_level_max);
- gtk_widget_show(item_new);
- }
-
- if(!no_root_item)
- gtk_tree_item_set_subtree(GTK_TREE_ITEM(item), item_subtree);
-}
-
-static void
-create_tree_sample(guint selection_mode,
- guint draw_line, guint view_line, guint no_root_item,
- guint nb_item_max, guint recursion_level_max)
-{
- GtkWidget* window;
- GtkWidget* box1;
- GtkWidget* box2;
- GtkWidget* separator;
- GtkWidget* button;
- GtkWidget* scrolled_win;
- GtkWidget* root_tree;
- GtkWidget* root_item;
- sTreeButtons* tree_buttons;
-
- /* create tree buttons struct */
- if ((tree_buttons = g_malloc (sizeof (sTreeButtons))) == NULL)
- {
- g_error("can't allocate memory for tree structure !\n");
- return;
- }
- tree_buttons->nb_item_add = 0;
-
- /* create top level window */
- window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title(GTK_WINDOW(window), "Tree Sample");
- gtk_signal_connect(GTK_OBJECT(window), "destroy",
- (GtkSignalFunc) cb_tree_destroy_event, NULL);
- gtk_object_set_user_data(GTK_OBJECT(window), tree_buttons);
-
- box1 = gtk_vbox_new(FALSE, 0);
- gtk_container_add(GTK_CONTAINER(window), box1);
- gtk_widget_show(box1);
-
- /* create tree box */
- box2 = gtk_vbox_new(FALSE, 0);
- gtk_box_pack_start(GTK_BOX(box1), box2, TRUE, TRUE, 0);
- gtk_container_set_border_width(GTK_CONTAINER(box2), 5);
- gtk_widget_show(box2);
-
- /* create scrolled window */
- scrolled_win = gtk_scrolled_window_new (NULL, NULL);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win),
- GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
- gtk_box_pack_start (GTK_BOX (box2), scrolled_win, TRUE, TRUE, 0);
- gtk_widget_set_usize (scrolled_win, 200, 200);
- gtk_widget_show (scrolled_win);
-
- /* create root tree widget */
- root_tree = gtk_tree_new();
- gtk_signal_connect(GTK_OBJECT(root_tree), "selection_changed",
- (GtkSignalFunc)cb_tree_changed,
- (gpointer)NULL);
- gtk_object_set_user_data(GTK_OBJECT(root_tree), tree_buttons);
- gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (scrolled_win), root_tree);
- gtk_tree_set_selection_mode(GTK_TREE(root_tree), selection_mode);
- gtk_tree_set_view_lines(GTK_TREE(root_tree), draw_line);
- gtk_tree_set_view_mode(GTK_TREE(root_tree), !view_line);
- gtk_widget_show(root_tree);
-
- if ( no_root_item )
- {
- /* set root tree to subtree function with root item variable */
- root_item = GTK_WIDGET(root_tree);
- }
- else
- {
- /* create root tree item widget */
- root_item = gtk_tree_item_new_with_label("root item");
- gtk_tree_append(GTK_TREE(root_tree), root_item);
- gtk_widget_show(root_item);
- }
- create_subtree(root_item, -no_root_item, nb_item_max, recursion_level_max);
-
- box2 = gtk_vbox_new(FALSE, 0);
- gtk_box_pack_start(GTK_BOX(box1), box2, FALSE, FALSE, 0);
- gtk_container_set_border_width(GTK_CONTAINER(box2), 5);
- gtk_widget_show(box2);
-
- button = gtk_button_new_with_label("Add Item");
- gtk_widget_set_sensitive(button, FALSE);
- gtk_signal_connect(GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) cb_add_new_item,
- (gpointer)root_tree);
- gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0);
- gtk_widget_show(button);
- tree_buttons->add_button = button;
-
- button = gtk_button_new_with_label("Remove Item(s)");
- gtk_widget_set_sensitive(button, FALSE);
- gtk_signal_connect(GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) cb_remove_item,
- (gpointer)root_tree);
- gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0);
- gtk_widget_show(button);
- tree_buttons->remove_button = button;
-
- button = gtk_button_new_with_label("Remove Subtree");
- gtk_widget_set_sensitive(button, FALSE);
- gtk_signal_connect(GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) cb_remove_subtree,
- (gpointer)root_tree);
- gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0);
- gtk_widget_show(button);
- tree_buttons->subtree_button = button;
-
- /* create separator */
- separator = gtk_hseparator_new();
- gtk_box_pack_start(GTK_BOX(box1), separator, FALSE, FALSE, 0);
- gtk_widget_show(separator);
-
- /* create button box */
- box2 = gtk_vbox_new(FALSE, 0);
- gtk_box_pack_start(GTK_BOX(box1), box2, FALSE, FALSE, 0);
- gtk_container_set_border_width(GTK_CONTAINER(box2), 5);
- gtk_widget_show(box2);
-
- button = gtk_button_new_with_label("Close");
- gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0);
- gtk_signal_connect_object(GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) gtk_widget_destroy,
- GTK_OBJECT(window));
- gtk_widget_show(button);
-
- gtk_widget_show(window);
-}
-
-static void
-cb_create_tree(GtkWidget* w)
-{
- guint selection_mode = GTK_SELECTION_SINGLE;
- guint view_line;
- guint draw_line;
- guint no_root_item;
- guint nb_item;
- guint recursion_level;
-
- /* get selection mode choice */
- if(GTK_TOGGLE_BUTTON(sTreeSampleSelection.single_button)->active)
- selection_mode = GTK_SELECTION_SINGLE;
- else
- if(GTK_TOGGLE_BUTTON(sTreeSampleSelection.browse_button)->active)
- selection_mode = GTK_SELECTION_BROWSE;
- else
- selection_mode = GTK_SELECTION_MULTIPLE;
-
- /* get options choice */
- draw_line = GTK_TOGGLE_BUTTON(sTreeSampleSelection.draw_line_button)->active;
- view_line = GTK_TOGGLE_BUTTON(sTreeSampleSelection.view_line_button)->active;
- no_root_item = GTK_TOGGLE_BUTTON(sTreeSampleSelection.no_root_item_button)->active;
-
- /* get levels */
- nb_item = gtk_spin_button_get_value_as_int(GTK_SPIN_BUTTON(sTreeSampleSelection.nb_item_spinner));
- recursion_level = gtk_spin_button_get_value_as_int(GTK_SPIN_BUTTON(sTreeSampleSelection.recursion_spinner));
-
- if (pow (nb_item, recursion_level) > 10000)
- {
- g_print ("%g total items? That will take a very long time. Try less\n",
- pow (nb_item, recursion_level));
- return;
- }
-
- create_tree_sample(selection_mode, draw_line, view_line, no_root_item, nb_item, recursion_level);
-}
-
-void
-create_tree_mode_window(void)
-{
- static GtkWidget* window;
- GtkWidget* box1;
- GtkWidget* box2;
- GtkWidget* box3;
- GtkWidget* box4;
- GtkWidget* box5;
- GtkWidget* button;
- GtkWidget* frame;
- GtkWidget* separator;
- GtkWidget* label;
- GtkWidget* spinner;
- GtkAdjustment *adj;
-
- if (!window)
- {
- /* create toplevel window */
- window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title(GTK_WINDOW(window), "Set Tree Parameters");
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
- box1 = gtk_vbox_new(FALSE, 0);
- gtk_container_add(GTK_CONTAINER(window), box1);
-
- /* create upper box - selection box */
- box2 = gtk_vbox_new(FALSE, 5);
- gtk_box_pack_start(GTK_BOX(box1), box2, TRUE, TRUE, 0);
- gtk_container_set_border_width(GTK_CONTAINER(box2), 5);
-
- box3 = gtk_hbox_new(FALSE, 5);
- gtk_box_pack_start(GTK_BOX(box2), box3, TRUE, TRUE, 0);
-
- /* create selection mode frame */
- frame = gtk_frame_new("Selection Mode");
- gtk_box_pack_start(GTK_BOX(box3), frame, TRUE, TRUE, 0);
-
- box4 = gtk_vbox_new(FALSE, 0);
- gtk_container_add(GTK_CONTAINER(frame), box4);
- gtk_container_set_border_width(GTK_CONTAINER(box4), 5);
-
- /* create radio button */
- button = gtk_radio_button_new_with_label(NULL, "SINGLE");
- gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0);
- sTreeSampleSelection.single_button = button;
-
- button = gtk_radio_button_new_with_label(gtk_radio_button_group (GTK_RADIO_BUTTON (button)),
- "BROWSE");
- gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0);
- sTreeSampleSelection.browse_button = button;
-
- button = gtk_radio_button_new_with_label(gtk_radio_button_group (GTK_RADIO_BUTTON (button)),
- "MULTIPLE");
- gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0);
- sTreeSampleSelection.multiple_button = button;
-
- sTreeSampleSelection.selection_mode_group = gtk_radio_button_group (GTK_RADIO_BUTTON (button));
-
- /* create option mode frame */
- frame = gtk_frame_new("Options");
- gtk_box_pack_start(GTK_BOX(box3), frame, TRUE, TRUE, 0);
-
- box4 = gtk_vbox_new(FALSE, 0);
- gtk_container_add(GTK_CONTAINER(frame), box4);
- gtk_container_set_border_width(GTK_CONTAINER(box4), 5);
-
- /* create check button */
- button = gtk_check_button_new_with_label("Draw line");
- gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(button), TRUE);
- sTreeSampleSelection.draw_line_button = button;
-
- button = gtk_check_button_new_with_label("View Line mode");
- gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(button), TRUE);
- sTreeSampleSelection.view_line_button = button;
-
- button = gtk_check_button_new_with_label("Without Root item");
- gtk_box_pack_start(GTK_BOX(box4), button, TRUE, TRUE, 0);
- sTreeSampleSelection.no_root_item_button = button;
-
- /* create recursion parameter */
- frame = gtk_frame_new("Size Parameters");
- gtk_box_pack_start(GTK_BOX(box2), frame, TRUE, TRUE, 0);
-
- box4 = gtk_hbox_new(FALSE, 5);
- gtk_container_add(GTK_CONTAINER(frame), box4);
- gtk_container_set_border_width(GTK_CONTAINER(box4), 5);
-
- /* create number of item spin button */
- box5 = gtk_hbox_new(FALSE, 5);
- gtk_box_pack_start(GTK_BOX(box4), box5, FALSE, FALSE, 0);
-
- label = gtk_label_new("Number of items : ");
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
- gtk_box_pack_start (GTK_BOX (box5), label, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (DEFAULT_NUMBER_OF_ITEM, 1.0, 255.0, 1.0,
- 5.0, 0.0);
- spinner = gtk_spin_button_new (adj, 0, 0);
- gtk_box_pack_start (GTK_BOX (box5), spinner, FALSE, TRUE, 0);
- sTreeSampleSelection.nb_item_spinner = spinner;
-
- /* create recursion level spin button */
- box5 = gtk_hbox_new(FALSE, 5);
- gtk_box_pack_start(GTK_BOX(box4), box5, FALSE, FALSE, 0);
-
- label = gtk_label_new("Depth : ");
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
- gtk_box_pack_start (GTK_BOX (box5), label, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (DEFAULT_RECURSION_LEVEL, 0.0, 255.0, 1.0,
- 5.0, 0.0);
- spinner = gtk_spin_button_new (adj, 0, 0);
- gtk_box_pack_start (GTK_BOX (box5), spinner, FALSE, TRUE, 0);
- sTreeSampleSelection.recursion_spinner = spinner;
-
- /* create horizontal separator */
- separator = gtk_hseparator_new();
- gtk_box_pack_start(GTK_BOX(box1), separator, FALSE, FALSE, 0);
-
- /* create bottom button box */
- box2 = gtk_hbox_new(TRUE, 10);
- gtk_box_pack_start(GTK_BOX(box1), box2, FALSE, FALSE, 0);
- gtk_container_set_border_width(GTK_CONTAINER(box2), 5);
-
- button = gtk_button_new_with_label("Create Tree");
- gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0);
- gtk_signal_connect(GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) cb_create_tree, NULL);
-
- button = gtk_button_new_with_label("Close");
- gtk_box_pack_start(GTK_BOX(box2), button, TRUE, TRUE, 0);
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- }
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkHandleBox
- */
-
-static void
-handle_box_child_signal (GtkHandleBox *hb,
- GtkWidget *child,
- const gchar *action)
-{
- printf ("%s: child <%s> %sed\n",
- gtk_type_name (GTK_OBJECT_TYPE (hb)),
- gtk_type_name (GTK_OBJECT_TYPE (child)),
- action);
-}
-
-static void
-create_handle_box (void)
-{
- static GtkWidget* window = NULL;
- GtkWidget *handle_box;
- GtkWidget *handle_box2;
- GtkWidget *vbox;
- GtkWidget *hbox;
- GtkWidget *toolbar;
- GtkWidget *label;
- GtkWidget *separator;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title (GTK_WINDOW (window),
- "Handle Box Test");
- gtk_window_set_policy (GTK_WINDOW (window),
- TRUE,
- TRUE,
- TRUE);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_container_set_border_width (GTK_CONTAINER (window), 20);
-
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), vbox);
- gtk_widget_show (vbox);
-
- label = gtk_label_new ("Above");
- gtk_container_add (GTK_CONTAINER (vbox), label);
- gtk_widget_show (label);
-
- separator = gtk_hseparator_new ();
- gtk_container_add (GTK_CONTAINER (vbox), separator);
- gtk_widget_show (separator);
-
- hbox = gtk_hbox_new (FALSE, 10);
- gtk_container_add (GTK_CONTAINER (vbox), hbox);
- gtk_widget_show (hbox);
-
- separator = gtk_hseparator_new ();
- gtk_container_add (GTK_CONTAINER (vbox), separator);
- gtk_widget_show (separator);
-
- label = gtk_label_new ("Below");
- gtk_container_add (GTK_CONTAINER (vbox), label);
- gtk_widget_show (label);
-
- handle_box = gtk_handle_box_new ();
- gtk_box_pack_start (GTK_BOX (hbox), handle_box, FALSE, FALSE, 0);
- gtk_signal_connect (GTK_OBJECT (handle_box),
- "child_attached",
- GTK_SIGNAL_FUNC (handle_box_child_signal),
- "attached");
- gtk_signal_connect (GTK_OBJECT (handle_box),
- "child_detached",
- GTK_SIGNAL_FUNC (handle_box_child_signal),
- "detached");
- gtk_widget_show (handle_box);
-
- toolbar = make_toolbar (window);
- gtk_toolbar_set_button_relief (GTK_TOOLBAR (toolbar), GTK_RELIEF_NORMAL);
- gtk_container_add (GTK_CONTAINER (handle_box), toolbar);
- gtk_widget_show (toolbar);
-
- handle_box = gtk_handle_box_new ();
- gtk_box_pack_start (GTK_BOX (hbox), handle_box, FALSE, FALSE, 0);
- gtk_signal_connect (GTK_OBJECT (handle_box),
- "child_attached",
- GTK_SIGNAL_FUNC (handle_box_child_signal),
- "attached");
- gtk_signal_connect (GTK_OBJECT (handle_box),
- "child_detached",
- GTK_SIGNAL_FUNC (handle_box_child_signal),
- "detached");
- gtk_widget_show (handle_box);
-
- handle_box2 = gtk_handle_box_new ();
- gtk_container_add (GTK_CONTAINER (handle_box), handle_box2);
- gtk_signal_connect (GTK_OBJECT (handle_box2),
- "child_attached",
- GTK_SIGNAL_FUNC (handle_box_child_signal),
- "attached");
- gtk_signal_connect (GTK_OBJECT (handle_box2),
- "child_detached",
- GTK_SIGNAL_FUNC (handle_box_child_signal),
- "detached");
- gtk_widget_show (handle_box2);
-
- label = gtk_label_new ("Fooo!");
- gtk_container_add (GTK_CONTAINER (handle_box2), label);
- gtk_widget_show (label);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Test for getting an image from a drawable
- */
-
-struct GetImageData
-{
- GtkWidget *src;
- GtkWidget *snap;
- GtkWidget *sw;
-};
-
-static void
-take_snapshot (GtkWidget *button,
- gpointer data)
-{
- struct GetImageData *gid = data;
- GdkRectangle visible;
- int width_fraction;
- int height_fraction;
- GdkGC *gc;
- GdkGC *black_gc;
- GdkColor color = { 0, 30000, 0, 0 };
- GdkRectangle target;
- GdkImage *shot;
-
- /* Do some begin_paint_rect on some random rects, draw some
- * distinctive stuff into those rects, then take the snapshot.
- * figure out whether any rects were overlapped and report to
- * user.
- */
-
- visible = gid->sw->allocation;
-
- visible.x = gtk_scrolled_window_get_hadjustment (GTK_SCROLLED_WINDOW (gid->sw))->value;
- visible.y = gtk_scrolled_window_get_vadjustment (GTK_SCROLLED_WINDOW (gid->sw))->value;
-
- width_fraction = visible.width / 4;
- height_fraction = visible.height / 4;
-
- gc = gdk_gc_new (gid->src->window);
- black_gc = gid->src->style->black_gc;
-
- gdk_gc_set_rgb_fg_color (gc, &color);
-
-
- target.x = visible.x + width_fraction;
- target.y = visible.y + height_fraction * 3;
- target.width = width_fraction;
- target.height = height_fraction / 2;
-
- gdk_window_begin_paint_rect (gid->src->window,
- &target);
-
- gdk_draw_rectangle (gid->src->window,
- gc,
- TRUE,
- target.x, target.y,
- target.width, target.height);
-
- gdk_draw_rectangle (gid->src->window,
- black_gc,
- FALSE,
- target.x + 10, target.y + 10,
- target.width - 20, target.height - 20);
-
- target.x = visible.x + width_fraction;
- target.y = visible.y + height_fraction;
- target.width = width_fraction;
- target.height = height_fraction;
-
- gdk_window_begin_paint_rect (gid->src->window,
- &target);
-
- gdk_draw_rectangle (gid->src->window,
- gc,
- TRUE,
- target.x, target.y,
- target.width, target.height);
-
- gdk_draw_rectangle (gid->src->window,
- black_gc,
- FALSE,
- target.x + 10, target.y + 10,
- target.width - 20, target.height - 20);
-
- target.x = visible.x + width_fraction * 3;
- target.y = visible.y + height_fraction;
- target.width = width_fraction / 2;
- target.height = height_fraction;
-
- gdk_window_begin_paint_rect (gid->src->window,
- &target);
-
- gdk_draw_rectangle (gid->src->window,
- gc,
- TRUE,
- target.x, target.y,
- target.width, target.height);
-
- gdk_draw_rectangle (gid->src->window,
- black_gc,
- FALSE,
- target.x + 10, target.y + 10,
- target.width - 20, target.height - 20);
-
- target.x = visible.x + width_fraction * 2;
- target.y = visible.y + height_fraction * 2;
- target.width = width_fraction / 4;
- target.height = height_fraction / 4;
-
- gdk_window_begin_paint_rect (gid->src->window,
- &target);
-
- gdk_draw_rectangle (gid->src->window,
- gc,
- TRUE,
- target.x, target.y,
- target.width, target.height);
-
- gdk_draw_rectangle (gid->src->window,
- black_gc,
- FALSE,
- target.x + 10, target.y + 10,
- target.width - 20, target.height - 20);
-
- target.x += target.width / 2;
- target.y += target.width / 2;
-
- gdk_window_begin_paint_rect (gid->src->window,
- &target);
-
- gdk_draw_rectangle (gid->src->window,
- gc,
- TRUE,
- target.x, target.y,
- target.width, target.height);
-
- gdk_draw_rectangle (gid->src->window,
- black_gc,
- FALSE,
- target.x + 10, target.y + 10,
- target.width - 20, target.height - 20);
-
- /* Screen shot area */
-
- target.x = visible.x + width_fraction * 1.5;
- target.y = visible.y + height_fraction * 1.5;
- target.width = width_fraction * 2;
- target.height = height_fraction * 2;
-
- shot = gdk_drawable_get_image (gid->src->window,
- target.x, target.y,
- target.width, target.height);
-
- gtk_image_set_from_image (GTK_IMAGE (gid->snap),
- shot, NULL);
-
- g_object_unref (G_OBJECT (shot));
-
- gdk_window_end_paint (gid->src->window);
- gdk_window_end_paint (gid->src->window);
- gdk_window_end_paint (gid->src->window);
- gdk_window_end_paint (gid->src->window);
- gdk_window_end_paint (gid->src->window);
-
- gdk_draw_rectangle (gid->src->window,
- gid->src->style->black_gc,
- FALSE,
- target.x, target.y,
- target.width, target.height);
-
- g_object_unref (G_OBJECT (gc));
-}
-
-static gint
-image_source_expose (GtkWidget *da,
- GdkEventExpose *event,
- gpointer data)
-{
- int x = event->area.x;
- GdkColor red = { 0, 65535, 0, 0 };
- GdkColor green = { 0, 0, 65535, 0 };
- GdkColor blue = { 0, 0, 0, 65535 };
- GdkGC *gc;
-
- gc = gdk_gc_new (event->window);
-
- while (x < (event->area.x + event->area.width))
- {
- switch (x % 7)
- {
- case 0:
- case 1:
- case 2:
- gdk_gc_set_rgb_fg_color (gc, &red);
- break;
-
- case 3:
- case 4:
- case 5:
- gdk_gc_set_rgb_fg_color (gc, &green);
- break;
-
- case 6:
- case 7:
- case 8:
- gdk_gc_set_rgb_fg_color (gc, &blue);
- break;
-
- default:
- g_assert_not_reached ();
- break;
- }
-
- gdk_draw_line (event->window,
- gc,
- x, event->area.y,
- x, event->area.y + event->area.height);
-
- ++x;
- }
-
- g_object_unref (G_OBJECT (gc));
-
- return TRUE;
-}
-
-static void
-create_get_image (void)
-{
- static GtkWidget *window = NULL;
-
- if (window)
- gtk_widget_destroy (window);
- else
- {
- GtkWidget *sw;
- GtkWidget *src;
- GtkWidget *snap;
- GtkWidget *vbox;
- GtkWidget *hbox;
- GtkWidget *button;
- struct GetImageData *gid;
-
- gid = g_new (struct GetImageData, 1);
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window),
- "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &window);
-
- gtk_object_set_data_full (GTK_OBJECT (window),
- "testgtk-get-image-data",
- gid,
- g_free);
-
- vbox = gtk_vbox_new (FALSE, 0);
-
- gtk_container_add (GTK_CONTAINER (window), vbox);
-
- sw = gtk_scrolled_window_new (NULL, NULL);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sw),
- GTK_POLICY_AUTOMATIC,
- GTK_POLICY_AUTOMATIC);
-
- gid->sw = sw;
-
- gtk_widget_set_usize (sw, 400, 400);
-
- src = gtk_drawing_area_new ();
- gtk_widget_set_usize (src, 10000, 10000);
-
- gtk_signal_connect (GTK_OBJECT (src),
- "expose_event",
- GTK_SIGNAL_FUNC (image_source_expose),
- gid);
-
- gid->src = src;
-
- gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (sw),
- src);
-
- gtk_box_pack_start (GTK_BOX (vbox),
- sw, TRUE, TRUE, 0);
-
-
- hbox = gtk_hbox_new (FALSE, 3);
-
- snap = gtk_widget_new (GTK_TYPE_IMAGE, NULL);
-
- gid->snap = snap;
-
- sw = gtk_scrolled_window_new (NULL, NULL);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sw),
- GTK_POLICY_AUTOMATIC,
- GTK_POLICY_AUTOMATIC);
- gtk_widget_set_usize (sw, 300, 300);
-
- gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (sw), snap);
-
- gtk_box_pack_end (GTK_BOX (hbox), sw, FALSE, FALSE, 5);
-
- button = gtk_button_new_with_label ("Get image from drawable");
-
- gtk_signal_connect (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC (take_snapshot),
- gid);
-
- gtk_box_pack_start (GTK_BOX (hbox), button, FALSE, FALSE, 0);
-
- gtk_box_pack_end (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
-
- gtk_widget_show_all (window);
- }
-}
-
-/*
- * Label Demo
- */
-static void
-sensitivity_toggled (GtkWidget *toggle,
- GtkWidget *widget)
-{
- gtk_widget_set_sensitive (widget, GTK_TOGGLE_BUTTON (toggle)->active);
-}
-
-static GtkWidget*
-create_sensitivity_control (GtkWidget *widget)
-{
- GtkWidget *button;
-
- button = gtk_toggle_button_new_with_label ("Sensitive");
-
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button),
- GTK_WIDGET_IS_SENSITIVE (widget));
-
- gtk_signal_connect (GTK_OBJECT (button),
- "toggled",
- GTK_SIGNAL_FUNC (sensitivity_toggled),
- widget);
-
- gtk_widget_show_all (button);
-
- return button;
-}
-
-static void
-set_selectable_recursive (GtkWidget *widget,
- gboolean setting)
-{
- if (GTK_IS_CONTAINER (widget))
- {
- GList *children;
- GList *tmp;
-
- children = gtk_container_children (GTK_CONTAINER (widget));
- tmp = children;
- while (tmp)
- {
- set_selectable_recursive (tmp->data, setting);
-
- tmp = tmp->next;
- }
- g_list_free (children);
- }
- else if (GTK_IS_LABEL (widget))
- {
- gtk_label_set_selectable (GTK_LABEL (widget), setting);
- }
-}
-
-static void
-selectable_toggled (GtkWidget *toggle,
- GtkWidget *widget)
-{
- set_selectable_recursive (widget,
- GTK_TOGGLE_BUTTON (toggle)->active);
-}
-
-static GtkWidget*
-create_selectable_control (GtkWidget *widget)
-{
- GtkWidget *button;
-
- button = gtk_toggle_button_new_with_label ("Selectable");
-
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button),
- FALSE);
-
- gtk_signal_connect (GTK_OBJECT (button),
- "toggled",
- GTK_SIGNAL_FUNC (selectable_toggled),
- widget);
-
- gtk_widget_show_all (button);
-
- return button;
-}
-
-void create_labels (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *hbox;
- GtkWidget *vbox;
- GtkWidget *frame;
- GtkWidget *label;
- GtkWidget *button;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Label");
-
- vbox = gtk_vbox_new (FALSE, 5);
-
- hbox = gtk_hbox_new (FALSE, 5);
- gtk_container_add (GTK_CONTAINER (window), vbox);
-
- gtk_box_pack_end (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
-
- button = create_sensitivity_control (hbox);
-
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = create_selectable_control (hbox);
-
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- vbox = gtk_vbox_new (FALSE, 5);
-
- gtk_box_pack_start (GTK_BOX (hbox), vbox, FALSE, FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (window), 5);
-
- frame = gtk_frame_new ("Normal Label");
- label = gtk_label_new ("This is a Normal label");
- gtk_container_add (GTK_CONTAINER (frame), label);
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
-
- frame = gtk_frame_new ("Multi-line Label");
- label = gtk_label_new ("This is a Multi-line label.\nSecond line\nThird line");
- gtk_container_add (GTK_CONTAINER (frame), label);
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
-
- frame = gtk_frame_new ("Left Justified Label");
- label = gtk_label_new ("This is a Left-Justified\nMulti-line label.\nThird line");
- gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_LEFT);
- gtk_container_add (GTK_CONTAINER (frame), label);
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
-
- frame = gtk_frame_new ("Right Justified Label");
- label = gtk_label_new ("This is a Right-Justified\nMulti-line label.\nFourth line, (j/k)");
- gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_RIGHT);
- gtk_container_add (GTK_CONTAINER (frame), label);
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
-
- frame = gtk_frame_new ("Internationalized Label");
- label = gtk_label_new ("French (Français) Bonjour, Salut\n"
- "Korean (한글) 안녕하세요, 안녕하십니까\n"
- "Russian (Русский) Здравствуйте!");
- gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_LEFT);
- gtk_container_add (GTK_CONTAINER (frame), label);
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
-
- frame = gtk_frame_new ("Bidirection Label");
- label = gtk_label_new ("Arabic السلام عليكم\n"
- "Hebrew שלום");
- gtk_widget_set_direction (label, GTK_TEXT_DIR_RTL);
- gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_RIGHT);
- gtk_container_add (GTK_CONTAINER (frame), label);
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
-
- vbox = gtk_vbox_new (FALSE, 5);
- gtk_box_pack_start (GTK_BOX (hbox), vbox, FALSE, FALSE, 0);
- frame = gtk_frame_new ("Line wrapped label");
- label = gtk_label_new ("This is an example of a line-wrapped label. It should not be taking "\
- "up the entire "/* big space to test spacing */\
- "width allocated to it, but automatically wraps the words to fit. "\
- "The time has come, for all good men, to come to the aid of their party. "\
- "The sixth sheik's six sheep's sick.\n"\
- " It supports multiple paragraphs correctly, and correctly adds "\
- "many extra spaces. ");
-
- gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
- gtk_container_add (GTK_CONTAINER (frame), label);
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
-
- frame = gtk_frame_new ("Filled, wrapped label");
- label = gtk_label_new ("This is an example of a line-wrapped, filled label. It should be taking "\
- "up the entire width allocated to it. Here is a seneance to prove "\
- "my point. Here is another sentence. "\
- "Here comes the sun, do de do de do.\n"\
- " This is a new paragraph.\n"\
- " This is another newer, longer, better paragraph. It is coming to an end, "\
- "unfortunately.");
- gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_FILL);
- gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
- gtk_container_add (GTK_CONTAINER (frame), label);
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
-
- frame = gtk_frame_new ("Underlined label");
- label = gtk_label_new ("This label is underlined!\n"
- "This one is underlined (こんにちは) in quite a funky fashion");
- gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_LEFT);
- gtk_label_set_pattern (GTK_LABEL (label), "_________________________ _ _________ _ _____ _ __ __ ___ ____ _____");
- gtk_container_add (GTK_CONTAINER (frame), label);
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
-
- frame = gtk_frame_new ("Markup label");
- label = gtk_label_new (NULL);
-
- /* There's also a gtk_label_set_markup() without accel if you
- * don't have an accelerator key
- */
- gtk_label_set_markup_with_mnemonic (GTK_LABEL (label),
- "This <span foreground=\"blue\" background=\"orange\">label</span> has "
- "<b>markup</b> _such as "
- "<big><i>Big Italics</i></big>\n"
- "<tt>Monospace font</tt>\n"
- "<u>Underline!</u>\n"
- "foo\n"
- "<span foreground=\"green\" background=\"red\">Ugly colors</span>\n"
- "and nothing on this line,\n"
- "or this.\n"
- "or this either\n"
- "or even on this one\n"
- "la <big>la <big>la <big>la <big>la</big></big></big></big>\n"
- "but this _word is <span foreground=\"purple\"><big>purple</big></span>\n"
- "<span underline=\"double\">We like <sup>superscript</sup> and <sub>subscript</sub> too</span>");
-
- g_assert (gtk_label_get_mnemonic_keyval (GTK_LABEL (label)) == GDK_s);
-
- gtk_container_add (GTK_CONTAINER (frame), label);
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Reparent demo
- */
-
-static void
-reparent_label (GtkWidget *widget,
- GtkWidget *new_parent)
-{
- GtkWidget *label;
-
- label = gtk_object_get_user_data (GTK_OBJECT (widget));
-
- gtk_widget_reparent (label, new_parent);
-}
-
-static void
-set_parent_signal (GtkWidget *child,
- GtkWidget *old_parent,
- gpointer func_data)
-{
- g_print ("set_parent for \"%s\": new parent: \"%s\", old parent: \"%s\", data: %d\n",
- gtk_type_name (GTK_OBJECT_TYPE (child)),
- child->parent ? gtk_type_name (GTK_OBJECT_TYPE (child->parent)) : "NULL",
- old_parent ? gtk_type_name (GTK_OBJECT_TYPE (old_parent)) : "NULL",
- GPOINTER_TO_INT (func_data));
-}
-
-static void
-create_reparent (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *box3;
- GtkWidget *frame;
- GtkWidget *button;
- GtkWidget *label;
- GtkWidget *separator;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "reparent");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- box2 = gtk_hbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
-
- label = gtk_label_new ("Hello World");
-
- frame = gtk_frame_new ("Frame 1");
- gtk_box_pack_start (GTK_BOX (box2), frame, TRUE, TRUE, 0);
-
- box3 = gtk_vbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (box3), 5);
- gtk_container_add (GTK_CONTAINER (frame), box3);
-
- button = gtk_button_new_with_label ("switch");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(reparent_label),
- box3);
- gtk_object_set_user_data (GTK_OBJECT (button), label);
- gtk_box_pack_start (GTK_BOX (box3), button, FALSE, TRUE, 0);
-
- gtk_box_pack_start (GTK_BOX (box3), label, FALSE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (label),
- "parent_set",
- GTK_SIGNAL_FUNC (set_parent_signal),
- GINT_TO_POINTER (42));
-
- frame = gtk_frame_new ("Frame 2");
- gtk_box_pack_start (GTK_BOX (box2), frame, TRUE, TRUE, 0);
-
- box3 = gtk_vbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (box3), 5);
- gtk_container_add (GTK_CONTAINER (frame), box3);
-
- button = gtk_button_new_with_label ("switch");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(reparent_label),
- box3);
- gtk_object_set_user_data (GTK_OBJECT (button), label);
- gtk_box_pack_start (GTK_BOX (box3), button, FALSE, TRUE, 0);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Saved Position
- */
-gint upositionx = 0;
-gint upositiony = 0;
-
-static gint
-uposition_configure (GtkWidget *window)
-{
- GtkLabel *lx;
- GtkLabel *ly;
- gchar buffer[64];
-
- lx = gtk_object_get_data (GTK_OBJECT (window), "x");
- ly = gtk_object_get_data (GTK_OBJECT (window), "y");
-
- gdk_window_get_root_origin (window->window, &upositionx, &upositiony);
- sprintf (buffer, "%d", upositionx);
- gtk_label_set_text (lx, buffer);
- sprintf (buffer, "%d", upositiony);
- gtk_label_set_text (ly, buffer);
-
- return FALSE;
-}
-
-static void
-uposition_stop_configure (GtkToggleButton *toggle,
- GtkObject *window)
-{
- if (toggle->active)
- gtk_signal_handler_block_by_func (window, GTK_SIGNAL_FUNC (uposition_configure), NULL);
- else
- gtk_signal_handler_unblock_by_func (window, GTK_SIGNAL_FUNC (uposition_configure), NULL);
-}
-
-static void
-create_saved_position (void)
-{
- static GtkWidget *window = NULL;
-
- if (!window)
- {
- GtkWidget *hbox;
- GtkWidget *main_vbox;
- GtkWidget *vbox;
- GtkWidget *x_label;
- GtkWidget *y_label;
- GtkWidget *button;
- GtkWidget *label;
- GtkWidget *any;
-
- window = g_object_connect (gtk_widget_new (GTK_TYPE_WINDOW,
- "type", GTK_WINDOW_TOPLEVEL,
- "x", upositionx,
- "y", upositiony,
- "title", "Saved Position",
- NULL),
- "signal::configure_event", uposition_configure, NULL,
- NULL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &window);
-
- main_vbox = gtk_vbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (main_vbox), 0);
- gtk_container_add (GTK_CONTAINER (window), main_vbox);
-
- vbox =
- gtk_widget_new (gtk_vbox_get_type (),
- "GtkBox::homogeneous", FALSE,
- "GtkBox::spacing", 5,
- "GtkContainer::border_width", 10,
- "GtkWidget::parent", main_vbox,
- "GtkWidget::visible", TRUE,
- "child", g_object_connect (gtk_widget_new (GTK_TYPE_TOGGLE_BUTTON,
- "label", "Stop Events",
- "active", FALSE,
- "visible", TRUE,
- NULL),
- "signal::clicked", uposition_stop_configure, window,
- NULL),
- NULL);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
-
- label = gtk_label_new ("X Origin : ");
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
-
- x_label = gtk_label_new ("");
- gtk_box_pack_start (GTK_BOX (hbox), x_label, TRUE, TRUE, 0);
- gtk_object_set_data (GTK_OBJECT (window), "x", x_label);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
-
- label = gtk_label_new ("Y Origin : ");
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
-
- y_label = gtk_label_new ("");
- gtk_box_pack_start (GTK_BOX (hbox), y_label, TRUE, TRUE, 0);
- gtk_object_set_data (GTK_OBJECT (window), "y", y_label);
-
- any =
- gtk_widget_new (gtk_hseparator_get_type (),
- "GtkWidget::visible", TRUE,
- NULL);
- gtk_box_pack_start (GTK_BOX (main_vbox), any, FALSE, TRUE, 0);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 10);
- gtk_box_pack_start (GTK_BOX (main_vbox), hbox, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("Close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
-
- gtk_widget_show_all (window);
- }
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkPixmap
- */
-
-static void
-create_pixmap (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *box3;
- GtkWidget *button;
- GtkWidget *label;
- GtkWidget *separator;
- GtkWidget *pixmapwid;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "GtkPixmap");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
- gtk_widget_realize(window);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
-
- button = gtk_button_new ();
- gtk_box_pack_start (GTK_BOX (box2), button, FALSE, FALSE, 0);
-
- pixmapwid = new_pixmap ("test.xpm", window->window, NULL);
-
- label = gtk_label_new ("Pixmap\ntest");
- box3 = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (box3), 2);
- gtk_container_add (GTK_CONTAINER (box3), pixmapwid);
- gtk_container_add (GTK_CONTAINER (box3), label);
- gtk_container_add (GTK_CONTAINER (button), box3);
-
- button = gtk_button_new ();
- gtk_box_pack_start (GTK_BOX (box2), button, FALSE, FALSE, 0);
-
- pixmapwid = new_pixmap ("test.xpm", window->window, NULL);
-
- label = gtk_label_new ("Pixmap\ntest");
- box3 = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (box3), 2);
- gtk_container_add (GTK_CONTAINER (box3), pixmapwid);
- gtk_container_add (GTK_CONTAINER (box3), label);
- gtk_container_add (GTK_CONTAINER (button), box3);
-
- gtk_widget_set_sensitive (button, FALSE);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-static void
-tips_query_widget_entered (GtkTipsQuery *tips_query,
- GtkWidget *widget,
- const gchar *tip_text,
- const gchar *tip_private,
- GtkWidget *toggle)
-{
- if (GTK_TOGGLE_BUTTON (toggle)->active)
- {
- gtk_label_set_text (GTK_LABEL (tips_query), tip_text ? "There is a Tip!" : "There is no Tip!");
- /* don't let GtkTipsQuery reset its label */
- gtk_signal_emit_stop_by_name (GTK_OBJECT (tips_query), "widget_entered");
- }
-}
-
-static gint
-tips_query_widget_selected (GtkWidget *tips_query,
- GtkWidget *widget,
- const gchar *tip_text,
- const gchar *tip_private,
- GdkEventButton *event,
- gpointer func_data)
-{
- if (widget)
- g_print ("Help \"%s\" requested for <%s>\n",
- tip_private ? tip_private : "None",
- gtk_type_name (GTK_OBJECT_TYPE (widget)));
- return TRUE;
-}
-
-static void
-create_tooltips (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *box3;
- GtkWidget *button;
- GtkWidget *toggle;
- GtkWidget *frame;
- GtkWidget *tips_query;
- GtkWidget *separator;
- GtkTooltips *tooltips;
-
- if (!window)
- {
- window =
- gtk_widget_new (gtk_window_get_type (),
- "GtkWindow::type", GTK_WINDOW_TOPLEVEL,
- "GtkContainer::border_width", 0,
- "GtkWindow::title", "Tooltips",
- "GtkWindow::allow_shrink", TRUE,
- "GtkWindow::allow_grow", FALSE,
- "GtkWindow::auto_shrink", TRUE,
- "GtkWidget::width", 200,
- NULL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (destroy_tooltips),
- &window);
-
- tooltips=gtk_tooltips_new();
- gtk_object_set_data (GTK_OBJECT (window), "tooltips", tooltips);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
-
- button = gtk_toggle_button_new_with_label ("button1");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- gtk_tooltips_set_tip (tooltips,button,"This is button 1", "ContextHelp/buttons/1");
-
- button = gtk_toggle_button_new_with_label ("button2");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- gtk_tooltips_set_tip (tooltips,
- button,
- "This is button 2. This is also a really long tooltip which probably won't fit on a single line and will therefore need to be wrapped. Hopefully the wrapping will work correctly.",
- "ContextHelp/buttons/2_long");
-
- toggle = gtk_toggle_button_new_with_label ("Override TipsQuery Label");
- gtk_box_pack_start (GTK_BOX (box2), toggle, TRUE, TRUE, 0);
-
- gtk_tooltips_set_tip (tooltips, toggle, "Toggle TipsQuery view.", "Hi msw! ;)");
-
- box3 =
- gtk_widget_new (gtk_vbox_get_type (),
- "homogeneous", FALSE,
- "spacing", 5,
- "border_width", 5,
- "visible", TRUE,
- NULL);
-
- tips_query = gtk_tips_query_new ();
-
- button =
- gtk_widget_new (gtk_button_get_type (),
- "label", "[?]",
- "visible", TRUE,
- "parent", box3,
- NULL);
- g_object_connect (G_OBJECT (button),
- "swapped_signal::clicked", gtk_tips_query_start_query, tips_query,
- NULL);
- gtk_box_set_child_packing (GTK_BOX (box3), button, FALSE, FALSE, 0, GTK_PACK_START);
- gtk_tooltips_set_tip (tooltips,
- button,
- "Start the Tooltips Inspector",
- "ContextHelp/buttons/?");
-
-
- gtk_widget_set (g_object_connect (tips_query,
- "signal::widget_entered", tips_query_widget_entered, toggle,
- "signal::widget_selected", tips_query_widget_selected, NULL,
- NULL),
- "visible", TRUE,
- "parent", box3,
- "caller", button,
- NULL);
-
- frame = gtk_widget_new (gtk_frame_get_type (),
- "label", "ToolTips Inspector",
- "label_xalign", (double) 0.5,
- "border_width", 0,
- "visible", TRUE,
- "parent", box2,
- "child", box3,
- NULL);
- gtk_box_set_child_packing (GTK_BOX (box2), frame, TRUE, TRUE, 10, GTK_PACK_START);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
-
- gtk_tooltips_set_tip (tooltips, button, "Push this button to close window", "ContextHelp/buttons/Close");
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkImage
- */
-
-static void
-pack_image (GtkWidget *box,
- const gchar *text,
- GtkWidget *image)
-{
- gtk_box_pack_start (GTK_BOX (box),
- gtk_label_new (text),
- FALSE, FALSE, 0);
-
- gtk_box_pack_start (GTK_BOX (box),
- image,
- TRUE, TRUE, 0);
-}
-
-static void
-create_image (void)
-{
- static GtkWidget *window = NULL;
-
- if (window == NULL)
- {
- GtkWidget *vbox;
- GdkPixmap *pixmap;
- GdkBitmap *mask;
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- vbox = gtk_vbox_new (FALSE, 5);
-
- gtk_container_add (GTK_CONTAINER (window), vbox);
-
- pack_image (vbox, "Stock Warning Dialog",
- gtk_image_new_from_stock (GTK_STOCK_DIALOG_WARNING,
- GTK_ICON_SIZE_DIALOG));
-
- pixmap = gdk_pixmap_colormap_create_from_xpm_d (NULL,
- gtk_widget_get_colormap (window),
- &mask,
- NULL,
- openfile);
-
- pack_image (vbox, "Pixmap",
- gtk_image_new_from_pixmap (pixmap, mask));
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Menu demo
- */
-
-static GtkWidget*
-create_menu (gint depth, gint length, gboolean tearoff)
-{
- GtkWidget *menu;
- GtkWidget *menuitem;
- GtkWidget *image;
- GSList *group;
- char buf[32];
- int i, j;
-
- if (depth < 1)
- return NULL;
-
- menu = gtk_menu_new ();
- group = NULL;
-
- if (tearoff)
- {
- menuitem = gtk_tearoff_menu_item_new ();
- gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
- gtk_widget_show (menuitem);
- }
-
- image = gtk_image_new_from_stock (GTK_STOCK_OPEN,
- GTK_ICON_SIZE_MENU);
- gtk_widget_show (image);
- menuitem = gtk_image_menu_item_new (image, "Image item");
- gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
- gtk_widget_show (menuitem);
-
- for (i = 0, j = 1; i < length; i++, j++)
- {
- sprintf (buf, "item %2d - %d", depth, j);
-
- menuitem = gtk_radio_menu_item_new_with_label (group, buf);
- group = gtk_radio_menu_item_group (GTK_RADIO_MENU_ITEM (menuitem));
-
- if (depth % 2)
- gtk_check_menu_item_set_show_toggle (GTK_CHECK_MENU_ITEM (menuitem), TRUE);
-
- gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
- gtk_widget_show (menuitem);
- if (i == 3)
- gtk_widget_set_sensitive (menuitem, FALSE);
-
- if (i == 5)
- gtk_check_menu_item_set_inconsistent (GTK_CHECK_MENU_ITEM (menuitem),
- TRUE);
-
- if (i < 5)
- gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), create_menu (depth - 1, 5, TRUE));
- }
-
- return menu;
-}
-
-static void
-create_menus (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *button;
- GtkWidget *optionmenu;
- GtkWidget *separator;
-
- if (!window)
- {
- GtkWidget *menubar;
- GtkWidget *menu;
- GtkWidget *menuitem;
- GtkAccelGroup *accel_group;
- GtkWidget *image;
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
- gtk_signal_connect (GTK_OBJECT (window), "delete-event",
- GTK_SIGNAL_FUNC (gtk_true),
- NULL);
-
- accel_group = gtk_accel_group_new ();
- gtk_accel_group_attach (accel_group, GTK_OBJECT (window));
-
- gtk_window_set_title (GTK_WINDOW (window), "menus");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
- gtk_widget_show (box1);
-
- menubar = gtk_menu_bar_new ();
- gtk_box_pack_start (GTK_BOX (box1), menubar, FALSE, TRUE, 0);
- gtk_widget_show (menubar);
-
- menu = create_menu (2, 50, TRUE);
-
- menuitem = gtk_menu_item_new_with_label ("test\nline2");
- gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), menu);
- gtk_menu_bar_append (GTK_MENU_BAR (menubar), menuitem);
- gtk_widget_show (menuitem);
-
- menuitem = gtk_menu_item_new_with_label ("foo");
- gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), create_menu (3, 5, TRUE));
- gtk_menu_bar_append (GTK_MENU_BAR (menubar), menuitem);
- gtk_widget_show (menuitem);
-
- image = gtk_image_new_from_stock (GTK_STOCK_HELP,
- GTK_ICON_SIZE_MENU);
- gtk_widget_show (image);
- menuitem = gtk_image_menu_item_new (image, "Help");
- gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), create_menu (4, 5, TRUE));
- gtk_menu_item_right_justify (GTK_MENU_ITEM (menuitem));
- gtk_menu_bar_append (GTK_MENU_BAR (menubar), menuitem);
- gtk_widget_show (menuitem);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
- gtk_widget_show (box2);
-
- menu = create_menu (1, 5, FALSE);
- gtk_menu_set_accel_group (GTK_MENU (menu), accel_group);
-
- menuitem = gtk_image_menu_item_new_from_stock (GTK_STOCK_NEW, accel_group);
- gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
- gtk_widget_show (menuitem);
-
- menuitem = gtk_check_menu_item_new_with_label ("Accelerate Me");
- gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
- gtk_widget_show (menuitem);
- gtk_widget_add_accelerator (menuitem,
- "activate",
- accel_group,
- GDK_F1,
- 0,
- GTK_ACCEL_VISIBLE | GTK_ACCEL_SIGNAL_VISIBLE);
- menuitem = gtk_check_menu_item_new_with_label ("Accelerator Locked");
- gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
- gtk_widget_show (menuitem);
- gtk_widget_add_accelerator (menuitem,
- "activate",
- accel_group,
- GDK_F2,
- 0,
- GTK_ACCEL_VISIBLE | GTK_ACCEL_LOCKED);
- menuitem = gtk_check_menu_item_new_with_label ("Accelerators Frozen");
- gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
- gtk_widget_show (menuitem);
- gtk_widget_add_accelerator (menuitem,
- "activate",
- accel_group,
- GDK_F2,
- 0,
- GTK_ACCEL_VISIBLE);
- gtk_widget_add_accelerator (menuitem,
- "activate",
- accel_group,
- GDK_F3,
- 0,
- GTK_ACCEL_VISIBLE);
- gtk_widget_lock_accelerators (menuitem);
-
- optionmenu = gtk_option_menu_new ();
- gtk_option_menu_set_menu (GTK_OPTION_MENU (optionmenu), menu);
- gtk_option_menu_set_history (GTK_OPTION_MENU (optionmenu), 3);
- gtk_box_pack_start (GTK_BOX (box2), optionmenu, TRUE, TRUE, 0);
- gtk_widget_show (optionmenu);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
- gtk_widget_show (separator);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
- gtk_widget_show (box2);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-static void
-gtk_ifactory_cb (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- g_message ("ItemFactory: activated \"%s\"", gtk_item_factory_path_from_widget (widget));
-}
-
-/* This file was automatically generated by the make-inline-pixbuf program.
- * It contains inline RGB image data.
- */
-static const guchar apple[] =
-{
- /* File magic (1197763408) */
- 0x47, 0x64, 0x6b, 0x50,
- /* Format of following stuff (0) */
- 0x00, 0x00, 0x00, 0x00,
- /* Rowstride (64) */
- 0x00, 0x00, 0x00, 0x40,
- /* Width (16) */
- 0x00, 0x00, 0x00, 0x10,
- /* Height (16) */
- 0x00, 0x00, 0x00, 0x10,
- /* Has an alpha channel (TRUE) */
- 0x01,
- /* Colorspace (0 == RGB, no other options implemented) (0) */
- 0x00, 0x00, 0x00, 0x00,
- /* Number of channels (4) */
- 0x00, 0x00, 0x00, 0x04,
- /* Bits per sample (8) */
- 0x00, 0x00, 0x00, 0x08,
- /* Image data */
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x16, 0x14, 0x0f, 0x04,
- 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x61, 0x6d, 0x5b, 0x2b, 0x6e, 0x7c, 0x61, 0xd9,
- 0x71, 0x80, 0x63, 0xd7, 0x5f, 0x6b, 0x5b, 0x35, 0x00, 0x00, 0x00, 0x00,
- 0x3a, 0x35, 0x28, 0x8f, 0x00, 0x00, 0x00, 0x32, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x60, 0x6c, 0x5c, 0x07, 0x6d, 0x7b, 0x61, 0xd8,
- 0x75, 0x84, 0x65, 0xf6, 0x76, 0x86, 0x66, 0xf7, 0x6a, 0x77, 0x60, 0xec,
- 0x5e, 0x6a, 0x58, 0x47, 0x1c, 0x1a, 0x13, 0xa2, 0x4b, 0x47, 0x30, 0x07,
- 0x55, 0x4e, 0x33, 0x21, 0x48, 0x3e, 0x2a, 0x08, 0xd0, 0xb8, 0x84, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x69, 0x76, 0x5f, 0x74,
- 0x75, 0x84, 0x65, 0xf3, 0x67, 0x75, 0x5e, 0xc4, 0x69, 0x62, 0x55, 0x75,
- 0x94, 0x50, 0x50, 0x69, 0x75, 0x5c, 0x52, 0xb2, 0x69, 0x38, 0x34, 0xa2,
- 0xa7, 0x5b, 0x53, 0xea, 0xa3, 0x52, 0x4f, 0xff, 0x90, 0x47, 0x42, 0xfa,
- 0x76, 0x44, 0x36, 0xb9, 0x59, 0x38, 0x29, 0x3c, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x5f, 0x6b, 0x5a, 0x09,
- 0x69, 0x76, 0x5e, 0xb0, 0x5f, 0x6b, 0x59, 0x57, 0x9a, 0x4b, 0x4d, 0x5b,
- 0xb8, 0x5f, 0x63, 0xfa, 0xcc, 0x7d, 0x7e, 0xff, 0xc5, 0x69, 0x68, 0xff,
- 0xc7, 0x6b, 0x67, 0xff, 0xc5, 0x6f, 0x67, 0xff, 0xba, 0x5e, 0x5a, 0xff,
- 0xb1, 0x4d, 0x4d, 0xff, 0x92, 0x4b, 0x42, 0xff, 0x6a, 0x3e, 0x30, 0xfc,
- 0x5c, 0x3b, 0x27, 0x6d, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x5d, 0x69, 0x57, 0x09, 0x5d, 0x69, 0x57, 0x09, 0x92, 0x47, 0x46, 0x1e,
- 0xba, 0x65, 0x64, 0xf4, 0xe7, 0xbf, 0xc0, 0xff, 0xdf, 0xa5, 0xa3, 0xff,
- 0xd4, 0x84, 0x81, 0xff, 0xd1, 0x7c, 0x76, 0xff, 0xc9, 0x78, 0x6d, 0xff,
- 0xbb, 0x6a, 0x5d, 0xff, 0xb3, 0x5a, 0x52, 0xff, 0x9f, 0x4b, 0x47, 0xff,
- 0x78, 0x45, 0x35, 0xff, 0x5f, 0x3c, 0x28, 0xfa, 0x53, 0x5a, 0x38, 0x24,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0xa1, 0x54, 0x4d, 0x8c, 0xcf, 0x8e, 0x89, 0xff, 0xe3, 0xb1, 0xae, 0xff,
- 0xd8, 0x94, 0x8e, 0xff, 0xd3, 0x8a, 0x82, 0xff, 0xcf, 0x80, 0x76, 0xff,
- 0xc4, 0x75, 0x67, 0xff, 0xb7, 0x6c, 0x5c, 0xff, 0xab, 0x5e, 0x51, 0xff,
- 0x9c, 0x4c, 0x46, 0xff, 0x7e, 0x4a, 0x3a, 0xff, 0x5c, 0x3c, 0x26, 0xff,
- 0x58, 0x3d, 0x28, 0x55, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0xa2, 0x59, 0x4f, 0xc3, 0xcd, 0x8e, 0x88, 0xff,
- 0xd3, 0x93, 0x8c, 0xff, 0xd0, 0x8c, 0x83, 0xff, 0xcc, 0x84, 0x79, 0xff,
- 0xc7, 0x7c, 0x6e, 0xff, 0xbc, 0x73, 0x61, 0xff, 0xb1, 0x6b, 0x59, 0xff,
- 0xa3, 0x5f, 0x4f, 0xff, 0x93, 0x50, 0x44, 0xff, 0x78, 0x48, 0x35, 0xff,
- 0x59, 0x3b, 0x25, 0xff, 0x4f, 0x3d, 0x28, 0x4f, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x9b, 0x5b, 0x4d, 0xbc,
- 0xbd, 0x7e, 0x72, 0xff, 0xc6, 0x86, 0x7a, 0xff, 0xc5, 0x7f, 0x72, 0xff,
- 0xc2, 0x7b, 0x6c, 0xff, 0xbf, 0x77, 0x63, 0xff, 0xb7, 0x72, 0x5b, 0xff,
- 0xa9, 0x6b, 0x53, 0xff, 0x9a, 0x60, 0x4b, 0xff, 0x8b, 0x56, 0x41, 0xff,
- 0x6a, 0x44, 0x2e, 0xff, 0x53, 0x38, 0x21, 0xfd, 0x42, 0x4b, 0x2e, 0x1a,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x8e, 0x57, 0x48, 0x6e, 0xa6, 0x6b, 0x5a, 0xff, 0xb3, 0x74, 0x62, 0xff,
- 0xb8, 0x75, 0x61, 0xff, 0xba, 0x76, 0x61, 0xff, 0xb7, 0x74, 0x5c, 0xff,
- 0xae, 0x6e, 0x54, 0xff, 0x9f, 0x67, 0x4c, 0xff, 0x90, 0x5d, 0x43, 0xff,
- 0x79, 0x4d, 0x38, 0xff, 0x5c, 0x3d, 0x25, 0xff, 0x50, 0x39, 0x23, 0xb8,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x78, 0x52, 0x43, 0x07, 0x92, 0x5c, 0x47, 0xdc,
- 0x9e, 0x64, 0x4e, 0xff, 0xa8, 0x6b, 0x52, 0xff, 0xaa, 0x6d, 0x53, 0xff,
- 0xa7, 0x6d, 0x50, 0xff, 0x9c, 0x67, 0x4a, 0xff, 0x8e, 0x5d, 0x41, 0xff,
- 0x7d, 0x54, 0x3a, 0xff, 0x6a, 0x4b, 0x32, 0xff, 0x51, 0x39, 0x23, 0xff,
- 0x28, 0x20, 0x12, 0x77, 0x00, 0x00, 0x00, 0x12, 0x00, 0x00, 0x00, 0x01,
- 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x6f, 0x4a, 0x37, 0x2a, 0x81, 0x54, 0x3d, 0xec, 0x8b, 0x5a, 0x41, 0xff,
- 0x8b, 0x5a, 0x3f, 0xff, 0x85, 0x56, 0x3c, 0xff, 0x7d, 0x52, 0x38, 0xff,
- 0x77, 0x51, 0x33, 0xff, 0x6f, 0x4e, 0x34, 0xff, 0x5f, 0x45, 0x2c, 0xff,
- 0x2e, 0x21, 0x14, 0xff, 0x00, 0x00, 0x00, 0xf8, 0x00, 0x00, 0x00, 0x92,
- 0x00, 0x00, 0x00, 0x0e, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x14, 0x11, 0x0b, 0x08, 0xb4,
- 0x50, 0x37, 0x25, 0xfe, 0x6d, 0x49, 0x2f, 0xff, 0x52, 0x37, 0x22, 0xff,
- 0x50, 0x37, 0x21, 0xff, 0x66, 0x45, 0x2b, 0xff, 0x60, 0x46, 0x2c, 0xff,
- 0x2d, 0x22, 0x16, 0xff, 0x00, 0x00, 0x00, 0xfe, 0x00, 0x00, 0x00, 0xd2,
- 0x00, 0x00, 0x00, 0x63, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02,
- 0x00, 0x00, 0x00, 0x22, 0x00, 0x00, 0x00, 0x64, 0x09, 0x0a, 0x07, 0xa4,
- 0x00, 0x00, 0x00, 0xbd, 0x00, 0x00, 0x00, 0xbe, 0x00, 0x00, 0x00, 0xc4,
- 0x00, 0x00, 0x00, 0xb8, 0x00, 0x00, 0x00, 0x9d, 0x00, 0x00, 0x00, 0x6c,
- 0x00, 0x00, 0x00, 0x2c, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01,
- 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x0b, 0x00, 0x00, 0x00, 0x0d,
- 0x00, 0x00, 0x00, 0x0b, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x06,
- 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00
-};
-
-
-static void
-dump_accels (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- gtk_item_factory_dump_items (NULL, FALSE, gtk_item_factory_print_func, stdout);
-}
-
-static GtkItemFactoryEntry menu_items[] =
-{
- { "/_File", NULL, 0, 0, "<Branch>" },
- { "/File/tearoff1", NULL, gtk_ifactory_cb, 0, "<Tearoff>" },
- { "/File/_New", NULL, gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_NEW },
- { "/File/_Open", NULL, gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_OPEN },
- { "/File/_Save", NULL, gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_SAVE },
- { "/File/Save _As...", "<control>A", gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_SAVE },
- { "/File/_Dump \"_Accels\"", NULL, dump_accels, 0 },
- { "/File/\\/Test__Escaping/And\\/\n\tWei\\\\rdly",
- NULL, gtk_ifactory_cb, 0 },
- { "/File/sep1", NULL, gtk_ifactory_cb, 0, "<Separator>" },
- { "/File/_Quit", NULL, gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_QUIT },
-
- { "/_Preferences", NULL, 0, 0, "<Branch>" },
- { "/_Preferences/_Color", NULL, 0, 0, "<Branch>" },
- { "/_Preferences/Color/_Red", NULL, gtk_ifactory_cb, 0, "<RadioItem>" },
- { "/_Preferences/Color/_Green", NULL, gtk_ifactory_cb, 0, "/Preferences/Color/Red" },
- { "/_Preferences/Color/_Blue", NULL, gtk_ifactory_cb, 0, "/Preferences/Color/Red" },
- { "/_Preferences/_Shape", NULL, 0, 0, "<Branch>" },
- { "/_Preferences/Shape/_Square", NULL, gtk_ifactory_cb, 0, "<RadioItem>" },
- { "/_Preferences/Shape/_Rectangle", NULL, gtk_ifactory_cb, 0, "/Preferences/Shape/Square" },
- { "/_Preferences/Shape/_Oval", NULL, gtk_ifactory_cb, 0, "/Preferences/Shape/Rectangle" },
- { "/_Preferences/Shape/_Rectangle", NULL, gtk_ifactory_cb, 0, "/Preferences/Shape/Square" },
- { "/_Preferences/Shape/_Oval", NULL, gtk_ifactory_cb, 0, "/Preferences/Shape/Rectangle" },
- { "/_Preferences/Shape/_Image", NULL, gtk_ifactory_cb, 0, "<ImageItem>", (gchar**) apple, sizeof(apple) },
-
- /* For testing deletion of menus */
- { "/_Preferences/Should_NotAppear", NULL, 0, 0, "<Branch>" },
- { "/Preferences/ShouldNotAppear/SubItem1", NULL, gtk_ifactory_cb, 0 },
- { "/Preferences/ShouldNotAppear/SubItem2", NULL, gtk_ifactory_cb, 0 },
-
- { "/_Help", NULL, 0, 0, "<LastBranch>" },
- { "/Help/_Help", NULL, gtk_ifactory_cb, 0, "<StockItem>", GTK_STOCK_HELP},
- { "/Help/_About", NULL, gtk_ifactory_cb, 0 },
-};
-
-
-static int nmenu_items = sizeof (menu_items) / sizeof (menu_items[0]);
-
-static void
-create_item_factory (void)
-{
- static GtkWidget *window = NULL;
-
- if (!window)
- {
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *separator;
- GtkWidget *label;
- GtkWidget *button;
- GtkAccelGroup *accel_group;
- GtkItemFactory *item_factory;
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
- gtk_signal_connect (GTK_OBJECT (window), "delete-event",
- GTK_SIGNAL_FUNC (gtk_true),
- NULL);
-
- accel_group = gtk_accel_group_new ();
- item_factory = gtk_item_factory_new (GTK_TYPE_MENU_BAR, "<main>", accel_group);
- gtk_object_set_data_full (GTK_OBJECT (window),
- "<main>",
- item_factory,
- (GtkDestroyNotify) gtk_object_unref);
- gtk_accel_group_attach (accel_group, GTK_OBJECT (window));
- gtk_window_set_title (GTK_WINDOW (window), "Item Factory");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
- gtk_item_factory_create_items (item_factory, nmenu_items, menu_items, NULL);
-
- /* preselect /Preferences/Shape/Oval over the other radios
- */
- gtk_check_menu_item_set_active (GTK_CHECK_MENU_ITEM (gtk_item_factory_get_item (item_factory,
- "/Preferences/Shape/Oval")),
- TRUE);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- gtk_box_pack_start (GTK_BOX (box1),
- gtk_item_factory_get_widget (item_factory, "<main>"),
- FALSE, FALSE, 0);
-
- label = gtk_label_new ("Type\n<alt>\nto start");
- gtk_widget_set_usize (label, 200, 200);
- gtk_misc_set_alignment (GTK_MISC (label), 0.5, 0.5);
- gtk_box_pack_start (GTK_BOX (box1), label, TRUE, TRUE, 0);
-
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
-
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
-
- gtk_item_factory_delete_item (item_factory, "/Preferences/ShouldNotAppear");
-
- gtk_widget_show_all (window);
- }
- else
- gtk_widget_destroy (window);
-}
-
-/*
- create_modal_window
- */
-
-static gboolean
-cmw_destroy_cb(GtkWidget *widget)
-{
- /* This is needed to get out of gtk_main */
- gtk_main_quit ();
-
- return FALSE;
-}
-
-static void
-cmw_color (GtkWidget *widget, GtkWidget *parent)
-{
- GtkWidget *csd;
-
- csd=gtk_color_selection_dialog_new ("This is a modal color selection dialog");
-
- /* Set as modal */
- gtk_window_set_modal (GTK_WINDOW(csd),TRUE);
-
- /* And mark it as a transient dialog */
- gtk_window_set_transient_for (GTK_WINDOW (csd), GTK_WINDOW (parent));
-
- gtk_signal_connect (GTK_OBJECT(csd), "destroy",
- GTK_SIGNAL_FUNC(cmw_destroy_cb),NULL);
-
- gtk_signal_connect_object (GTK_OBJECT(GTK_COLOR_SELECTION_DIALOG(csd)->ok_button),
- "clicked", GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (csd));
- gtk_signal_connect_object (GTK_OBJECT(GTK_COLOR_SELECTION_DIALOG(csd)->cancel_button),
- "clicked", GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (csd));
-
- /* wait until destroy calls gtk_main_quit */
- gtk_widget_show (csd);
- gtk_main ();
-}
-
-static void
-cmw_file (GtkWidget *widget, GtkWidget *parent)
-{
- GtkWidget *fs;
-
- fs = gtk_file_selection_new("This is a modal file selection dialog");
-
- /* Set as modal */
- gtk_window_set_modal (GTK_WINDOW(fs),TRUE);
-
- /* And mark it as a transient dialog */
- gtk_window_set_transient_for (GTK_WINDOW (fs), GTK_WINDOW (parent));
-
- gtk_signal_connect (GTK_OBJECT(fs), "destroy",
- GTK_SIGNAL_FUNC(cmw_destroy_cb),NULL);
-
- gtk_signal_connect_object (GTK_OBJECT(GTK_FILE_SELECTION(fs)->ok_button),
- "clicked",GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (fs));
- gtk_signal_connect_object (GTK_OBJECT(GTK_FILE_SELECTION(fs)->cancel_button),
- "clicked",GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (fs));
-
- /* wait until destroy calls gtk_main_quit */
- gtk_widget_show (fs);
-
- gtk_main();
-}
-
-
-static void
-create_modal_window (void)
-{
- GtkWidget *window = NULL;
- GtkWidget *box1,*box2;
- GtkWidget *frame1;
- GtkWidget *btnColor,*btnFile,*btnClose;
-
- /* Create modal window (Here you can use any window descendent )*/
- window=gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title (GTK_WINDOW(window),"This window is modal");
-
- /* Set window as modal */
- gtk_window_set_modal (GTK_WINDOW(window),TRUE);
-
- /* Create widgets */
- box1 = gtk_vbox_new (FALSE,5);
- frame1 = gtk_frame_new ("Standard dialogs in modal form");
- box2 = gtk_vbox_new (TRUE,5);
- btnColor = gtk_button_new_with_label ("Color");
- btnFile = gtk_button_new_with_label ("File Selection");
- btnClose = gtk_button_new_with_label ("Close");
-
- /* Init widgets */
- gtk_container_set_border_width (GTK_CONTAINER(box1),3);
- gtk_container_set_border_width (GTK_CONTAINER(box2),3);
-
- /* Pack widgets */
- gtk_container_add (GTK_CONTAINER (window), box1);
- gtk_box_pack_start (GTK_BOX (box1), frame1, TRUE, TRUE, 4);
- gtk_container_add (GTK_CONTAINER (frame1), box2);
- gtk_box_pack_start (GTK_BOX (box2), btnColor, FALSE, FALSE, 4);
- gtk_box_pack_start (GTK_BOX (box2), btnFile, FALSE, FALSE, 4);
- gtk_box_pack_start (GTK_BOX (box1), gtk_hseparator_new (), FALSE, FALSE, 4);
- gtk_box_pack_start (GTK_BOX (box1), btnClose, FALSE, FALSE, 4);
-
- /* connect signals */
- gtk_signal_connect_object (GTK_OBJECT (btnClose), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (window));
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (cmw_destroy_cb),NULL);
-
- gtk_signal_connect (GTK_OBJECT (btnColor), "clicked",
- GTK_SIGNAL_FUNC (cmw_color),window);
- gtk_signal_connect (GTK_OBJECT (btnFile), "clicked",
- GTK_SIGNAL_FUNC (cmw_file),window);
-
- /* Show widgets */
- gtk_widget_show_all (window);
-
- /* wait until dialog get destroyed */
- gtk_main();
-}
-
-/*
- * GtkMessageDialog
- */
-
-static void
-make_message_dialog (GtkWidget **dialog,
- GtkMessageType type,
- GtkButtonsType buttons)
-{
- if (*dialog)
- {
- gtk_widget_destroy (*dialog);
-
- return;
- }
-
- *dialog = gtk_message_dialog_new (NULL, 0, type, buttons,
- "This is a message dialog; it can wrap long lines. This is a long line. La la la. Look this line is wrapped. Blah blah blah blah blah blah. (Note: testgtk has a nonstandard gtkrc that changes some of the message dialog icons.)");
-
- gtk_signal_connect_object (GTK_OBJECT (*dialog),
- "response",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (*dialog));
-
- gtk_signal_connect (GTK_OBJECT (*dialog),
- "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- dialog);
-
- gtk_widget_show (*dialog);
-}
-
-static void
-create_message_dialog (void)
-{
- static GtkWidget *info = NULL;
- static GtkWidget *warning = NULL;
- static GtkWidget *error = NULL;
- static GtkWidget *question = NULL;
-
- make_message_dialog (&info, GTK_MESSAGE_INFO, GTK_BUTTONS_OK);
- make_message_dialog (&warning, GTK_MESSAGE_WARNING, GTK_BUTTONS_CLOSE);
- make_message_dialog (&error, GTK_MESSAGE_ERROR, GTK_BUTTONS_OK_CANCEL);
- make_message_dialog (&question, GTK_MESSAGE_QUESTION, GTK_BUTTONS_YES_NO);
-}
-
-/*
- * GtkScrolledWindow
- */
-
-static GtkWidget *sw_parent = NULL;
-static GtkWidget *sw_float_parent;
-static guint sw_destroyed_handler = 0;
-
-static gboolean
-scrolled_windows_delete_cb (GtkWidget *widget, GdkEventAny *event, GtkWidget *scrollwin)
-{
- gtk_widget_reparent (scrollwin, sw_parent);
-
- gtk_signal_disconnect (GTK_OBJECT (sw_parent), sw_destroyed_handler);
- sw_float_parent = NULL;
- sw_parent = NULL;
- sw_destroyed_handler = 0;
-
- return FALSE;
-}
-
-static void
-scrolled_windows_destroy_cb (GtkWidget *widget, GtkWidget *scrollwin)
-{
- gtk_widget_destroy (sw_float_parent);
-
- sw_float_parent = NULL;
- sw_parent = NULL;
- sw_destroyed_handler = 0;
-}
-
-static void
-scrolled_windows_remove (GtkWidget *widget, GtkWidget *scrollwin)
-{
- if (sw_parent)
- {
- gtk_widget_reparent (scrollwin, sw_parent);
- gtk_widget_destroy (sw_float_parent);
-
- gtk_signal_disconnect (GTK_OBJECT (sw_parent), sw_destroyed_handler);
- sw_float_parent = NULL;
- sw_parent = NULL;
- sw_destroyed_handler = 0;
- }
- else
- {
- sw_parent = scrollwin->parent;
- sw_float_parent = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_default_size (GTK_WINDOW (sw_float_parent), 200, 200);
-
- gtk_widget_reparent (scrollwin, sw_float_parent);
- gtk_widget_show (sw_float_parent);
-
- sw_destroyed_handler =
- gtk_signal_connect (GTK_OBJECT (sw_parent), "destroy",
- GTK_SIGNAL_FUNC (scrolled_windows_destroy_cb), scrollwin);
- gtk_signal_connect (GTK_OBJECT (sw_float_parent), "delete_event",
- GTK_SIGNAL_FUNC (scrolled_windows_delete_cb), scrollwin);
- }
-}
-
-static void
-create_scrolled_windows (void)
-{
- static GtkWidget *window;
- GtkWidget *scrolled_window;
- GtkWidget *table;
- GtkWidget *button;
- char buffer[32];
- int i, j;
-
- if (!window)
- {
- window = gtk_dialog_new ();
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "dialog");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
-
- scrolled_window = gtk_scrolled_window_new (NULL, NULL);
- gtk_container_set_border_width (GTK_CONTAINER (scrolled_window), 10);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window),
- GTK_POLICY_AUTOMATIC,
- GTK_POLICY_AUTOMATIC);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox),
- scrolled_window, TRUE, TRUE, 0);
- gtk_widget_show (scrolled_window);
-
- table = gtk_table_new (20, 20, FALSE);
- gtk_table_set_row_spacings (GTK_TABLE (table), 10);
- gtk_table_set_col_spacings (GTK_TABLE (table), 10);
- gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (scrolled_window), table);
- gtk_container_set_focus_hadjustment (GTK_CONTAINER (table),
- gtk_scrolled_window_get_hadjustment (GTK_SCROLLED_WINDOW (scrolled_window)));
- gtk_container_set_focus_vadjustment (GTK_CONTAINER (table),
- gtk_scrolled_window_get_vadjustment (GTK_SCROLLED_WINDOW (scrolled_window)));
- gtk_widget_show (table);
-
- for (i = 0; i < 20; i++)
- for (j = 0; j < 20; j++)
- {
- sprintf (buffer, "button (%d,%d)\n", i, j);
- button = gtk_toggle_button_new_with_label (buffer);
- gtk_table_attach_defaults (GTK_TABLE (table), button,
- i, i+1, j, j+1);
- gtk_widget_show (button);
- }
-
-
- button = gtk_button_new_with_label ("Close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("Reparent Out");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(scrolled_windows_remove),
- scrolled_window);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
-
- gtk_window_set_default_size (GTK_WINDOW (window), 300, 300);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkEntry
- */
-
-static void
-entry_toggle_frame (GtkWidget *checkbutton,
- GtkWidget *entry)
-{
- gtk_entry_set_has_frame (GTK_ENTRY(entry),
- GTK_TOGGLE_BUTTON(checkbutton)->active);
-}
-
-static void
-entry_toggle_editable (GtkWidget *checkbutton,
- GtkWidget *entry)
-{
- gtk_entry_set_editable(GTK_ENTRY(entry),
- GTK_TOGGLE_BUTTON(checkbutton)->active);
-}
-
-static void
-entry_toggle_sensitive (GtkWidget *checkbutton,
- GtkWidget *entry)
-{
- gtk_widget_set_sensitive (entry, GTK_TOGGLE_BUTTON(checkbutton)->active);
-}
-
-static void
-entry_toggle_visibility (GtkWidget *checkbutton,
- GtkWidget *entry)
-{
- gtk_entry_set_visibility (GTK_ENTRY (entry),
- GTK_TOGGLE_BUTTON (checkbutton)->active);
-}
-
-static void
-entry_toggle_invisible_char (GtkWidget *checkbutton,
- GtkWidget *entry)
-{
- if (GTK_TOGGLE_BUTTON (checkbutton)->active)
- gtk_entry_set_invisible_char (GTK_ENTRY (entry), 0);
- else
- gtk_entry_set_invisible_char (GTK_ENTRY (entry), '*');
-}
-
-
-static void
-entry_toggle_activate_default (GtkWidget *checkbutton,
- GtkWidget *entry)
-{
- gtk_entry_set_activates_default (GTK_ENTRY (entry),
- GTK_TOGGLE_BUTTON (checkbutton)->active);
-}
-
-static void
-create_entry (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *editable_check;
- GtkWidget *sensitive_check;
- GtkWidget *invisible_char_check;
- GtkWidget *activate_check;
- GtkWidget *entry, *cb;
- GtkWidget *button;
- GtkWidget *separator;
- GList *cbitems = NULL;
-
- if (!window)
- {
- cbitems = g_list_append(cbitems, "item0");
- cbitems = g_list_append(cbitems, "item1 item1");
- cbitems = g_list_append(cbitems, "item2 item2 item2");
- cbitems = g_list_append(cbitems, "item3 item3 item3 item3");
- cbitems = g_list_append(cbitems, "item4 item4 item4 item4 item4");
- cbitems = g_list_append(cbitems, "item5 item5 item5 item5 item5 item5");
- cbitems = g_list_append(cbitems, "item6 item6 item6 item6 item6");
- cbitems = g_list_append(cbitems, "item7 item7 item7 item7");
- cbitems = g_list_append(cbitems, "item8 item8 item8");
- cbitems = g_list_append(cbitems, "item9 item9");
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "entry");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
- gtk_widget_show (box1);
-
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
- gtk_widget_show (box2);
-
- entry = gtk_entry_new ();
- gtk_entry_set_text (GTK_ENTRY (entry), "hello world السلام عليكم");
- gtk_editable_select_region (GTK_EDITABLE (entry), 0, 5);
- gtk_box_pack_start (GTK_BOX (box2), entry, TRUE, TRUE, 0);
- gtk_widget_show (entry);
-
- cb = gtk_combo_new ();
- gtk_combo_set_popdown_strings (GTK_COMBO (cb), cbitems);
- gtk_entry_set_text (GTK_ENTRY (GTK_COMBO(cb)->entry), "hello world");
- gtk_editable_select_region (GTK_EDITABLE (GTK_COMBO(cb)->entry),
- 0, -1);
- gtk_box_pack_start (GTK_BOX (box2), cb, TRUE, TRUE, 0);
- gtk_widget_show (cb);
-
- editable_check = gtk_check_button_new_with_label("Editable");
- gtk_box_pack_start (GTK_BOX (box2), editable_check, FALSE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT(editable_check), "toggled",
- GTK_SIGNAL_FUNC(entry_toggle_editable), entry);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(editable_check), TRUE);
- gtk_widget_show (editable_check);
-
- editable_check = gtk_check_button_new_with_label("Visible");
- gtk_box_pack_start (GTK_BOX (box2), editable_check, FALSE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT(editable_check), "toggled",
- GTK_SIGNAL_FUNC(entry_toggle_visibility), entry);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(editable_check), TRUE);
- gtk_widget_show (editable_check);
-
- sensitive_check = gtk_check_button_new_with_label("Sensitive");
- gtk_box_pack_start (GTK_BOX (box2), sensitive_check, FALSE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT(sensitive_check), "toggled",
- GTK_SIGNAL_FUNC(entry_toggle_sensitive), entry);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(sensitive_check), TRUE);
- gtk_widget_show (sensitive_check);
-
- activate_check = gtk_check_button_new_with_label ("Activates default");
- gtk_box_pack_start (GTK_BOX (box2), activate_check, FALSE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (activate_check), "toggled",
- GTK_SIGNAL_FUNC (entry_toggle_activate_default), entry);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (activate_check), FALSE);
- gtk_widget_show (activate_check);
-
- invisible_char_check = gtk_check_button_new_with_label("invisible_char = 0");
- gtk_box_pack_start (GTK_BOX (box2), invisible_char_check, FALSE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT(invisible_char_check), "toggled",
- GTK_SIGNAL_FUNC(entry_toggle_invisible_char), entry);
- gtk_widget_show (invisible_char_check);
-
- editable_check = gtk_check_button_new_with_label("Has Frame");
- gtk_box_pack_start (GTK_BOX (box2), editable_check, FALSE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT(editable_check), "toggled",
- GTK_SIGNAL_FUNC(entry_toggle_frame), entry);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(editable_check), TRUE);
- gtk_widget_show (editable_check);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
- gtk_widget_show (separator);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
- gtk_widget_show (box2);
-
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkSpinButton
- */
-
-static GtkWidget *spinner1;
-
-static void
-toggle_snap (GtkWidget *widget, GtkSpinButton *spin)
-{
- gtk_spin_button_set_snap_to_ticks (spin, GTK_TOGGLE_BUTTON (widget)->active);
-}
-
-static void
-toggle_numeric (GtkWidget *widget, GtkSpinButton *spin)
-{
- gtk_spin_button_set_numeric (spin, GTK_TOGGLE_BUTTON (widget)->active);
-}
-
-static void
-change_digits (GtkWidget *widget, GtkSpinButton *spin)
-{
- gtk_spin_button_set_digits (GTK_SPIN_BUTTON (spinner1),
- gtk_spin_button_get_value_as_int (spin));
-}
-
-static void
-get_value (GtkWidget *widget, gpointer data)
-{
- gchar buf[32];
- GtkLabel *label;
- GtkSpinButton *spin;
-
- spin = GTK_SPIN_BUTTON (spinner1);
- label = GTK_LABEL (gtk_object_get_user_data (GTK_OBJECT (widget)));
- if (GPOINTER_TO_INT (data) == 1)
- sprintf (buf, "%d", gtk_spin_button_get_value_as_int (spin));
- else
- sprintf (buf, "%0.*f", spin->digits,
- gtk_spin_button_get_value_as_float (spin));
- gtk_label_set_text (label, buf);
-}
-
-static void
-get_spin_value (GtkWidget *widget, gpointer data)
-{
- gchar *buffer;
- GtkLabel *label;
- GtkSpinButton *spin;
-
- spin = GTK_SPIN_BUTTON (widget);
- label = GTK_LABEL (data);
-
- buffer = g_strdup_printf ("%0.*f", spin->digits,
- gtk_spin_button_get_value_as_float (spin));
- gtk_label_set_text (label, buffer);
-
- g_free (buffer);
-}
-
-static gint
-spin_button_time_output_func (GtkSpinButton *spin_button)
-{
- static gchar buf[6];
- gdouble hours;
- gdouble minutes;
-
- hours = spin_button->adjustment->value / 60.0;
- minutes = (fabs(floor (hours) - hours) < 1e-5) ? 0.0 : 30;
- sprintf (buf, "%02.0f:%02.0f", floor (hours), minutes);
- if (strcmp (buf, gtk_entry_get_text (GTK_ENTRY (spin_button))))
- gtk_entry_set_text (GTK_ENTRY (spin_button), buf);
- return TRUE;
-}
-
-static gint
-spin_button_month_input_func (GtkSpinButton *spin_button,
- gdouble *new_val)
-{
- gint i;
- static gchar *month[12] = { "January", "February", "March", "April",
- "May", "June", "July", "August",
- "September", "October", "November", "December" };
- gchar *tmp1, *tmp2;
- gboolean found = FALSE;
-
- for (i = 1; i <= 12; i++)
- {
- tmp1 = g_strdup (month[i-1]);
- g_strup (tmp1);
- tmp2 = g_strdup (gtk_entry_get_text (GTK_ENTRY (spin_button)));
- g_strup (tmp2);
- if (strstr (tmp1, tmp2) == tmp1)
- found = TRUE;
- g_free (tmp1);
- g_free (tmp2);
- if (found)
- break;
- }
- if (!found)
- {
- *new_val = 0.0;
- return GTK_INPUT_ERROR;
- }
- *new_val = (gdouble) i;
- return TRUE;
-}
-
-static gint
-spin_button_month_output_func (GtkSpinButton *spin_button)
-{
- gint i;
- static gchar *month[12] = { "January", "February", "March", "April",
- "May", "June", "July", "August", "September",
- "October", "November", "December" };
-
- for (i = 1; i <= 12; i++)
- if (fabs (spin_button->adjustment->value - (double)i) < 1e-5)
- {
- if (strcmp (month[i-1], gtk_entry_get_text (GTK_ENTRY (spin_button))))
- gtk_entry_set_text (GTK_ENTRY (spin_button), month[i-1]);
- }
- return TRUE;
-}
-
-static gint
-spin_button_hex_input_func (GtkSpinButton *spin_button,
- gdouble *new_val)
-{
- gchar *buf;
- gchar *err;
- gdouble res;
-
- buf = gtk_entry_get_text (GTK_ENTRY (spin_button));
- res = strtol(buf, &err, 16);
- *new_val = res;
- if (*err)
- return GTK_INPUT_ERROR;
- else
- return TRUE;
-}
-
-static gint
-spin_button_hex_output_func (GtkSpinButton *spin_button)
-{
- static gchar buf[7];
- gint val;
-
- val = (gint) spin_button->adjustment->value;
- if (fabs (val) < 1e-5)
- sprintf (buf, "0x00");
- else
- sprintf (buf, "0x%.2X", val);
- if (strcmp (buf, gtk_entry_get_text (GTK_ENTRY (spin_button))))
- gtk_entry_set_text (GTK_ENTRY (spin_button), buf);
- return TRUE;
-}
-
-static void
-create_spins (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *frame;
- GtkWidget *hbox;
- GtkWidget *main_vbox;
- GtkWidget *vbox;
- GtkWidget *vbox2;
- GtkWidget *spinner2;
- GtkWidget *spinner;
- GtkWidget *button;
- GtkWidget *label;
- GtkWidget *val_label;
- GtkAdjustment *adj;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "GtkSpinButton");
-
- main_vbox = gtk_vbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (main_vbox), 10);
- gtk_container_add (GTK_CONTAINER (window), main_vbox);
-
- frame = gtk_frame_new ("Not accelerated");
- gtk_box_pack_start (GTK_BOX (main_vbox), frame, TRUE, TRUE, 0);
-
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (vbox), 5);
- gtk_container_add (GTK_CONTAINER (frame), vbox);
-
- /* Time, month, hex spinners */
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, TRUE, TRUE, 5);
-
- vbox2 = gtk_vbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (hbox), vbox2, TRUE, TRUE, 5);
-
- label = gtk_label_new ("Time :");
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox2), label, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (0, 0, 1410, 30, 60, 0);
- spinner = gtk_spin_button_new (adj, 0, 0);
- gtk_editable_set_editable (GTK_EDITABLE (spinner), FALSE);
- gtk_signal_connect (GTK_OBJECT (spinner),
- "output",
- GTK_SIGNAL_FUNC (spin_button_time_output_func),
- NULL);
- gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spinner), TRUE);
- gtk_widget_set_usize (spinner, 55, -1);
- gtk_box_pack_start (GTK_BOX (vbox2), spinner, FALSE, TRUE, 0);
-
- vbox2 = gtk_vbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (hbox), vbox2, TRUE, TRUE, 5);
-
- label = gtk_label_new ("Month :");
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox2), label, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (1.0, 1.0, 12.0, 1.0,
- 5.0, 0.0);
- spinner = gtk_spin_button_new (adj, 0, 0);
- gtk_spin_button_set_update_policy (GTK_SPIN_BUTTON (spinner),
- GTK_UPDATE_IF_VALID);
- gtk_signal_connect (GTK_OBJECT (spinner),
- "input",
- GTK_SIGNAL_FUNC (spin_button_month_input_func),
- NULL);
- gtk_signal_connect (GTK_OBJECT (spinner),
- "output",
- GTK_SIGNAL_FUNC (spin_button_month_output_func),
- NULL);
- gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spinner), TRUE);
- gtk_widget_set_usize (spinner, 85, -1);
- gtk_box_pack_start (GTK_BOX (vbox2), spinner, FALSE, TRUE, 0);
-
- vbox2 = gtk_vbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (hbox), vbox2, TRUE, TRUE, 5);
-
- label = gtk_label_new ("Hex :");
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox2), label, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (0, 0, 255, 1, 16, 0);
- spinner = gtk_spin_button_new (adj, 0, 0);
- gtk_editable_set_editable (GTK_EDITABLE (spinner), TRUE);
- gtk_signal_connect (GTK_OBJECT (spinner),
- "input",
- GTK_SIGNAL_FUNC (spin_button_hex_input_func),
- NULL);
- gtk_signal_connect (GTK_OBJECT (spinner),
- "output",
- GTK_SIGNAL_FUNC (spin_button_hex_output_func),
- NULL);
- gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spinner), TRUE);
- gtk_widget_set_usize (spinner, 55, 0);
- gtk_box_pack_start (GTK_BOX (vbox2), spinner, FALSE, TRUE, 0);
-
- frame = gtk_frame_new ("Accelerated");
- gtk_box_pack_start (GTK_BOX (main_vbox), frame, TRUE, TRUE, 0);
-
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (vbox), 5);
- gtk_container_add (GTK_CONTAINER (frame), vbox);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 5);
-
- vbox2 = gtk_vbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (hbox), vbox2, FALSE, FALSE, 5);
-
- label = gtk_label_new ("Value :");
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox2), label, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (0.0, -10000.0, 10000.0,
- 0.5, 100.0, 0.0);
- spinner1 = gtk_spin_button_new (adj, 1.0, 2);
- gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spinner1), TRUE);
- gtk_box_pack_start (GTK_BOX (vbox2), spinner1, FALSE, TRUE, 0);
-
- vbox2 = gtk_vbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (hbox), vbox2, FALSE, FALSE, 5);
-
- label = gtk_label_new ("Digits :");
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox2), label, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (2, 1, 5, 1, 1, 0);
- spinner2 = gtk_spin_button_new (adj, 0.0, 0);
- gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
- GTK_SIGNAL_FUNC (change_digits),
- (gpointer) spinner2);
- gtk_box_pack_start (GTK_BOX (vbox2), spinner2, FALSE, TRUE, 0);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 5);
-
- button = gtk_check_button_new_with_label ("Snap to 0.5-ticks");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (toggle_snap),
- spinner1);
- gtk_box_pack_start (GTK_BOX (vbox), button, TRUE, TRUE, 0);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), TRUE);
-
- button = gtk_check_button_new_with_label ("Numeric only input mode");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (toggle_numeric),
- spinner1);
- gtk_box_pack_start (GTK_BOX (vbox), button, TRUE, TRUE, 0);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), TRUE);
-
- val_label = gtk_label_new ("");
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 5);
-
- button = gtk_button_new_with_label ("Value as Int");
- gtk_object_set_user_data (GTK_OBJECT (button), val_label);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (get_value),
- GINT_TO_POINTER (1));
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5);
-
- button = gtk_button_new_with_label ("Value as Float");
- gtk_object_set_user_data (GTK_OBJECT (button), val_label);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (get_value),
- GINT_TO_POINTER (2));
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5);
-
- gtk_box_pack_start (GTK_BOX (vbox), val_label, TRUE, TRUE, 0);
- gtk_label_set_text (GTK_LABEL (val_label), "0");
-
- frame = gtk_frame_new ("Using Convenience Constructor");
- gtk_box_pack_start (GTK_BOX (main_vbox), frame, TRUE, TRUE, 0);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_container_add (GTK_CONTAINER (frame), hbox);
-
- val_label = gtk_label_new ("0.0");
-
- spinner = gtk_spin_button_new_with_range (0.0, 10.0, 0.009);
- gtk_spin_button_set_value (GTK_SPIN_BUTTON (spinner), 0.0);
- gtk_signal_connect (GTK_OBJECT (spinner), "value_changed",
- GTK_SIGNAL_FUNC (get_spin_value), val_label);
- gtk_box_pack_start (GTK_BOX (hbox), spinner, TRUE, TRUE, 5);
- gtk_box_pack_start (GTK_BOX (hbox), val_label, TRUE, TRUE, 5);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (main_vbox), hbox, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("Close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-
-/*
- * Cursors
- */
-
-static gint
-cursor_expose_event (GtkWidget *widget,
- GdkEvent *event,
- gpointer user_data)
-{
- GtkDrawingArea *darea;
- GdkDrawable *drawable;
- GdkGC *black_gc;
- GdkGC *gray_gc;
- GdkGC *white_gc;
- guint max_width;
- guint max_height;
-
- g_return_val_if_fail (widget != NULL, TRUE);
- g_return_val_if_fail (GTK_IS_DRAWING_AREA (widget), TRUE);
-
- darea = GTK_DRAWING_AREA (widget);
- drawable = widget->window;
- white_gc = widget->style->white_gc;
- gray_gc = widget->style->bg_gc[GTK_STATE_NORMAL];
- black_gc = widget->style->black_gc;
- max_width = widget->allocation.width;
- max_height = widget->allocation.height;
-
- gdk_draw_rectangle (drawable, white_gc,
- TRUE,
- 0,
- 0,
- max_width,
- max_height / 2);
-
- gdk_draw_rectangle (drawable, black_gc,
- TRUE,
- 0,
- max_height / 2,
- max_width,
- max_height / 2);
-
- gdk_draw_rectangle (drawable, gray_gc,
- TRUE,
- max_width / 3,
- max_height / 3,
- max_width / 3,
- max_height / 3);
-
- return TRUE;
-}
-
-static void
-set_cursor (GtkWidget *spinner,
- GtkWidget *widget)
-{
- guint c;
- GdkCursor *cursor;
- GtkWidget *label;
- GtkEnumValue *vals;
-
- c = CLAMP (gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spinner)), 0, 152);
- c &= 0xfe;
-
- label = gtk_object_get_user_data (GTK_OBJECT (spinner));
- vals = gtk_type_enum_get_values (GDK_TYPE_CURSOR_TYPE);
- while (vals && vals->value != c)
- vals++;
- if (vals)
- gtk_label_set_text (GTK_LABEL (label), vals->value_nick);
- else
- gtk_label_set_text (GTK_LABEL (label), "<unknown>");
-
- cursor = gdk_cursor_new (c);
- gdk_window_set_cursor (widget->window, cursor);
- gdk_cursor_unref (cursor);
-}
-
-static gint
-cursor_event (GtkWidget *widget,
- GdkEvent *event,
- GtkSpinButton *spinner)
-{
- if ((event->type == GDK_BUTTON_PRESS) &&
- ((event->button.button == 1) ||
- (event->button.button == 3)))
- {
- gtk_spin_button_spin (spinner, event->button.button == 1 ?
- GTK_SPIN_STEP_FORWARD : GTK_SPIN_STEP_BACKWARD, 0);
- return TRUE;
- }
-
- return FALSE;
-}
-
-static void
-create_cursors (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *frame;
- GtkWidget *hbox;
- GtkWidget *main_vbox;
- GtkWidget *vbox;
- GtkWidget *darea;
- GtkWidget *spinner;
- GtkWidget *button;
- GtkWidget *label;
- GtkWidget *any;
- GtkAdjustment *adj;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Cursors");
-
- main_vbox = gtk_vbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (main_vbox), 0);
- gtk_container_add (GTK_CONTAINER (window), main_vbox);
-
- vbox =
- gtk_widget_new (gtk_vbox_get_type (),
- "GtkBox::homogeneous", FALSE,
- "GtkBox::spacing", 5,
- "GtkContainer::border_width", 10,
- "GtkWidget::parent", main_vbox,
- "GtkWidget::visible", TRUE,
- NULL);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
-
- label = gtk_label_new ("Cursor Value : ");
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (0,
- 0, 152,
- 2,
- 10, 0);
- spinner = gtk_spin_button_new (adj, 0, 0);
- gtk_box_pack_start (GTK_BOX (hbox), spinner, TRUE, TRUE, 0);
-
- frame =
- gtk_widget_new (gtk_frame_get_type (),
- "GtkFrame::shadow", GTK_SHADOW_ETCHED_IN,
- "GtkFrame::label_xalign", 0.5,
- "GtkFrame::label", "Cursor Area",
- "GtkContainer::border_width", 10,
- "GtkWidget::parent", vbox,
- "GtkWidget::visible", TRUE,
- NULL);
-
- darea = gtk_drawing_area_new ();
- gtk_widget_set_usize (darea, 80, 80);
- gtk_container_add (GTK_CONTAINER (frame), darea);
- gtk_signal_connect (GTK_OBJECT (darea),
- "expose_event",
- GTK_SIGNAL_FUNC (cursor_expose_event),
- NULL);
- gtk_widget_set_events (darea, GDK_EXPOSURE_MASK | GDK_BUTTON_PRESS_MASK);
- gtk_signal_connect (GTK_OBJECT (darea),
- "button_press_event",
- GTK_SIGNAL_FUNC (cursor_event),
- spinner);
- gtk_widget_show (darea);
-
- gtk_signal_connect (GTK_OBJECT (spinner), "changed",
- GTK_SIGNAL_FUNC (set_cursor),
- darea);
-
- label = gtk_widget_new (GTK_TYPE_LABEL,
- "visible", TRUE,
- "label", "XXX",
- "parent", vbox,
- NULL);
- gtk_container_child_set (GTK_CONTAINER (vbox), label,
- "expand", FALSE,
- NULL);
- gtk_object_set_user_data (GTK_OBJECT (spinner), label);
-
- any =
- gtk_widget_new (gtk_hseparator_get_type (),
- "GtkWidget::visible", TRUE,
- NULL);
- gtk_box_pack_start (GTK_BOX (main_vbox), any, FALSE, TRUE, 0);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 10);
- gtk_box_pack_start (GTK_BOX (main_vbox), hbox, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("Close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5);
-
- gtk_widget_show_all (window);
-
- set_cursor (spinner, darea);
- }
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkList
- */
-
-static void
-list_add (GtkWidget *widget,
- GtkWidget *list)
-{
- static int i = 1;
- gchar buffer[64];
- GtkWidget *list_item;
- GtkContainer *container;
-
- container = GTK_CONTAINER (list);
-
- sprintf (buffer, "added item %d", i++);
- list_item = gtk_list_item_new_with_label (buffer);
- gtk_widget_show (list_item);
-
- gtk_container_add (container, list_item);
-}
-
-static void
-list_remove (GtkWidget *widget,
- GtkList *list)
-{
- GList *clear_list = NULL;
- GList *sel_row = NULL;
- GList *work = NULL;
-
- if (list->selection_mode == GTK_SELECTION_EXTENDED)
- {
- GtkWidget *item;
-
- item = GTK_CONTAINER (list)->focus_child;
- if (!item && list->selection)
- item = list->selection->data;
-
- if (item)
- {
- work = g_list_find (list->children, item);
- for (sel_row = work; sel_row; sel_row = sel_row->next)
- if (GTK_WIDGET (sel_row->data)->state != GTK_STATE_SELECTED)
- break;
-
- if (!sel_row)
- {
- for (sel_row = work; sel_row; sel_row = sel_row->prev)
- if (GTK_WIDGET (sel_row->data)->state != GTK_STATE_SELECTED)
- break;
- }
- }
- }
-
- for (work = list->selection; work; work = work->next)
- clear_list = g_list_prepend (clear_list, work->data);
-
- clear_list = g_list_reverse (clear_list);
- gtk_list_remove_items (GTK_LIST (list), clear_list);
- g_list_free (clear_list);
-
- if (list->selection_mode == GTK_SELECTION_EXTENDED && sel_row)
- gtk_list_select_child (list, GTK_WIDGET(sel_row->data));
-}
-
-static void
-list_clear (GtkWidget *widget,
- GtkWidget *list)
-{
- gtk_list_clear_items (GTK_LIST (list), 0, -1);
-}
-
-#define RADIOMENUTOGGLED(_rmi_, __i) { \
- GSList * __g; \
- __i = 0; \
- __g = gtk_radio_menu_item_group(_rmi_); \
- while( __g && !((GtkCheckMenuItem *)(__g->data))->active) { \
- __g = __g->next; \
- __i++; \
- }\
-}
-
-static GtkWidget *list_omenu;
-
-static void
-list_toggle_sel_mode (GtkWidget *widget, GtkList *list)
-{
- gint i;
-
- if (!GTK_WIDGET_MAPPED (widget))
- return;
-
- RADIOMENUTOGGLED ((GtkRadioMenuItem *)
- (((GtkOptionMenu *)list_omenu)->menu_item), i);
-
- gtk_list_set_selection_mode (list, (GtkSelectionMode) (3-i));
-}
-
-static void
-create_list (void)
-{
- static GtkWidget *window = NULL;
-
- static OptionMenuItem items[] =
- {
- { "Single", GTK_SIGNAL_FUNC (list_toggle_sel_mode) },
- { "Browse", GTK_SIGNAL_FUNC (list_toggle_sel_mode) },
- { "Multiple", GTK_SIGNAL_FUNC (list_toggle_sel_mode) },
- { "Extended", GTK_SIGNAL_FUNC (list_toggle_sel_mode) }
- };
-
- if (!window)
- {
- GtkWidget *cbox;
- GtkWidget *vbox;
- GtkWidget *hbox;
- GtkWidget *label;
- GtkWidget *scrolled_win;
- GtkWidget *list;
- GtkWidget *button;
- GtkWidget *separator;
- FILE *infile;
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "list");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), vbox);
-
- scrolled_win = gtk_scrolled_window_new (NULL, NULL);
- gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 5);
- gtk_widget_set_usize (scrolled_win, -1, 300);
- gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win),
- GTK_POLICY_AUTOMATIC,
- GTK_POLICY_AUTOMATIC);
-
- list = gtk_list_new ();
- gtk_list_set_selection_mode (GTK_LIST (list), GTK_SELECTION_EXTENDED);
- gtk_scrolled_window_add_with_viewport
- (GTK_SCROLLED_WINDOW (scrolled_win), list);
- gtk_container_set_focus_vadjustment
- (GTK_CONTAINER (list),
- gtk_scrolled_window_get_vadjustment
- (GTK_SCROLLED_WINDOW (scrolled_win)));
- gtk_container_set_focus_hadjustment
- (GTK_CONTAINER (list),
- gtk_scrolled_window_get_hadjustment
- (GTK_SCROLLED_WINDOW (scrolled_win)));
-
- if ((infile = fopen("gtkenums.h", "r")))
- {
- char buffer[256];
- char *pos;
- GtkWidget *item;
-
- while (fgets (buffer, 256, infile))
- {
- if ((pos = strchr (buffer, '\n')))
- *pos = 0;
- item = gtk_list_item_new_with_label (buffer);
- gtk_container_add (GTK_CONTAINER (list), item);
- }
-
- fclose (infile);
- }
-
-
- hbox = gtk_hbox_new (TRUE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("Insert Row");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (list_add),
- list);
-
- button = gtk_button_new_with_label ("Clear List");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (list_clear),
- list);
-
- button = gtk_button_new_with_label ("Remove Selection");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (list_remove),
- list);
-
- cbox = gtk_hbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (vbox), cbox, FALSE, TRUE, 0);
-
- hbox = gtk_hbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_box_pack_start (GTK_BOX (cbox), hbox, TRUE, FALSE, 0);
-
- label = gtk_label_new ("Selection Mode :");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
-
- list_omenu = build_option_menu (items, 4, 3, list);
- gtk_box_pack_start (GTK_BOX (hbox), list_omenu, FALSE, TRUE, 0);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (vbox), separator, FALSE, TRUE, 0);
-
- cbox = gtk_hbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (vbox), cbox, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("close");
- gtk_container_set_border_width (GTK_CONTAINER (button), 10);
- gtk_box_pack_start (GTK_BOX (cbox), button, TRUE, TRUE, 0);
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
-
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkCList
- */
-
-static char * book_open_xpm[] = {
-"16 16 4 1",
-" c None s None",
-". c black",
-"X c #808080",
-"o c white",
-" ",
-" .. ",
-" .Xo. ... ",
-" .Xoo. ..oo. ",
-" .Xooo.Xooo... ",
-" .Xooo.oooo.X. ",
-" .Xooo.Xooo.X. ",
-" .Xooo.oooo.X. ",
-" .Xooo.Xooo.X. ",
-" .Xooo.oooo.X. ",
-" .Xoo.Xoo..X. ",
-" .Xo.o..ooX. ",
-" .X..XXXXX. ",
-" ..X....... ",
-" .. ",
-" "};
-
-static char * book_closed_xpm[] = {
-"16 16 6 1",
-" c None s None",
-". c black",
-"X c red",
-"o c yellow",
-"O c #808080",
-"# c white",
-" ",
-" .. ",
-" ..XX. ",
-" ..XXXXX. ",
-" ..XXXXXXXX. ",
-".ooXXXXXXXXX. ",
-"..ooXXXXXXXXX. ",
-".X.ooXXXXXXXXX. ",
-".XX.ooXXXXXX.. ",
-" .XX.ooXXX..#O ",
-" .XX.oo..##OO. ",
-" .XX..##OO.. ",
-" .X.#OO.. ",
-" ..O.. ",
-" .. ",
-" "};
-
-static char * mini_page_xpm[] = {
-"16 16 4 1",
-" c None s None",
-". c black",
-"X c white",
-"o c #808080",
-" ",
-" ....... ",
-" .XXXXX.. ",
-" .XoooX.X. ",
-" .XXXXX.... ",
-" .XooooXoo.o ",
-" .XXXXXXXX.o ",
-" .XooooooX.o ",
-" .XXXXXXXX.o ",
-" .XooooooX.o ",
-" .XXXXXXXX.o ",
-" .XooooooX.o ",
-" .XXXXXXXX.o ",
-" ..........o ",
-" oooooooooo ",
-" "};
-
-static char * gtk_mini_xpm[] = {
-"15 20 17 1",
-" c None",
-". c #14121F",
-"+ c #278828",
-"@ c #9B3334",
-"# c #284C72",
-"$ c #24692A",
-"% c #69282E",
-"& c #37C539",
-"* c #1D2F4D",
-"= c #6D7076",
-"- c #7D8482",
-"; c #E24A49",
-"> c #515357",
-", c #9B9C9B",
-"' c #2FA232",
-") c #3CE23D",
-"! c #3B6CCB",
-" ",
-" ***> ",
-" >.*!!!* ",
-" ***....#*= ",
-" *!*.!!!**!!# ",
-" .!!#*!#*!!!!# ",
-" @%#!.##.*!!$& ",
-" @;%*!*.#!#')) ",
-" @;;@%!!*$&)'' ",
-" @%.%@%$'&)$+' ",
-" @;...@$'*'*)+ ",
-" @;%..@$+*.')$ ",
-" @;%%;;$+..$)# ",
-" @;%%;@$$$'.$# ",
-" %;@@;;$$+))&* ",
-" %;;;@+$&)&* ",
-" %;;@'))+> ",
-" %;@'&# ",
-" >%$$ ",
-" >= "};
-
-#define TESTGTK_CLIST_COLUMNS 12
-static gint clist_rows = 0;
-static GtkWidget *clist_omenu;
-
-static void
-add1000_clist (GtkWidget *widget, gpointer data)
-{
- gint i, row;
- char text[TESTGTK_CLIST_COLUMNS][50];
- char *texts[TESTGTK_CLIST_COLUMNS];
- GdkBitmap *mask;
- GdkPixmap *pixmap;
- GtkCList *clist;
-
- clist = GTK_CLIST (data);
-
- pixmap = gdk_pixmap_create_from_xpm_d (clist->clist_window,
- &mask,
- &GTK_WIDGET (data)->style->white,
- gtk_mini_xpm);
-
- for (i = 0; i < TESTGTK_CLIST_COLUMNS; i++)
- {
- texts[i] = text[i];
- sprintf (text[i], "Column %d", i);
- }
-
- texts[3] = NULL;
- sprintf (text[1], "Right");
- sprintf (text[2], "Center");
-
- gtk_clist_freeze (GTK_CLIST (data));
- for (i = 0; i < 1000; i++)
- {
- sprintf (text[0], "CListRow %d", rand() % 10000);
- row = gtk_clist_append (clist, texts);
- gtk_clist_set_pixtext (clist, row, 3, "gtk+", 5, pixmap, mask);
- }
-
- gtk_clist_thaw (GTK_CLIST (data));
-
- gdk_pixmap_unref (pixmap);
- gdk_bitmap_unref (mask);
-}
-
-static void
-add10000_clist (GtkWidget *widget, gpointer data)
-{
- gint i;
- char text[TESTGTK_CLIST_COLUMNS][50];
- char *texts[TESTGTK_CLIST_COLUMNS];
-
- for (i = 0; i < TESTGTK_CLIST_COLUMNS; i++)
- {
- texts[i] = text[i];
- sprintf (text[i], "Column %d", i);
- }
-
- sprintf (text[1], "Right");
- sprintf (text[2], "Center");
-
- gtk_clist_freeze (GTK_CLIST (data));
- for (i = 0; i < 10000; i++)
- {
- sprintf (text[0], "CListRow %d", rand() % 10000);
- gtk_clist_append (GTK_CLIST (data), texts);
- }
- gtk_clist_thaw (GTK_CLIST (data));
-}
-
-void
-clear_clist (GtkWidget *widget, gpointer data)
-{
- gtk_clist_clear (GTK_CLIST (data));
- clist_rows = 0;
-}
-
-void clist_remove_selection (GtkWidget *widget, GtkCList *clist)
-{
- gtk_clist_freeze (clist);
-
- while (clist->selection)
- {
- gint row;
-
- clist_rows--;
- row = GPOINTER_TO_INT (clist->selection->data);
-
- gtk_clist_remove (clist, row);
-
- if (clist->selection_mode == GTK_SELECTION_BROWSE)
- break;
- }
-
- if (clist->selection_mode == GTK_SELECTION_EXTENDED && !clist->selection &&
- clist->focus_row >= 0)
- gtk_clist_select_row (clist, clist->focus_row, -1);
-
- gtk_clist_thaw (clist);
-}
-
-void toggle_title_buttons (GtkWidget *widget, GtkCList *clist)
-{
- if (GTK_TOGGLE_BUTTON (widget)->active)
- gtk_clist_column_titles_show (clist);
- else
- gtk_clist_column_titles_hide (clist);
-}
-
-void toggle_reorderable (GtkWidget *widget, GtkCList *clist)
-{
- gtk_clist_set_reorderable (clist, GTK_TOGGLE_BUTTON (widget)->active);
-}
-
-static void
-insert_row_clist (GtkWidget *widget, gpointer data)
-{
- static char *text[] =
- {
- "This", "is an", "inserted", "row.",
- "This", "is an", "inserted", "row.",
- "This", "is an", "inserted", "row."
- };
-
- static GtkStyle *style1 = NULL;
- static GtkStyle *style2 = NULL;
- static GtkStyle *style3 = NULL;
- gint row;
-
- if (GTK_CLIST (data)->focus_row >= 0)
- row = gtk_clist_insert (GTK_CLIST (data), GTK_CLIST (data)->focus_row,
- text);
- else
- row = gtk_clist_prepend (GTK_CLIST (data), text);
-
- if (!style1)
- {
- GdkColor col1;
- GdkColor col2;
-
- col1.red = 0;
- col1.green = 56000;
- col1.blue = 0;
- col2.red = 32000;
- col2.green = 0;
- col2.blue = 56000;
-
- style1 = gtk_style_copy (GTK_WIDGET (data)->style);
- style1->base[GTK_STATE_NORMAL] = col1;
- style1->base[GTK_STATE_SELECTED] = col2;
-
- style2 = gtk_style_copy (GTK_WIDGET (data)->style);
- style2->fg[GTK_STATE_NORMAL] = col1;
- style2->fg[GTK_STATE_SELECTED] = col2;
-
- style3 = gtk_style_copy (GTK_WIDGET (data)->style);
- style3->fg[GTK_STATE_NORMAL] = col1;
- style3->base[GTK_STATE_NORMAL] = col2;
- pango_font_description_free (style3->font_desc);
- style3->font_desc = pango_font_description_from_string ("courier 12");
- }
-
- gtk_clist_set_cell_style (GTK_CLIST (data), row, 3, style1);
- gtk_clist_set_cell_style (GTK_CLIST (data), row, 4, style2);
- gtk_clist_set_cell_style (GTK_CLIST (data), row, 0, style3);
-
- clist_rows++;
-}
-
-static void
-clist_warning_test (GtkWidget *button,
- GtkWidget *clist)
-{
- GtkWidget *child;
- static gboolean add_remove = FALSE;
-
- add_remove = !add_remove;
-
- child = gtk_label_new ("Test");
- gtk_widget_ref (child);
- gtk_object_sink (GTK_OBJECT (child));
-
- if (add_remove)
- gtk_container_add (GTK_CONTAINER (clist), child);
- else
- {
- child->parent = clist;
- gtk_container_remove (GTK_CONTAINER (clist), child);
- child->parent = NULL;
- }
-
- gtk_widget_destroy (child);
- gtk_widget_unref (child);
-}
-
-static void
-undo_selection (GtkWidget *button, GtkCList *clist)
-{
- gtk_clist_undo_selection (clist);
-}
-
-static void
-clist_toggle_sel_mode (GtkWidget *widget, GtkCList *clist)
-{
- gint i;
-
- if (!GTK_WIDGET_MAPPED (widget))
- return;
-
- RADIOMENUTOGGLED ((GtkRadioMenuItem *)
- (((GtkOptionMenu *)clist_omenu)->menu_item), i);
-
- gtk_clist_set_selection_mode (clist, (GtkSelectionMode) (3-i));
-}
-
-static void
-clist_click_column (GtkCList *clist, gint column, gpointer data)
-{
- if (column == 4)
- gtk_clist_set_column_visibility (clist, column, FALSE);
- else if (column == clist->sort_column)
- {
- if (clist->sort_type == GTK_SORT_ASCENDING)
- clist->sort_type = GTK_SORT_DESCENDING;
- else
- clist->sort_type = GTK_SORT_ASCENDING;
- }
- else
- gtk_clist_set_sort_column (clist, column);
-
- gtk_clist_sort (clist);
-}
-
-static void
-create_clist (void)
-{
- gint i;
- static GtkWidget *window = NULL;
-
- static char *titles[] =
- {
- "auto resize", "not resizeable", "max width 100", "min width 50",
- "hide column", "Title 5", "Title 6", "Title 7",
- "Title 8", "Title 9", "Title 10", "Title 11"
- };
-
- static OptionMenuItem items[] =
- {
- { "Single", GTK_SIGNAL_FUNC (clist_toggle_sel_mode) },
- { "Browse", GTK_SIGNAL_FUNC (clist_toggle_sel_mode) },
- { "Multiple", GTK_SIGNAL_FUNC (clist_toggle_sel_mode) },
- { "Extended", GTK_SIGNAL_FUNC (clist_toggle_sel_mode) }
- };
-
- char text[TESTGTK_CLIST_COLUMNS][50];
- char *texts[TESTGTK_CLIST_COLUMNS];
-
- GtkWidget *vbox;
- GtkWidget *hbox;
- GtkWidget *clist;
- GtkWidget *button;
- GtkWidget *separator;
- GtkWidget *scrolled_win;
- GtkWidget *check;
-
- GtkWidget *undo_button;
- GtkWidget *label;
-
- GtkStyle *style;
- GdkColor col1;
- GdkColor col2;
-
- if (!window)
- {
- clist_rows = 0;
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed), &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "clist");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), vbox);
-
- scrolled_win = gtk_scrolled_window_new (NULL, NULL);
- gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 5);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win),
- GTK_POLICY_AUTOMATIC,
- GTK_POLICY_AUTOMATIC);
-
- /* create GtkCList here so we have a pointer to throw at the
- * button callbacks -- more is done with it later */
- clist = gtk_clist_new_with_titles (TESTGTK_CLIST_COLUMNS, titles);
- gtk_container_add (GTK_CONTAINER (scrolled_win), clist);
- gtk_signal_connect (GTK_OBJECT (clist), "click_column",
- (GtkSignalFunc) clist_click_column, NULL);
-
- /* control buttons */
- hbox = gtk_hbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Insert Row");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) insert_row_clist, (gpointer) clist);
-
- button = gtk_button_new_with_label ("Add 1,000 Rows With Pixmaps");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) add1000_clist, (gpointer) clist);
-
- button = gtk_button_new_with_label ("Add 10,000 Rows");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) add10000_clist, (gpointer) clist);
-
- /* second layer of buttons */
- hbox = gtk_hbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Clear List");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) clear_clist, (gpointer) clist);
-
- button = gtk_button_new_with_label ("Remove Selection");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) clist_remove_selection,
- (gpointer) clist);
-
- undo_button = gtk_button_new_with_label ("Undo Selection");
- gtk_box_pack_start (GTK_BOX (hbox), undo_button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (undo_button), "clicked",
- (GtkSignalFunc) undo_selection, (gpointer) clist);
-
- button = gtk_button_new_with_label ("Warning Test");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) clist_warning_test,(gpointer) clist);
-
- /* third layer of buttons */
- hbox = gtk_hbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
-
- check = gtk_check_button_new_with_label ("Show Title Buttons");
- gtk_box_pack_start (GTK_BOX (hbox), check, FALSE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (check), "clicked",
- GTK_SIGNAL_FUNC (toggle_title_buttons), clist);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check), TRUE);
-
- check = gtk_check_button_new_with_label ("Reorderable");
- gtk_box_pack_start (GTK_BOX (hbox), check, FALSE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (check), "clicked",
- GTK_SIGNAL_FUNC (toggle_reorderable), clist);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check), TRUE);
-
- label = gtk_label_new ("Selection Mode :");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
-
- clist_omenu = build_option_menu (items, 4, 3, clist);
- gtk_box_pack_start (GTK_BOX (hbox), clist_omenu, FALSE, TRUE, 0);
-
- /*
- * the rest of the clist configuration
- */
-
- gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0);
- gtk_clist_set_row_height (GTK_CLIST (clist), 18);
- gtk_widget_set_usize (clist, -1, 300);
-
- for (i = 1; i < TESTGTK_CLIST_COLUMNS; i++)
- gtk_clist_set_column_width (GTK_CLIST (clist), i, 80);
-
- gtk_clist_set_column_auto_resize (GTK_CLIST (clist), 0, TRUE);
- gtk_clist_set_column_resizeable (GTK_CLIST (clist), 1, FALSE);
- gtk_clist_set_column_max_width (GTK_CLIST (clist), 2, 100);
- gtk_clist_set_column_min_width (GTK_CLIST (clist), 3, 50);
- gtk_clist_set_selection_mode (GTK_CLIST (clist), GTK_SELECTION_EXTENDED);
- gtk_clist_set_column_justification (GTK_CLIST (clist), 1,
- GTK_JUSTIFY_RIGHT);
- gtk_clist_set_column_justification (GTK_CLIST (clist), 2,
- GTK_JUSTIFY_CENTER);
-
- for (i = 0; i < TESTGTK_CLIST_COLUMNS; i++)
- {
- texts[i] = text[i];
- sprintf (text[i], "Column %d", i);
- }
-
- sprintf (text[1], "Right");
- sprintf (text[2], "Center");
-
- col1.red = 56000;
- col1.green = 0;
- col1.blue = 0;
- col2.red = 0;
- col2.green = 56000;
- col2.blue = 32000;
-
- style = gtk_style_new ();
- style->fg[GTK_STATE_NORMAL] = col1;
- style->base[GTK_STATE_NORMAL] = col2;
-
- style->font_desc->size = 14 * PANGO_SCALE;
- style->font_desc->weight = PANGO_WEIGHT_BOLD;
-
- for (i = 0; i < 10; i++)
- {
- sprintf (text[0], "CListRow %d", clist_rows++);
- gtk_clist_append (GTK_CLIST (clist), texts);
-
- switch (i % 4)
- {
- case 2:
- gtk_clist_set_row_style (GTK_CLIST (clist), i, style);
- break;
- default:
- gtk_clist_set_cell_style (GTK_CLIST (clist), i, i % 4, style);
- break;
- }
- }
-
- gtk_style_unref (style);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (vbox), separator, FALSE, TRUE, 0);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("close");
- gtk_container_set_border_width (GTK_CONTAINER (button), 10);
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
-
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- {
- clist_rows = 0;
- gtk_widget_destroy (window);
- }
-}
-
-/*
- * GtkCTree
- */
-
-GdkPixmap *pixmap1;
-GdkPixmap *pixmap2;
-GdkPixmap *pixmap3;
-GdkBitmap *mask1;
-GdkBitmap *mask2;
-GdkBitmap *mask3;
-
-static gint books = 0;
-static gint pages = 0;
-
-static GtkWidget *book_label;
-static GtkWidget *page_label;
-static GtkWidget *sel_label;
-static GtkWidget *vis_label;
-static GtkWidget *omenu1;
-static GtkWidget *omenu2;
-static GtkWidget *omenu3;
-static GtkWidget *omenu4;
-static GtkWidget *spin1;
-static GtkWidget *spin2;
-static GtkWidget *spin3;
-static gint line_style;
-
-void after_press (GtkCTree *ctree, gpointer data)
-{
- char buf[80];
-
- sprintf (buf, "%d", g_list_length (GTK_CLIST (ctree)->selection));
- gtk_label_set_text (GTK_LABEL (sel_label), buf);
-
- sprintf (buf, "%d", g_list_length (GTK_CLIST (ctree)->row_list));
- gtk_label_set_text (GTK_LABEL (vis_label), buf);
-
- sprintf (buf, "%d", books);
- gtk_label_set_text (GTK_LABEL (book_label), buf);
-
- sprintf (buf, "%d", pages);
- gtk_label_set_text (GTK_LABEL (page_label), buf);
-}
-
-void after_move (GtkCTree *ctree, GtkCTreeNode *child, GtkCTreeNode *parent,
- GtkCTreeNode *sibling, gpointer data)
-{
- char *source;
- char *target1;
- char *target2;
-
- gtk_ctree_get_node_info (ctree, child, &source,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- if (parent)
- gtk_ctree_get_node_info (ctree, parent, &target1,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL);
- if (sibling)
- gtk_ctree_get_node_info (ctree, sibling, &target2,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL);
-
- g_print ("Moving \"%s\" to \"%s\" with sibling \"%s\".\n", source,
- (parent) ? target1 : "nil", (sibling) ? target2 : "nil");
-}
-
-void count_items (GtkCTree *ctree, GtkCTreeNode *list)
-{
- if (GTK_CTREE_ROW (list)->is_leaf)
- pages--;
- else
- books--;
-}
-
-void expand_all (GtkWidget *widget, GtkCTree *ctree)
-{
- gtk_ctree_expand_recursive (ctree, NULL);
- after_press (ctree, NULL);
-}
-
-void collapse_all (GtkWidget *widget, GtkCTree *ctree)
-{
- gtk_ctree_collapse_recursive (ctree, NULL);
- after_press (ctree, NULL);
-}
-
-void select_all (GtkWidget *widget, GtkCTree *ctree)
-{
- gtk_ctree_select_recursive (ctree, NULL);
- after_press (ctree, NULL);
-}
-
-void change_style (GtkWidget *widget, GtkCTree *ctree)
-{
- static GtkStyle *style1 = NULL;
- static GtkStyle *style2 = NULL;
-
- GtkCTreeNode *node;
- GdkColor col1;
- GdkColor col2;
-
- if (GTK_CLIST (ctree)->focus_row >= 0)
- node = GTK_CTREE_NODE
- (g_list_nth (GTK_CLIST (ctree)->row_list,GTK_CLIST (ctree)->focus_row));
- else
- node = GTK_CTREE_NODE (GTK_CLIST (ctree)->row_list);
-
- if (!node)
- return;
-
- if (!style1)
- {
- col1.red = 0;
- col1.green = 56000;
- col1.blue = 0;
- col2.red = 32000;
- col2.green = 0;
- col2.blue = 56000;
-
- style1 = gtk_style_new ();
- style1->base[GTK_STATE_NORMAL] = col1;
- style1->fg[GTK_STATE_SELECTED] = col2;
-
- style2 = gtk_style_new ();
- style2->base[GTK_STATE_SELECTED] = col2;
- style2->fg[GTK_STATE_NORMAL] = col1;
- style2->base[GTK_STATE_NORMAL] = col2;
- pango_font_description_free (style2->font_desc);
- style2->font_desc = pango_font_description_from_string ("courier 30");
- }
-
- gtk_ctree_node_set_cell_style (ctree, node, 1, style1);
- gtk_ctree_node_set_cell_style (ctree, node, 0, style2);
-
- if (GTK_CTREE_ROW (node)->children)
- gtk_ctree_node_set_row_style (ctree, GTK_CTREE_ROW (node)->children,
- style2);
-}
-
-void unselect_all (GtkWidget *widget, GtkCTree *ctree)
-{
- gtk_ctree_unselect_recursive (ctree, NULL);
- after_press (ctree, NULL);
-}
-
-void remove_selection (GtkWidget *widget, GtkCTree *ctree)
-{
- GtkCList *clist;
- GtkCTreeNode *node;
-
- clist = GTK_CLIST (ctree);
-
- gtk_clist_freeze (clist);
-
- while (clist->selection)
- {
- node = clist->selection->data;
-
- if (GTK_CTREE_ROW (node)->is_leaf)
- pages--;
- else
- gtk_ctree_post_recursive (ctree, node,
- (GtkCTreeFunc) count_items, NULL);
-
- gtk_ctree_remove_node (ctree, node);
-
- if (clist->selection_mode == GTK_SELECTION_BROWSE)
- break;
- }
-
- if (clist->selection_mode == GTK_SELECTION_EXTENDED && !clist->selection &&
- clist->focus_row >= 0)
- {
- node = gtk_ctree_node_nth (ctree, clist->focus_row);
-
- if (node)
- gtk_ctree_select (ctree, node);
- }
-
- gtk_clist_thaw (clist);
- after_press (ctree, NULL);
-}
-
-struct _ExportStruct {
- gchar *tree;
- gchar *info;
- gboolean is_leaf;
-};
-
-typedef struct _ExportStruct ExportStruct;
-
-gboolean
-gnode2ctree (GtkCTree *ctree,
- guint depth,
- GNode *gnode,
- GtkCTreeNode *cnode,
- gpointer data)
-{
- ExportStruct *es;
- GdkPixmap *pixmap_closed;
- GdkBitmap *mask_closed;
- GdkPixmap *pixmap_opened;
- GdkBitmap *mask_opened;
-
- if (!cnode || !gnode || (!(es = gnode->data)))
- return FALSE;
-
- if (es->is_leaf)
- {
- pixmap_closed = pixmap3;
- mask_closed = mask3;
- pixmap_opened = NULL;
- mask_opened = NULL;
- }
- else
- {
- pixmap_closed = pixmap1;
- mask_closed = mask1;
- pixmap_opened = pixmap2;
- mask_opened = mask2;
- }
-
- gtk_ctree_set_node_info (ctree, cnode, es->tree, 2, pixmap_closed,
- mask_closed, pixmap_opened, mask_opened,
- es->is_leaf, (depth < 3));
- gtk_ctree_node_set_text (ctree, cnode, 1, es->info);
- g_free (es);
- gnode->data = NULL;
-
- return TRUE;
-}
-
-gboolean
-ctree2gnode (GtkCTree *ctree,
- guint depth,
- GNode *gnode,
- GtkCTreeNode *cnode,
- gpointer data)
-{
- ExportStruct *es;
-
- if (!cnode || !gnode)
- return FALSE;
-
- es = g_new (ExportStruct, 1);
- gnode->data = es;
- es->is_leaf = GTK_CTREE_ROW (cnode)->is_leaf;
- es->tree = GTK_CELL_PIXTEXT (GTK_CTREE_ROW (cnode)->row.cell[0])->text;
- es->info = GTK_CELL_PIXTEXT (GTK_CTREE_ROW (cnode)->row.cell[1])->text;
- return TRUE;
-}
-
-void export_ctree (GtkWidget *widget, GtkCTree *ctree)
-{
- char *title[] = { "Tree" , "Info" };
- static GtkWidget *export_window = NULL;
- static GtkCTree *export_ctree;
- GtkWidget *vbox;
- GtkWidget *scrolled_win;
- GtkWidget *button;
- GtkWidget *sep;
- GNode *gnode;
- GtkCTreeNode *node;
-
- if (!export_window)
- {
- export_window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (export_window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &export_window);
-
- gtk_window_set_title (GTK_WINDOW (export_window), "exported ctree");
- gtk_container_set_border_width (GTK_CONTAINER (export_window), 5);
-
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (export_window), vbox);
-
- button = gtk_button_new_with_label ("Close");
- gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, TRUE, 0);
-
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) gtk_widget_destroy,
- GTK_OBJECT(export_window));
-
- sep = gtk_hseparator_new ();
- gtk_box_pack_end (GTK_BOX (vbox), sep, FALSE, TRUE, 10);
-
- export_ctree = GTK_CTREE (gtk_ctree_new_with_titles (2, 0, title));
- gtk_ctree_set_line_style (export_ctree, GTK_CTREE_LINES_DOTTED);
-
- scrolled_win = gtk_scrolled_window_new (NULL, NULL);
- gtk_container_add (GTK_CONTAINER (scrolled_win),
- GTK_WIDGET (export_ctree));
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win),
- GTK_POLICY_AUTOMATIC,
- GTK_POLICY_AUTOMATIC);
- gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0);
- gtk_clist_set_selection_mode (GTK_CLIST (export_ctree),
- GTK_SELECTION_EXTENDED);
- gtk_clist_set_column_width (GTK_CLIST (export_ctree), 0, 200);
- gtk_clist_set_column_width (GTK_CLIST (export_ctree), 1, 200);
- gtk_widget_set_usize (GTK_WIDGET (export_ctree), 300, 200);
- }
-
- if (!GTK_WIDGET_VISIBLE (export_window))
- gtk_widget_show_all (export_window);
-
- gtk_clist_clear (GTK_CLIST (export_ctree));
-
- node = GTK_CTREE_NODE (g_list_nth (GTK_CLIST (ctree)->row_list,
- GTK_CLIST (ctree)->focus_row));
- if (!node)
- return;
-
- gnode = gtk_ctree_export_to_gnode (ctree, NULL, NULL, node,
- ctree2gnode, NULL);
- if (gnode)
- {
- gtk_ctree_insert_gnode (export_ctree, NULL, NULL, gnode,
- gnode2ctree, NULL);
- g_node_destroy (gnode);
- }
-}
-
-void change_indent (GtkWidget *widget, GtkCTree *ctree)
-{
- gtk_ctree_set_indent (ctree, GTK_ADJUSTMENT (widget)->value);
-}
-
-void change_spacing (GtkWidget *widget, GtkCTree *ctree)
-{
- gtk_ctree_set_spacing (ctree, GTK_ADJUSTMENT (widget)->value);
-}
-
-void change_row_height (GtkWidget *widget, GtkCList *clist)
-{
- gtk_clist_set_row_height (clist, GTK_ADJUSTMENT (widget)->value);
-}
-
-void set_background (GtkCTree *ctree, GtkCTreeNode *node, gpointer data)
-{
- GtkStyle *style = NULL;
-
- if (!node)
- return;
-
- if (ctree->line_style != GTK_CTREE_LINES_TABBED)
- {
- if (!GTK_CTREE_ROW (node)->is_leaf)
- style = GTK_CTREE_ROW (node)->row.data;
- else if (GTK_CTREE_ROW (node)->parent)
- style = GTK_CTREE_ROW (GTK_CTREE_ROW (node)->parent)->row.data;
- }
-
- gtk_ctree_node_set_row_style (ctree, node, style);
-}
-
-void ctree_toggle_line_style (GtkWidget *widget, GtkCTree *ctree)
-{
- gint i;
-
- if (!GTK_WIDGET_MAPPED (widget))
- return;
-
- RADIOMENUTOGGLED ((GtkRadioMenuItem *)
- (((GtkOptionMenu *)omenu1)->menu_item), i);
-
- if ((ctree->line_style == GTK_CTREE_LINES_TABBED &&
- ((GtkCTreeLineStyle) (3 - i)) != GTK_CTREE_LINES_TABBED) ||
- (ctree->line_style != GTK_CTREE_LINES_TABBED &&
- ((GtkCTreeLineStyle) (3 - i)) == GTK_CTREE_LINES_TABBED))
- gtk_ctree_pre_recursive (ctree, NULL, set_background, NULL);
- gtk_ctree_set_line_style (ctree, 3 - i);
- line_style = 3 - i;
-}
-
-void ctree_toggle_expander_style (GtkWidget *widget, GtkCTree *ctree)
-{
- gint i;
-
- if (!GTK_WIDGET_MAPPED (widget))
- return;
-
- RADIOMENUTOGGLED ((GtkRadioMenuItem *)
- (((GtkOptionMenu *)omenu2)->menu_item), i);
-
- gtk_ctree_set_expander_style (ctree, (GtkCTreeExpanderStyle) (3 - i));
-}
-
-void ctree_toggle_justify (GtkWidget *widget, GtkCTree *ctree)
-{
- gint i;
-
- if (!GTK_WIDGET_MAPPED (widget))
- return;
-
- RADIOMENUTOGGLED ((GtkRadioMenuItem *)
- (((GtkOptionMenu *)omenu3)->menu_item), i);
-
- gtk_clist_set_column_justification (GTK_CLIST (ctree), ctree->tree_column,
- (GtkJustification) (1 - i));
-}
-
-void ctree_toggle_sel_mode (GtkWidget *widget, GtkCTree *ctree)
-{
- gint i;
-
- if (!GTK_WIDGET_MAPPED (widget))
- return;
-
- RADIOMENUTOGGLED ((GtkRadioMenuItem *)
- (((GtkOptionMenu *)omenu4)->menu_item), i);
-
- gtk_clist_set_selection_mode (GTK_CLIST (ctree), (GtkSelectionMode) (3 - i));
- after_press (ctree, NULL);
-}
-
-void build_recursive (GtkCTree *ctree, gint cur_depth, gint depth,
- gint num_books, gint num_pages, GtkCTreeNode *parent)
-{
- gchar *text[2];
- gchar buf1[60];
- gchar buf2[60];
- GtkCTreeNode *sibling;
- gint i;
-
- text[0] = buf1;
- text[1] = buf2;
- sibling = NULL;
-
- for (i = num_pages + num_books; i > num_books; i--)
- {
- pages++;
- sprintf (buf1, "Page %02d", (gint) rand() % 100);
- sprintf (buf2, "Item %d-%d", cur_depth, i);
- sibling = gtk_ctree_insert_node (ctree, parent, sibling, text, 5,
- pixmap3, mask3, NULL, NULL,
- TRUE, FALSE);
-
- if (parent && ctree->line_style == GTK_CTREE_LINES_TABBED)
- gtk_ctree_node_set_row_style (ctree, sibling,
- GTK_CTREE_ROW (parent)->row.style);
- }
-
- if (cur_depth == depth)
- return;
-
- for (i = num_books; i > 0; i--)
- {
- GtkStyle *style;
-
- books++;
- sprintf (buf1, "Book %02d", (gint) rand() % 100);
- sprintf (buf2, "Item %d-%d", cur_depth, i);
- sibling = gtk_ctree_insert_node (ctree, parent, sibling, text, 5,
- pixmap1, mask1, pixmap2, mask2,
- FALSE, FALSE);
-
- style = gtk_style_new ();
- switch (cur_depth % 3)
- {
- case 0:
- style->base[GTK_STATE_NORMAL].red = 10000 * (cur_depth % 6);
- style->base[GTK_STATE_NORMAL].green = 0;
- style->base[GTK_STATE_NORMAL].blue = 65535 - ((i * 10000) % 65535);
- break;
- case 1:
- style->base[GTK_STATE_NORMAL].red = 10000 * (cur_depth % 6);
- style->base[GTK_STATE_NORMAL].green = 65535 - ((i * 10000) % 65535);
- style->base[GTK_STATE_NORMAL].blue = 0;
- break;
- default:
- style->base[GTK_STATE_NORMAL].red = 65535 - ((i * 10000) % 65535);
- style->base[GTK_STATE_NORMAL].green = 0;
- style->base[GTK_STATE_NORMAL].blue = 10000 * (cur_depth % 6);
- break;
- }
- gtk_ctree_node_set_row_data_full (ctree, sibling, style,
- (GtkDestroyNotify) gtk_style_unref);
-
- if (ctree->line_style == GTK_CTREE_LINES_TABBED)
- gtk_ctree_node_set_row_style (ctree, sibling, style);
-
- build_recursive (ctree, cur_depth + 1, depth, num_books, num_pages,
- sibling);
- }
-}
-
-void rebuild_tree (GtkWidget *widget, GtkCTree *ctree)
-{
- gchar *text [2];
- gchar label1[] = "Root";
- gchar label2[] = "";
- GtkCTreeNode *parent;
- GtkStyle *style;
- guint b, d, p, n;
-
- text[0] = label1;
- text[1] = label2;
-
- d = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spin1));
- b = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spin2));
- p = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spin3));
-
- n = ((pow (b, d) - 1) / (b - 1)) * (p + 1);
-
- if (n > 100000)
- {
- g_print ("%d total items? Try less\n",n);
- return;
- }
-
- gtk_clist_freeze (GTK_CLIST (ctree));
- gtk_clist_clear (GTK_CLIST (ctree));
-
- books = 1;
- pages = 0;
-
- parent = gtk_ctree_insert_node (ctree, NULL, NULL, text, 5, pixmap1,
- mask1, pixmap2, mask2, FALSE, TRUE);
-
- style = gtk_style_new ();
- style->base[GTK_STATE_NORMAL].red = 0;
- style->base[GTK_STATE_NORMAL].green = 45000;
- style->base[GTK_STATE_NORMAL].blue = 55000;
- gtk_ctree_node_set_row_data_full (ctree, parent, style,
- (GtkDestroyNotify) gtk_style_unref);
-
- if (ctree->line_style == GTK_CTREE_LINES_TABBED)
- gtk_ctree_node_set_row_style (ctree, parent, style);
-
- build_recursive (ctree, 1, d, b, p, parent);
- gtk_clist_thaw (GTK_CLIST (ctree));
- after_press (ctree, NULL);
-}
-
-static void
-ctree_click_column (GtkCTree *ctree, gint column, gpointer data)
-{
- GtkCList *clist;
-
- clist = GTK_CLIST (ctree);
-
- if (column == clist->sort_column)
- {
- if (clist->sort_type == GTK_SORT_ASCENDING)
- clist->sort_type = GTK_SORT_DESCENDING;
- else
- clist->sort_type = GTK_SORT_ASCENDING;
- }
- else
- gtk_clist_set_sort_column (clist, column);
-
- gtk_ctree_sort_recursive (ctree, NULL);
-}
-
-void create_ctree (void)
-{
- static GtkWidget *window = NULL;
- GtkTooltips *tooltips;
- GtkCTree *ctree;
- GtkWidget *scrolled_win;
- GtkWidget *vbox;
- GtkWidget *bbox;
- GtkWidget *mbox;
- GtkWidget *hbox;
- GtkWidget *hbox2;
- GtkWidget *frame;
- GtkWidget *label;
- GtkWidget *button;
- GtkWidget *check;
- GtkAdjustment *adj;
- GtkWidget *spinner;
- GdkColor transparent = { 0 };
-
- char *title[] = { "Tree" , "Info" };
- char buf[80];
-
- static OptionMenuItem items1[] =
- {
- { "No lines", GTK_SIGNAL_FUNC (ctree_toggle_line_style) },
- { "Solid", GTK_SIGNAL_FUNC (ctree_toggle_line_style) },
- { "Dotted", GTK_SIGNAL_FUNC (ctree_toggle_line_style) },
- { "Tabbed", GTK_SIGNAL_FUNC (ctree_toggle_line_style) }
- };
-
- static OptionMenuItem items2[] =
- {
- { "None", GTK_SIGNAL_FUNC (ctree_toggle_expander_style) },
- { "Square", GTK_SIGNAL_FUNC (ctree_toggle_expander_style) },
- { "Triangle", GTK_SIGNAL_FUNC (ctree_toggle_expander_style) },
- { "Circular", GTK_SIGNAL_FUNC (ctree_toggle_expander_style) }
- };
-
- static OptionMenuItem items3[] =
- {
- { "Left", GTK_SIGNAL_FUNC (ctree_toggle_justify) },
- { "Right", GTK_SIGNAL_FUNC (ctree_toggle_justify) }
- };
-
- static OptionMenuItem items4[] =
- {
- { "Single", GTK_SIGNAL_FUNC (ctree_toggle_sel_mode) },
- { "Browse", GTK_SIGNAL_FUNC (ctree_toggle_sel_mode) },
- { "Multiple", GTK_SIGNAL_FUNC (ctree_toggle_sel_mode) },
- { "Extended", GTK_SIGNAL_FUNC (ctree_toggle_sel_mode) }
- };
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "GtkCTree");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- tooltips = gtk_tooltips_new ();
- gtk_object_ref (GTK_OBJECT (tooltips));
- gtk_object_sink (GTK_OBJECT (tooltips));
-
- gtk_object_set_data_full (GTK_OBJECT (window), "tooltips", tooltips,
- (GtkDestroyNotify) gtk_object_unref);
-
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), vbox);
-
- hbox = gtk_hbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 0);
-
- label = gtk_label_new ("Depth :");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (4, 1, 10, 1, 5, 0);
- spin1 = gtk_spin_button_new (adj, 0, 0);
- gtk_box_pack_start (GTK_BOX (hbox), spin1, FALSE, TRUE, 5);
-
- label = gtk_label_new ("Books :");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (3, 1, 20, 1, 5, 0);
- spin2 = gtk_spin_button_new (adj, 0, 0);
- gtk_box_pack_start (GTK_BOX (hbox), spin2, FALSE, TRUE, 5);
-
- label = gtk_label_new ("Pages :");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (5, 1, 20, 1, 5, 0);
- spin3 = gtk_spin_button_new (adj, 0, 0);
- gtk_box_pack_start (GTK_BOX (hbox), spin3, FALSE, TRUE, 5);
-
- button = gtk_button_new_with_label ("Close");
- gtk_box_pack_end (GTK_BOX (hbox), button, TRUE, TRUE, 0);
-
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) gtk_widget_destroy,
- GTK_OBJECT(window));
-
- button = gtk_button_new_with_label ("Rebuild Tree");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
-
- scrolled_win = gtk_scrolled_window_new (NULL, NULL);
- gtk_container_set_border_width (GTK_CONTAINER (scrolled_win), 5);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win),
- GTK_POLICY_AUTOMATIC,
- GTK_POLICY_ALWAYS);
- gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0);
-
- ctree = GTK_CTREE (gtk_ctree_new_with_titles (2, 0, title));
- gtk_container_add (GTK_CONTAINER (scrolled_win), GTK_WIDGET (ctree));
-
- gtk_clist_set_column_auto_resize (GTK_CLIST (ctree), 0, TRUE);
- gtk_clist_set_column_width (GTK_CLIST (ctree), 1, 200);
- gtk_clist_set_selection_mode (GTK_CLIST (ctree), GTK_SELECTION_EXTENDED);
- gtk_ctree_set_line_style (ctree, GTK_CTREE_LINES_DOTTED);
- line_style = GTK_CTREE_LINES_DOTTED;
-
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (rebuild_tree), ctree);
- gtk_signal_connect (GTK_OBJECT (ctree), "click_column",
- (GtkSignalFunc) ctree_click_column, NULL);
-
- gtk_signal_connect_after (GTK_OBJECT (ctree), "button_press_event",
- GTK_SIGNAL_FUNC (after_press), NULL);
- gtk_signal_connect_after (GTK_OBJECT (ctree), "button_release_event",
- GTK_SIGNAL_FUNC (after_press), NULL);
- gtk_signal_connect_after (GTK_OBJECT (ctree), "tree_move",
- GTK_SIGNAL_FUNC (after_move), NULL);
- gtk_signal_connect_after (GTK_OBJECT (ctree), "end_selection",
- GTK_SIGNAL_FUNC (after_press), NULL);
- gtk_signal_connect_after (GTK_OBJECT (ctree), "toggle_focus_row",
- GTK_SIGNAL_FUNC (after_press), NULL);
- gtk_signal_connect_after (GTK_OBJECT (ctree), "select_all",
- GTK_SIGNAL_FUNC (after_press), NULL);
- gtk_signal_connect_after (GTK_OBJECT (ctree), "unselect_all",
- GTK_SIGNAL_FUNC (after_press), NULL);
- gtk_signal_connect_after (GTK_OBJECT (ctree), "scroll_vertical",
- GTK_SIGNAL_FUNC (after_press), NULL);
-
- bbox = gtk_hbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (bbox), 5);
- gtk_box_pack_start (GTK_BOX (vbox), bbox, FALSE, TRUE, 0);
-
- mbox = gtk_vbox_new (TRUE, 5);
- gtk_box_pack_start (GTK_BOX (bbox), mbox, FALSE, TRUE, 0);
-
- label = gtk_label_new ("Row Height :");
- gtk_box_pack_start (GTK_BOX (mbox), label, FALSE, FALSE, 0);
-
- label = gtk_label_new ("Indent :");
- gtk_box_pack_start (GTK_BOX (mbox), label, FALSE, FALSE, 0);
-
- label = gtk_label_new ("Spacing :");
- gtk_box_pack_start (GTK_BOX (mbox), label, FALSE, FALSE, 0);
-
- mbox = gtk_vbox_new (TRUE, 5);
- gtk_box_pack_start (GTK_BOX (bbox), mbox, FALSE, TRUE, 0);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (20, 12, 100, 1, 10, 0);
- spinner = gtk_spin_button_new (adj, 0, 0);
- gtk_box_pack_start (GTK_BOX (mbox), spinner, FALSE, FALSE, 5);
- gtk_tooltips_set_tip (tooltips, spinner,
- "Row height of list items", NULL);
- gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
- GTK_SIGNAL_FUNC (change_row_height), ctree);
- gtk_clist_set_row_height ( GTK_CLIST (ctree), adj->value);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (20, 0, 60, 1, 10, 0);
- spinner = gtk_spin_button_new (adj, 0, 0);
- gtk_box_pack_start (GTK_BOX (mbox), spinner, FALSE, FALSE, 5);
- gtk_tooltips_set_tip (tooltips, spinner, "Tree Indentation.", NULL);
- gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
- GTK_SIGNAL_FUNC (change_indent), ctree);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (5, 0, 60, 1, 10, 0);
- spinner = gtk_spin_button_new (adj, 0, 0);
- gtk_box_pack_start (GTK_BOX (mbox), spinner, FALSE, FALSE, 5);
- gtk_tooltips_set_tip (tooltips, spinner, "Tree Spacing.", NULL);
- gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
- GTK_SIGNAL_FUNC (change_spacing), ctree);
-
- mbox = gtk_vbox_new (TRUE, 5);
- gtk_box_pack_start (GTK_BOX (bbox), mbox, FALSE, TRUE, 0);
-
- hbox = gtk_hbox_new (FALSE, 5);
- gtk_box_pack_start (GTK_BOX (mbox), hbox, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Expand All");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (expand_all), ctree);
-
- button = gtk_button_new_with_label ("Collapse All");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (collapse_all), ctree);
-
- button = gtk_button_new_with_label ("Change Style");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (change_style), ctree);
-
- button = gtk_button_new_with_label ("Export Tree");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (export_ctree), ctree);
-
- hbox = gtk_hbox_new (FALSE, 5);
- gtk_box_pack_start (GTK_BOX (mbox), hbox, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Select All");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (select_all), ctree);
-
- button = gtk_button_new_with_label ("Unselect All");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (unselect_all), ctree);
-
- button = gtk_button_new_with_label ("Remove Selection");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (remove_selection), ctree);
-
- check = gtk_check_button_new_with_label ("Reorderable");
- gtk_box_pack_start (GTK_BOX (hbox), check, FALSE, TRUE, 0);
- gtk_tooltips_set_tip (tooltips, check,
- "Tree items can be reordered by dragging.", NULL);
- gtk_signal_connect (GTK_OBJECT (check), "clicked",
- GTK_SIGNAL_FUNC (toggle_reorderable), ctree);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check), TRUE);
-
- hbox = gtk_hbox_new (TRUE, 5);
- gtk_box_pack_start (GTK_BOX (mbox), hbox, FALSE, FALSE, 0);
-
- omenu1 = build_option_menu (items1, 4, 2, ctree);
- gtk_box_pack_start (GTK_BOX (hbox), omenu1, FALSE, TRUE, 0);
- gtk_tooltips_set_tip (tooltips, omenu1, "The tree's line style.", NULL);
-
- omenu2 = build_option_menu (items2, 4, 1, ctree);
- gtk_box_pack_start (GTK_BOX (hbox), omenu2, FALSE, TRUE, 0);
- gtk_tooltips_set_tip (tooltips, omenu2, "The tree's expander style.",
- NULL);
-
- omenu3 = build_option_menu (items3, 2, 0, ctree);
- gtk_box_pack_start (GTK_BOX (hbox), omenu3, FALSE, TRUE, 0);
- gtk_tooltips_set_tip (tooltips, omenu3, "The tree's justification.",
- NULL);
-
- omenu4 = build_option_menu (items4, 4, 3, ctree);
- gtk_box_pack_start (GTK_BOX (hbox), omenu4, FALSE, TRUE, 0);
- gtk_tooltips_set_tip (tooltips, omenu4, "The list's selection mode.",
- NULL);
-
- gtk_widget_realize (window);
-
- if (!pixmap1)
- pixmap1 = gdk_pixmap_create_from_xpm_d (window->window, &mask1,
- &transparent, book_closed_xpm);
- if (!pixmap2)
- pixmap2 = gdk_pixmap_create_from_xpm_d (window->window, &mask2,
- &transparent, book_open_xpm);
- if (!pixmap3)
- pixmap3 = gdk_pixmap_create_from_xpm_d (window->window, &mask3,
- &transparent, mini_page_xpm);
-
- gtk_widget_set_usize (GTK_WIDGET (ctree), 0, 300);
-
- frame = gtk_frame_new (NULL);
- gtk_container_set_border_width (GTK_CONTAINER (frame), 0);
- gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_OUT);
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, TRUE, 0);
-
- hbox = gtk_hbox_new (TRUE, 2);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 2);
- gtk_container_add (GTK_CONTAINER (frame), hbox);
-
- frame = gtk_frame_new (NULL);
- gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN);
- gtk_box_pack_start (GTK_BOX (hbox), frame, FALSE, TRUE, 0);
-
- hbox2 = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (hbox2), 2);
- gtk_container_add (GTK_CONTAINER (frame), hbox2);
-
- label = gtk_label_new ("Books :");
- gtk_box_pack_start (GTK_BOX (hbox2), label, FALSE, TRUE, 0);
-
- sprintf (buf, "%d", books);
- book_label = gtk_label_new (buf);
- gtk_box_pack_end (GTK_BOX (hbox2), book_label, FALSE, TRUE, 5);
-
- frame = gtk_frame_new (NULL);
- gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN);
- gtk_box_pack_start (GTK_BOX (hbox), frame, FALSE, TRUE, 0);
-
- hbox2 = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (hbox2), 2);
- gtk_container_add (GTK_CONTAINER (frame), hbox2);
-
- label = gtk_label_new ("Pages :");
- gtk_box_pack_start (GTK_BOX (hbox2), label, FALSE, TRUE, 0);
-
- sprintf (buf, "%d", pages);
- page_label = gtk_label_new (buf);
- gtk_box_pack_end (GTK_BOX (hbox2), page_label, FALSE, TRUE, 5);
-
- frame = gtk_frame_new (NULL);
- gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN);
- gtk_box_pack_start (GTK_BOX (hbox), frame, FALSE, TRUE, 0);
-
- hbox2 = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (hbox2), 2);
- gtk_container_add (GTK_CONTAINER (frame), hbox2);
-
- label = gtk_label_new ("Selected :");
- gtk_box_pack_start (GTK_BOX (hbox2), label, FALSE, TRUE, 0);
-
- sprintf (buf, "%d", g_list_length (GTK_CLIST (ctree)->selection));
- sel_label = gtk_label_new (buf);
- gtk_box_pack_end (GTK_BOX (hbox2), sel_label, FALSE, TRUE, 5);
-
- frame = gtk_frame_new (NULL);
- gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN);
- gtk_box_pack_start (GTK_BOX (hbox), frame, FALSE, TRUE, 0);
-
- hbox2 = gtk_hbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (hbox2), 2);
- gtk_container_add (GTK_CONTAINER (frame), hbox2);
-
- label = gtk_label_new ("Visible :");
- gtk_box_pack_start (GTK_BOX (hbox2), label, FALSE, TRUE, 0);
-
- sprintf (buf, "%d", g_list_length (GTK_CLIST (ctree)->row_list));
- vis_label = gtk_label_new (buf);
- gtk_box_pack_end (GTK_BOX (hbox2), vis_label, FALSE, TRUE, 5);
-
- rebuild_tree (NULL, ctree);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkColorSelection
- */
-
-void
-color_selection_ok (GtkWidget *w,
- GtkColorSelectionDialog *cs)
-{
- GtkColorSelection *colorsel;
- gdouble color[4];
-
- colorsel=GTK_COLOR_SELECTION(cs->colorsel);
-
- gtk_color_selection_get_color(colorsel,color);
- gtk_color_selection_set_color(colorsel,color);
-}
-
-void
-color_selection_changed (GtkWidget *w,
- GtkColorSelectionDialog *cs)
-{
- GtkColorSelection *colorsel;
- gdouble color[4];
-
- colorsel=GTK_COLOR_SELECTION(cs->colorsel);
- gtk_color_selection_get_color(colorsel,color);
-}
-
-static void
-opacity_toggled_cb (GtkWidget *w,
- GtkColorSelectionDialog *cs)
-{
- GtkColorSelection *colorsel;
-
- colorsel = GTK_COLOR_SELECTION (cs->colorsel);
- gtk_color_selection_set_use_opacity (colorsel,
- gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (w)));
-}
-
-static void
-palette_toggled_cb (GtkWidget *w,
- GtkColorSelectionDialog *cs)
-{
- GtkColorSelection *colorsel;
-
- colorsel = GTK_COLOR_SELECTION (cs->colorsel);
- gtk_color_selection_set_use_palette (colorsel,
- gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (w)));
-}
-
-void
-create_color_selection (void)
-{
- static GtkWidget *window = NULL;
-
- if (!window)
- {
- GtkWidget *options_hbox;
- GtkWidget *check_button;
-
- window = gtk_color_selection_dialog_new ("color selection dialog");
-
- gtk_window_set_position (GTK_WINDOW (window), GTK_WIN_POS_MOUSE);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- options_hbox = gtk_hbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), options_hbox, FALSE, FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (options_hbox), 10);
-
- check_button = gtk_check_button_new_with_label ("Show Opacity");
- gtk_box_pack_start (GTK_BOX (options_hbox), check_button, FALSE, FALSE, 0);
- gtk_signal_connect (GTK_OBJECT (check_button), "toggled",
- GTK_SIGNAL_FUNC (opacity_toggled_cb), window);
-
- check_button = gtk_check_button_new_with_label ("Show Palette");
- gtk_box_pack_end (GTK_BOX (options_hbox), check_button, FALSE, FALSE, 0);
- gtk_signal_connect (GTK_OBJECT (check_button), "toggled",
- GTK_SIGNAL_FUNC (palette_toggled_cb), window);
-
- gtk_widget_show_all (options_hbox);
-
- gtk_signal_connect (
- GTK_OBJECT (GTK_COLOR_SELECTION_DIALOG (window)->colorsel),
- "color_changed",
- GTK_SIGNAL_FUNC(color_selection_changed),
- window);
-
- gtk_signal_connect (
- GTK_OBJECT (GTK_COLOR_SELECTION_DIALOG (window)->ok_button),
- "clicked",
- GTK_SIGNAL_FUNC(color_selection_ok),
- window);
-
- gtk_signal_connect_object (
- GTK_OBJECT (GTK_COLOR_SELECTION_DIALOG (window)->cancel_button),
- "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkFileSelection
- */
-
-void
-file_selection_hide_fileops (GtkWidget *widget,
- GtkFileSelection *fs)
-{
- gtk_file_selection_hide_fileop_buttons (fs);
-}
-
-void
-file_selection_ok (GtkWidget *w,
- GtkFileSelection *fs)
-{
- g_print ("%s\n", gtk_file_selection_get_filename (fs));
- gtk_widget_destroy (GTK_WIDGET (fs));
-}
-
-void
-create_file_selection (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *button;
-
- if (!window)
- {
- window = gtk_file_selection_new ("file selection dialog");
-
- gtk_file_selection_hide_fileop_buttons (GTK_FILE_SELECTION (window));
-
- gtk_window_set_position (GTK_WINDOW (window), GTK_WIN_POS_MOUSE);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_signal_connect (GTK_OBJECT (GTK_FILE_SELECTION (window)->ok_button),
- "clicked", GTK_SIGNAL_FUNC(file_selection_ok),
- window);
- gtk_signal_connect_object (GTK_OBJECT (GTK_FILE_SELECTION (window)->cancel_button),
- "clicked", GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
-
- button = gtk_button_new_with_label ("Hide Fileops");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) file_selection_hide_fileops,
- (gpointer) window);
- gtk_box_pack_start (GTK_BOX (GTK_FILE_SELECTION (window)->action_area),
- button, FALSE, FALSE, 0);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("Show Fileops");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) gtk_file_selection_show_fileop_buttons,
- (gpointer) window);
- gtk_box_pack_start (GTK_BOX (GTK_FILE_SELECTION (window)->action_area),
- button, FALSE, FALSE, 0);
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-void
-flipping_toggled_cb (GtkWidget *widget, gpointer data)
-{
- int state = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget));
- int new_direction = state ? GTK_TEXT_DIR_RTL : GTK_TEXT_DIR_LTR;
-
- gtk_widget_set_default_direction (new_direction);
-}
-
-void
-create_flipping (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *check_button, *button;
-
- if (!window)
- {
- window = gtk_dialog_new ();
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Bidirectional Flipping");
-
- check_button = gtk_check_button_new_with_label ("Right-to-left global direction");
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox),
- check_button, TRUE, TRUE, 0);
-
- if (gtk_widget_get_default_direction () == GTK_TEXT_DIR_RTL)
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check_button), TRUE);
-
- gtk_signal_connect (GTK_OBJECT (check_button), "toggled",
- GTK_SIGNAL_FUNC (flipping_toggled_cb), FALSE);
-
- gtk_container_set_border_width (GTK_CONTAINER (check_button), 10);
-
- button = gtk_button_new_with_label ("Close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy), GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Focus test
- */
-
-static GtkWidget*
-make_focus_table (GList **list)
-{
- GtkWidget *table;
- gint i, j;
-
- table = gtk_table_new (5, 5, FALSE);
-
- i = 0;
- j = 0;
-
- while (i < 5)
- {
- j = 0;
- while (j < 5)
- {
- GtkWidget *widget;
-
- if ((i + j) % 2)
- widget = gtk_entry_new ();
- else
- widget = gtk_button_new_with_label ("Foo");
-
- *list = g_list_prepend (*list, widget);
-
- gtk_table_attach (GTK_TABLE (table),
- widget,
- i, i + 1,
- j, j + 1,
- GTK_EXPAND | GTK_FILL,
- GTK_EXPAND | GTK_FILL,
- 5, 5);
-
- ++j;
- }
-
- ++i;
- }
-
- *list = g_list_reverse (*list);
-
- return table;
-}
-
-static void
-create_focus (void)
-{
- static GtkWidget *window = NULL;
-
- if (!window)
- {
- GtkWidget *table;
- GtkWidget *frame;
- GList *list = NULL;
-
- window = gtk_dialog_new_with_buttons ("Keyboard focus navigation",
- NULL, 0,
- GTK_STOCK_BUTTON_CLOSE,
- GTK_RESPONSE_NONE,
- NULL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &window);
-
- gtk_signal_connect (GTK_OBJECT (window), "response",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- NULL);
-
- gtk_window_set_title (GTK_WINDOW (window), "Keyboard Focus Navigation");
-
- frame = gtk_frame_new ("Weird tab focus chain");
-
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox),
- frame, TRUE, TRUE, 0);
-
- table = make_focus_table (&list);
-
- gtk_container_add (GTK_CONTAINER (frame), table);
-
- gtk_container_set_focus_chain (GTK_CONTAINER (table),
- list);
-
- g_list_free (list);
-
- frame = gtk_frame_new ("Default tab focus chain");
-
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox),
- frame, TRUE, TRUE, 0);
-
- list = NULL;
- table = make_focus_table (&list);
-
- g_list_free (list);
-
- gtk_container_add (GTK_CONTAINER (frame), table);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkFontSelection
- */
-
-void
-font_selection_ok (GtkWidget *w,
- GtkFontSelectionDialog *fs)
-{
- gchar *s = gtk_font_selection_dialog_get_font_name (fs);
-
- g_print ("%s\n", s);
- g_free (s);
- gtk_widget_destroy (GTK_WIDGET (fs));
-}
-
-void
-create_font_selection (void)
-{
- static GtkWidget *window = NULL;
-
- if (!window)
- {
- window = gtk_font_selection_dialog_new ("Font Selection Dialog");
-
- gtk_window_set_position (GTK_WINDOW (window), GTK_WIN_POS_MOUSE);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_signal_connect (GTK_OBJECT (GTK_FONT_SELECTION_DIALOG (window)->ok_button),
- "clicked", GTK_SIGNAL_FUNC(font_selection_ok),
- GTK_FONT_SELECTION_DIALOG (window));
- gtk_signal_connect_object (GTK_OBJECT (GTK_FONT_SELECTION_DIALOG (window)->cancel_button),
- "clicked", GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkDialog
- */
-
-static GtkWidget *dialog_window = NULL;
-
-static void
-label_toggle (GtkWidget *widget,
- GtkWidget **label)
-{
- if (!(*label))
- {
- *label = gtk_label_new ("Dialog Test");
- gtk_signal_connect (GTK_OBJECT (*label),
- "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- label);
- gtk_misc_set_padding (GTK_MISC (*label), 10, 10);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog_window)->vbox),
- *label, TRUE, TRUE, 0);
- gtk_widget_show (*label);
- }
- else
- gtk_widget_destroy (*label);
-}
-
-#define RESPONSE_TOGGLE_SEPARATOR 1
-
-static void
-print_response (GtkWidget *dialog,
- gint response_id,
- gpointer data)
-{
- g_print ("response signal received (%d)\n", response_id);
-
- if (response_id == RESPONSE_TOGGLE_SEPARATOR)
- {
- gtk_dialog_set_has_separator (GTK_DIALOG (dialog),
- !gtk_dialog_get_has_separator (GTK_DIALOG (dialog)));
- }
-}
-
-static void
-create_dialog (void)
-{
- static GtkWidget *label;
- GtkWidget *button;
-
- if (!dialog_window)
- {
- /* This is a terrible example; it's much simpler to create
- * dialogs than this. Don't use testgtk for example code,
- * use gtk-demo ;-)
- */
-
- dialog_window = gtk_dialog_new ();
-
- gtk_signal_connect (GTK_OBJECT (dialog_window),
- "response",
- GTK_SIGNAL_FUNC (print_response),
- NULL);
-
- gtk_signal_connect (GTK_OBJECT (dialog_window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &dialog_window);
-
- gtk_window_set_title (GTK_WINDOW (dialog_window), "GtkDialog");
- gtk_container_set_border_width (GTK_CONTAINER (dialog_window), 0);
-
- button = gtk_button_new_with_label ("OK");
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog_window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("Toggle");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (label_toggle),
- &label);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog_window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_show (button);
-
- label = NULL;
-
- button = gtk_button_new_with_label ("Separator");
-
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
-
- gtk_dialog_add_action_widget (GTK_DIALOG (dialog_window),
- button,
- RESPONSE_TOGGLE_SEPARATOR);
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (dialog_window))
- gtk_widget_show (dialog_window);
- else
- gtk_widget_destroy (dialog_window);
-}
-
-/* Event Watcher
- */
-static gboolean event_watcher_enter_id = 0;
-static gboolean event_watcher_leave_id = 0;
-
-static gboolean
-event_watcher (GSignalInvocationHint *ihint,
- guint n_param_values,
- const GValue *param_values,
- gpointer data)
-{
- g_print ("Watch: \"%s\" emitted for %s\n",
- gtk_signal_name (ihint->signal_id),
- gtk_type_name (GTK_OBJECT_TYPE (g_value_get_object (param_values + 0))));
-
- return TRUE;
-}
-
-static void
-event_watcher_down (void)
-{
- if (event_watcher_enter_id)
- {
- guint signal_id;
-
- signal_id = gtk_signal_lookup ("enter_notify_event", GTK_TYPE_WIDGET);
- g_signal_remove_emission_hook (signal_id, event_watcher_enter_id);
- event_watcher_enter_id = 0;
- signal_id = gtk_signal_lookup ("leave_notify_event", GTK_TYPE_WIDGET);
- g_signal_remove_emission_hook (signal_id, event_watcher_leave_id);
- event_watcher_leave_id = 0;
- }
-}
-
-static void
-event_watcher_toggle (void)
-{
- if (event_watcher_enter_id)
- event_watcher_down ();
- else
- {
- guint signal_id;
-
- signal_id = gtk_signal_lookup ("enter_notify_event", GTK_TYPE_WIDGET);
- event_watcher_enter_id = g_signal_add_emission_hook (signal_id, 0, event_watcher, NULL, NULL);
- signal_id = gtk_signal_lookup ("leave_notify_event", GTK_TYPE_WIDGET);
- event_watcher_leave_id = g_signal_add_emission_hook (signal_id, 0, event_watcher, NULL, NULL);
- }
-}
-
-static void
-create_event_watcher (void)
-{
- GtkWidget *button;
-
- if (!dialog_window)
- {
- dialog_window = gtk_dialog_new ();
-
- gtk_signal_connect (GTK_OBJECT (dialog_window), "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroyed),
- &dialog_window);
- gtk_signal_connect (GTK_OBJECT (dialog_window),
- "destroy",
- GTK_SIGNAL_FUNC (event_watcher_down),
- NULL);
-
- gtk_window_set_title (GTK_WINDOW (dialog_window), "Event Watcher");
- gtk_container_set_border_width (GTK_CONTAINER (dialog_window), 0);
- gtk_widget_set_usize (dialog_window, 200, 110);
-
- button = gtk_toggle_button_new_with_label ("Activate Watch");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (event_watcher_toggle),
- NULL);
- gtk_container_set_border_width (GTK_CONTAINER (button), 10);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog_window)->vbox),
- button, TRUE, TRUE, 0);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("Close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- (GtkObject*) dialog_window);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog_window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (dialog_window))
- gtk_widget_show (dialog_window);
- else
- gtk_widget_destroy (dialog_window);
-}
-
-/*
- * GtkRange
- */
-
-static void
-create_range_controls (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *button;
- GtkWidget *scrollbar;
- GtkWidget *scale;
- GtkWidget *separator;
- GtkObject *adjustment;
- GtkWidget *hbox;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "range controls");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
- gtk_widget_show (box1);
-
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
- gtk_widget_show (box2);
-
-
- adjustment = gtk_adjustment_new (0.0, 0.0, 101.0, 0.1, 1.0, 1.0);
-
- scale = gtk_hscale_new (GTK_ADJUSTMENT (adjustment));
- gtk_widget_set_usize (GTK_WIDGET (scale), 150, 30);
- gtk_range_set_update_policy (GTK_RANGE (scale), GTK_UPDATE_DELAYED);
- gtk_scale_set_digits (GTK_SCALE (scale), 1);
- gtk_scale_set_draw_value (GTK_SCALE (scale), TRUE);
- gtk_box_pack_start (GTK_BOX (box2), scale, TRUE, TRUE, 0);
- gtk_widget_show (scale);
-
- scrollbar = gtk_hscrollbar_new (GTK_ADJUSTMENT (adjustment));
- gtk_range_set_update_policy (GTK_RANGE (scrollbar),
- GTK_UPDATE_CONTINUOUS);
- gtk_box_pack_start (GTK_BOX (box2), scrollbar, TRUE, TRUE, 0);
- gtk_widget_show (scrollbar);
-
- hbox = gtk_hbox_new (FALSE, 0);
-
- scale = gtk_vscale_new (GTK_ADJUSTMENT (adjustment));
- gtk_widget_set_usize (scale, -1, 200);
- gtk_scale_set_digits (GTK_SCALE (scale), 2);
- gtk_scale_set_draw_value (GTK_SCALE (scale), TRUE);
- gtk_box_pack_start (GTK_BOX (hbox), scale, TRUE, TRUE, 0);
- gtk_widget_show (scale);
-
- scale = gtk_vscale_new (GTK_ADJUSTMENT (adjustment));
- gtk_widget_set_usize (scale, -1, 200);
- gtk_scale_set_digits (GTK_SCALE (scale), 2);
- gtk_scale_set_draw_value (GTK_SCALE (scale), TRUE);
- gtk_range_set_inverted (GTK_RANGE (scale), TRUE);
- gtk_box_pack_start (GTK_BOX (hbox), scale, TRUE, TRUE, 0);
- gtk_widget_show (scale);
-
- gtk_box_pack_start (GTK_BOX (box2), hbox, TRUE, TRUE, 0);
- gtk_widget_show (hbox);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
- gtk_widget_show (separator);
-
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
- gtk_widget_show (box2);
-
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkRulers
- */
-
-void
-create_rulers (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *table;
- GtkWidget *ruler;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_policy (GTK_WINDOW (window), TRUE, TRUE, FALSE);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "rulers");
- gtk_widget_set_usize (window, 300, 300);
- gtk_widget_set_events (window,
- GDK_POINTER_MOTION_MASK
- | GDK_POINTER_MOTION_HINT_MASK);
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- table = gtk_table_new (2, 2, FALSE);
- gtk_container_add (GTK_CONTAINER (window), table);
- gtk_widget_show (table);
-
- ruler = gtk_hruler_new ();
- gtk_ruler_set_metric (GTK_RULER (ruler), GTK_CENTIMETERS);
- gtk_ruler_set_range (GTK_RULER (ruler), 100, 0, 0, 20);
-
- gtk_signal_connect_object (GTK_OBJECT (window),
- "motion_notify_event",
- GTK_SIGNAL_FUNC (GTK_WIDGET_GET_CLASS (ruler)->motion_notify_event),
- GTK_OBJECT (ruler));
-
- gtk_table_attach (GTK_TABLE (table), ruler, 1, 2, 0, 1,
- GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
- gtk_widget_show (ruler);
-
-
- ruler = gtk_vruler_new ();
- gtk_ruler_set_range (GTK_RULER (ruler), 5, 15, 0, 20);
-
- gtk_signal_connect_object (GTK_OBJECT (window),
- "motion_notify_event",
- GTK_SIGNAL_FUNC (GTK_WIDGET_GET_CLASS (ruler)->motion_notify_event),
- GTK_OBJECT (ruler));
-
- gtk_table_attach (GTK_TABLE (table), ruler, 0, 1, 1, 2,
- GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
- gtk_widget_show (ruler);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-static void
-text_toggle_editable (GtkWidget *checkbutton,
- GtkWidget *text)
-{
- gtk_text_set_editable(GTK_TEXT(text),
- GTK_TOGGLE_BUTTON(checkbutton)->active);
-}
-
-static void
-text_toggle_word_wrap (GtkWidget *checkbutton,
- GtkWidget *text)
-{
- gtk_text_set_word_wrap(GTK_TEXT(text),
- GTK_TOGGLE_BUTTON(checkbutton)->active);
-}
-
-struct {
- GdkColor color;
- gchar *name;
-} text_colors[] = {
- { { 0, 0x0000, 0x0000, 0x0000 }, "black" },
- { { 0, 0xFFFF, 0xFFFF, 0xFFFF }, "white" },
- { { 0, 0xFFFF, 0x0000, 0x0000 }, "red" },
- { { 0, 0x0000, 0xFFFF, 0x0000 }, "green" },
- { { 0, 0x0000, 0x0000, 0xFFFF }, "blue" },
- { { 0, 0x0000, 0xFFFF, 0xFFFF }, "cyan" },
- { { 0, 0xFFFF, 0x0000, 0xFFFF }, "magenta" },
- { { 0, 0xFFFF, 0xFFFF, 0x0000 }, "yellow" }
-};
-
-int ntext_colors = sizeof(text_colors) / sizeof(text_colors[0]);
-
-/*
- * GtkText
- */
-void
-text_insert_random (GtkWidget *w, GtkText *text)
-{
- int i;
- char c;
- for (i=0; i<10; i++)
- {
- c = 'A' + rand() % ('Z' - 'A');
- gtk_text_set_point (text, rand() % gtk_text_get_length (text));
- gtk_text_insert (text, NULL, NULL, NULL, &c, 1);
- }
-}
-
-void
-create_text (void)
-{
- int i, j;
-
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *hbox;
- GtkWidget *button;
- GtkWidget *check;
- GtkWidget *separator;
- GtkWidget *scrolled_window;
- GtkWidget *text;
-
- FILE *infile;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_widget_set_name (window, "text window");
- gtk_widget_set_usize (window, 500, 500);
- gtk_window_set_policy (GTK_WINDOW(window), TRUE, TRUE, FALSE);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "test");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
- gtk_widget_show (box1);
-
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
- gtk_widget_show (box2);
-
-
- scrolled_window = gtk_scrolled_window_new (NULL, NULL);
- gtk_box_pack_start (GTK_BOX (box2), scrolled_window, TRUE, TRUE, 0);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window),
- GTK_POLICY_NEVER,
- GTK_POLICY_ALWAYS);
- gtk_widget_show (scrolled_window);
-
- text = gtk_text_new (NULL, NULL);
- gtk_text_set_editable (GTK_TEXT (text), TRUE);
- gtk_container_add (GTK_CONTAINER (scrolled_window), text);
- gtk_widget_grab_focus (text);
- gtk_widget_show (text);
-
-
- gtk_text_freeze (GTK_TEXT (text));
-
- for (i=0; i<ntext_colors; i++)
- {
- gtk_text_insert (GTK_TEXT (text), NULL, NULL, NULL,
- text_colors[i].name, -1);
- gtk_text_insert (GTK_TEXT (text), NULL, NULL, NULL, "\t", -1);
-
- for (j=0; j<ntext_colors; j++)
- {
- gtk_text_insert (GTK_TEXT (text), NULL,
- &text_colors[j].color, &text_colors[i].color,
- "XYZ", -1);
- }
- gtk_text_insert (GTK_TEXT (text), NULL, NULL, NULL, "\n", -1);
- }
-
- infile = fopen("testgtk.c", "r");
-
- if (infile)
- {
- char *buffer;
- int nbytes_read, nbytes_alloc;
-
- nbytes_read = 0;
- nbytes_alloc = 1024;
- buffer = g_new (char, nbytes_alloc);
- while (1)
- {
- int len;
- if (nbytes_alloc < nbytes_read + 1024)
- {
- nbytes_alloc *= 2;
- buffer = g_realloc (buffer, nbytes_alloc);
- }
- len = fread (buffer + nbytes_read, 1, 1024, infile);
- nbytes_read += len;
- if (len < 1024)
- break;
- }
-
- gtk_text_insert (GTK_TEXT (text), NULL, NULL,
- NULL, buffer, nbytes_read);
- g_free(buffer);
- fclose (infile);
- }
-
- gtk_text_thaw (GTK_TEXT (text));
-
- hbox = gtk_hbutton_box_new ();
- gtk_box_pack_start (GTK_BOX (box2), hbox, FALSE, FALSE, 0);
- gtk_widget_show (hbox);
-
- check = gtk_check_button_new_with_label("Editable");
- gtk_box_pack_start (GTK_BOX (hbox), check, FALSE, FALSE, 0);
- gtk_signal_connect (GTK_OBJECT(check), "toggled",
- GTK_SIGNAL_FUNC(text_toggle_editable), text);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(check), TRUE);
- gtk_widget_show (check);
-
- check = gtk_check_button_new_with_label("Wrap Words");
- gtk_box_pack_start (GTK_BOX (hbox), check, FALSE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT(check), "toggled",
- GTK_SIGNAL_FUNC(text_toggle_word_wrap), text);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(check), FALSE);
- gtk_widget_show (check);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
- gtk_widget_show (separator);
-
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
- gtk_widget_show (box2);
-
-
- button = gtk_button_new_with_label ("insert random");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(text_insert_random),
- GTK_TEXT (text));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkNotebook
- */
-
-GdkPixmap *book_open;
-GdkPixmap *book_closed;
-GdkBitmap *book_open_mask;
-GdkBitmap *book_closed_mask;
-GtkWidget *sample_notebook;
-
-static void
-set_page_pixmaps (GtkNotebook *notebook, gint page_num,
- GdkPixmap *pixmap, GdkPixmap *mask)
-{
- GtkWidget *page_widget;
- GtkWidget *pixwid;
-
- page_widget = gtk_notebook_get_nth_page (notebook, page_num);
-
- pixwid = gtk_object_get_data (GTK_OBJECT (page_widget), "tab_pixmap");
- gtk_pixmap_set (GTK_PIXMAP (pixwid), pixmap, mask);
-
- pixwid = gtk_object_get_data (GTK_OBJECT (page_widget), "menu_pixmap");
- gtk_pixmap_set (GTK_PIXMAP (pixwid), pixmap, mask);
-}
-
-static void
-page_switch (GtkWidget *widget, GtkNotebookPage *page, gint page_num)
-{
- GtkNotebook *notebook = GTK_NOTEBOOK (widget);
- gint old_page_num = gtk_notebook_get_current_page (notebook);
-
- if (page_num == old_page_num)
- return;
-
- set_page_pixmaps (notebook, page_num, book_open, book_open_mask);
-
- if (old_page_num != -1)
- set_page_pixmaps (notebook, old_page_num, book_closed, book_closed_mask);
-}
-
-static void
-tab_fill (GtkToggleButton *button, GtkWidget *child)
-{
- gboolean expand;
- GtkPackType pack_type;
-
- gtk_notebook_query_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child,
- &expand, NULL, &pack_type);
- gtk_notebook_set_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child,
- expand, button->active, pack_type);
-}
-
-static void
-tab_expand (GtkToggleButton *button, GtkWidget *child)
-{
- gboolean fill;
- GtkPackType pack_type;
-
- gtk_notebook_query_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child,
- NULL, &fill, &pack_type);
- gtk_notebook_set_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child,
- button->active, fill, pack_type);
-}
-
-static void
-tab_pack (GtkToggleButton *button, GtkWidget *child)
-
-{
- gboolean expand;
- gboolean fill;
-
- gtk_notebook_query_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child,
- &expand, &fill, NULL);
- gtk_notebook_set_tab_label_packing (GTK_NOTEBOOK (sample_notebook), child,
- expand, fill, button->active);
-}
-
-static void
-create_pages (GtkNotebook *notebook, gint start, gint end)
-{
- GtkWidget *child = NULL;
- GtkWidget *button;
- GtkWidget *label;
- GtkWidget *hbox;
- GtkWidget *vbox;
- GtkWidget *label_box;
- GtkWidget *menu_box;
- GtkWidget *pixwid;
- gint i;
- char buffer[32];
- char accel_buffer[32];
-
- for (i = start; i <= end; i++)
- {
- sprintf (buffer, "Page %d", i);
- sprintf (accel_buffer, "Page _%d", i);
-
- child = gtk_frame_new (buffer);
- gtk_container_set_border_width (GTK_CONTAINER (child), 10);
-
- vbox = gtk_vbox_new (TRUE,0);
- gtk_container_set_border_width (GTK_CONTAINER (vbox), 10);
- gtk_container_add (GTK_CONTAINER (child), vbox);
-
- hbox = gtk_hbox_new (TRUE,0);
- gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, TRUE, 5);
-
- button = gtk_check_button_new_with_label ("Fill Tab");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), TRUE);
- gtk_signal_connect (GTK_OBJECT (button), "toggled",
- GTK_SIGNAL_FUNC (tab_fill), child);
-
- button = gtk_check_button_new_with_label ("Expand Tab");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5);
- gtk_signal_connect (GTK_OBJECT (button), "toggled",
- GTK_SIGNAL_FUNC (tab_expand), child);
-
- button = gtk_check_button_new_with_label ("Pack end");
- gtk_box_pack_start (GTK_BOX (hbox), button, TRUE, TRUE, 5);
- gtk_signal_connect (GTK_OBJECT (button), "toggled",
- GTK_SIGNAL_FUNC (tab_pack), child);
-
- button = gtk_button_new_with_label ("Hide Page");
- gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 5);
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_hide),
- GTK_OBJECT (child));
-
- gtk_widget_show_all (child);
-
- label_box = gtk_hbox_new (FALSE, 0);
- pixwid = gtk_pixmap_new (book_closed, book_closed_mask);
- gtk_object_set_data (GTK_OBJECT (child), "tab_pixmap", pixwid);
-
- gtk_box_pack_start (GTK_BOX (label_box), pixwid, FALSE, TRUE, 0);
- gtk_misc_set_padding (GTK_MISC (pixwid), 3, 1);
- label = gtk_label_new_with_mnemonic (accel_buffer);
- gtk_box_pack_start (GTK_BOX (label_box), label, FALSE, TRUE, 0);
- gtk_widget_show_all (label_box);
-
-
- menu_box = gtk_hbox_new (FALSE, 0);
- pixwid = gtk_pixmap_new (book_closed, book_closed_mask);
- gtk_object_set_data (GTK_OBJECT (child), "menu_pixmap", pixwid);
-
- gtk_box_pack_start (GTK_BOX (menu_box), pixwid, FALSE, TRUE, 0);
- gtk_misc_set_padding (GTK_MISC (pixwid), 3, 1);
- label = gtk_label_new (buffer);
- gtk_box_pack_start (GTK_BOX (menu_box), label, FALSE, TRUE, 0);
- gtk_widget_show_all (menu_box);
-
- gtk_notebook_append_page_menu (notebook, child, label_box, menu_box);
- }
-}
-
-static void
-rotate_notebook (GtkButton *button,
- GtkNotebook *notebook)
-{
- gtk_notebook_set_tab_pos (notebook, (notebook->tab_pos + 1) % 4);
-}
-
-static void
-show_all_pages (GtkButton *button,
- GtkNotebook *notebook)
-{
- gtk_container_foreach (GTK_CONTAINER (notebook),
- (GtkCallback) gtk_widget_show, NULL);
-}
-
-static void
-standard_notebook (GtkButton *button,
- GtkNotebook *notebook)
-{
- gint i;
-
- gtk_notebook_set_show_tabs (notebook, TRUE);
- gtk_notebook_set_show_border (notebook, TRUE);
- gtk_notebook_set_scrollable (notebook, FALSE);
- if (g_list_length (notebook->children) == 15)
- for (i = 0; i < 10; i++)
- gtk_notebook_remove_page (notebook, 5);
-}
-
-static void
-notabs_notebook (GtkButton *button,
- GtkNotebook *notebook)
-{
- gint i;
-
- gtk_notebook_set_show_tabs (notebook, FALSE);
- gtk_notebook_set_show_border (notebook, TRUE);
- if (g_list_length (notebook->children) == 15)
- for (i = 0; i < 10; i++)
- gtk_notebook_remove_page (notebook, 5);
-}
-
-static void
-borderless_notebook (GtkButton *button,
- GtkNotebook *notebook)
-{
- gint i;
-
- gtk_notebook_set_show_tabs (notebook, FALSE);
- gtk_notebook_set_show_border (notebook, FALSE);
- if (g_list_length (notebook->children) == 15)
- for (i = 0; i < 10; i++)
- gtk_notebook_remove_page (notebook, 5);
-}
-
-static void
-scrollable_notebook (GtkButton *button,
- GtkNotebook *notebook)
-{
- gtk_notebook_set_show_tabs (notebook, TRUE);
- gtk_notebook_set_show_border (notebook, TRUE);
- gtk_notebook_set_scrollable (notebook, TRUE);
- if (g_list_length (notebook->children) == 5)
- create_pages (notebook, 6, 15);
-}
-
-static void
-notebook_popup (GtkToggleButton *button,
- GtkNotebook *notebook)
-{
- if (button->active)
- gtk_notebook_popup_enable (notebook);
- else
- gtk_notebook_popup_disable (notebook);
-}
-
-static void
-notebook_homogeneous (GtkToggleButton *button,
- GtkNotebook *notebook)
-{
- gtk_notebook_set_homogeneous_tabs (notebook, button->active);
-}
-
-static void
-create_notebook (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *button;
- GtkWidget *separator;
- GtkWidget *omenu;
- GdkColor *transparent = NULL;
- GtkWidget *label;
-
- static OptionMenuItem items[] =
- {
- { "Standard", GTK_SIGNAL_FUNC (standard_notebook) },
- { "No tabs", GTK_SIGNAL_FUNC (notabs_notebook) },
- { "Borderless", GTK_SIGNAL_FUNC (borderless_notebook) },
- { "Scrollable", GTK_SIGNAL_FUNC (scrollable_notebook) },
- };
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "notebook");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- sample_notebook = gtk_notebook_new ();
- gtk_signal_connect (GTK_OBJECT (sample_notebook), "switch_page",
- GTK_SIGNAL_FUNC (page_switch), NULL);
- gtk_notebook_set_tab_pos (GTK_NOTEBOOK (sample_notebook), GTK_POS_TOP);
- gtk_box_pack_start (GTK_BOX (box1), sample_notebook, TRUE, TRUE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (sample_notebook), 10);
-
- gtk_widget_realize (sample_notebook);
- if (!book_open)
- book_open = gdk_pixmap_create_from_xpm_d (sample_notebook->window,
- &book_open_mask,
- transparent,
- book_open_xpm);
- if (!book_closed)
- book_closed = gdk_pixmap_create_from_xpm_d (sample_notebook->window,
- &book_closed_mask,
- transparent,
- book_closed_xpm);
-
- create_pages (GTK_NOTEBOOK (sample_notebook), 1, 5);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 10);
-
- box2 = gtk_hbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button = gtk_check_button_new_with_label ("popup menu");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, FALSE, 0);
- gtk_signal_connect (GTK_OBJECT(button), "clicked",
- GTK_SIGNAL_FUNC (notebook_popup),
- GTK_OBJECT (sample_notebook));
-
- button = gtk_check_button_new_with_label ("homogeneous tabs");
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, FALSE, 0);
- gtk_signal_connect (GTK_OBJECT(button), "clicked",
- GTK_SIGNAL_FUNC (notebook_homogeneous),
- GTK_OBJECT (sample_notebook));
-
- box2 = gtk_hbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- label = gtk_label_new ("Notebook Style :");
- gtk_box_pack_start (GTK_BOX (box2), label, FALSE, TRUE, 0);
-
- omenu = build_option_menu (items, G_N_ELEMENTS (items), 0, sample_notebook);
- gtk_box_pack_start (GTK_BOX (box2), omenu, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("Show all Pages");
- gtk_box_pack_start (GTK_BOX (box2), button, FALSE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (show_all_pages), sample_notebook);
-
- box2 = gtk_hbox_new (TRUE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("prev");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_notebook_prev_page),
- GTK_OBJECT (sample_notebook));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- button = gtk_button_new_with_label ("next");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_notebook_next_page),
- GTK_OBJECT (sample_notebook));
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- button = gtk_button_new_with_label ("rotate");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (rotate_notebook), sample_notebook);
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 5);
-
- button = gtk_button_new_with_label ("close");
- gtk_container_set_border_width (GTK_CONTAINER (button), 5);
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (box1), button, FALSE, FALSE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkPanes
- */
-
-void
-toggle_resize (GtkWidget *widget, GtkWidget *child)
-{
- GtkPaned *paned = GTK_PANED (child->parent);
- gboolean is_child1 = (child == paned->child1);
- gboolean resize, shrink;
-
- resize = is_child1 ? paned->child1_resize : paned->child2_resize;
- shrink = is_child1 ? paned->child1_shrink : paned->child2_shrink;
-
- gtk_widget_ref (child);
- gtk_container_remove (GTK_CONTAINER (child->parent), child);
- if (is_child1)
- gtk_paned_pack1 (paned, child, !resize, shrink);
- else
- gtk_paned_pack2 (paned, child, !resize, shrink);
- gtk_widget_unref (child);
-}
-
-void
-toggle_shrink (GtkWidget *widget, GtkWidget *child)
-{
- GtkPaned *paned = GTK_PANED (child->parent);
- gboolean is_child1 = (child == paned->child1);
- gboolean resize, shrink;
-
- resize = is_child1 ? paned->child1_resize : paned->child2_resize;
- shrink = is_child1 ? paned->child1_shrink : paned->child2_shrink;
-
- gtk_widget_ref (child);
- gtk_container_remove (GTK_CONTAINER (child->parent), child);
- if (is_child1)
- gtk_paned_pack1 (paned, child, resize, !shrink);
- else
- gtk_paned_pack2 (paned, child, resize, !shrink);
- gtk_widget_unref (child);
-}
-
-GtkWidget *
-create_pane_options (GtkPaned *paned,
- const gchar *frame_label,
- const gchar *label1,
- const gchar *label2)
-{
- GtkWidget *frame;
- GtkWidget *table;
- GtkWidget *label;
- GtkWidget *check_button;
-
- frame = gtk_frame_new (frame_label);
- gtk_container_set_border_width (GTK_CONTAINER (frame), 4);
-
- table = gtk_table_new (3, 2, 4);
- gtk_container_add (GTK_CONTAINER (frame), table);
-
- label = gtk_label_new (label1);
- gtk_table_attach_defaults (GTK_TABLE (table), label,
- 0, 1, 0, 1);
-
- check_button = gtk_check_button_new_with_label ("Resize");
- gtk_table_attach_defaults (GTK_TABLE (table), check_button,
- 0, 1, 1, 2);
- gtk_signal_connect (GTK_OBJECT (check_button), "toggled",
- GTK_SIGNAL_FUNC (toggle_resize),
- paned->child1);
-
- check_button = gtk_check_button_new_with_label ("Shrink");
- gtk_table_attach_defaults (GTK_TABLE (table), check_button,
- 0, 1, 2, 3);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check_button),
- TRUE);
- gtk_signal_connect (GTK_OBJECT (check_button), "toggled",
- GTK_SIGNAL_FUNC (toggle_shrink),
- paned->child1);
-
- label = gtk_label_new (label2);
- gtk_table_attach_defaults (GTK_TABLE (table), label,
- 1, 2, 0, 1);
-
- check_button = gtk_check_button_new_with_label ("Resize");
- gtk_table_attach_defaults (GTK_TABLE (table), check_button,
- 1, 2, 1, 2);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check_button),
- TRUE);
- gtk_signal_connect (GTK_OBJECT (check_button), "toggled",
- GTK_SIGNAL_FUNC (toggle_resize),
- paned->child2);
-
- check_button = gtk_check_button_new_with_label ("Shrink");
- gtk_table_attach_defaults (GTK_TABLE (table), check_button,
- 1, 2, 2, 3);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (check_button),
- TRUE);
- gtk_signal_connect (GTK_OBJECT (check_button), "toggled",
- GTK_SIGNAL_FUNC (toggle_shrink),
- paned->child2);
-
- return frame;
-}
-
-void
-create_panes (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *frame;
- GtkWidget *hpaned;
- GtkWidget *vpaned;
- GtkWidget *button;
- GtkWidget *vbox;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Panes");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), vbox);
-
- vpaned = gtk_vpaned_new ();
- gtk_box_pack_start (GTK_BOX (vbox), vpaned, TRUE, TRUE, 0);
- gtk_container_set_border_width (GTK_CONTAINER(vpaned), 5);
-
- hpaned = gtk_hpaned_new ();
- gtk_paned_add1 (GTK_PANED (vpaned), hpaned);
-
- frame = gtk_frame_new (NULL);
- gtk_frame_set_shadow_type (GTK_FRAME(frame), GTK_SHADOW_IN);
- gtk_widget_set_usize (frame, 60, 60);
- gtk_paned_add1 (GTK_PANED (hpaned), frame);
-
- button = gtk_button_new_with_label ("Hi there");
- gtk_container_add (GTK_CONTAINER(frame), button);
-
- frame = gtk_frame_new (NULL);
- gtk_frame_set_shadow_type (GTK_FRAME(frame), GTK_SHADOW_IN);
- gtk_widget_set_usize (frame, 80, 60);
- gtk_paned_add2 (GTK_PANED (hpaned), frame);
-
- frame = gtk_frame_new (NULL);
- gtk_frame_set_shadow_type (GTK_FRAME(frame), GTK_SHADOW_IN);
- gtk_widget_set_usize (frame, 60, 80);
- gtk_paned_add2 (GTK_PANED (vpaned), frame);
-
- /* Now create toggle buttons to control sizing */
-
- gtk_box_pack_start (GTK_BOX (vbox),
- create_pane_options (GTK_PANED (hpaned),
- "Horizontal",
- "Left",
- "Right"),
- FALSE, FALSE, 0);
-
- gtk_box_pack_start (GTK_BOX (vbox),
- create_pane_options (GTK_PANED (vpaned),
- "Vertical",
- "Top",
- "Bottom"),
- FALSE, FALSE, 0);
-
- gtk_widget_show_all (vbox);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Drag -N- Drop
- */
-
-#if 0
-gint
-dnd_drop_destroy_popup (GtkWidget *widget, GtkWindow **window)
-{
- if(GTK_IS_BUTTON(widget)) /* I.e. they clicked the close button */
- gtk_widget_destroy(GTK_WIDGET(*window));
- else {
- gtk_grab_remove(GTK_WIDGET(*window));
- *window = NULL;
- }
-
- return FALSE;
-}
-
-void
-dnd_drop (GtkWidget *button, GdkEvent *event)
-{
- static GtkWidget *window = NULL;
- GtkWidget *vbox, *lbl, *btn;
- gchar *msg;
-
- /* DND doesn't obey gtk_grab's, so check if we're already displaying
- * drop modal dialog first
- */
- if (window)
- return;
-
- window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
- gtk_container_set_border_width (GTK_CONTAINER(window), 10);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(dnd_drop_destroy_popup),
- &window);
- gtk_signal_connect (GTK_OBJECT (window), "delete-event",
- GTK_SIGNAL_FUNC(gtk_false),
- &window);
-
- vbox = gtk_vbox_new(FALSE, 5);
-
- /* Display message that we got from drop source */
- msg = g_malloc(strlen(event->dropdataavailable.data)
- + strlen(event->dropdataavailable.data_type) + 100);
- sprintf(msg, "Drop data of type %s was:\n\n%s",
- event->dropdataavailable.data_type,
- (char *)event->dropdataavailable.data);
- lbl = gtk_label_new(msg);
- gtk_label_set_justify(GTK_LABEL(lbl), GTK_JUSTIFY_FILL);
- g_free(msg);
- gtk_widget_show(lbl);
- gtk_box_pack_start_defaults(GTK_BOX(vbox), lbl);
-
- /* Provide an obvious way out of this heinousness */
- btn = gtk_button_new_with_label("Continue with life in\nspite of this oppression");
- gtk_signal_connect_object (GTK_OBJECT (btn), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_widget_show(btn);
- gtk_box_pack_start_defaults(GTK_BOX(vbox), btn);
-
- gtk_container_add(GTK_CONTAINER(window), vbox);
-
- gtk_widget_show(vbox);
- gtk_grab_add(window);
- gtk_widget_show(window);
-}
-
-void
-dnd_drag_request (GtkWidget *button, GdkEvent *event)
-{
-#define DND_STRING "Bill Gates demands royalties for\nyour use of his innovation."
- gtk_widget_dnd_data_set (button, event, DND_STRING, strlen(DND_STRING) + 1);
-}
-
-void
-create_dnd (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *box3;
- GtkWidget *frame;
- GtkWidget *button;
- GtkWidget *separator;
-
- /* For clarity... */
- char *possible_drag_types[] = {"text/plain"};
- char *accepted_drop_types[] = {"text/plain"};
-
- static GtkWidget *drag_icon = NULL;
- static GtkWidget *drop_icon = NULL;
-
- if (!window)
- {
- GdkPoint hotspot = {5,5};
-
- if (!drag_icon)
- {
- drag_icon = shape_create_icon ("Modeller.xpm",
- 440, 140, 0,0, GTK_WINDOW_POPUP);
-
- gtk_signal_connect (GTK_OBJECT (drag_icon), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &drag_icon);
-
- gtk_widget_hide (drag_icon);
- }
-
- if (!drop_icon)
- {
- drop_icon = shape_create_icon ("3DRings.xpm",
- 440, 140, 0,0, GTK_WINDOW_POPUP);
-
- gtk_signal_connect (GTK_OBJECT (drop_icon), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &drop_icon);
-
- gtk_widget_hide (drop_icon);
- }
-
- gdk_dnd_set_drag_shape(drag_icon->window,
- &hotspot,
- drop_icon->window,
- &hotspot);
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Drag -N- Drop");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
- gtk_widget_show (box1);
-
- box2 = gtk_hbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, TRUE, TRUE, 0);
- gtk_widget_show (box2);
-
- frame = gtk_frame_new ("Drag");
- gtk_box_pack_start (GTK_BOX (box2), frame, TRUE, TRUE, 0);
- gtk_widget_show (frame);
-
- box3 = gtk_vbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (box3), 5);
- gtk_container_add (GTK_CONTAINER (frame), box3);
- gtk_widget_show (box3);
-
- /*
- * FROM Button
- */
- button = gtk_button_new_with_label ("Drag me!");
- gtk_box_pack_start (GTK_BOX (box3), button, FALSE, TRUE, 0);
- gtk_widget_show (button);
-
- /*
- * currently, the widget has to be realized to
- * set dnd on it, this needs to change
- */
- gtk_widget_realize (button);
- gtk_signal_connect (GTK_OBJECT (button),
- "drag_request_event",
- GTK_SIGNAL_FUNC(dnd_drag_request),
- button);
-
- gtk_widget_dnd_drag_set (button, TRUE, possible_drag_types, 1);
-
-
- frame = gtk_frame_new ("Drop");
- gtk_box_pack_start (GTK_BOX (box2), frame, TRUE, TRUE, 0);
- gtk_widget_show (frame);
-
- box3 = gtk_vbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (box3), 5);
- gtk_container_add (GTK_CONTAINER (frame), box3);
- gtk_widget_show (box3);
-
-
- /*
- * TO Button
- */
- button = gtk_button_new_with_label ("To");
- gtk_box_pack_start (GTK_BOX (box3), button, FALSE, TRUE, 0);
- gtk_widget_show (button);
-
- gtk_widget_realize (button);
- gtk_signal_connect (GTK_OBJECT (button),
- "drop_data_available_event",
- GTK_SIGNAL_FUNC(dnd_drop),
- button);
-
- gtk_widget_dnd_drop_set (button, TRUE, accepted_drop_types, 1, FALSE);
-
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
- gtk_widget_show (separator);
-
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
- gtk_widget_show (box2);
-
-
- button = gtk_button_new_with_label ("close");
-
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
-
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-#endif
-
-/*
- * Shaped Windows
- */
-
-typedef struct _cursoroffset {gint x,y;} CursorOffset;
-
-static void
-shape_pressed (GtkWidget *widget, GdkEventButton *event)
-{
- CursorOffset *p;
-
- /* ignore double and triple click */
- if (event->type != GDK_BUTTON_PRESS)
- return;
-
- p = gtk_object_get_user_data (GTK_OBJECT(widget));
- p->x = (int) event->x;
- p->y = (int) event->y;
-
- gtk_grab_add (widget);
- gdk_pointer_grab (widget->window, TRUE,
- GDK_BUTTON_RELEASE_MASK |
- GDK_BUTTON_MOTION_MASK |
- GDK_POINTER_MOTION_HINT_MASK,
- NULL, NULL, 0);
-}
-
-static void
-shape_released (GtkWidget *widget)
-{
- gtk_grab_remove (widget);
- gdk_pointer_ungrab (0);
-}
-
-static void
-shape_motion (GtkWidget *widget,
- GdkEventMotion *event)
-{
- gint xp, yp;
- CursorOffset * p;
- GdkModifierType mask;
-
- p = gtk_object_get_user_data (GTK_OBJECT (widget));
-
- /*
- * Can't use event->x / event->y here
- * because I need absolute coordinates.
- */
- gdk_window_get_pointer (NULL, &xp, &yp, &mask);
- gtk_widget_set_uposition (widget, xp - p->x, yp - p->y);
-}
-
-GtkWidget *
-shape_create_icon (char *xpm_file,
- gint x,
- gint y,
- gint px,
- gint py,
- gint window_type)
-{
- GtkWidget *window;
- GtkWidget *pixmap;
- GtkWidget *fixed;
- CursorOffset* icon_pos;
- GdkGC* gc;
- GdkBitmap *gdk_pixmap_mask;
- GdkPixmap *gdk_pixmap;
- GtkStyle *style;
-
- style = gtk_widget_get_default_style ();
- gc = style->black_gc;
-
- /*
- * GDK_WINDOW_TOPLEVEL works also, giving you a title border
- */
- window = gtk_window_new (window_type);
-
- fixed = gtk_fixed_new ();
- gtk_widget_set_usize (fixed, 100,100);
- gtk_container_add (GTK_CONTAINER (window), fixed);
- gtk_widget_show (fixed);
-
- gtk_widget_set_events (window,
- gtk_widget_get_events (window) |
- GDK_BUTTON_MOTION_MASK |
- GDK_POINTER_MOTION_HINT_MASK |
- GDK_BUTTON_PRESS_MASK);
-
- gtk_widget_realize (window);
- gdk_pixmap = gdk_pixmap_create_from_xpm (window->window, &gdk_pixmap_mask,
- &style->bg[GTK_STATE_NORMAL],
- xpm_file);
-
- pixmap = gtk_pixmap_new (gdk_pixmap, gdk_pixmap_mask);
- gtk_fixed_put (GTK_FIXED (fixed), pixmap, px,py);
- gtk_widget_show (pixmap);
-
- gtk_widget_shape_combine_mask (window, gdk_pixmap_mask, px, py);
-
- gdk_drawable_unref (gdk_pixmap_mask);
- gdk_drawable_unref (gdk_pixmap);
-
- gtk_signal_connect (GTK_OBJECT (window), "button_press_event",
- GTK_SIGNAL_FUNC (shape_pressed),NULL);
- gtk_signal_connect (GTK_OBJECT (window), "button_release_event",
- GTK_SIGNAL_FUNC (shape_released),NULL);
- gtk_signal_connect (GTK_OBJECT (window), "motion_notify_event",
- GTK_SIGNAL_FUNC (shape_motion),NULL);
-
- icon_pos = g_new (CursorOffset, 1);
- gtk_object_set_user_data(GTK_OBJECT(window), icon_pos);
-
- gtk_widget_set_uposition (window, x, y);
- gtk_widget_show (window);
-
- return window;
-}
-
-void
-create_shapes (void)
-{
- /* Variables used by the Drag/Drop and Shape Window demos */
- static GtkWidget *modeller = NULL;
- static GtkWidget *sheets = NULL;
- static GtkWidget *rings = NULL;
- static GtkWidget *with_region = NULL;
-
- if (!(file_exists ("Modeller.xpm") &&
- file_exists ("FilesQueue.xpm") &&
- file_exists ("3DRings.xpm")))
- return;
-
-
- if (!modeller)
- {
- modeller = shape_create_icon ("Modeller.xpm",
- 440, 140, 0,0, GTK_WINDOW_POPUP);
-
- gtk_signal_connect (GTK_OBJECT (modeller), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &modeller);
- }
- else
- gtk_widget_destroy (modeller);
-
- if (!sheets)
- {
- sheets = shape_create_icon ("FilesQueue.xpm",
- 580, 170, 0,0, GTK_WINDOW_POPUP);
-
- gtk_signal_connect (GTK_OBJECT (sheets), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &sheets);
-
- }
- else
- gtk_widget_destroy (sheets);
-
- if (!rings)
- {
- rings = shape_create_icon ("3DRings.xpm",
- 460, 270, 25,25, GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (rings), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &rings);
- }
- else
- gtk_widget_destroy (rings);
-
- if (!with_region)
- {
- GdkRegion *region;
- gint x, y;
-
- with_region = shape_create_icon ("3DRings.xpm",
- 460, 270, 25,25, GTK_WINDOW_TOPLEVEL);
-
- gtk_window_set_decorated (GTK_WINDOW (with_region), FALSE);
-
- gtk_signal_connect (GTK_OBJECT (with_region), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &with_region);
-
- /* reset shape from mask to a region */
- x = 0;
- y = 0;
- region = gdk_region_new ();
-
- while (x < 460)
- {
- while (y < 270)
- {
- GdkRectangle rect;
- rect.x = x;
- rect.y = y;
- rect.width = 10;
- rect.height = 10;
-
- gdk_region_union_with_rect (region, &rect);
-
- y += 20;
- }
- y = 0;
- x += 20;
- }
-
- gdk_window_shape_combine_region (with_region->window,
- region,
- 0, 0);
- }
- else
- gtk_widget_destroy (with_region);
-}
-
-/*
- * WM Hints demo
- */
-
-void
-create_wmhints (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *label;
- GtkWidget *separator;
- GtkWidget *button;
- GtkWidget *box1;
- GtkWidget *box2;
-
- GdkBitmap *circles;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "WM Hints");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- gtk_widget_realize (window);
-
- circles = gdk_bitmap_create_from_data (window->window,
- circles_bits,
- circles_width,
- circles_height);
- gdk_window_set_icon (window->window, NULL,
- circles, circles);
-
- gdk_window_set_icon_name (window->window, "WMHints Test Icon");
-
- gdk_window_set_decorations (window->window, GDK_DECOR_ALL | GDK_DECOR_MENU);
- gdk_window_set_functions (window->window, GDK_FUNC_ALL | GDK_FUNC_RESIZE);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
- gtk_widget_show (box1);
-
- label = gtk_label_new ("Try iconizing me!");
- gtk_widget_set_usize (label, 150, 50);
- gtk_box_pack_start (GTK_BOX (box1), label, TRUE, TRUE, 0);
- gtk_widget_show (label);
-
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
- gtk_widget_show (separator);
-
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
- gtk_widget_show (box2);
-
-
- button = gtk_button_new_with_label ("close");
-
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
-
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-
-/*
- * Window state tracking
- */
-
-static gint
-window_state_callback (GtkWidget *widget,
- GdkEventWindowState *event,
- gpointer data)
-{
- GtkWidget *label = data;
- gchar *msg;
-
- msg = g_strconcat (GTK_WINDOW (widget)->title, ": ",
- (event->new_window_state & GDK_WINDOW_STATE_WITHDRAWN) ?
- "withdrawn" : "not withdrawn", ", ",
- (event->new_window_state & GDK_WINDOW_STATE_ICONIFIED) ?
- "iconified" : "not iconified", ", ",
- (event->new_window_state & GDK_WINDOW_STATE_STICKY) ?
- "sticky" : "not sticky", ", ",
- (event->new_window_state & GDK_WINDOW_STATE_MAXIMIZED) ?
- "maximized" : "not maximized",
- NULL);
-
- gtk_label_set_text (GTK_LABEL (label), msg);
-
- g_free (msg);
-
- return FALSE;
-}
-
-static GtkWidget*
-tracking_label (GtkWidget *window)
-{
- GtkWidget *label;
- GtkWidget *hbox;
- GtkWidget *button;
-
- hbox = gtk_hbox_new (FALSE, 5);
-
- gtk_signal_connect_object (GTK_OBJECT (hbox),
- "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (window));
-
- label = gtk_label_new ("<no window state events received>");
- gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
-
- gtk_signal_connect (GTK_OBJECT (window),
- "window_state_event",
- GTK_SIGNAL_FUNC (window_state_callback),
- label);
-
- button = gtk_button_new_with_label ("Deiconify");
- gtk_signal_connect_object (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_window_deiconify),
- GTK_OBJECT (window));
- gtk_box_pack_end (GTK_BOX (hbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Iconify");
- gtk_signal_connect_object (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_window_iconify),
- GTK_OBJECT (window));
- gtk_box_pack_end (GTK_BOX (hbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Present");
- gtk_signal_connect_object (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_window_present),
- GTK_OBJECT (window));
- gtk_box_pack_end (GTK_BOX (hbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Show");
- gtk_signal_connect_object (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_show),
- GTK_OBJECT (window));
- gtk_box_pack_end (GTK_BOX (hbox), button, FALSE, FALSE, 0);
-
- gtk_widget_show_all (hbox);
-
- return hbox;
-}
-
-static GtkWidget*
-get_state_controls (GtkWidget *window)
-{
- GtkWidget *vbox;
- GtkWidget *button;
-
- vbox = gtk_vbox_new (FALSE, 0);
-
- button = gtk_button_new_with_label ("Stick");
- gtk_signal_connect_object (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_window_stick),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Unstick");
- gtk_signal_connect_object (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_window_unstick),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Maximize");
- gtk_signal_connect_object (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_window_maximize),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Unmaximize");
- gtk_signal_connect_object (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_window_unmaximize),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Iconify");
- gtk_signal_connect_object (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_window_iconify),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Hide (withdraw)");
- gtk_signal_connect_object (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_hide),
- GTK_OBJECT (window));
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- gtk_widget_show_all (vbox);
-
- return vbox;
-}
-
-void
-create_window_states (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *label;
- GtkWidget *box1;
- GtkWidget *iconified;
- GtkWidget *normal;
- GtkWidget *controls;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Window states");
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- iconified = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_iconify (GTK_WINDOW (iconified));
- gtk_window_set_title (GTK_WINDOW (iconified), "Iconified initially");
- controls = get_state_controls (iconified);
- gtk_container_add (GTK_CONTAINER (iconified), controls);
-
- normal = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title (GTK_WINDOW (normal), "Deiconified initially");
- controls = get_state_controls (normal);
- gtk_container_add (GTK_CONTAINER (normal), controls);
-
- label = tracking_label (iconified);
- gtk_container_add (GTK_CONTAINER (box1), label);
-
- label = tracking_label (normal);
- gtk_container_add (GTK_CONTAINER (box1), label);
-
- gtk_widget_show_all (iconified);
- gtk_widget_show_all (normal);
- gtk_widget_show_all (box1);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Window sizing
- */
-
-static gint
-configure_event_callback (GtkWidget *widget,
- GdkEventConfigure *event,
- gpointer data)
-{
- GtkWidget *label = data;
- gchar *msg;
- gint x, y;
-
- x = widget->allocation.x;
- y = widget->allocation.y;
-
- msg = g_strdup_printf ("event: %d,%d %d x %d\n"
- "location: %d, %d",
- event->x, event->y, event->width, event->height,
- x, y);
-
- gtk_label_set_text (GTK_LABEL (label), msg);
-
- g_free (msg);
-
- return FALSE;
-}
-
-static void
-get_ints (GtkWidget *window,
- gint *a,
- gint *b)
-{
- GtkWidget *spin1;
- GtkWidget *spin2;
-
- spin1 = g_object_get_data (G_OBJECT (window), "spin1");
- spin2 = g_object_get_data (G_OBJECT (window), "spin2");
-
- *a = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spin1));
- *b = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (spin2));
-}
-
-static void
-set_size_callback (GtkWidget *widget,
- gpointer data)
-{
- gint w, h;
-
- get_ints (data, &w, &h);
-
- gtk_window_set_default_size (GTK_WINDOW (g_object_get_data (data, "target")), w, h);
-}
-
-static void
-set_default_size_callback (GtkWidget *widget,
- gpointer data)
-{
- gint w, h;
-
- get_ints (data, &w, &h);
-
- gtk_window_set_default_size (g_object_get_data (data, "target"),
- w, h);
-}
-
-static void
-set_usize_callback (GtkWidget *widget,
- gpointer data)
-{
- gint w, h;
-
- get_ints (data, &w, &h);
-
- gtk_widget_set_usize (g_object_get_data (data, "target"),
- w, h);
-}
-
-static void
-set_location_callback (GtkWidget *widget,
- gpointer data)
-{
- gint x, y;
-
- get_ints (data, &x, &y);
-
- gtk_widget_set_uposition (g_object_get_data (data, "target"), x, y);
-}
-
-static void
-allow_shrink_callback (GtkWidget *widget,
- gpointer data)
-{
- g_object_set (G_OBJECT (g_object_get_data (data, "target")),
- "allow_shrink",
- GTK_TOGGLE_BUTTON (widget)->active,
- NULL);
-}
-
-static void
-allow_grow_callback (GtkWidget *widget,
- gpointer data)
-{
- g_object_set (G_OBJECT (g_object_get_data (data, "target")),
- "allow_grow",
- GTK_TOGGLE_BUTTON (widget)->active,
- NULL);
-}
-
-static void
-auto_shrink_callback (GtkWidget *widget,
- gpointer data)
-{
- g_object_set (G_OBJECT (g_object_get_data (data, "target")),
- "auto_shrink",
- GTK_TOGGLE_BUTTON (widget)->active,
- NULL);
-}
-
-static void
-gravity_selected (GtkWidget *widget,
- gpointer data)
-{
- gtk_window_set_gravity (GTK_WINDOW (g_object_get_data (data, "target")),
- gtk_option_menu_get_history (GTK_OPTION_MENU (widget)) + GDK_GRAVITY_NORTH_WEST);
-}
-
-static GtkWidget*
-window_controls (GtkWidget *window)
-{
- GtkWidget *control_window;
- GtkWidget *label;
- GtkWidget *vbox;
- GtkWidget *button;
- GtkWidget *spin;
- GtkAdjustment *adj;
- GtkWidget *om;
- GtkWidget *menu;
- gint i;
-
- control_window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_window_set_title (GTK_WINDOW (control_window), "Size controls");
-
- g_object_set_data (G_OBJECT (control_window),
- "target",
- window);
-
- gtk_signal_connect_object (GTK_OBJECT (control_window),
- "destroy",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (window));
-
- vbox = gtk_vbox_new (FALSE, 5);
-
- gtk_container_add (GTK_CONTAINER (control_window), vbox);
-
- label = gtk_label_new ("<no configure events>");
- gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
-
- gtk_signal_connect (GTK_OBJECT (window),
- "configure_event",
- GTK_SIGNAL_FUNC (configure_event_callback),
- label);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (10.0, -3.0, 800.0, 1.0,
- 5.0, 0.0);
- spin = gtk_spin_button_new (adj, 0, 0);
-
- gtk_box_pack_start (GTK_BOX (vbox), spin, FALSE, FALSE, 0);
-
- g_object_set_data (G_OBJECT (control_window), "spin1", spin);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (10.0, -3.0, 800.0, 1.0,
- 5.0, 0.0);
- spin = gtk_spin_button_new (adj, 0, 0);
-
- gtk_box_pack_start (GTK_BOX (vbox), spin, FALSE, FALSE, 0);
-
- g_object_set_data (G_OBJECT (control_window), "spin2", spin);
-
- button = gtk_button_new_with_label ("Queue resize");
- gtk_signal_connect_object (GTK_WIDGET (button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_queue_resize),
- GTK_OBJECT (control_window));
- gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Set size");
- gtk_signal_connect (GTK_WIDGET (button),
- "clicked",
- GTK_SIGNAL_FUNC (set_size_callback),
- GTK_OBJECT (control_window));
- gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Set default size");
- gtk_signal_connect (GTK_WIDGET (button),
- "clicked",
- GTK_SIGNAL_FUNC (set_default_size_callback),
- GTK_OBJECT (control_window));
- gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Set usize");
- gtk_signal_connect (GTK_WIDGET (button),
- "clicked",
- GTK_SIGNAL_FUNC (set_usize_callback),
- GTK_OBJECT (control_window));
- gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Set location");
- gtk_signal_connect (GTK_WIDGET (button),
- "clicked",
- GTK_SIGNAL_FUNC (set_location_callback),
- GTK_OBJECT (control_window));
- gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_check_button_new_with_label ("Allow shrink");
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), FALSE);
- gtk_signal_connect (GTK_WIDGET (button),
- "toggled",
- GTK_SIGNAL_FUNC (allow_shrink_callback),
- GTK_OBJECT (control_window));
- gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_check_button_new_with_label ("Allow grow");
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), TRUE);
- gtk_signal_connect (GTK_WIDGET (button),
- "toggled",
- GTK_SIGNAL_FUNC (allow_grow_callback),
- GTK_OBJECT (control_window));
- gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- button = gtk_check_button_new_with_label ("Auto shrink");
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (button), FALSE);
- gtk_signal_connect (GTK_WIDGET (button),
- "toggled",
- GTK_SIGNAL_FUNC (auto_shrink_callback),
- GTK_OBJECT (control_window));
- gtk_box_pack_end (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- menu = gtk_menu_new ();
-
- i = 0;
- while (i < 10)
- {
- GtkWidget *mi;
- static gchar *names[] = {
- "GDK_GRAVITY_NORTH_WEST",
- "GDK_GRAVITY_NORTH",
- "GDK_GRAVITY_NORTH_EAST",
- "GDK_GRAVITY_WEST",
- "GDK_GRAVITY_CENTER",
- "GDK_GRAVITY_EAST",
- "GDK_GRAVITY_SOUTH_WEST",
- "GDK_GRAVITY_SOUTH",
- "GDK_GRAVITY_SOUTH_EAST",
- "GDK_GRAVITY_STATIC",
- NULL
- };
-
- g_assert (names[i]);
-
- mi = gtk_menu_item_new_with_label (names[i]);
-
- gtk_menu_shell_append (GTK_MENU_SHELL (menu), mi);
-
- ++i;
- }
-
- gtk_widget_show_all (menu);
-
- om = gtk_option_menu_new ();
- gtk_option_menu_set_menu (GTK_OPTION_MENU (om), menu);
-
-
- gtk_signal_connect (GTK_OBJECT (om),
- "changed",
- GTK_SIGNAL_FUNC (gravity_selected),
- control_window);
-
- gtk_box_pack_end (GTK_BOX (vbox), om, FALSE, FALSE, 0);
-
- gtk_widget_show_all (vbox);
-
- return control_window;
-}
-
-void
-create_window_sizing (void)
-{
- static GtkWidget *window = NULL;
-
- if (!window)
- {
- GtkWidget *label;
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- label = gtk_label_new (NULL);
- gtk_label_set_markup (GTK_LABEL (label), "<span foreground=\"purple\"><big>Window being resized</big></span>\nBlah blah blah blah\nblah blah blah\nblah blah blah blah blah");
- gtk_container_add (GTK_CONTAINER (window), label);
- gtk_widget_show (label);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Window to size");
-
- gtk_widget_show (window_controls (window));
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * GtkProgressBar
- */
-
-typedef struct _ProgressData {
- GtkWidget *window;
- GtkWidget *pbar;
- GtkWidget *block_spin;
- GtkWidget *x_align_spin;
- GtkWidget *y_align_spin;
- GtkWidget *step_spin;
- GtkWidget *act_blocks_spin;
- GtkWidget *label;
- GtkWidget *omenu1;
- GtkWidget *omenu2;
- GtkWidget *entry;
- int timer;
-} ProgressData;
-
-gint
-progress_timeout (gpointer data)
-{
- gdouble new_val;
- GtkAdjustment *adj;
-
- adj = GTK_PROGRESS (data)->adjustment;
-
- new_val = adj->value + 1;
- if (new_val > adj->upper)
- new_val = adj->lower;
-
- gtk_progress_set_value (GTK_PROGRESS (data), new_val);
-
- return TRUE;
-}
-
-static void
-destroy_progress (GtkWidget *widget,
- ProgressData **pdata)
-{
- gtk_timeout_remove ((*pdata)->timer);
- (*pdata)->timer = 0;
- (*pdata)->window = NULL;
- g_free (*pdata);
- *pdata = NULL;
-}
-
-static void
-progressbar_toggle_orientation (GtkWidget *widget, ProgressData *pdata)
-{
- gint i;
-
- if (!GTK_WIDGET_MAPPED (widget))
- return;
-
- RADIOMENUTOGGLED ((GtkRadioMenuItem *)
- (((GtkOptionMenu *)(pdata->omenu1))->menu_item), i);
-
- gtk_progress_bar_set_orientation (GTK_PROGRESS_BAR (pdata->pbar),
- (GtkProgressBarOrientation) (3-i));
-}
-
-static void
-toggle_show_text (GtkWidget *widget, ProgressData *pdata)
-{
- gtk_progress_set_show_text (GTK_PROGRESS (pdata->pbar),
- GTK_TOGGLE_BUTTON (widget)->active);
- gtk_widget_set_sensitive (pdata->entry, GTK_TOGGLE_BUTTON (widget)->active);
- gtk_widget_set_sensitive (pdata->x_align_spin,
- GTK_TOGGLE_BUTTON (widget)->active);
- gtk_widget_set_sensitive (pdata->y_align_spin,
- GTK_TOGGLE_BUTTON (widget)->active);
-}
-
-static void
-progressbar_toggle_bar_style (GtkWidget *widget, ProgressData *pdata)
-{
- gint i;
-
- if (!GTK_WIDGET_MAPPED (widget))
- return;
-
- RADIOMENUTOGGLED ((GtkRadioMenuItem *)
- (((GtkOptionMenu *)(pdata->omenu2))->menu_item), i);
-
- i = 1 - i;
-
- if (i == 1)
- gtk_widget_set_sensitive (pdata->block_spin, TRUE);
- else
- gtk_widget_set_sensitive (pdata->block_spin, FALSE);
-
- gtk_progress_bar_set_bar_style (GTK_PROGRESS_BAR (pdata->pbar),
- (GtkProgressBarStyle) i);
-}
-
-static void
-progress_value_changed (GtkAdjustment *adj, ProgressData *pdata)
-{
- char buf[20];
-
- if (GTK_PROGRESS (pdata->pbar)->activity_mode)
- sprintf (buf, "???");
- else
- sprintf (buf, "%.0f%%", 100 *
- gtk_progress_get_current_percentage (GTK_PROGRESS (pdata->pbar)));
- gtk_label_set_text (GTK_LABEL (pdata->label), buf);
-}
-
-static void
-adjust_blocks (GtkAdjustment *adj, ProgressData *pdata)
-{
- gtk_progress_set_percentage (GTK_PROGRESS (pdata->pbar), 0);
- gtk_progress_bar_set_discrete_blocks (GTK_PROGRESS_BAR (pdata->pbar),
- gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (pdata->block_spin)));
-}
-
-static void
-adjust_step (GtkAdjustment *adj, ProgressData *pdata)
-{
- gtk_progress_bar_set_activity_step (GTK_PROGRESS_BAR (pdata->pbar),
- gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (pdata->step_spin)));
-}
-
-static void
-adjust_act_blocks (GtkAdjustment *adj, ProgressData *pdata)
-{
- gtk_progress_bar_set_activity_blocks (GTK_PROGRESS_BAR (pdata->pbar),
- gtk_spin_button_get_value_as_int
- (GTK_SPIN_BUTTON (pdata->act_blocks_spin)));
-}
-
-static void
-adjust_align (GtkAdjustment *adj, ProgressData *pdata)
-{
- gtk_progress_set_text_alignment (GTK_PROGRESS (pdata->pbar),
- gtk_spin_button_get_value_as_float
- (GTK_SPIN_BUTTON (pdata->x_align_spin)),
- gtk_spin_button_get_value_as_float
- (GTK_SPIN_BUTTON (pdata->y_align_spin)));
-}
-
-static void
-toggle_activity_mode (GtkWidget *widget, ProgressData *pdata)
-{
- gtk_progress_set_activity_mode (GTK_PROGRESS (pdata->pbar),
- GTK_TOGGLE_BUTTON (widget)->active);
- gtk_widget_set_sensitive (pdata->step_spin,
- GTK_TOGGLE_BUTTON (widget)->active);
- gtk_widget_set_sensitive (pdata->act_blocks_spin,
- GTK_TOGGLE_BUTTON (widget)->active);
-}
-
-static void
-entry_changed (GtkWidget *widget, ProgressData *pdata)
-{
- gtk_progress_set_format_string (GTK_PROGRESS (pdata->pbar),
- gtk_entry_get_text (GTK_ENTRY (pdata->entry)));
-}
-
-void
-create_progress_bar (void)
-{
- GtkWidget *button;
- GtkWidget *vbox;
- GtkWidget *vbox2;
- GtkWidget *hbox;
- GtkWidget *check;
- GtkWidget *frame;
- GtkWidget *tab;
- GtkWidget *label;
- GtkWidget *align;
- GtkAdjustment *adj;
- static ProgressData *pdata = NULL;
-
- static OptionMenuItem items1[] =
- {
- { "Left-Right", GTK_SIGNAL_FUNC (progressbar_toggle_orientation) },
- { "Right-Left", GTK_SIGNAL_FUNC (progressbar_toggle_orientation) },
- { "Bottom-Top", GTK_SIGNAL_FUNC (progressbar_toggle_orientation) },
- { "Top-Bottom", GTK_SIGNAL_FUNC (progressbar_toggle_orientation) }
- };
-
- static OptionMenuItem items2[] =
- {
- { "Continuous", GTK_SIGNAL_FUNC (progressbar_toggle_bar_style) },
- { "Discrete", GTK_SIGNAL_FUNC (progressbar_toggle_bar_style) }
- };
-
- if (!pdata)
- pdata = g_new0 (ProgressData, 1);
-
- if (!pdata->window)
- {
- pdata->window = gtk_dialog_new ();
-
- gtk_window_set_policy (GTK_WINDOW (pdata->window), FALSE, FALSE, TRUE);
-
- gtk_signal_connect (GTK_OBJECT (pdata->window), "destroy",
- GTK_SIGNAL_FUNC (destroy_progress),
- &pdata);
-
- pdata->timer = 0;
-
- gtk_window_set_title (GTK_WINDOW (pdata->window), "GtkProgressBar");
- gtk_container_set_border_width (GTK_CONTAINER (pdata->window), 0);
-
- vbox = gtk_vbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (vbox), 10);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (pdata->window)->vbox),
- vbox, FALSE, TRUE, 0);
-
- frame = gtk_frame_new ("Progress");
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, TRUE, 0);
-
- vbox2 = gtk_vbox_new (FALSE, 5);
- gtk_container_add (GTK_CONTAINER (frame), vbox2);
-
- align = gtk_alignment_new (0.5, 0.5, 0, 0);
- gtk_box_pack_start (GTK_BOX (vbox2), align, FALSE, FALSE, 5);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (0, 1, 300, 0, 0, 0);
- gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
- GTK_SIGNAL_FUNC (progress_value_changed), pdata);
-
- pdata->pbar = gtk_progress_bar_new_with_adjustment (adj);
- gtk_progress_set_format_string (GTK_PROGRESS (pdata->pbar),
- "%v from [%l,%u] (=%p%%)");
- gtk_container_add (GTK_CONTAINER (align), pdata->pbar);
- pdata->timer = gtk_timeout_add (100, progress_timeout, pdata->pbar);
-
- align = gtk_alignment_new (0.5, 0.5, 0, 0);
- gtk_box_pack_start (GTK_BOX (vbox2), align, FALSE, FALSE, 5);
-
- hbox = gtk_hbox_new (FALSE, 5);
- gtk_container_add (GTK_CONTAINER (align), hbox);
- label = gtk_label_new ("Label updated by user :");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
- pdata->label = gtk_label_new ("");
- gtk_box_pack_start (GTK_BOX (hbox), pdata->label, FALSE, TRUE, 0);
-
- frame = gtk_frame_new ("Options");
- gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, TRUE, 0);
-
- vbox2 = gtk_vbox_new (FALSE, 5);
- gtk_container_add (GTK_CONTAINER (frame), vbox2);
-
- tab = gtk_table_new (7, 2, FALSE);
- gtk_box_pack_start (GTK_BOX (vbox2), tab, FALSE, TRUE, 0);
-
- label = gtk_label_new ("Orientation :");
- gtk_table_attach (GTK_TABLE (tab), label, 0, 1, 0, 1,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
-
- pdata->omenu1 = build_option_menu (items1, 4, 0, pdata);
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 0, 1,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
- gtk_box_pack_start (GTK_BOX (hbox), pdata->omenu1, TRUE, TRUE, 0);
-
- check = gtk_check_button_new_with_label ("Show text");
- gtk_signal_connect (GTK_OBJECT (check), "clicked",
- GTK_SIGNAL_FUNC (toggle_show_text),
- pdata);
- gtk_table_attach (GTK_TABLE (tab), check, 0, 1, 1, 2,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 1, 2,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
-
- label = gtk_label_new ("Format : ");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
-
- pdata->entry = gtk_entry_new ();
- gtk_signal_connect (GTK_OBJECT (pdata->entry), "changed",
- GTK_SIGNAL_FUNC (entry_changed),
- pdata);
- gtk_box_pack_start (GTK_BOX (hbox), pdata->entry, TRUE, TRUE, 0);
- gtk_entry_set_text (GTK_ENTRY (pdata->entry), "%v from [%l,%u] (=%p%%)");
- gtk_widget_set_usize (pdata->entry, 100, -1);
- gtk_widget_set_sensitive (pdata->entry, FALSE);
-
- label = gtk_label_new ("Text align :");
- gtk_table_attach (GTK_TABLE (tab), label, 0, 1, 2, 3,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 2, 3,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
-
- label = gtk_label_new ("x :");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 5);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (0.5, 0, 1, 0.1, 0.1, 0);
- pdata->x_align_spin = gtk_spin_button_new (adj, 0, 1);
- gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
- GTK_SIGNAL_FUNC (adjust_align), pdata);
- gtk_box_pack_start (GTK_BOX (hbox), pdata->x_align_spin, FALSE, TRUE, 0);
- gtk_widget_set_sensitive (pdata->x_align_spin, FALSE);
-
- label = gtk_label_new ("y :");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 5);
-
- adj = (GtkAdjustment *) gtk_adjustment_new (0.5, 0, 1, 0.1, 0.1, 0);
- pdata->y_align_spin = gtk_spin_button_new (adj, 0, 1);
- gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
- GTK_SIGNAL_FUNC (adjust_align), pdata);
- gtk_box_pack_start (GTK_BOX (hbox), pdata->y_align_spin, FALSE, TRUE, 0);
- gtk_widget_set_sensitive (pdata->y_align_spin, FALSE);
-
- label = gtk_label_new ("Bar Style :");
- gtk_table_attach (GTK_TABLE (tab), label, 0, 1, 3, 4,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
-
- pdata->omenu2 = build_option_menu (items2, 2, 0, pdata);
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 3, 4,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
- gtk_box_pack_start (GTK_BOX (hbox), pdata->omenu2, TRUE, TRUE, 0);
-
- label = gtk_label_new ("Block count :");
- gtk_table_attach (GTK_TABLE (tab), label, 0, 1, 4, 5,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0.5);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 4, 5,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
- adj = (GtkAdjustment *) gtk_adjustment_new (10, 2, 20, 1, 5, 0);
- pdata->block_spin = gtk_spin_button_new (adj, 0, 0);
- gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
- GTK_SIGNAL_FUNC (adjust_blocks), pdata);
- gtk_box_pack_start (GTK_BOX (hbox), pdata->block_spin, FALSE, TRUE, 0);
- gtk_widget_set_sensitive (pdata->block_spin, FALSE);
-
- check = gtk_check_button_new_with_label ("Activity mode");
- gtk_signal_connect (GTK_OBJECT (check), "clicked",
- GTK_SIGNAL_FUNC (toggle_activity_mode),
- pdata);
- gtk_table_attach (GTK_TABLE (tab), check, 0, 1, 5, 6,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 5, 6,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
- label = gtk_label_new ("Step size : ");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
- adj = (GtkAdjustment *) gtk_adjustment_new (3, 1, 20, 1, 5, 0);
- pdata->step_spin = gtk_spin_button_new (adj, 0, 0);
- gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
- GTK_SIGNAL_FUNC (adjust_step), pdata);
- gtk_box_pack_start (GTK_BOX (hbox), pdata->step_spin, FALSE, TRUE, 0);
- gtk_widget_set_sensitive (pdata->step_spin, FALSE);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_table_attach (GTK_TABLE (tab), hbox, 1, 2, 6, 7,
- GTK_EXPAND | GTK_FILL, GTK_EXPAND | GTK_FILL,
- 5, 5);
- label = gtk_label_new ("Blocks : ");
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, TRUE, 0);
- adj = (GtkAdjustment *) gtk_adjustment_new (5, 2, 10, 1, 5, 0);
- pdata->act_blocks_spin = gtk_spin_button_new (adj, 0, 0);
- gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
- GTK_SIGNAL_FUNC (adjust_act_blocks), pdata);
- gtk_box_pack_start (GTK_BOX (hbox), pdata->act_blocks_spin, FALSE, TRUE,
- 0);
- gtk_widget_set_sensitive (pdata->act_blocks_spin, FALSE);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (pdata->window));
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (pdata->window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_grab_default (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (pdata->window))
- gtk_widget_show_all (pdata->window);
- else
- gtk_widget_destroy (pdata->window);
-}
-
-/*
- * Color Preview
- */
-
-static int color_idle = 0;
-
-gint
-color_idle_func (GtkWidget *preview)
-{
- static int count = 1;
- guchar buf[768];
- int i, j, k;
-
- for (i = 0; i < 256; i++)
- {
- for (j = 0, k = 0; j < 256; j++)
- {
- buf[k+0] = i + count;
- buf[k+1] = 0;
- buf[k+2] = j + count;
- k += 3;
- }
-
- gtk_preview_draw_row (GTK_PREVIEW (preview), buf, 0, i, 256);
- }
-
- count += 1;
-
- gtk_widget_draw (preview, NULL);
-
- return TRUE;
-}
-
-static void
-color_preview_destroy (GtkWidget *widget,
- GtkWidget **window)
-{
- gtk_idle_remove (color_idle);
- color_idle = 0;
-
- *window = NULL;
-}
-
-void
-create_color_preview (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *preview;
- guchar buf[768];
- int i, j, k;
-
- if (!window)
- {
- gtk_widget_push_colormap (gdk_rgb_get_cmap ());
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_widget_pop_colormap ();
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(color_preview_destroy),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "test");
- gtk_container_set_border_width (GTK_CONTAINER (window), 10);
-
- preview = gtk_preview_new (GTK_PREVIEW_COLOR);
- gtk_preview_size (GTK_PREVIEW (preview), 256, 256);
- gtk_container_add (GTK_CONTAINER (window), preview);
-
- for (i = 0; i < 256; i++)
- {
- for (j = 0, k = 0; j < 256; j++)
- {
- buf[k+0] = i;
- buf[k+1] = 0;
- buf[k+2] = j;
- k += 3;
- }
-
- gtk_preview_draw_row (GTK_PREVIEW (preview), buf, 0, i, 256);
- }
-
- color_idle = gtk_idle_add ((GtkFunction) color_idle_func, preview);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Gray Preview
- */
-
-static int gray_idle = 0;
-
-gint
-gray_idle_func (GtkWidget *preview)
-{
- static int count = 1;
- guchar buf[256];
- int i, j;
-
- for (i = 0; i < 256; i++)
- {
- for (j = 0; j < 256; j++)
- buf[j] = i + j + count;
-
- gtk_preview_draw_row (GTK_PREVIEW (preview), buf, 0, i, 256);
- }
-
- count += 1;
-
- gtk_widget_draw (preview, NULL);
-
- return TRUE;
-}
-
-static void
-gray_preview_destroy (GtkWidget *widget,
- GtkWidget **window)
-{
- gtk_idle_remove (gray_idle);
- gray_idle = 0;
-
- *window = NULL;
-}
-
-void
-create_gray_preview (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *preview;
- guchar buf[256];
- int i, j;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gray_preview_destroy),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "test");
- gtk_container_set_border_width (GTK_CONTAINER (window), 10);
-
- preview = gtk_preview_new (GTK_PREVIEW_GRAYSCALE);
- gtk_preview_size (GTK_PREVIEW (preview), 256, 256);
- gtk_container_add (GTK_CONTAINER (window), preview);
-
- for (i = 0; i < 256; i++)
- {
- for (j = 0; j < 256; j++)
- buf[j] = i + j;
-
- gtk_preview_draw_row (GTK_PREVIEW (preview), buf, 0, i, 256);
- }
-
- gray_idle = gtk_idle_add ((GtkFunction) gray_idle_func, preview);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-
-/*
- * Selection Test
- */
-
-void
-selection_test_received (GtkWidget *list, GtkSelectionData *data)
-{
- GdkAtom *atoms;
- GtkWidget *list_item;
- GList *item_list;
- int i, l;
-
- if (data->length < 0)
- {
- g_print ("Selection retrieval failed\n");
- return;
- }
- if (data->type != GDK_SELECTION_TYPE_ATOM)
- {
- g_print ("Selection \"TARGETS\" was not returned as atoms!\n");
- return;
- }
-
- /* Clear out any current list items */
-
- gtk_list_clear_items (GTK_LIST(list), 0, -1);
-
- /* Add new items to list */
-
- atoms = (GdkAtom *)data->data;
-
- item_list = NULL;
- l = data->length / sizeof (GdkAtom);
- for (i = 0; i < l; i++)
- {
- char *name;
- name = gdk_atom_name (atoms[i]);
- if (name != NULL)
- {
- list_item = gtk_list_item_new_with_label (name);
- g_free (name);
- }
- else
- list_item = gtk_list_item_new_with_label ("(bad atom)");
-
- gtk_widget_show (list_item);
- item_list = g_list_append (item_list, list_item);
- }
-
- gtk_list_append_items (GTK_LIST (list), item_list);
-
- return;
-}
-
-void
-selection_test_get_targets (GtkWidget *widget, GtkWidget *list)
-{
- static GdkAtom targets_atom = GDK_NONE;
-
- if (targets_atom == GDK_NONE)
- targets_atom = gdk_atom_intern ("TARGETS", FALSE);
-
- gtk_selection_convert (list, GDK_SELECTION_PRIMARY, targets_atom,
- GDK_CURRENT_TIME);
-}
-
-void
-create_selection_test (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *button;
- GtkWidget *vbox;
- GtkWidget *scrolled_win;
- GtkWidget *list;
- GtkWidget *label;
-
- if (!window)
- {
- window = gtk_dialog_new ();
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Selection Test");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- /* Create the list */
-
- vbox = gtk_vbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (vbox), 10);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), vbox,
- TRUE, TRUE, 0);
-
- label = gtk_label_new ("Gets available targets for current selection");
- gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
-
- scrolled_win = gtk_scrolled_window_new (NULL, NULL);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_win),
- GTK_POLICY_AUTOMATIC,
- GTK_POLICY_AUTOMATIC);
- gtk_box_pack_start (GTK_BOX (vbox), scrolled_win, TRUE, TRUE, 0);
- gtk_widget_set_usize (scrolled_win, 100, 200);
-
- list = gtk_list_new ();
- gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (scrolled_win), list);
-
- gtk_signal_connect (GTK_OBJECT(list), "selection_received",
- GTK_SIGNAL_FUNC (selection_test_received), NULL);
-
- /* .. And create some buttons */
- button = gtk_button_new_with_label ("Get Targets");
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
-
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (selection_test_get_targets), list);
-
- button = gtk_button_new_with_label ("Quit");
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
-
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (window));
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Gamma Curve
- */
-
-void
-create_gamma_curve (void)
-{
- static GtkWidget *window = NULL, *curve;
- static int count = 0;
- gfloat vec[256];
- gint max;
- gint i;
-
- if (!window)
- {
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title (GTK_WINDOW (window), "test");
- gtk_container_set_border_width (GTK_CONTAINER (window), 10);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- curve = gtk_gamma_curve_new ();
- gtk_container_add (GTK_CONTAINER (window), curve);
- gtk_widget_show (curve);
- }
-
- max = 127 + (count % 2)*128;
- gtk_curve_set_range (GTK_CURVE (GTK_GAMMA_CURVE (curve)->curve),
- 0, max, 0, max);
- for (i = 0; i < max; ++i)
- vec[i] = (127 / sqrt (max)) * sqrt (i);
- gtk_curve_set_vector (GTK_CURVE (GTK_GAMMA_CURVE (curve)->curve),
- max, vec);
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else if (count % 4 == 3)
- {
- gtk_widget_destroy (window);
- window = NULL;
- }
-
- ++count;
-}
-
-/*
- * Test scrolling
- */
-
-static int scroll_test_pos = 0.0;
-
-static gint
-scroll_test_expose (GtkWidget *widget, GdkEventExpose *event,
- GtkAdjustment *adj)
-{
- gint i,j;
- gint imin, imax, jmin, jmax;
-
- imin = (event->area.x) / 10;
- imax = (event->area.x + event->area.width + 9) / 10;
-
- jmin = ((int)adj->value + event->area.y) / 10;
- jmax = ((int)adj->value + event->area.y + event->area.height + 9) / 10;
-
- gdk_window_clear_area (widget->window,
- event->area.x, event->area.y,
- event->area.width, event->area.height);
-
- for (i=imin; i<imax; i++)
- for (j=jmin; j<jmax; j++)
- if ((i+j) % 2)
- gdk_draw_rectangle (widget->window,
- widget->style->black_gc,
- TRUE,
- 10*i, 10*j - (int)adj->value, 1+i%10, 1+j%10);
-
- return TRUE;
-}
-
-static gint
-scroll_test_scroll (GtkWidget *widget, GdkEventScroll *event,
- GtkAdjustment *adj)
-{
- gdouble new_value = adj->value + ((event->direction == GDK_SCROLL_UP) ?
- -adj->page_increment / 2:
- adj->page_increment / 2);
- new_value = CLAMP (new_value, adj->lower, adj->upper - adj->page_size);
- gtk_adjustment_set_value (adj, new_value);
-
- return TRUE;
-}
-
-static void
-scroll_test_configure (GtkWidget *widget, GdkEventConfigure *event,
- GtkAdjustment *adj)
-{
- adj->page_increment = 0.9 * widget->allocation.height;
- adj->page_size = widget->allocation.height;
-
- gtk_signal_emit_by_name (GTK_OBJECT (adj), "changed");
-}
-
-static void
-scroll_test_adjustment_changed (GtkAdjustment *adj, GtkWidget *widget)
-{
- gint source_min = (int)adj->value - scroll_test_pos;
- gint dy;
-
- dy = scroll_test_pos - (int)adj->value;
- scroll_test_pos = adj->value;
-
- if (!GTK_WIDGET_DRAWABLE (widget))
- return;
- gdk_window_scroll (widget->window, 0, dy);
- gdk_window_process_updates (widget->window, FALSE);
-}
-
-
-void
-create_scroll_test (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *hbox;
- GtkWidget *drawing_area;
- GtkWidget *scrollbar;
- GtkWidget *button;
- GtkAdjustment *adj;
- GdkGeometry geometry;
- GdkWindowHints geometry_mask;
-
- if (!window)
- {
- window = gtk_dialog_new ();
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Scroll Test");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- hbox = gtk_hbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), hbox,
- TRUE, TRUE, 0);
- gtk_widget_show (hbox);
-
- drawing_area = gtk_drawing_area_new ();
- gtk_drawing_area_size (GTK_DRAWING_AREA (drawing_area), 200, 200);
- gtk_box_pack_start (GTK_BOX (hbox), drawing_area, TRUE, TRUE, 0);
- gtk_widget_show (drawing_area);
-
- gtk_widget_set_events (drawing_area, GDK_EXPOSURE_MASK | GDK_SCROLL_MASK);
-
- adj = GTK_ADJUSTMENT (gtk_adjustment_new (0.0, 0.0, 1000.0, 1.0, 180.0, 200.0));
- scroll_test_pos = 0.0;
-
- scrollbar = gtk_vscrollbar_new (adj);
- gtk_box_pack_start (GTK_BOX (hbox), scrollbar, FALSE, FALSE, 0);
- gtk_widget_show (scrollbar);
-
- gtk_signal_connect (GTK_OBJECT (drawing_area), "expose_event",
- GTK_SIGNAL_FUNC (scroll_test_expose), adj);
- gtk_signal_connect (GTK_OBJECT (drawing_area), "configure_event",
- GTK_SIGNAL_FUNC (scroll_test_configure), adj);
- gtk_signal_connect (GTK_OBJECT (drawing_area), "scroll_event",
- GTK_SIGNAL_FUNC (scroll_test_scroll), adj);
-
- gtk_signal_connect (GTK_OBJECT (adj), "value_changed",
- GTK_SIGNAL_FUNC (scroll_test_adjustment_changed),
- drawing_area);
-
- /* .. And create some buttons */
-
- button = gtk_button_new_with_label ("Quit");
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
-
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_widget_show (button);
-
- /* Set up gridded geometry */
-
- geometry_mask = GDK_HINT_MIN_SIZE |
- GDK_HINT_BASE_SIZE |
- GDK_HINT_RESIZE_INC;
-
- geometry.min_width = 20;
- geometry.min_height = 20;
- geometry.base_width = 0;
- geometry.base_height = 0;
- geometry.width_inc = 10;
- geometry.height_inc = 10;
-
- gtk_window_set_geometry_hints (GTK_WINDOW (window),
- drawing_area, &geometry, geometry_mask);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Timeout Test
- */
-
-static int timer = 0;
-
-gint
-timeout_test (GtkWidget *label)
-{
- static int count = 0;
- static char buffer[32];
-
- sprintf (buffer, "count: %d", ++count);
- gtk_label_set_text (GTK_LABEL (label), buffer);
-
- return TRUE;
-}
-
-void
-start_timeout_test (GtkWidget *widget,
- GtkWidget *label)
-{
- if (!timer)
- {
- timer = gtk_timeout_add (100, (GtkFunction) timeout_test, label);
- }
-}
-
-void
-stop_timeout_test (GtkWidget *widget,
- gpointer data)
-{
- if (timer)
- {
- gtk_timeout_remove (timer);
- timer = 0;
- }
-}
-
-void
-destroy_timeout_test (GtkWidget *widget,
- GtkWidget **window)
-{
- stop_timeout_test (NULL, NULL);
-
- *window = NULL;
-}
-
-void
-create_timeout_test (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *button;
- GtkWidget *label;
-
- if (!window)
- {
- window = gtk_dialog_new ();
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(destroy_timeout_test),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Timeout Test");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- label = gtk_label_new ("count: 0");
- gtk_misc_set_padding (GTK_MISC (label), 10, 10);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox),
- label, TRUE, TRUE, 0);
- gtk_widget_show (label);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("start");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(start_timeout_test),
- label);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("stop");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(stop_timeout_test),
- NULL);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Idle Test
- */
-
-static int idle_id = 0;
-
-static gint
-idle_test (GtkWidget *label)
-{
- static int count = 0;
- static char buffer[32];
-
- sprintf (buffer, "count: %d", ++count);
- gtk_label_set_text (GTK_LABEL (label), buffer);
-
- return TRUE;
-}
-
-static void
-start_idle_test (GtkWidget *widget,
- GtkWidget *label)
-{
- if (!idle_id)
- {
- idle_id = gtk_idle_add ((GtkFunction) idle_test, label);
- }
-}
-
-static void
-stop_idle_test (GtkWidget *widget,
- gpointer data)
-{
- if (idle_id)
- {
- gtk_idle_remove (idle_id);
- idle_id = 0;
- }
-}
-
-static void
-destroy_idle_test (GtkWidget *widget,
- GtkWidget **window)
-{
- stop_idle_test (NULL, NULL);
-
- *window = NULL;
-}
-
-static void
-toggle_idle_container (GtkObject *button,
- GtkContainer *container)
-{
- gtk_container_set_resize_mode (container, GPOINTER_TO_INT (gtk_object_get_user_data (button)));
-}
-
-static void
-create_idle_test (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *button;
- GtkWidget *label;
- GtkWidget *container;
-
- if (!window)
- {
- GtkWidget *frame;
- GtkWidget *box;
-
- window = gtk_dialog_new ();
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(destroy_idle_test),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Idle Test");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- label = gtk_label_new ("count: 0");
- gtk_misc_set_padding (GTK_MISC (label), 10, 10);
- gtk_widget_show (label);
-
- container =
- gtk_widget_new (GTK_TYPE_HBOX,
- "visible", TRUE,
- /* "GtkContainer::child", gtk_widget_new (GTK_TYPE_HBOX,
- * "GtkWidget::visible", TRUE,
- */
- "child", label,
- /* NULL), */
- NULL);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox),
- container, TRUE, TRUE, 0);
-
- frame =
- gtk_widget_new (GTK_TYPE_FRAME,
- "border_width", 5,
- "label", "Label Container",
- "visible", TRUE,
- "parent", GTK_DIALOG (window)->vbox,
- NULL);
- box =
- gtk_widget_new (GTK_TYPE_VBOX,
- "visible", TRUE,
- "parent", frame,
- NULL);
- button =
- g_object_connect (gtk_widget_new (GTK_TYPE_RADIO_BUTTON,
- "label", "Resize-Parent",
- "user_data", (void*)GTK_RESIZE_PARENT,
- "visible", TRUE,
- "parent", box,
- NULL),
- "signal::clicked", toggle_idle_container, container,
- NULL);
- button =
- g_object_connect (gtk_widget_new (GTK_TYPE_RADIO_BUTTON,
- "label", "Resize-Queue",
- "user_data", (void*)GTK_RESIZE_QUEUE,
- "group", button,
- "visible", TRUE,
- "parent", box,
- NULL),
- "signal::clicked", toggle_idle_container, container,
- NULL);
- button =
- g_object_set (g_object_connect (gtk_widget_new (GTK_TYPE_RADIO_BUTTON,
- "label", "Resize-Immediate",
- "user_data", (void*)GTK_RESIZE_IMMEDIATE,
- NULL),
- "signal::clicked", toggle_idle_container, container,
- NULL),
- "group", button,
- "visible", TRUE,
- "parent", box,
- NULL);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("start");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(start_idle_test),
- label);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("stop");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(stop_idle_test),
- NULL);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * rc file test
- */
-
-void
-reload_rc_file (void)
-{
- GList *toplevels;
-
- if (gtk_rc_reparse_all ())
- {
- toplevels = gdk_window_get_toplevels();
- while (toplevels)
- {
- GtkWidget *widget;
- gdk_window_get_user_data (toplevels->data, (gpointer *)&widget);
-
- if (widget)
- gtk_widget_reset_rc_styles (widget);
-
- toplevels = toplevels->next;
- }
- g_list_free (toplevels);
- }
-}
-
-void
-reload_all_rc_files (void)
-{
- static GdkAtom atom_rcfiles = GDK_NONE;
-
- GdkEventClient sev;
- int i;
-
- if (!atom_rcfiles)
- atom_rcfiles = gdk_atom_intern("_GTK_READ_RCFILES", FALSE);
-
- for(i = 0; i < 5; i++)
- sev.data.l[i] = 0;
- sev.data_format = 32;
- sev.message_type = atom_rcfiles;
- gdk_event_send_clientmessage_toall ((GdkEvent *) &sev);
-}
-
-void
-create_rc_file (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *button;
-
- if (!window)
- {
- window = gtk_dialog_new ();
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(destroy_idle_test),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Reload Rc file");
- gtk_container_set_border_width (GTK_CONTAINER (window), 0);
-
- button = gtk_button_new_with_label ("Reload");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(reload_rc_file), NULL);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_grab_default (button);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("Reload All");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(reload_all_rc_files), NULL);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("Close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_show (button);
-
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Test of recursive mainloop
- */
-
-void
-mainloop_destroyed (GtkWidget *w, GtkWidget **window)
-{
- *window = NULL;
- gtk_main_quit ();
-}
-
-void
-create_mainloop (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *label;
- GtkWidget *button;
-
- if (!window)
- {
- window = gtk_dialog_new ();
-
- gtk_window_set_title (GTK_WINDOW (window), "Test Main Loop");
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(mainloop_destroyed),
- &window);
-
- label = gtk_label_new ("In recursive main loop...");
- gtk_misc_set_padding (GTK_MISC(label), 20, 20);
-
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), label,
- TRUE, TRUE, 0);
- gtk_widget_show (label);
-
- button = gtk_button_new_with_label ("Leave");
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), button,
- FALSE, TRUE, 0);
-
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (window));
-
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
-
- gtk_widget_show (button);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- {
- gtk_widget_show (window);
-
- g_print ("create_mainloop: start\n");
- gtk_main ();
- g_print ("create_mainloop: done\n");
- }
- else
- gtk_widget_destroy (window);
-}
-
-gint
-layout_expose_handler (GtkWidget *widget, GdkEventExpose *event)
-{
- GtkLayout *layout;
-
- gint i,j;
- gint imin, imax, jmin, jmax;
-
- layout = GTK_LAYOUT (widget);
-
- imin = (layout->xoffset + event->area.x) / 10;
- imax = (layout->xoffset + event->area.x + event->area.width + 9) / 10;
-
- jmin = (layout->yoffset + event->area.y) / 10;
- jmax = (layout->yoffset + event->area.y + event->area.height + 9) / 10;
-
- gdk_window_clear_area (widget->window,
- event->area.x, event->area.y,
- event->area.width, event->area.height);
-
- for (i=imin; i<imax; i++)
- for (j=jmin; j<jmax; j++)
- if ((i+j) % 2)
- gdk_draw_rectangle (layout->bin_window,
- widget->style->black_gc,
- TRUE,
- 10*i - layout->xoffset, 10*j - layout->yoffset,
- 1+i%10, 1+j%10);
-
- return TRUE;
-}
-
-void create_layout (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *layout;
- GtkWidget *scrolledwindow;
- GtkWidget *button;
-
- if (!window)
- {
- gchar buf[16];
-
- gint i, j;
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
- gtk_window_set_title (GTK_WINDOW (window), "Layout");
- gtk_widget_set_usize (window, 200, 200);
-
- scrolledwindow = gtk_scrolled_window_new (NULL, NULL);
- gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scrolledwindow),
- GTK_SHADOW_IN);
- gtk_scrolled_window_set_placement (GTK_SCROLLED_WINDOW (scrolledwindow),
- GTK_CORNER_TOP_RIGHT);
-
- gtk_container_add (GTK_CONTAINER (window), scrolledwindow);
-
- layout = gtk_layout_new (NULL, NULL);
- gtk_container_add (GTK_CONTAINER (scrolledwindow), layout);
-
- /* We set step sizes here since GtkLayout does not set
- * them itself.
- */
- GTK_LAYOUT (layout)->hadjustment->step_increment = 10.0;
- GTK_LAYOUT (layout)->vadjustment->step_increment = 10.0;
-
- gtk_widget_set_events (layout, GDK_EXPOSURE_MASK);
- gtk_signal_connect (GTK_OBJECT (layout), "expose_event",
- GTK_SIGNAL_FUNC (layout_expose_handler), NULL);
-
- gtk_layout_set_size (GTK_LAYOUT (layout), 1600, 128000);
-
- for (i=0 ; i < 16 ; i++)
- for (j=0 ; j < 16 ; j++)
- {
- sprintf(buf, "Button %d, %d", i, j);
- if ((i + j) % 2)
- button = gtk_button_new_with_label (buf);
- else
- button = gtk_label_new (buf);
-
- gtk_layout_put (GTK_LAYOUT (layout), button,
- j*100, i*100);
- }
-
- for (i=16; i < 1280; i++)
- {
- sprintf(buf, "Button %d, %d", i, 0);
- if (i % 2)
- button = gtk_button_new_with_label (buf);
- else
- button = gtk_label_new (buf);
-
- gtk_layout_put (GTK_LAYOUT (layout), button,
- 0, i*100);
- }
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-void
-create_styles (void)
-{
- static GtkWidget *window = NULL;
- GtkWidget *label;
- GtkWidget *button;
- GtkWidget *entry;
- GtkWidget *vbox;
- static GdkColor red = { 0, 0xffff, 0, 0 };
- static GdkColor green = { 0, 0, 0xffff, 0 };
- static GdkColor blue = { 0, 0, 0, 0xffff };
- static GdkColor yellow = { 0, 0xffff, 0xffff, 0 };
- static GdkColor cyan = { 0, 0 , 0xffff, 0xffff };
- PangoFontDescription *font_desc;
-
- GtkRcStyle *rc_style;
-
- if (!window)
- {
- window = gtk_dialog_new ();
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_widget_destroyed),
- &window);
-
-
- button = gtk_button_new_with_label ("Close");
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC(gtk_widget_destroy),
- GTK_OBJECT (window));
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area),
- button, TRUE, TRUE, 0);
- gtk_widget_show (button);
-
- vbox = gtk_vbox_new (FALSE, 5);
- gtk_container_set_border_width (GTK_CONTAINER (vbox), 10);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->vbox), vbox, FALSE, FALSE, 0);
-
- label = gtk_label_new ("Font:");
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
-
- font_desc = pango_font_description_from_string ("Helvetica,Sans Oblique 18");
-
- button = gtk_button_new_with_label ("Some Text");
- gtk_widget_modify_font (GTK_BIN (button)->child, font_desc);
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- label = gtk_label_new ("Foreground:");
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Some Text");
- gtk_widget_modify_fg (GTK_BIN (button)->child, GTK_STATE_NORMAL, &red);
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- label = gtk_label_new ("Background:");
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Some Text");
- gtk_widget_modify_bg (button, GTK_STATE_NORMAL, &green);
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- label = gtk_label_new ("Text:");
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
-
- entry = gtk_entry_new ();
- gtk_entry_set_text (GTK_ENTRY (entry), "Some Text");
- gtk_widget_modify_text (entry, GTK_STATE_NORMAL, &blue);
- gtk_box_pack_start (GTK_BOX (vbox), entry, FALSE, FALSE, 0);
-
- label = gtk_label_new ("Base:");
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
-
- entry = gtk_entry_new ();
- gtk_entry_set_text (GTK_ENTRY (entry), "Some Text");
- gtk_widget_modify_base (entry, GTK_STATE_NORMAL, &yellow);
- gtk_box_pack_start (GTK_BOX (vbox), entry, FALSE, FALSE, 0);
-
- label = gtk_label_new ("Multiple:");
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Some Text");
-
- rc_style = gtk_rc_style_new ();
-
- rc_style->font_desc = font_desc;
- rc_style->color_flags[GTK_STATE_NORMAL] = GTK_RC_FG | GTK_RC_BG;
- rc_style->color_flags[GTK_STATE_PRELIGHT] = GTK_RC_FG | GTK_RC_BG;
- rc_style->color_flags[GTK_STATE_ACTIVE] = GTK_RC_FG | GTK_RC_BG;
- rc_style->fg[GTK_STATE_NORMAL] = yellow;
- rc_style->bg[GTK_STATE_NORMAL] = blue;
- rc_style->fg[GTK_STATE_PRELIGHT] = blue;
- rc_style->bg[GTK_STATE_PRELIGHT] = yellow;
- rc_style->fg[GTK_STATE_ACTIVE] = red;
- rc_style->bg[GTK_STATE_ACTIVE] = cyan;
- rc_style->xthickness = 5;
- rc_style->ythickness = 5;
-
- gtk_widget_modify_style (button, rc_style);
- gtk_widget_modify_style (GTK_BIN (button)->child, rc_style);
-
- g_object_unref (G_OBJECT (rc_style));
-
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
- }
-
- if (!GTK_WIDGET_VISIBLE (window))
- gtk_widget_show_all (window);
- else
- gtk_widget_destroy (window);
-}
-
-/*
- * Main Window and Exit
- */
-
-void
-do_exit (GtkWidget *widget, GtkWidget *window)
-{
- gtk_widget_destroy (window);
- gtk_main_quit ();
-}
-
-void
-create_main_window (void)
-{
- struct {
- char *label;
- void (*func) ();
- } buttons[] =
- {
- { "button box", create_button_box },
- { "buttons", create_buttons },
- { "check buttons", create_check_buttons },
- { "clist", create_clist},
- { "color selection", create_color_selection },
- { "ctree", create_ctree },
- { "cursors", create_cursors },
- { "dialog", create_dialog },
- /* { "dnd", create_dnd }, */
- { "entry", create_entry },
- { "event watcher", create_event_watcher },
- { "file selection", create_file_selection },
- { "flipping", create_flipping },
- { "focus", create_focus },
- { "font selection", create_font_selection },
- { "gamma curve", create_gamma_curve },
- { "handle box", create_handle_box },
- { "image from drawable", create_get_image },
- { "image", create_image },
- { "item factory", create_item_factory },
- { "labels", create_labels },
- { "layout", create_layout },
- { "list", create_list },
- { "menus", create_menus },
- { "message dialog", create_message_dialog },
- { "modal window", create_modal_window },
- { "notebook", create_notebook },
- { "panes", create_panes },
- { "pixmap", create_pixmap },
- { "preview color", create_color_preview },
- { "preview gray", create_gray_preview },
- { "progress bar", create_progress_bar },
- { "radio buttons", create_radio_buttons },
- { "range controls", create_range_controls },
- { "rc file", create_rc_file },
- { "reparent", create_reparent },
- { "rulers", create_rulers },
- { "saved position", create_saved_position },
- { "scrolled windows", create_scrolled_windows },
- { "shapes", create_shapes },
- { "spinbutton", create_spins },
- { "statusbar", create_statusbar },
- { "styles", create_styles },
- { "test idle", create_idle_test },
- { "test mainloop", create_mainloop },
- { "test scrolling", create_scroll_test },
- { "test selection", create_selection_test },
- { "test timeout", create_timeout_test },
- { "text", create_text },
- { "toggle buttons", create_toggle_buttons },
- { "toolbar", create_toolbar },
- { "tooltips", create_tooltips },
- { "tree", create_tree_mode_window},
- { "WM hints", create_wmhints },
- { "window sizing", create_window_sizing },
- { "window states", create_window_states }
- };
- int nbuttons = sizeof (buttons) / sizeof (buttons[0]);
- GtkWidget *window;
- GtkWidget *box1;
- GtkWidget *box2;
- GtkWidget *scrolled_window;
- GtkWidget *button;
- GtkWidget *label;
- gchar buffer[64];
- GtkWidget *separator;
- GdkGeometry geometry;
- int i;
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_widget_set_name (window, "main window");
- gtk_widget_set_uposition (window, 20, 20);
- gtk_window_set_default_size (GTK_WINDOW (window), -1, 400);
-
- geometry.min_width = -1;
- geometry.min_height = -1;
- geometry.max_width = -1;
- geometry.max_height = G_MAXSHORT;
- gtk_window_set_geometry_hints (GTK_WINDOW (window), NULL,
- &geometry,
- GDK_HINT_MIN_SIZE | GDK_HINT_MAX_SIZE);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC(gtk_main_quit),
- NULL);
- gtk_signal_connect (GTK_OBJECT (window), "delete-event",
- GTK_SIGNAL_FUNC (gtk_false),
- NULL);
-
- box1 = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), box1);
-
- if (gtk_micro_version > 0)
- sprintf (buffer,
- "Gtk+ v%d.%d.%d",
- gtk_major_version,
- gtk_minor_version,
- gtk_micro_version);
- else
- sprintf (buffer,
- "Gtk+ v%d.%d",
- gtk_major_version,
- gtk_minor_version);
-
- label = gtk_label_new (buffer);
- gtk_box_pack_start (GTK_BOX (box1), label, FALSE, FALSE, 0);
-
- scrolled_window = gtk_scrolled_window_new (NULL, NULL);
- gtk_container_set_border_width (GTK_CONTAINER (scrolled_window), 10);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window),
- GTK_POLICY_NEVER,
- GTK_POLICY_AUTOMATIC);
- gtk_box_pack_start (GTK_BOX (box1), scrolled_window, TRUE, TRUE, 0);
-
- box2 = gtk_vbox_new (FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (scrolled_window), box2);
- gtk_container_set_focus_vadjustment (GTK_CONTAINER (box2),
- gtk_scrolled_window_get_vadjustment (GTK_SCROLLED_WINDOW (scrolled_window)));
- gtk_widget_show (box2);
-
- for (i = 0; i < nbuttons; i++)
- {
- button = gtk_button_new_with_label (buttons[i].label);
- if (buttons[i].func)
- gtk_signal_connect (GTK_OBJECT (button),
- "clicked",
- GTK_SIGNAL_FUNC(buttons[i].func),
- NULL);
- else
- gtk_widget_set_sensitive (button, FALSE);
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- }
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
-
- box2 = gtk_vbox_new (FALSE, 10);
- gtk_container_set_border_width (GTK_CONTAINER (box2), 10);
- gtk_box_pack_start (GTK_BOX (box1), box2, FALSE, TRUE, 0);
-
- button = gtk_button_new_with_label ("close");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (do_exit),
- window);
- gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_widget_grab_default (button);
-
- gtk_widget_show_all (window);
-}
-
-static void
-test_init ()
-{
- if (file_exists ("../gdk-pixbuf/.libs/libpixbufloader-pnm.so"))
- {
- putenv ("GDK_PIXBUF_MODULEDIR=../gdk-pixbuf/.libs");
- putenv ("GTK_IM_MODULE_FILE=./gtk.immodules");
- }
-}
-
-int
-main (int argc, char *argv[])
-{
- GtkBindingSet *binding_set;
-
- srand (time (NULL));
-
- test_init ();
- gtk_set_locale ();
-
- /* Check to see if we are being run from the correct
- * directory.
- */
- if (file_exists ("testgtkrc"))
- gtk_rc_add_default_file ("testgtkrc");
-
- gtk_init (&argc, &argv);
-
- /* bindings test
- */
- binding_set = gtk_binding_set_by_class (gtk_type_class (GTK_TYPE_WIDGET));
- gtk_binding_entry_add_signal (binding_set,
- '9', GDK_CONTROL_MASK | GDK_RELEASE_MASK,
- "debug_msg",
- 1,
- GTK_TYPE_STRING, "GtkWidgetClass <ctrl><release>9 test");
-
- create_main_window ();
-
- gtk_main ();
-
- if (1)
- {
- while (g_main_pending ())
- g_main_iteration (FALSE);
-#if 0
- sleep (1);
- while (g_main_pending ())
- g_main_iteration (FALSE);
-#endif
- }
-
- return 0;
-}
diff --git a/gtk/testinput.c b/gtk/testinput.c
deleted file mode 100644
index 4801c31250..0000000000
--- a/gtk/testinput.c
+++ /dev/null
@@ -1,393 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-/*
- * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
- * file for a list of people on the GTK+ Team. See the ChangeLog
- * files for a list of changes. These files are distributed with
- * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
- */
-
-#include <stdio.h>
-#include "gtk.h"
-
-/* Backing pixmap for drawing area */
-
-static GdkPixmap *pixmap = NULL;
-
-/* Information about cursor */
-
-static gint cursor_proximity = TRUE;
-static gdouble cursor_x;
-static gdouble cursor_y;
-
-/* Unique ID of current device */
-static GdkDevice *current_device;
-
-/* Erase the old cursor, and/or draw a new one, if necessary */
-static void
-update_cursor (GtkWidget *widget, gdouble x, gdouble y)
-{
- static gint cursor_present = 0;
- gint state = !current_device->has_cursor && cursor_proximity;
-
- if (pixmap != NULL)
- {
- if (cursor_present && (cursor_present != state ||
- x != cursor_x || y != cursor_y))
- {
- gdk_draw_pixmap(widget->window,
- widget->style->fg_gc[GTK_WIDGET_STATE (widget)],
- pixmap,
- cursor_x - 5, cursor_y - 5,
- cursor_x - 5, cursor_y - 5,
- 10, 10);
- }
-
- cursor_present = state;
- cursor_x = x;
- cursor_y = y;
-
- if (cursor_present)
- {
- gdk_draw_rectangle (widget->window,
- widget->style->black_gc,
- TRUE,
- cursor_x - 5, cursor_y -5,
- 10, 10);
- }
- }
-}
-
-/* Create a new backing pixmap of the appropriate size */
-static gint
-configure_event (GtkWidget *widget, GdkEventConfigure *event)
-{
- if (pixmap)
- gdk_pixmap_unref (pixmap);
- pixmap = gdk_pixmap_new(widget->window,
- widget->allocation.width,
- widget->allocation.height,
- -1);
- gdk_draw_rectangle (pixmap,
- widget->style->white_gc,
- TRUE,
- 0, 0,
- widget->allocation.width,
- widget->allocation.height);
-
- return TRUE;
-}
-
-/* Refill the screen from the backing pixmap */
-static gint
-expose_event (GtkWidget *widget, GdkEventExpose *event)
-{
- gdk_draw_pixmap(widget->window,
- widget->style->fg_gc[GTK_WIDGET_STATE (widget)],
- pixmap,
- event->area.x, event->area.y,
- event->area.x, event->area.y,
- event->area.width, event->area.height);
-
- return FALSE;
-}
-
-/* Draw a rectangle on the screen, size depending on pressure,
- and color on the type of device */
-static void
-draw_brush (GtkWidget *widget, GdkInputSource source,
- gdouble x, gdouble y, gdouble pressure)
-{
- GdkGC *gc;
- GdkRectangle update_rect;
-
- switch (source)
- {
- case GDK_SOURCE_MOUSE:
- gc = widget->style->dark_gc[GTK_WIDGET_STATE (widget)];
- break;
- case GDK_SOURCE_PEN:
- gc = widget->style->black_gc;
- break;
- case GDK_SOURCE_ERASER:
- gc = widget->style->white_gc;
- break;
- default:
- gc = widget->style->light_gc[GTK_WIDGET_STATE (widget)];
- }
-
- update_rect.x = x - 10 * pressure;
- update_rect.y = y - 10 * pressure;
- update_rect.width = 20 * pressure;
- update_rect.height = 20 * pressure;
- gdk_draw_rectangle (pixmap, gc, TRUE,
- update_rect.x, update_rect.y,
- update_rect.width, update_rect.height);
- gtk_widget_draw (widget, &update_rect);
-}
-
-static guint32 motion_time;
-
-static void
-print_axes (GdkDevice *device, gdouble *axes)
-{
- int i;
-
- if (axes)
- {
- g_print ("%s ", device->name);
-
- for (i=0; i<device->num_axes; i++)
- g_print ("%g ", axes[i]);
-
- g_print ("\n");
- }
-}
-
-static gint
-button_press_event (GtkWidget *widget, GdkEventButton *event)
-{
- current_device = event->device;
- cursor_proximity = TRUE;
-
- if (event->button == 1 && pixmap != NULL)
- {
- gdouble pressure = 0.5;
-
- print_axes (event->device, event->axes);
- gdk_event_get_axis ((GdkEvent *)event, GDK_AXIS_PRESSURE, &pressure);
- draw_brush (widget, event->device->source, event->x, event->y, pressure);
-
- motion_time = event->time;
- }
-
- update_cursor (widget, event->x, event->y);
-
- return TRUE;
-}
-
-static gint
-key_press_event (GtkWidget *widget, GdkEventKey *event)
-{
- if ((event->keyval >= 0x20) && (event->keyval <= 0xFF))
- printf("I got a %c\n", event->keyval);
- else
- printf("I got some other key\n");
-
- return TRUE;
-}
-
-static gint
-motion_notify_event (GtkWidget *widget, GdkEventMotion *event)
-{
- GdkTimeCoord **events;
- int n_events;
- int i;
-
- current_device = event->device;
- cursor_proximity = TRUE;
-
- if (event->state & GDK_BUTTON1_MASK && pixmap != NULL)
- {
- if (gdk_device_get_history (event->device, event->window,
- motion_time, event->time,
- &events, &n_events))
- {
- for (i=0; i<n_events; i++)
- {
- double x = 0, y = 0, pressure = 0.5;
-
- gdk_device_get_axis (event->device, events[i]->axes, GDK_AXIS_X, &x);
- gdk_device_get_axis (event->device, events[i]->axes, GDK_AXIS_Y, &y);
- gdk_device_get_axis (event->device, events[i]->axes, GDK_AXIS_PRESSURE, &pressure);
- draw_brush (widget, event->device->source, x, y, pressure);
-
- print_axes (event->device, events[i]->axes);
- }
- gdk_device_free_history (events, n_events);
- }
- else
- {
- double pressure = 0.5;
-
- gdk_event_get_axis ((GdkEvent *)event, GDK_AXIS_PRESSURE, &pressure);
-
- draw_brush (widget, event->device->source, event->x, event->y, pressure);
- }
- motion_time = event->time;
- }
-
- if (event->is_hint)
- gdk_device_get_state (event->device, event->window, NULL, NULL);
-
- print_axes (event->device, event->axes);
- update_cursor (widget, event->x, event->y);
-
- return TRUE;
-}
-
-/* We track the next two events to know when we need to draw a
- cursor */
-
-static gint
-proximity_out_event (GtkWidget *widget, GdkEventProximity *event)
-{
- cursor_proximity = FALSE;
- update_cursor (widget, cursor_x, cursor_y);
- return TRUE;
-}
-
-static gint
-leave_notify_event (GtkWidget *widget, GdkEventCrossing *event)
-{
- cursor_proximity = FALSE;
- update_cursor (widget, cursor_x, cursor_y);
- return TRUE;
-}
-
-void
-input_dialog_destroy (GtkWidget *w, gpointer data)
-{
- *((GtkWidget **)data) = NULL;
-}
-
-void
-create_input_dialog (void)
-{
- static GtkWidget *inputd = NULL;
-
- if (!inputd)
- {
- inputd = gtk_input_dialog_new();
-
- gtk_signal_connect (GTK_OBJECT(inputd), "destroy",
- (GtkSignalFunc)input_dialog_destroy, &inputd);
- gtk_signal_connect_object (GTK_OBJECT(GTK_INPUT_DIALOG(inputd)->close_button),
- "clicked",
- (GtkSignalFunc)gtk_widget_hide,
- GTK_OBJECT(inputd));
- gtk_widget_hide (GTK_INPUT_DIALOG(inputd)->save_button);
-
- gtk_widget_show (inputd);
- }
- else
- {
- if (!GTK_WIDGET_MAPPED(inputd))
- gtk_widget_show(inputd);
- else
- gdk_window_raise(inputd->window);
- }
-}
-
-void
-quit (void)
-{
- gtk_exit (0);
-}
-
-int
-main (int argc, char *argv[])
-{
- GtkWidget *window;
- GtkWidget *drawing_area;
- GtkWidget *vbox;
-
- GtkWidget *button;
-
- gtk_init (&argc, &argv);
-
- current_device = gdk_core_pointer;
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_widget_set_name (window, "Test Input");
-
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (window), vbox);
- gtk_widget_show (vbox);
-
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- GTK_SIGNAL_FUNC (quit), NULL);
-
- /* Create the drawing area */
-
- drawing_area = gtk_drawing_area_new ();
- gtk_drawing_area_size (GTK_DRAWING_AREA (drawing_area), 200, 200);
- gtk_box_pack_start (GTK_BOX (vbox), drawing_area, TRUE, TRUE, 0);
-
- gtk_widget_show (drawing_area);
-
- /* Signals used to handle backing pixmap */
-
- gtk_signal_connect (GTK_OBJECT (drawing_area), "expose_event",
- (GtkSignalFunc) expose_event, NULL);
- gtk_signal_connect (GTK_OBJECT(drawing_area),"configure_event",
- (GtkSignalFunc) configure_event, NULL);
-
- /* Event signals */
-
- gtk_signal_connect (GTK_OBJECT (drawing_area), "motion_notify_event",
- (GtkSignalFunc) motion_notify_event, NULL);
- gtk_signal_connect (GTK_OBJECT (drawing_area), "button_press_event",
- (GtkSignalFunc) button_press_event, NULL);
- gtk_signal_connect (GTK_OBJECT (drawing_area), "key_press_event",
- (GtkSignalFunc) key_press_event, NULL);
-
- gtk_signal_connect (GTK_OBJECT (drawing_area), "leave_notify_event",
- (GtkSignalFunc) leave_notify_event, NULL);
- gtk_signal_connect (GTK_OBJECT (drawing_area), "proximity_out_event",
- (GtkSignalFunc) proximity_out_event, NULL);
-
- gtk_widget_set_events (drawing_area, GDK_EXPOSURE_MASK
- | GDK_LEAVE_NOTIFY_MASK
- | GDK_BUTTON_PRESS_MASK
- | GDK_KEY_PRESS_MASK
- | GDK_POINTER_MOTION_MASK
- | GDK_POINTER_MOTION_HINT_MASK
- | GDK_PROXIMITY_OUT_MASK);
-
- /* The following call enables tracking and processing of extension
- events for the drawing area */
- gtk_widget_set_extension_events (drawing_area, GDK_EXTENSION_EVENTS_ALL);
-
- GTK_WIDGET_SET_FLAGS (drawing_area, GTK_CAN_FOCUS);
- gtk_widget_grab_focus (drawing_area);
-
- /* .. And create some buttons */
- button = gtk_button_new_with_label ("Input Dialog");
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (create_input_dialog), NULL);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("Quit");
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (window));
- gtk_widget_show (button);
-
- gtk_widget_show (window);
-
- gtk_main ();
-
- return 0;
-}
diff --git a/gtk/testrgb.c b/gtk/testrgb.c
deleted file mode 100644
index ccf246b74e..0000000000
--- a/gtk/testrgb.c
+++ /dev/null
@@ -1,292 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-#include "config.h"
-
-#include <glib.h>
-
-/*
- * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
- * file for a list of people on the GTK+ Team. See the ChangeLog
- * files for a list of changes. These files are distributed with
- * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
- */
-
-
-/* Note: these #includes differ slightly from the testrgb.c file included
- in the GdkRgb release. */
-
-#include <stdlib.h>
-#ifdef HAVE_UNISTD_H
-#include <unistd.h>
-#endif
-#include <string.h>
-
-#include "gtk.h"
-
-static void
-quit_func (GtkWidget *widget, gpointer dummy)
-{
- gtk_main_quit ();
-}
-
-#define WIDTH 640
-#define HEIGHT 400
-#define NUM_ITERS 100
-
-static void
-testrgb_rgb_test (GtkWidget *drawing_area)
-{
- guchar *buf;
- gint i, j;
- gint offset;
- guchar val;
- gdouble start_time, total_time;
- gint x, y;
- gboolean dither;
- int dith_max;
- GTimer *timer;
-
- buf = g_malloc (WIDTH * HEIGHT * 6);
-
- val = 0;
- for (j = 0; j < WIDTH * HEIGHT * 6; j++)
- {
- val = (val + ((val + (rand () & 0xff)) >> 1)) >> 1;
- buf[j] = val;
- }
-
- /* Let's warm up the cache, and also wait for the window manager
- to settle. */
- for (i = 0; i < NUM_ITERS; i++)
- {
- offset = (rand () % (WIDTH * HEIGHT * 3)) & -4;
- gdk_draw_rgb_image (drawing_area->window,
- drawing_area->style->white_gc,
- 0, 0, WIDTH, HEIGHT,
- GDK_RGB_DITHER_NONE,
- buf + offset, WIDTH * 3);
- }
-
- if (gdk_rgb_ditherable ())
- dith_max = 2;
- else
- dith_max = 1;
-
- timer = g_timer_new ();
- for (dither = 0; dither < dith_max; dither++)
- {
- start_time = g_timer_elapsed (timer, NULL);
- for (i = 0; i < NUM_ITERS; i++)
- {
- offset = (rand () % (WIDTH * HEIGHT * 3)) & -4;
- gdk_draw_rgb_image (drawing_area->window,
- drawing_area->style->white_gc,
- 0, 0, WIDTH, HEIGHT,
- dither ? GDK_RGB_DITHER_MAX :
- GDK_RGB_DITHER_NONE,
- buf + offset, WIDTH * 3);
- }
- total_time = g_timer_elapsed (timer, NULL) - start_time;
- g_print ("Color test%s time elapsed: %.2fs, %.1f fps, %.2f megapixels/s\n",
- dither ? " (dithered)" : "",
- total_time,
- NUM_ITERS / total_time,
- NUM_ITERS * (WIDTH * HEIGHT * 1e-6) / total_time);
- }
-
- for (dither = 0; dither < dith_max; dither++)
- {
- start_time = g_timer_elapsed (timer, NULL);
- for (i = 0; i < NUM_ITERS; i++)
- {
- offset = (rand () % (WIDTH * HEIGHT)) & -4;
- gdk_draw_gray_image (drawing_area->window,
- drawing_area->style->white_gc,
- 0, 0, WIDTH, HEIGHT,
- dither ? GDK_RGB_DITHER_MAX :
- GDK_RGB_DITHER_NONE,
- buf + offset, WIDTH);
- }
- total_time = g_timer_elapsed (timer, NULL) - start_time;
- g_print ("Grayscale test%s time elapsed: %.2fs, %.1f fps, %.2f megapixels/s\n",
- dither ? " (dithered)" : "",
- total_time,
- NUM_ITERS / total_time,
- NUM_ITERS * (WIDTH * HEIGHT * 1e-6) / total_time);
- }
-
- g_print ("Please submit these results to http://www.levien.com/gdkrgb/survey.html\n");
-
-#if 1
- for (x = 0; x < WIDTH; x++)
- {
- int cindex;
-
- cindex = (x * 8) / WIDTH;
- buf[x * 3] = cindex & 4 ? 0 : 255;
- buf[x * 3 + 1] = cindex & 2 ? 0 : 255;
- buf[x * 3 + 2] = cindex & 1 ? 0 : 255;
- }
- for (y = 1; y < (HEIGHT * 19) / 32; y++)
- {
- memcpy (buf + y * WIDTH * 3, buf, WIDTH * 3);
- }
- for (; y < (HEIGHT * 20) / 32; y++)
- {
- for (x = 0; x < WIDTH; x++)
- {
- guchar gray;
-
- gray = (x * 255) / (WIDTH - 1);
- buf[y * WIDTH * 3 + x * 3] = gray;
- buf[y * WIDTH * 3 + x * 3 + 1] = 0;
- buf[y * WIDTH * 3 + x * 3 + 2] = 0;
- }
- }
- for (; y < (HEIGHT * 21) / 32; y++)
- {
- for (x = 0; x < WIDTH; x++)
- {
- guchar gray;
-
- gray = (x * 255) / (WIDTH - 1);
- buf[y * WIDTH * 3 + x * 3] = 0;
- buf[y * WIDTH * 3 + x * 3 + 1] = gray;
- buf[y * WIDTH * 3 + x * 3 + 2] = 0;
- }
- }
- for (; y < (HEIGHT * 22) / 32; y++)
- {
- for (x = 0; x < WIDTH; x++)
- {
- guchar gray;
-
- gray = (x * 255) / (WIDTH - 1);
- buf[y * WIDTH * 3 + x * 3] = 0;
- buf[y * WIDTH * 3 + x * 3 + 1] = 0;
- buf[y * WIDTH * 3 + x * 3 + 2] = gray;
- }
- }
- for (; y < (HEIGHT * 24) / 32; y++)
- {
- for (x = 0; x < WIDTH; x++)
- {
- guchar gray;
-
- gray = 112 + (x * 31) / (WIDTH - 1);
- buf[y * WIDTH * 3 + x * 3] = gray;
- buf[y * WIDTH * 3 + x * 3 + 1] = gray;
- buf[y * WIDTH * 3 + x * 3 + 2] = gray;
- }
- }
- for (; y < (HEIGHT * 26) / 32; y++)
- {
- for (x = 0; x < WIDTH; x++)
- {
- guchar gray;
-
- gray = (x * 255) / (WIDTH - 1);
- buf[y * WIDTH * 3 + x * 3] = gray;
- buf[y * WIDTH * 3 + x * 3 + 1] = gray;
- buf[y * WIDTH * 3 + x * 3 + 2] = gray;
- }
- }
-
- for (; y < HEIGHT; y++)
- {
- for (x = 0; x < WIDTH; x++)
- {
- int cindex;
- guchar gray;
-
- cindex = (x * 16) / WIDTH;
- gray = cindex < 3 ? 0 :
- cindex < 5 ? 255 :
- cindex < 7 ? 128 :
- 0;
- buf[y * WIDTH * 3 + x * 3] = gray;
- buf[y * WIDTH * 3 + x * 3 + 1] = gray;
- buf[y * WIDTH * 3 + x * 3 + 2] = gray;
- }
- }
- gdk_draw_rgb_image (drawing_area->window,
- drawing_area->style->white_gc,
- 0, 0, WIDTH, HEIGHT, GDK_RGB_DITHER_MAX,
- buf, WIDTH * 3);
-#endif
-}
-
-void
-new_testrgb_window (void)
-{
- GtkWidget *window;
- GtkWidget *vbox;
- GtkWidget *button;
- GtkWidget *drawing_area;
-
- window = gtk_widget_new (gtk_window_get_type (),
- "GtkObject::user_data", NULL,
- "GtkWindow::type", GTK_WINDOW_TOPLEVEL,
- "GtkWindow::title", "testrgb",
- "GtkWindow::allow_shrink", FALSE,
- NULL);
- gtk_signal_connect (GTK_OBJECT (window), "destroy",
- (GtkSignalFunc) quit_func, NULL);
-
- vbox = gtk_vbox_new (FALSE, 0);
-
- drawing_area = gtk_drawing_area_new ();
-
- gtk_widget_set_usize (drawing_area, WIDTH, HEIGHT);
- gtk_box_pack_start (GTK_BOX (vbox), drawing_area, FALSE, FALSE, 0);
- gtk_widget_show (drawing_area);
-
- button = gtk_button_new_with_label ("Quit");
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- (GtkSignalFunc) gtk_widget_destroy,
- GTK_OBJECT (window));
-
- gtk_widget_show (button);
-
- gtk_container_add (GTK_CONTAINER (window), vbox);
- gtk_widget_show (vbox);
-
- gtk_widget_show (window);
-
- testrgb_rgb_test (drawing_area);
-}
-
-int
-main (int argc, char **argv)
-{
- gtk_init (&argc, &argv);
-
- gdk_rgb_set_verbose (TRUE);
-
- gdk_rgb_init ();
-
- gtk_widget_set_default_colormap (gdk_rgb_get_cmap ());
- new_testrgb_window ();
-
- gtk_main ();
-
- return 0;
-}
diff --git a/gtk/testselection.c b/gtk/testselection.c
deleted file mode 100644
index 4f7f6b7e0b..0000000000
--- a/gtk/testselection.c
+++ /dev/null
@@ -1,490 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-/*
- * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
- * file for a list of people on the GTK+ Team. See the ChangeLog
- * files for a list of changes. These files are distributed with
- * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
- */
-
-#include <stdio.h>
-#include <string.h>
-#define GTK_ENABLE_BROKEN
-#include "gtk.h"
-
-typedef enum {
- SEL_TYPE_NONE,
- APPLE_PICT,
- ATOM,
- ATOM_PAIR,
- BITMAP,
- C_STRING,
- COLORMAP,
- COMPOUND_TEXT,
- DRAWABLE,
- INTEGER,
- PIXEL,
- PIXMAP,
- SPAN,
- STRING,
- TEXT,
- WINDOW,
- LAST_SEL_TYPE
-} SelType;
-
-GdkAtom seltypes[LAST_SEL_TYPE];
-
-typedef struct _Target {
- gchar *target_name;
- SelType type;
- GdkAtom target;
- gint format;
-} Target;
-
-/* The following is a list of all the selection targets defined
- in the ICCCM */
-
-static Target targets[] = {
- { "ADOBE_PORTABLE_DOCUMENT_FORMAT", STRING, 0, 8 },
- { "APPLE_PICT", APPLE_PICT, 0, 8 },
- { "BACKGROUND", PIXEL, 0, 32 },
- { "BITMAP", BITMAP, 0, 32 },
- { "CHARACTER_POSITION", SPAN, 0, 32 },
- { "CLASS", TEXT, 0, 8 },
- { "CLIENT_WINDOW", WINDOW, 0, 32 },
- { "COLORMAP", COLORMAP, 0, 32 },
- { "COLUMN_NUMBER", SPAN, 0, 32 },
- { "COMPOUND_TEXT", COMPOUND_TEXT, 0, 8 },
- /* { "DELETE", "NULL", 0, ? }, */
- { "DRAWABLE", DRAWABLE, 0, 32 },
- { "ENCAPSULATED_POSTSCRIPT", STRING, 0, 8 },
- { "ENCAPSULATED_POSTSCRIPT_INTERCHANGE", STRING, 0, 8 },
- { "FILE_NAME", TEXT, 0, 8 },
- { "FOREGROUND", PIXEL, 0, 32 },
- { "HOST_NAME", TEXT, 0, 8 },
- /* { "INSERT_PROPERTY", "NULL", 0, ? NULL }, */
- /* { "INSERT_SELECTION", "NULL", 0, ? NULL }, */
- { "LENGTH", INTEGER, 0, 32 },
- { "LINE_NUMBER", SPAN, 0, 32 },
- { "LIST_LENGTH", INTEGER, 0, 32 },
- { "MODULE", TEXT, 0, 8 },
- /* { "MULTIPLE", "ATOM_PAIR", 0, 32 }, */
- { "NAME", TEXT, 0, 8 },
- { "ODIF", TEXT, 0, 8 },
- { "OWNER_OS", TEXT, 0, 8 },
- { "PIXMAP", PIXMAP, 0, 32 },
- { "POSTSCRIPT", STRING, 0, 8 },
- { "PROCEDURE", TEXT, 0, 8 },
- { "PROCESS", INTEGER, 0, 32 },
- { "STRING", STRING, 0, 8 },
- { "TARGETS", ATOM, 0, 32 },
- { "TASK", INTEGER, 0, 32 },
- { "TEXT", TEXT, 0, 8 },
- { "TIMESTAMP", INTEGER, 0, 32 },
- { "USER", TEXT, 0, 8 },
-};
-
-static int num_targets = sizeof(targets)/sizeof(Target);
-
-static int have_selection = FALSE;
-
-GtkWidget *selection_text;
-GtkWidget *selection_button;
-GString *selection_string = NULL;
-
-static void
-init_atoms (void)
-{
- int i;
-
- seltypes[SEL_TYPE_NONE] = GDK_NONE;
- seltypes[APPLE_PICT] = gdk_atom_intern ("APPLE_PICT",FALSE);
- seltypes[ATOM] = gdk_atom_intern ("ATOM",FALSE);
- seltypes[ATOM_PAIR] = gdk_atom_intern ("ATOM_PAIR",FALSE);
- seltypes[BITMAP] = gdk_atom_intern ("BITMAP",FALSE);
- seltypes[C_STRING] = gdk_atom_intern ("C_STRING",FALSE);
- seltypes[COLORMAP] = gdk_atom_intern ("COLORMAP",FALSE);
- seltypes[COMPOUND_TEXT] = gdk_atom_intern ("COMPOUND_TEXT",FALSE);
- seltypes[DRAWABLE] = gdk_atom_intern ("DRAWABLE",FALSE);
- seltypes[INTEGER] = gdk_atom_intern ("INTEGER",FALSE);
- seltypes[PIXEL] = gdk_atom_intern ("PIXEL",FALSE);
- seltypes[PIXMAP] = gdk_atom_intern ("PIXMAP",FALSE);
- seltypes[SPAN] = gdk_atom_intern ("SPAN",FALSE);
- seltypes[STRING] = gdk_atom_intern ("STRING",FALSE);
- seltypes[TEXT] = gdk_atom_intern ("TEXT",FALSE);
- seltypes[WINDOW] = gdk_atom_intern ("WINDOW",FALSE);
-
- for (i=0; i<num_targets; i++)
- targets[i].target = gdk_atom_intern (targets[i].target_name, FALSE);
-}
-
-void
-selection_toggled (GtkWidget *widget)
-{
- if (GTK_TOGGLE_BUTTON(widget)->active)
- {
- have_selection = gtk_selection_owner_set (widget,
- GDK_SELECTION_PRIMARY,
- GDK_CURRENT_TIME);
- if (!have_selection)
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON(widget), FALSE);
- }
- else
- {
- if (have_selection)
- {
- if (gdk_selection_owner_get (GDK_SELECTION_PRIMARY) == widget->window)
- gtk_selection_owner_set (NULL, GDK_SELECTION_PRIMARY,
- GDK_CURRENT_TIME);
- have_selection = FALSE;
- }
- }
-}
-
-void
-selection_get (GtkWidget *widget,
- GtkSelectionData *selection_data,
- guint info,
- guint time,
- gpointer data)
-{
- guchar *buffer;
- gint len;
- GdkAtom type = GDK_NONE;
-
- if (!selection_string)
- {
- buffer = NULL;
- len = 0;
- }
- else
- {
- buffer = (guchar *)selection_string->str;
- len = selection_string->len;
- }
-
- switch (info)
- {
- case COMPOUND_TEXT:
- case TEXT:
- type = seltypes[COMPOUND_TEXT];
- case STRING:
- type = seltypes[STRING];
- }
-
- gtk_selection_data_set (selection_data, type, 8, buffer, len);
-}
-
-gint
-selection_clear (GtkWidget *widget, GdkEventSelection *event)
-{
- have_selection = FALSE;
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON(widget), FALSE);
-
- return TRUE;
-}
-
-gchar *
-stringify_atom (guchar *data, gint *position)
-{
- gchar *str = gdk_atom_name (*(GdkAtom *)(data+*position));
- *position += sizeof(GdkAtom);
-
- return str;
-}
-
-gchar *
-stringify_text (guchar *data, gint *position)
-{
- gchar *str = g_strdup ((gchar *)(data+*position));
- *position += strlen (str) + 1;
-
- return str;
-}
-
-gchar *
-stringify_xid (guchar *data, gint *position)
-{
- gchar buffer[20];
- gchar *str;
-
- sprintf(buffer,"0x%x",*(guint32 *)(data+*position));
- str = g_strdup (buffer);
-
- *position += sizeof(guint32);
-
- return str;
-}
-
-gchar *
-stringify_integer (guchar *data, gint *position)
-{
- gchar buffer[20];
- gchar *str;
-
- sprintf(buffer,"%d",*(int *)(data+*position));
- str = g_strdup (buffer);
-
- *position += sizeof(int);
-
- return str;
-}
-
-gchar *
-stringify_span (guchar *data, gint *position)
-{
- gchar buffer[42];
- gchar *str;
-
- sprintf(buffer,"%d - %d",((int *)(data+*position))[0],
- ((int *)(data+*position))[1]);
- str = g_strdup (buffer);
-
- *position += 2*sizeof(int);
-
- return str;
-}
-
-void
-selection_received (GtkWidget *widget, GtkSelectionData *data)
-{
- int position;
- int i;
- SelType seltype;
- char *str;
-
- if (data->length < 0)
- {
- g_print("Error retrieving selection\n");
- return;
- }
-
- seltype = SEL_TYPE_NONE;
- for (i=0; i<LAST_SEL_TYPE; i++)
- {
- if (seltypes[i] == data->type)
- {
- seltype = i;
- break;
- }
- }
-
- if (seltype == SEL_TYPE_NONE)
- {
- char *name = gdk_atom_name (data->type);
- g_print("Don't know how to handle type: %s (%ld)\n",
- name?name:"<unknown>",
- data->type);
- return;
- }
-
- if (selection_string != NULL)
- g_string_free (selection_string, TRUE);
-
- selection_string = g_string_new (NULL);
-
- gtk_text_freeze (GTK_TEXT (selection_text));
- gtk_text_set_point (GTK_TEXT (selection_text), 0);
- gtk_text_forward_delete (GTK_TEXT (selection_text),
- gtk_text_get_length (GTK_TEXT (selection_text)));
-
- position = 0;
- while (position < data->length)
- {
- switch (seltype)
- {
- case ATOM:
- str = stringify_atom (data->data, &position);
- break;
- case COMPOUND_TEXT:
- case STRING:
- case TEXT:
- str = stringify_text (data->data, &position);
- break;
- case BITMAP:
- case DRAWABLE:
- case PIXMAP:
- case WINDOW:
- case COLORMAP:
- str = stringify_xid (data->data, &position);
- break;
- case INTEGER:
- case PIXEL:
- str = stringify_integer (data->data, &position);
- break;
- case SPAN:
- str = stringify_span (data->data, &position);
- break;
- default:
- {
- char *name = gdk_atom_name (data->type);
- g_print("Can't convert type %s (%ld) to string\n",
- name?name:"<unknown>",
- data->type);
- position = data->length;
- continue;
- }
- }
- gtk_text_insert (GTK_TEXT (selection_text), NULL,
- &selection_text->style->black,
- NULL, str, -1);
- gtk_text_insert (GTK_TEXT (selection_text), NULL,
- &selection_text->style->black,
- NULL, "\n", -1);
- g_string_append (selection_string, str);
- g_free (str);
- }
- gtk_text_thaw (GTK_TEXT (selection_text));
-}
-
-void
-paste (GtkWidget *widget, GtkWidget *entry)
-{
- char *name;
- GdkAtom atom;
-
- name = gtk_entry_get_text (GTK_ENTRY(entry));
- atom = gdk_atom_intern (name, FALSE);
-
- if (atom == GDK_NONE)
- {
- g_print("Could not create atom: \"%s\"\n",name);
- return;
- }
-
- gtk_selection_convert (selection_button, GDK_SELECTION_PRIMARY, atom,
- GDK_CURRENT_TIME);
-}
-
-void
-quit (void)
-{
- gtk_exit (0);
-}
-
-int
-main (int argc, char *argv[])
-{
- GtkWidget *dialog;
- GtkWidget *button;
- GtkWidget *table;
- GtkWidget *label;
- GtkWidget *entry;
- GtkWidget *hscrollbar;
- GtkWidget *vscrollbar;
- GtkWidget *hbox;
-
- static GtkTargetEntry targetlist[] = {
- { "STRING", 0, STRING },
- { "TEXT", 0, TEXT },
- { "COMPOUND_TEXT", 0, COMPOUND_TEXT }
- };
- static gint ntargets = sizeof(targetlist) / sizeof(targetlist[0]);
-
- gtk_init (&argc, &argv);
-
- init_atoms();
-
- dialog = gtk_dialog_new ();
- gtk_widget_set_name (dialog, "Test Input");
- gtk_container_set_border_width (GTK_CONTAINER(dialog), 0);
-
- gtk_signal_connect (GTK_OBJECT (dialog), "destroy",
- GTK_SIGNAL_FUNC (quit), NULL);
-
- table = gtk_table_new (4, 2, FALSE);
- gtk_container_set_border_width (GTK_CONTAINER(table), 10);
-
- gtk_table_set_row_spacing (GTK_TABLE (table), 0, 5);
- gtk_table_set_row_spacing (GTK_TABLE (table), 1, 2);
- gtk_table_set_row_spacing (GTK_TABLE (table), 2, 2);
- gtk_table_set_col_spacing (GTK_TABLE (table), 0, 2);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG(dialog)->vbox),
- table, TRUE, TRUE, 0);
- gtk_widget_show (table);
-
- selection_button = gtk_toggle_button_new_with_label ("Claim Selection");
- gtk_table_attach (GTK_TABLE (table), selection_button, 0, 2, 0, 1,
- GTK_EXPAND | GTK_FILL, 0, 0, 0);
- gtk_widget_show (selection_button);
-
- gtk_signal_connect (GTK_OBJECT(selection_button), "toggled",
- GTK_SIGNAL_FUNC (selection_toggled), NULL);
- gtk_signal_connect (GTK_OBJECT(selection_button), "selection_clear_event",
- GTK_SIGNAL_FUNC (selection_clear), NULL);
- gtk_signal_connect (GTK_OBJECT(selection_button), "selection_received",
- GTK_SIGNAL_FUNC (selection_received), NULL);
-
- gtk_selection_add_targets (selection_button, GDK_SELECTION_PRIMARY,
- targetlist, ntargets);
-
- gtk_signal_connect (GTK_OBJECT(selection_button), "selection_get",
- GTK_SIGNAL_FUNC (selection_get), NULL);
-
- selection_text = gtk_text_new (NULL, NULL);
- gtk_table_attach_defaults (GTK_TABLE (table), selection_text, 0, 1, 1, 2);
- gtk_widget_show (selection_text);
-
- hscrollbar = gtk_hscrollbar_new (GTK_TEXT (selection_text)->hadj);
- gtk_table_attach (GTK_TABLE (table), hscrollbar, 0, 1, 2, 3,
- GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
- gtk_widget_show (hscrollbar);
-
- vscrollbar = gtk_vscrollbar_new (GTK_TEXT (selection_text)->vadj);
- gtk_table_attach (GTK_TABLE (table), vscrollbar, 1, 2, 1, 2,
- GTK_FILL, GTK_EXPAND | GTK_FILL, 0, 0);
- gtk_widget_show (vscrollbar);
-
- hbox = gtk_hbox_new (FALSE, 2);
- gtk_table_attach (GTK_TABLE (table), hbox, 0, 2, 3, 4,
- GTK_EXPAND | GTK_FILL, 0, 0, 0);
- gtk_widget_show (hbox);
-
- label = gtk_label_new ("Target:");
- gtk_box_pack_start (GTK_BOX(hbox), label, FALSE, FALSE, 0);
- gtk_widget_show (label);
-
- entry = gtk_entry_new ();
- gtk_box_pack_start (GTK_BOX(hbox), entry, TRUE, TRUE, 0);
- gtk_widget_show (entry);
-
- /* .. And create some buttons */
- button = gtk_button_new_with_label ("Paste");
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG(dialog)->action_area),
- button, TRUE, TRUE, 0);
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (paste), entry);
- gtk_widget_show (button);
-
- button = gtk_button_new_with_label ("Quit");
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG(dialog)->action_area),
- button, TRUE, TRUE, 0);
-
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (dialog));
- gtk_widget_show (button);
-
- gtk_widget_show (dialog);
-
- gtk_main ();
-
- return 0;
-}
diff --git a/gtk/testtext.c b/gtk/testtext.c
deleted file mode 100644
index badbaf17a7..0000000000
--- a/gtk/testtext.c
+++ /dev/null
@@ -1,2287 +0,0 @@
-#include <stdio.h>
-#include <sys/stat.h>
-#include <errno.h>
-#include <stdlib.h>
-#include <string.h>
-
-#include <gtk/gtk.h>
-#include <gdk/gdkkeysyms.h>
-
-typedef struct _Buffer Buffer;
-typedef struct _View View;
-
-static gint untitled_serial = 1;
-
-GSList *active_window_stack = NULL;
-
-struct _Buffer
-{
- gint refcount;
- GtkTextBuffer *buffer;
- char *filename;
- gint untitled_serial;
- GtkTextTag *invisible_tag;
- GtkTextTag *not_editable_tag;
- GtkTextTag *found_text_tag;
- GtkTextTag *custom_tabs_tag;
- GSList *color_tags;
- guint color_cycle_timeout;
- gdouble start_hue;
-};
-
-struct _View
-{
- GtkWidget *window;
- GtkWidget *text_view;
- GtkAccelGroup *accel_group;
- GtkItemFactory *item_factory;
- Buffer *buffer;
-};
-
-static void push_active_window (GtkWindow *window);
-static void pop_active_window (void);
-static GtkWindow *get_active_window (void);
-
-static Buffer * create_buffer (void);
-static gboolean check_buffer_saved (Buffer *buffer);
-static gboolean save_buffer (Buffer *buffer);
-static gboolean save_as_buffer (Buffer *buffer);
-static char * buffer_pretty_name (Buffer *buffer);
-static void buffer_filename_set (Buffer *buffer);
-static void buffer_search_forward (Buffer *buffer,
- const char *str,
- View *view);
-static void buffer_search_backward (Buffer *buffer,
- const char *str,
- View *view);
-static void buffer_set_colors (Buffer *buffer,
- gboolean enabled);
-static void buffer_cycle_colors (Buffer *buffer);
-
-static View *view_from_widget (GtkWidget *widget);
-
-static View *create_view (Buffer *buffer);
-static void check_close_view (View *view);
-static void close_view (View *view);
-static void view_set_title (View *view);
-static void view_init_menus (View *view);
-static void view_add_example_widgets (View *view);
-
-GSList *buffers = NULL;
-GSList *views = NULL;
-
-static void
-push_active_window (GtkWindow *window)
-{
- g_object_ref (G_OBJECT (window));
- active_window_stack = g_slist_prepend (active_window_stack, window);
-}
-
-static void
-pop_active_window (void)
-{
- gtk_object_unref (active_window_stack->data);
- active_window_stack = g_slist_delete_link (active_window_stack, active_window_stack);
-}
-
-static GtkWindow *
-get_active_window (void)
-{
- if (active_window_stack)
- return active_window_stack->data;
- else
- return NULL;
-}
-
-/*
- * Filesel utility function
- */
-
-typedef gboolean (*FileselOKFunc) (const char *filename, gpointer data);
-
-static void
-filesel_ok_cb (GtkWidget *button, GtkWidget *filesel)
-{
- FileselOKFunc ok_func = g_object_get_data (G_OBJECT (filesel), "ok-func");
- gpointer data = g_object_get_data (G_OBJECT (filesel), "ok-data");
- gint *result = g_object_get_data (G_OBJECT (filesel), "ok-result");
-
- gtk_widget_hide (filesel);
-
- if ((*ok_func) (gtk_file_selection_get_filename (GTK_FILE_SELECTION (filesel)), data))
- {
- gtk_widget_destroy (filesel);
- *result = TRUE;
- }
- else
- gtk_widget_show (filesel);
-}
-
-gboolean
-filesel_run (GtkWindow *parent,
- const char *title,
- const char *start_file,
- FileselOKFunc func,
- gpointer data)
-{
- GtkWidget *filesel = gtk_file_selection_new (title);
- gboolean result = FALSE;
-
- if (!parent)
- parent = get_active_window ();
-
- if (parent)
- gtk_window_set_transient_for (GTK_WINDOW (filesel), parent);
-
- if (start_file)
- gtk_file_selection_set_filename (GTK_FILE_SELECTION (filesel), start_file);
-
-
- g_object_set_data (G_OBJECT (filesel), "ok-func", func);
- g_object_set_data (G_OBJECT (filesel), "ok-data", data);
- g_object_set_data (G_OBJECT (filesel), "ok-result", &result);
-
- gtk_signal_connect (GTK_OBJECT (GTK_FILE_SELECTION (filesel)->ok_button),
- "clicked",
- GTK_SIGNAL_FUNC (filesel_ok_cb), filesel);
- gtk_signal_connect_object (GTK_OBJECT (GTK_FILE_SELECTION (filesel)->cancel_button),
- "clicked",
- GTK_SIGNAL_FUNC (gtk_widget_destroy), GTK_OBJECT (filesel));
-
- gtk_signal_connect (GTK_OBJECT (filesel), "destroy",
- GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
- gtk_window_set_modal (GTK_WINDOW (filesel), TRUE);
-
- gtk_widget_show (filesel);
- gtk_main ();
-
- return result;
-}
-
-/*
- * MsgBox utility functions
- */
-
-static void
-msgbox_yes_cb (GtkWidget *widget, gboolean *result)
-{
- *result = 0;
- gtk_object_destroy (GTK_OBJECT (gtk_widget_get_toplevel (widget)));
-}
-
-static void
-msgbox_no_cb (GtkWidget *widget, gboolean *result)
-{
- *result = 1;
- gtk_object_destroy (GTK_OBJECT (gtk_widget_get_toplevel (widget)));
-}
-
-static gboolean
-msgbox_key_press_cb (GtkWidget *widget, GdkEventKey *event, gpointer data)
-{
- if (event->keyval == GDK_Escape)
- {
- gtk_signal_emit_stop_by_name (GTK_OBJECT (widget), "key_press_event");
- gtk_object_destroy (GTK_OBJECT (widget));
- return TRUE;
- }
-
- return FALSE;
-}
-
-gint
-msgbox_run (GtkWindow *parent,
- const char *message,
- const char *yes_button,
- const char *no_button,
- const char *cancel_button,
- gint default_index)
-{
- gboolean result = -1;
- GtkWidget *dialog;
- GtkWidget *button;
- GtkWidget *label;
- GtkWidget *vbox;
- GtkWidget *button_box;
- GtkWidget *separator;
-
- g_return_val_if_fail (message != NULL, FALSE);
- g_return_val_if_fail (default_index >= 0 && default_index <= 1, FALSE);
-
- if (!parent)
- parent = get_active_window ();
-
- /* Create a dialog
- */
- dialog = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_modal (GTK_WINDOW (dialog), TRUE);
- if (parent)
- gtk_window_set_transient_for (GTK_WINDOW (dialog), parent);
- gtk_window_set_position (GTK_WINDOW (dialog), GTK_WIN_POS_MOUSE);
-
- /* Quit our recursive main loop when the dialog is destroyed.
- */
- gtk_signal_connect (GTK_OBJECT (dialog), "destroy",
- GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
-
- /* Catch Escape key presses and have them destroy the dialog
- */
- gtk_signal_connect (GTK_OBJECT (dialog), "key_press_event",
- GTK_SIGNAL_FUNC (msgbox_key_press_cb), NULL);
-
- /* Fill in the contents of the widget
- */
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (dialog), vbox);
-
- label = gtk_label_new (message);
- gtk_misc_set_padding (GTK_MISC (label), 12, 12);
- gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
- gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, TRUE, 0);
-
- separator = gtk_hseparator_new ();
- gtk_box_pack_start (GTK_BOX (vbox), separator, FALSE, FALSE, 0);
-
- button_box = gtk_hbutton_box_new ();
- gtk_box_pack_start (GTK_BOX (vbox), button_box, FALSE, FALSE, 0);
- gtk_container_set_border_width (GTK_CONTAINER (button_box), 8);
-
-
- /* When Yes is clicked, call the msgbox_yes_cb
- * This sets the result variable and destroys the dialog
- */
- if (yes_button)
- {
- button = gtk_button_new_with_label (yes_button);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_container_add (GTK_CONTAINER (button_box), button);
-
- if (default_index == 0)
- gtk_widget_grab_default (button);
-
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (msgbox_yes_cb), &result);
- }
-
- /* When No is clicked, call the msgbox_no_cb
- * This sets the result variable and destroys the dialog
- */
- if (no_button)
- {
- button = gtk_button_new_with_label (no_button);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_container_add (GTK_CONTAINER (button_box), button);
-
- if (default_index == 0)
- gtk_widget_grab_default (button);
-
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (msgbox_no_cb), &result);
- }
-
- /* When Cancel is clicked, destroy the dialog
- */
- if (cancel_button)
- {
- button = gtk_button_new_with_label (cancel_button);
- GTK_WIDGET_SET_FLAGS (button, GTK_CAN_DEFAULT);
- gtk_container_add (GTK_CONTAINER (button_box), button);
-
- if (default_index == 1)
- gtk_widget_grab_default (button);
-
- gtk_signal_connect_object (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (gtk_object_destroy), GTK_OBJECT (dialog));
- }
-
- gtk_widget_show_all (dialog);
-
- /* Run a recursive main loop until a button is clicked
- * or the user destroys the dialog through the window mananger */
- gtk_main ();
-
- return result;
-}
-
-/*
- * Example buffer filling code
- */
-static gint
-blink_timeout (gpointer data)
-{
- GtkTextTag *tag;
- static gboolean flip = FALSE;
-
- tag = GTK_TEXT_TAG (data);
-
- g_object_set (G_OBJECT (tag),
- "foreground", flip ? "blue" : "purple",
- NULL);
-
- flip = !flip;
-
- return TRUE;
-}
-
-static gint
-tag_event_handler (GtkTextTag *tag, GtkWidget *widget, GdkEvent *event,
- const GtkTextIter *iter, gpointer user_data)
-{
- gint char_index;
-
- char_index = gtk_text_iter_get_offset (iter);
-
- switch (event->type)
- {
- case GDK_MOTION_NOTIFY:
- printf ("Motion event at char %d tag `%s'\n",
- char_index, tag->name);
- break;
-
- case GDK_BUTTON_PRESS:
- printf ("Button press at char %d tag `%s'\n",
- char_index, tag->name);
- break;
-
- case GDK_2BUTTON_PRESS:
- printf ("Double click at char %d tag `%s'\n",
- char_index, tag->name);
- break;
-
- case GDK_3BUTTON_PRESS:
- printf ("Triple click at char %d tag `%s'\n",
- char_index, tag->name);
- break;
-
- case GDK_BUTTON_RELEASE:
- printf ("Button release at char %d tag `%s'\n",
- char_index, tag->name);
- break;
-
- case GDK_KEY_PRESS:
- case GDK_KEY_RELEASE:
- printf ("Key event at char %d tag `%s'\n",
- char_index, tag->name);
- break;
-
- case GDK_ENTER_NOTIFY:
- case GDK_LEAVE_NOTIFY:
- case GDK_PROPERTY_NOTIFY:
- case GDK_SELECTION_CLEAR:
- case GDK_SELECTION_REQUEST:
- case GDK_SELECTION_NOTIFY:
- case GDK_PROXIMITY_IN:
- case GDK_PROXIMITY_OUT:
- case GDK_DRAG_ENTER:
- case GDK_DRAG_LEAVE:
- case GDK_DRAG_MOTION:
- case GDK_DRAG_STATUS:
- case GDK_DROP_START:
- case GDK_DROP_FINISHED:
- default:
- break;
- }
-
- return FALSE;
-}
-
-static void
-setup_tag (GtkTextTag *tag)
-{
- g_signal_connect_data (G_OBJECT (tag),
- "event",
- G_CALLBACK (tag_event_handler),
- NULL, NULL, FALSE, FALSE);
-}
-
-static const char *book_closed_xpm[] = {
-"16 16 6 1",
-" c None s None",
-". c black",
-"X c red",
-"o c yellow",
-"O c #808080",
-"# c white",
-" ",
-" .. ",
-" ..XX. ",
-" ..XXXXX. ",
-" ..XXXXXXXX. ",
-".ooXXXXXXXXX. ",
-"..ooXXXXXXXXX. ",
-".X.ooXXXXXXXXX. ",
-".XX.ooXXXXXX.. ",
-" .XX.ooXXX..#O ",
-" .XX.oo..##OO. ",
-" .XX..##OO.. ",
-" .X.#OO.. ",
-" ..O.. ",
-" .. ",
-" "};
-
-void
-fill_example_buffer (GtkTextBuffer *buffer)
-{
- GtkTextIter iter, iter2;
- GtkTextTag *tag;
- GdkColor color;
- GdkColor color2;
- GdkPixbuf *pixbuf;
- int i;
- char *str;
-
- /* FIXME this is broken if called twice on a buffer, since
- * we try to create tags a second time.
- */
-
- tag = gtk_text_buffer_create_tag (buffer, "fg_blue", NULL);
-
- /* gtk_timeout_add (1000, blink_timeout, tag); */
-
- setup_tag (tag);
-
- color.red = color.green = 0;
- color.blue = 0xffff;
- color2.red = 0xfff;
- color2.blue = 0x0;
- color2.green = 0;
- g_object_set (G_OBJECT (tag),
- "foreground_gdk", &color,
- "background_gdk", &color2,
- "size_points", 24.0,
- NULL);
-
- tag = gtk_text_buffer_create_tag (buffer, "fg_red", NULL);
-
- setup_tag (tag);
-
- color.blue = color.green = 0;
- color.red = 0xffff;
- g_object_set (G_OBJECT (tag),
- "rise", -4 * PANGO_SCALE,
- "foreground_gdk", &color,
- NULL);
-
- tag = gtk_text_buffer_create_tag (buffer, "bg_green", NULL);
-
- setup_tag (tag);
-
- color.blue = color.red = 0;
- color.green = 0xffff;
- g_object_set (G_OBJECT (tag),
- "background_gdk", &color,
- "size_points", 10.0,
- NULL);
-
- tag = gtk_text_buffer_create_tag (buffer, "strikethrough", NULL);
-
- setup_tag (tag);
-
- g_object_set (G_OBJECT (tag),
- "strikethrough", TRUE,
- NULL);
-
-
- tag = gtk_text_buffer_create_tag (buffer, "underline", NULL);
-
- setup_tag (tag);
-
- g_object_set (G_OBJECT (tag),
- "underline", PANGO_UNDERLINE_SINGLE,
- NULL);
-
- setup_tag (tag);
-
- g_object_set (G_OBJECT (tag),
- "underline", PANGO_UNDERLINE_SINGLE,
- NULL);
-
- tag = gtk_text_buffer_create_tag (buffer, "centered", NULL);
-
- g_object_set (G_OBJECT (tag),
- "justification", GTK_JUSTIFY_CENTER,
- NULL);
-
- tag = gtk_text_buffer_create_tag (buffer, "rtl_quote", NULL);
-
- g_object_set (G_OBJECT (tag),
- "wrap_mode", GTK_WRAP_WORD,
- "direction", GTK_TEXT_DIR_RTL,
- "indent", 30,
- "left_margin", 20,
- "right_margin", 20,
- NULL);
-
-
-#if 0
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 0);
-
- anchor = gtk_text_buffer_create_child_anchor (buffer, &iter);
-
- g_object_ref (G_OBJECT (anchor));
-
- g_object_set_data_full (G_OBJECT (buffer), "anchor", anchor,
- (GDestroyNotify) g_object_unref);
-#endif
-
- pixbuf = gdk_pixbuf_new_from_xpm_data (book_closed_xpm);
-
- i = 0;
- while (i < 100)
- {
- GtkTextMark * temp_mark;
-
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 0);
-
- gtk_text_buffer_insert_pixbuf (buffer, &iter, pixbuf);
-
- str = g_strdup_printf ("%d Hello World! blah blah blah blah blah blah blah blah blah blah blah blah\nwoo woo woo woo woo woo woo woo woo woo woo woo woo woo woo\n",
- i);
-
- gtk_text_buffer_insert (buffer, &iter, str, -1);
-
- g_free (str);
-
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter, 0, 5);
-
- gtk_text_buffer_insert (buffer, &iter,
- "(Hello World!)\nfoo foo Hello this is some text we are using to text word wrap. It has punctuation! gee; blah - hmm, great.\nnew line with a significant quantity of text on it. This line really does contain some text. More text! More text! More text!\n"
- /* This is UTF8 stuff, Emacs doesn't
- really know how to display it */
- "German (Deutsch Süd) Grüß Gott Greek (Ελληνικά) Γειά σας Hebrew שלום Japanese (日本語) Thai (สวัสดีครับ!! Oop!! คำต่อไปนื่สะกดผิด พัั้ัั่งโกะ )\n", -1);
-
- temp_mark =
- gtk_text_buffer_create_mark (buffer, "tmp_mark", &iter, TRUE);
-
-#if 1
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter, 0, 6);
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter2, 0, 13);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "fg_blue", &iter, &iter2);
-
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter, 1, 10);
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter2, 1, 16);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "underline", &iter, &iter2);
-
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter, 1, 14);
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter2, 1, 24);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "strikethrough", &iter, &iter2);
-
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter, 0, 9);
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter2, 0, 16);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "bg_green", &iter, &iter2);
-
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter, 4, 2);
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter2, 4, 10);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "bg_green", &iter, &iter2);
-
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter, 4, 8);
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter2, 4, 15);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "fg_red", &iter, &iter2);
-#endif
-
- gtk_text_buffer_get_iter_at_mark (buffer, &iter, temp_mark);
- gtk_text_buffer_insert (buffer, &iter, "Centered text!\n", -1);
-
- gtk_text_buffer_get_iter_at_mark (buffer, &iter2, temp_mark);
- gtk_text_buffer_apply_tag_by_name (buffer, "centered", &iter2, &iter);
-
- gtk_text_buffer_move_mark (buffer, temp_mark, &iter);
- gtk_text_buffer_insert (buffer, &iter, "Word wrapped, Right-to-left Quote\n", -1);
- gtk_text_buffer_insert (buffer, &iter, "وقد بدأ ثلاث من أكثر المؤسسات تقدما في شبكة اكسيون برامجها كمنظمات لا تسعى للربح، ثم تحولت في السنوات الخمس الماضية إلى مؤسسات مالية منظمة، وباتت جزءا من النظام المالي في بلدانها، ولكنها تتخصص في خدمة قطاع المشروعات الصغيرة. وأحد أكثر هذه المؤسسات نجاحا هو »بانكوسول« في بوليفيا.\n", -1);
- gtk_text_buffer_get_iter_at_mark (buffer, &iter2, temp_mark);
- gtk_text_buffer_apply_tag_by_name (buffer, "rtl_quote", &iter2, &iter);
-
- ++i;
- }
-
- g_object_unref (G_OBJECT (pixbuf));
-
- printf ("%d lines %d chars\n",
- gtk_text_buffer_get_line_count (buffer),
- gtk_text_buffer_get_char_count (buffer));
-
- /* Move cursor to start */
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 0);
- gtk_text_buffer_place_cursor (buffer, &iter);
-
- gtk_text_buffer_set_modified (buffer, FALSE);
-}
-
-gboolean
-fill_file_buffer (GtkTextBuffer *buffer, const char *filename)
-{
- FILE* f;
- gchar buf[2048];
- gint remaining = 0;
- GtkTextIter iter, end;
-
- f = fopen (filename, "r");
-
- if (f == NULL)
- {
- gchar *err = g_strdup_printf ("Cannot open file '%s': %s",
- filename, g_strerror (errno));
- msgbox_run (NULL, err, "OK", NULL, NULL, 0);
- g_free (err);
- return FALSE;
- }
-
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 0);
- while (!feof (f))
- {
- gint count;
- const char *leftover;
- int to_read = 2047 - remaining;
-
- count = fread (buf + remaining, 1, to_read, f);
- buf[count + remaining] = '\0';
-
- g_utf8_validate (buf, count + remaining, &leftover);
-
- g_assert (g_utf8_validate (buf, leftover - buf, NULL));
- gtk_text_buffer_insert (buffer, &iter, buf, leftover - buf);
-
- remaining = (buf + remaining + count) - leftover;
- g_memmove (buf, leftover, remaining);
-
- if (remaining > 6 || count < to_read)
- break;
- }
-
- if (remaining)
- {
- gchar *err = g_strdup_printf ("Invalid UTF-8 data encountered reading file '%s'", filename);
- msgbox_run (NULL, err, "OK", NULL, NULL, 0);
- g_free (err);
- }
-
- /* We had a newline in the buffer to begin with. (The buffer always contains
- * a newline, so we delete to the end of the buffer to clean up.
- */
- gtk_text_buffer_get_end_iter (buffer, &end);
- gtk_text_buffer_delete (buffer, &iter, &end);
-
- gtk_text_buffer_set_modified (buffer, FALSE);
-
- return TRUE;
-}
-
-static gint
-delete_event_cb (GtkWidget *window, GdkEventAny *event, gpointer data)
-{
- View *view = view_from_widget (window);
-
- push_active_window (GTK_WINDOW (window));
- check_close_view (view);
- pop_active_window ();
-
- return TRUE;
-}
-
-/*
- * Menu callbacks
- */
-
-static View *
-get_empty_view (View *view)
-{
- if (!view->buffer->filename &&
- !gtk_text_buffer_get_modified (view->buffer->buffer))
- return view;
- else
- return create_view (create_buffer ());
-}
-
-static View *
-view_from_widget (GtkWidget *widget)
-{
- if (GTK_IS_MENU_ITEM (widget))
- {
- GtkItemFactory *item_factory = gtk_item_factory_from_widget (widget);
- return g_object_get_data (G_OBJECT (item_factory), "view");
- }
- else
- {
- GtkWidget *app = gtk_widget_get_toplevel (widget);
- return g_object_get_data (G_OBJECT (app), "view");
- }
-}
-
-static void
-do_new (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- create_view (create_buffer ());
-}
-
-static void
-do_new_view (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- create_view (view->buffer);
-}
-
-gboolean
-open_ok_func (const char *filename, gpointer data)
-{
- View *view = data;
- View *new_view = get_empty_view (view);
-
- if (!fill_file_buffer (new_view->buffer->buffer, filename))
- {
- if (new_view != view)
- close_view (new_view);
- return FALSE;
- }
- else
- {
- g_free (new_view->buffer->filename);
- new_view->buffer->filename = g_strdup (filename);
- buffer_filename_set (new_view->buffer);
-
- return TRUE;
- }
-}
-
-static void
-do_open (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- push_active_window (GTK_WINDOW (view->window));
- filesel_run (NULL, "Open File", NULL, open_ok_func, view);
- pop_active_window ();
-}
-
-static void
-do_save_as (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- push_active_window (GTK_WINDOW (view->window));
- save_as_buffer (view->buffer);
- pop_active_window ();
-}
-
-static void
-do_save (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- push_active_window (GTK_WINDOW (view->window));
- if (!view->buffer->filename)
- do_save_as (callback_data, callback_action, widget);
- else
- save_buffer (view->buffer);
- pop_active_window ();
-}
-
-static void
-do_close (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- push_active_window (GTK_WINDOW (view->window));
- check_close_view (view);
- pop_active_window ();
-}
-
-static void
-do_exit (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- GSList *tmp_list = buffers;
-
- push_active_window (GTK_WINDOW (view->window));
- while (tmp_list)
- {
- if (!check_buffer_saved (tmp_list->data))
- return;
-
- tmp_list = tmp_list->next;
- }
-
- gtk_main_quit ();
- pop_active_window ();
-}
-
-static void
-do_example (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
- View *new_view;
-
- new_view = get_empty_view (view);
-
- fill_example_buffer (new_view->buffer->buffer);
-
- view_add_example_widgets (new_view);
-}
-
-static void
-do_wrap_changed (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- gtk_text_view_set_wrap_mode (GTK_TEXT_VIEW (view->text_view), callback_action);
-}
-
-static void
-do_direction_changed (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- gtk_widget_set_direction (view->text_view, callback_action);
- gtk_widget_queue_resize (view->text_view);
-}
-
-
-static void
-do_spacing_changed (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- if (callback_action)
- {
- gtk_text_view_set_pixels_above_lines (GTK_TEXT_VIEW (view->text_view),
- 23);
- gtk_text_view_set_pixels_below_lines (GTK_TEXT_VIEW (view->text_view),
- 21);
- gtk_text_view_set_pixels_inside_wrap (GTK_TEXT_VIEW (view->text_view),
- 9);
- }
- else
- {
- gtk_text_view_set_pixels_above_lines (GTK_TEXT_VIEW (view->text_view),
- 0);
- gtk_text_view_set_pixels_below_lines (GTK_TEXT_VIEW (view->text_view),
- 0);
- gtk_text_view_set_pixels_inside_wrap (GTK_TEXT_VIEW (view->text_view),
- 0);
- }
-}
-
-static void
-do_editable_changed (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- gtk_text_view_set_editable (GTK_TEXT_VIEW (view->text_view), callback_action);
-}
-
-static void
-do_cursor_visible_changed (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- gtk_text_view_set_cursor_visible (GTK_TEXT_VIEW (view->text_view), callback_action);
-}
-
-static void
-do_color_cycle_changed (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
-
- buffer_set_colors (view->buffer, callback_action);
-}
-
-static void
-do_apply_editable (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
- GtkTextIter start;
- GtkTextIter end;
-
- if (gtk_text_buffer_get_selection_bounds (view->buffer->buffer,
- &start, &end))
- {
- if (callback_action)
- {
- gtk_text_buffer_remove_tag (view->buffer->buffer,
- view->buffer->not_editable_tag,
- &start, &end);
- }
- else
- {
- gtk_text_buffer_apply_tag (view->buffer->buffer,
- view->buffer->not_editable_tag,
- &start, &end);
- }
- }
-}
-
-static void
-do_apply_invisible (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
- GtkTextIter start;
- GtkTextIter end;
-
- if (gtk_text_buffer_get_selection_bounds (view->buffer->buffer,
- &start, &end))
- {
- if (callback_action)
- {
- gtk_text_buffer_remove_tag (view->buffer->buffer,
- view->buffer->invisible_tag,
- &start, &end);
- }
- else
- {
- gtk_text_buffer_apply_tag (view->buffer->buffer,
- view->buffer->invisible_tag,
- &start, &end);
- }
- }
-}
-
-static void
-do_apply_tabs (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
- GtkTextIter start;
- GtkTextIter end;
-
- if (gtk_text_buffer_get_selection_bounds (view->buffer->buffer,
- &start, &end))
- {
- if (callback_action)
- {
- gtk_text_buffer_remove_tag (view->buffer->buffer,
- view->buffer->custom_tabs_tag,
- &start, &end);
- }
- else
- {
- gtk_text_buffer_apply_tag (view->buffer->buffer,
- view->buffer->custom_tabs_tag,
- &start, &end);
- }
- }
-}
-
-static void
-do_apply_colors (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
- Buffer *buffer = view->buffer;
- GtkTextIter start;
- GtkTextIter end;
-
- if (gtk_text_buffer_get_selection_bounds (view->buffer->buffer,
- &start, &end))
- {
- if (!callback_action)
- {
- GSList *tmp;
-
- tmp = buffer->color_tags;
- while (tmp != NULL)
- {
- gtk_text_buffer_remove_tag (view->buffer->buffer,
- tmp->data,
- &start, &end);
- tmp = g_slist_next (tmp);
- }
- }
- else
- {
- GSList *tmp;
-
- tmp = buffer->color_tags;
- while (TRUE)
- {
- GtkTextIter next;
- gboolean done = FALSE;
-
- next = start;
- gtk_text_iter_forward_char (&next);
- gtk_text_iter_forward_char (&next);
-
- if (gtk_text_iter_compare (&next, &end) > 0)
- {
- next = end;
- done = TRUE;
- }
-
- gtk_text_buffer_apply_tag (view->buffer->buffer,
- tmp->data,
- &start, &next);
-
- start = next;
-
- if (done)
- return;
-
- tmp = g_slist_next (tmp);
- if (tmp == NULL)
- tmp = buffer->color_tags;
- }
- }
- }
-}
-
-enum
-{
- RESPONSE_FORWARD,
- RESPONSE_BACKWARD
-};
-
-static void
-dialog_response_callback (GtkWidget *dialog, gint response_id, gpointer data)
-{
- GtkTextBuffer *buffer;
- View *view = data;
- GtkTextIter start, end;
- gchar *search_string;
-
- if (response_id != RESPONSE_FORWARD &&
- response_id != RESPONSE_BACKWARD)
- {
- gtk_widget_destroy (dialog);
- return;
- }
-
- buffer = g_object_get_data (G_OBJECT (dialog), "buffer");
-
- gtk_text_buffer_get_bounds (buffer, &start, &end);
-
- /* Remove trailing newline */
- gtk_text_iter_backward_char (&end);
-
- search_string = gtk_text_iter_get_text (&start, &end);
-
- printf ("Searching for `%s'\n", search_string);
-
- if (response_id == RESPONSE_FORWARD)
- buffer_search_forward (view->buffer, search_string, view);
- else if (response_id == RESPONSE_BACKWARD)
- buffer_search_backward (view->buffer, search_string, view);
-
- g_free (search_string);
-
- gtk_widget_destroy (dialog);
-}
-
-static void
-do_search (gpointer callback_data,
- guint callback_action,
- GtkWidget *widget)
-{
- View *view = view_from_widget (widget);
- GtkWidget *dialog;
- GtkWidget *search_text;
- GtkTextBuffer *buffer;
-
- dialog = gtk_dialog_new_with_buttons ("Search",
- GTK_WINDOW (view->window),
- GTK_DIALOG_DESTROY_WITH_PARENT,
- "Forward", RESPONSE_FORWARD,
- "Backward", RESPONSE_BACKWARD,
- GTK_STOCK_BUTTON_CANCEL,
- GTK_RESPONSE_NONE, NULL);
-
-
- buffer = gtk_text_buffer_new (NULL);
-
- search_text = gtk_text_view_new_with_buffer (buffer);
-
- g_object_unref (G_OBJECT (buffer));
-
- gtk_box_pack_end (GTK_BOX (GTK_DIALOG (dialog)->vbox),
- search_text,
- TRUE, TRUE, 0);
-
- g_object_set_data (G_OBJECT (dialog), "buffer", buffer);
-
- gtk_signal_connect (GTK_OBJECT (dialog),
- "response",
- GTK_SIGNAL_FUNC (dialog_response_callback),
- view);
-
- gtk_widget_show (search_text);
-
- gtk_widget_grab_focus (search_text);
-
- gtk_widget_show_all (dialog);
-}
-
-static void
-view_init_menus (View *view)
-{
- GtkTextDirection direction = gtk_widget_get_direction (view->text_view);
- GtkWrapMode wrap_mode = gtk_text_view_get_wrap_mode (GTK_TEXT_VIEW (view->text_view));
- GtkWidget *menu_item = NULL;
-
- switch (direction)
- {
- case GTK_TEXT_DIR_LTR:
- menu_item = gtk_item_factory_get_widget (view->item_factory, "/Settings/Left-to-Right");
- break;
- case GTK_TEXT_DIR_RTL:
- menu_item = gtk_item_factory_get_widget (view->item_factory, "/Settings/Right-to-Left");
- break;
- default:
- break;
- }
-
- if (menu_item)
- gtk_menu_item_activate (GTK_MENU_ITEM (menu_item));
-
- switch (wrap_mode)
- {
- case GTK_WRAP_NONE:
- menu_item = gtk_item_factory_get_widget (view->item_factory, "/Settings/Wrap Off");
- break;
- case GTK_WRAP_WORD:
- menu_item = gtk_item_factory_get_widget (view->item_factory, "/Settings/Wrap Words");
- break;
- case GTK_WRAP_CHAR:
- menu_item = gtk_item_factory_get_widget (view->item_factory, "/Settings/Wrap Chars");
- break;
- default:
- break;
- }
-
- if (menu_item)
- gtk_menu_item_activate (GTK_MENU_ITEM (menu_item));
-}
-
-static GtkItemFactoryEntry menu_items[] =
-{
- { "/_File", NULL, 0, 0, "<Branch>" },
- { "/File/_New", "<control>N", do_new, 0, NULL },
- { "/File/New _View", NULL, do_new_view, 0, NULL },
- { "/File/_Open", "<control>O", do_open, 0, NULL },
- { "/File/_Save", "<control>S", do_save, 0, NULL },
- { "/File/Save _As...", NULL, do_save_as, 0, NULL },
- { "/File/sep1", NULL, 0, 0, "<Separator>" },
- { "/File/_Close", "<control>W" , do_close, 0, NULL },
- { "/File/E_xit", "<control>Q" , do_exit, 0, NULL },
-
- { "/_Edit", NULL, 0, 0, "<Branch>" },
- { "/Edit/Find...", NULL, do_search, 0, NULL },
-
- { "/_Settings", NULL, 0, 0, "<Branch>" },
- { "/Settings/Wrap _Off", NULL, do_wrap_changed, GTK_WRAP_NONE, "<RadioItem>" },
- { "/Settings/Wrap _Words", NULL, do_wrap_changed, GTK_WRAP_WORD, "/Settings/Wrap Off" },
- { "/Settings/Wrap _Chars", NULL, do_wrap_changed, GTK_WRAP_CHAR, "/Settings/Wrap Off" },
- { "/Settings/sep1", NULL, 0, 0, "<Separator>" },
- { "/Settings/Editable", NULL, do_editable_changed, TRUE, "<RadioItem>" },
- { "/Settings/Not editable", NULL, do_editable_changed, FALSE, "/Settings/Editable" },
- { "/Settings/sep1", NULL, 0, 0, "<Separator>" },
-
- { "/Settings/Cursor visible", NULL, do_cursor_visible_changed, TRUE, "<RadioItem>" },
- { "/Settings/Cursor not visible", NULL, do_cursor_visible_changed, FALSE, "/Settings/Cursor visible" },
- { "/Settings/sep1", NULL, 0, 0, "<Separator>" },
-
- { "/Settings/Left-to-Right", NULL, do_direction_changed, GTK_TEXT_DIR_LTR, "<RadioItem>" },
- { "/Settings/Right-to-Left", NULL, do_direction_changed, GTK_TEXT_DIR_RTL, "/Settings/Left-to-Right" },
-
- { "/Settings/sep1", NULL, 0, 0, "<Separator>" },
- { "/Settings/Sane spacing", NULL, do_spacing_changed, FALSE, "<RadioItem>" },
- { "/Settings/Funky spacing", NULL, do_spacing_changed, TRUE, "/Settings/Sane spacing" },
- { "/Settings/sep1", NULL, 0, 0, "<Separator>" },
- { "/Settings/Don't cycle color tags", NULL, do_color_cycle_changed, FALSE, "<RadioItem>" },
- { "/Settings/Cycle colors", NULL, do_color_cycle_changed, TRUE, "/Settings/Don't cycle color tags" },
- { "/_Attributes", NULL, 0, 0, "<Branch>" },
- { "/Attributes/Editable", NULL, do_apply_editable, TRUE, NULL },
- { "/Attributes/Not editable", NULL, do_apply_editable, FALSE, NULL },
- { "/Attributes/Invisible", NULL, do_apply_invisible, FALSE, NULL },
- { "/Attributes/Visible", NULL, do_apply_invisible, TRUE, NULL },
- { "/Attributes/Custom tabs", NULL, do_apply_tabs, FALSE, NULL },
- { "/Attributes/Default tabs", NULL, do_apply_tabs, TRUE, NULL },
- { "/Attributes/Color cycles", NULL, do_apply_colors, TRUE, NULL },
- { "/Attributes/No colors", NULL, do_apply_colors, FALSE, NULL },
- { "/_Test", NULL, 0, 0, "<Branch>" },
- { "/Test/_Example", NULL, do_example, 0, NULL },
-};
-
-static gboolean
-save_buffer (Buffer *buffer)
-{
- GtkTextIter start, end;
- gchar *chars;
- gboolean result = FALSE;
- gboolean have_backup = FALSE;
- gchar *bak_filename;
- FILE *file;
-
- g_return_val_if_fail (buffer->filename != NULL, FALSE);
-
- bak_filename = g_strconcat (buffer->filename, "~", NULL);
-
- if (rename (buffer->filename, bak_filename) != 0)
- {
- if (errno != ENOENT)
- {
- gchar *err = g_strdup_printf ("Cannot back up '%s' to '%s': %s",
- buffer->filename, bak_filename, g_strerror (errno));
- msgbox_run (NULL, err, "OK", NULL, NULL, 0);
- g_free (err);
- return FALSE;
- }
- }
- else
- have_backup = TRUE;
-
- file = fopen (buffer->filename, "w");
- if (!file)
- {
- gchar *err = g_strdup_printf ("Cannot back up '%s' to '%s': %s",
- buffer->filename, bak_filename, g_strerror (errno));
- msgbox_run (NULL, err, "OK", NULL, NULL, 0);
- }
- else
- {
- gtk_text_buffer_get_iter_at_offset (buffer->buffer, &start, 0);
- gtk_text_buffer_get_end_iter (buffer->buffer, &end);
-
- chars = gtk_text_buffer_get_slice (buffer->buffer, &start, &end, FALSE);
-
- if (fputs (chars, file) == EOF ||
- fclose (file) == EOF)
- {
- gchar *err = g_strdup_printf ("Error writing to '%s': %s",
- buffer->filename, g_strerror (errno));
- msgbox_run (NULL, err, "OK", NULL, NULL, 0);
- g_free (err);
- }
- else
- {
- /* Success
- */
- result = TRUE;
- gtk_text_buffer_set_modified (buffer->buffer, FALSE);
- }
-
- g_free (chars);
- }
-
- if (!result && have_backup)
- {
- if (rename (bak_filename, buffer->filename) != 0)
- {
- gchar *err = g_strdup_printf ("Error restoring backup file '%s' to '%s': %s\nBackup left as '%s'",
- buffer->filename, bak_filename, g_strerror (errno), bak_filename);
- msgbox_run (NULL, err, "OK", NULL, NULL, 0);
- g_free (err);
- }
- }
-
- g_free (bak_filename);
-
- return result;
-}
-
-static gboolean
-save_as_ok_func (const char *filename, gpointer data)
-{
- Buffer *buffer = data;
- char *old_filename = buffer->filename;
-
- if (!buffer->filename || strcmp (filename, buffer->filename) != 0)
- {
- struct stat statbuf;
-
- if (stat (filename, &statbuf) == 0)
- {
- gchar *err = g_strdup_printf ("Ovewrite existing file '%s'?", filename);
- gint result = msgbox_run (NULL, err, "Yes", "No", NULL, 1);
- g_free (err);
-
- if (result != 0)
- return FALSE;
- }
- }
-
- buffer->filename = g_strdup (filename);
-
- if (save_buffer (buffer))
- {
- g_free (old_filename);
- buffer_filename_set (buffer);
- return TRUE;
- }
- else
- {
- g_free (buffer->filename);
- buffer->filename = old_filename;
- return FALSE;
- }
-}
-
-static gboolean
-save_as_buffer (Buffer *buffer)
-{
- return filesel_run (NULL, "Save File", NULL, save_as_ok_func, buffer);
-}
-
-static gboolean
-check_buffer_saved (Buffer *buffer)
-{
- if (gtk_text_buffer_get_modified (buffer->buffer))
- {
- char *pretty_name = buffer_pretty_name (buffer);
- char *msg = g_strdup_printf ("Save changes to '%s'?", pretty_name);
- gint result;
-
- g_free (pretty_name);
-
- result = msgbox_run (NULL, msg, "Yes", "No", "Cancel", 0);
- g_free (msg);
-
- if (result == 0)
- return save_as_buffer (buffer);
- else if (result == 1)
- return TRUE;
- else
- return FALSE;
- }
- else
- return TRUE;
-}
-
-#define N_COLORS 16
-
-static Buffer *
-create_buffer (void)
-{
- Buffer *buffer;
- PangoTabArray *tabs;
- gint i;
-
- buffer = g_new (Buffer, 1);
-
- buffer->buffer = gtk_text_buffer_new (NULL);
-
- buffer->refcount = 1;
- buffer->filename = NULL;
- buffer->untitled_serial = -1;
-
- buffer->color_tags = NULL;
- buffer->color_cycle_timeout = 0;
- buffer->start_hue = 0.0;
-
- i = 0;
- while (i < N_COLORS)
- {
- GtkTextTag *tag;
-
- tag = gtk_text_buffer_create_tag (buffer->buffer, NULL, NULL);
-
- buffer->color_tags = g_slist_prepend (buffer->color_tags, tag);
-
- ++i;
- }
-
- buffer->invisible_tag = gtk_text_buffer_create_tag (buffer->buffer, NULL,
- "invisible", TRUE, NULL);
-
- buffer->not_editable_tag =
- gtk_text_buffer_create_tag (buffer->buffer, NULL,
- "editable", FALSE,
- "foreground", "purple", NULL);
-
- buffer->found_text_tag = gtk_text_buffer_create_tag (buffer->buffer, NULL,
- "foreground", "red", NULL);
-
- tabs = pango_tab_array_new_with_positions (4,
- TRUE,
- PANGO_TAB_LEFT, 10,
- PANGO_TAB_LEFT, 30,
- PANGO_TAB_LEFT, 60,
- PANGO_TAB_LEFT, 120);
-
- buffer->custom_tabs_tag = gtk_text_buffer_create_tag (buffer->buffer, NULL,
- "tabs", tabs,
- "foreground", "green", NULL);
-
- pango_tab_array_free (tabs);
-
- buffers = g_slist_prepend (buffers, buffer);
-
- return buffer;
-}
-
-static char *
-buffer_pretty_name (Buffer *buffer)
-{
- if (buffer->filename)
- {
- char *p;
- char *result = g_path_get_basename (buffer->filename);
- p = strchr (result, '/');
- if (p)
- *p = '\0';
-
- return result;
- }
- else
- {
- if (buffer->untitled_serial == -1)
- buffer->untitled_serial = untitled_serial++;
-
- if (buffer->untitled_serial == 1)
- return g_strdup ("Untitled");
- else
- return g_strdup_printf ("Untitled #%d", buffer->untitled_serial);
- }
-}
-
-static void
-buffer_filename_set (Buffer *buffer)
-{
- GSList *tmp_list = views;
-
- while (tmp_list)
- {
- View *view = tmp_list->data;
-
- if (view->buffer == buffer)
- view_set_title (view);
-
- tmp_list = tmp_list->next;
- }
-}
-
-static void
-buffer_search (Buffer *buffer,
- const char *str,
- View *view,
- gboolean forward)
-{
- GtkTextIter iter;
- GtkTextIter start, end;
- GtkWidget *dialog;
- int i;
-
- /* remove tag from whole buffer */
- gtk_text_buffer_get_bounds (buffer->buffer, &start, &end);
- gtk_text_buffer_remove_tag (buffer->buffer, buffer->found_text_tag,
- &start, &end );
-
- gtk_text_buffer_get_iter_at_mark (buffer->buffer, &iter,
- gtk_text_buffer_get_mark (buffer->buffer,
- "insert"));
-
- i = 0;
- if (*str != '\0')
- {
- GtkTextIter match_start, match_end;
-
- if (forward)
- {
- while (gtk_text_iter_forward_search (&iter, str, TRUE, FALSE,
- &match_start, &match_end,
- NULL))
- {
- ++i;
- gtk_text_buffer_apply_tag (buffer->buffer, buffer->found_text_tag,
- &match_start, &match_end);
-
- iter = match_end;
- }
- }
- else
- {
- while (gtk_text_iter_backward_search (&iter, str, TRUE, FALSE,
- &match_start, &match_end,
- NULL))
- {
- ++i;
- gtk_text_buffer_apply_tag (buffer->buffer, buffer->found_text_tag,
- &match_start, &match_end);
-
- iter = match_start;
- }
- }
- }
-
- dialog = gtk_message_dialog_new (GTK_WINDOW (view->window),
- GTK_MESSAGE_INFO,
- GTK_BUTTONS_OK,
- GTK_DIALOG_DESTROY_WITH_PARENT,
- "%d strings found and marked in red",
- i);
-
- gtk_signal_connect_object (GTK_OBJECT (dialog),
- "response",
- GTK_SIGNAL_FUNC (gtk_widget_destroy),
- GTK_OBJECT (dialog));
-
- gtk_widget_show (dialog);
-}
-
-static void
-buffer_search_forward (Buffer *buffer, const char *str,
- View *view)
-{
- buffer_search (buffer, str, view, TRUE);
-}
-
-static void
-buffer_search_backward (Buffer *buffer, const char *str,
- View *view)
-{
- buffer_search (buffer, str, view, FALSE);
-}
-
-static void
-buffer_ref (Buffer *buffer)
-{
- buffer->refcount++;
-}
-
-static void
-buffer_unref (Buffer *buffer)
-{
- buffer->refcount--;
- if (buffer->refcount == 0)
- {
- buffer_set_colors (buffer, FALSE);
- buffers = g_slist_remove (buffers, buffer);
- g_object_unref (G_OBJECT (buffer->buffer));
- g_free (buffer->filename);
- g_free (buffer);
- }
-}
-
-static void
-hsv_to_rgb (gdouble *h,
- gdouble *s,
- gdouble *v)
-{
- gdouble hue, saturation, value;
- gdouble f, p, q, t;
-
- if (*s == 0.0)
- {
- *h = *v;
- *s = *v;
- *v = *v; /* heh */
- }
- else
- {
- hue = *h * 6.0;
- saturation = *s;
- value = *v;
-
- if (hue >= 6.0)
- hue = 0.0;
-
- f = hue - (int) hue;
- p = value * (1.0 - saturation);
- q = value * (1.0 - saturation * f);
- t = value * (1.0 - saturation * (1.0 - f));
-
- switch ((int) hue)
- {
- case 0:
- *h = value;
- *s = t;
- *v = p;
- break;
-
- case 1:
- *h = q;
- *s = value;
- *v = p;
- break;
-
- case 2:
- *h = p;
- *s = value;
- *v = t;
- break;
-
- case 3:
- *h = p;
- *s = q;
- *v = value;
- break;
-
- case 4:
- *h = t;
- *s = p;
- *v = value;
- break;
-
- case 5:
- *h = value;
- *s = p;
- *v = q;
- break;
-
- default:
- g_assert_not_reached ();
- }
- }
-}
-
-static void
-hue_to_color (gdouble hue,
- GdkColor *color)
-{
- gdouble h, s, v;
-
- h = hue;
- s = 1.0;
- v = 1.0;
-
- g_return_if_fail (hue <= 1.0);
-
- hsv_to_rgb (&h, &s, &v);
-
- color->red = h * 65535;
- color->green = s * 65535;
- color->blue = v * 65535;
-}
-
-
-static gint
-color_cycle_timeout (gpointer data)
-{
- Buffer *buffer = data;
-
- buffer_cycle_colors (buffer);
-
- return TRUE;
-}
-
-static void
-buffer_set_colors (Buffer *buffer,
- gboolean enabled)
-{
- GSList *tmp;
- gdouble hue = 0.0;
-
- if (enabled && buffer->color_cycle_timeout == 0)
- buffer->color_cycle_timeout = gtk_timeout_add (200, color_cycle_timeout, buffer);
- else if (!enabled && buffer->color_cycle_timeout != 0)
- {
- gtk_timeout_remove (buffer->color_cycle_timeout);
- buffer->color_cycle_timeout = 0;
- }
-
- tmp = buffer->color_tags;
- while (tmp != NULL)
- {
- if (enabled)
- {
- GdkColor color;
-
- hue_to_color (hue, &color);
-
- g_object_set (G_OBJECT (tmp->data),
- "foreground_gdk", &color,
- NULL);
- }
- else
- g_object_set (G_OBJECT (tmp->data),
- "foreground_set", FALSE,
- NULL);
-
- hue += 1.0 / N_COLORS;
-
- tmp = g_slist_next (tmp);
- }
-}
-
-static void
-buffer_cycle_colors (Buffer *buffer)
-{
- GSList *tmp;
- gdouble hue = buffer->start_hue;
-
- tmp = buffer->color_tags;
- while (tmp != NULL)
- {
- GdkColor color;
-
- hue_to_color (hue, &color);
-
- g_object_set (G_OBJECT (tmp->data),
- "foreground_gdk", &color,
- NULL);
-
- hue += 1.0 / N_COLORS;
- if (hue > 1.0)
- hue = 0.0;
-
- tmp = g_slist_next (tmp);
- }
-
- buffer->start_hue += 1.0 / N_COLORS;
- if (buffer->start_hue > 1.0)
- buffer->start_hue = 0.0;
-}
-
-static void
-close_view (View *view)
-{
- views = g_slist_remove (views, view);
- buffer_unref (view->buffer);
- gtk_widget_destroy (view->window);
- g_object_unref (G_OBJECT (view->item_factory));
-
- g_free (view);
-
- if (!views)
- gtk_main_quit ();
-}
-
-static void
-check_close_view (View *view)
-{
- if (view->buffer->refcount > 1 ||
- check_buffer_saved (view->buffer))
- close_view (view);
-}
-
-static void
-view_set_title (View *view)
-{
- char *pretty_name = buffer_pretty_name (view->buffer);
- char *title = g_strconcat ("testtext - ", pretty_name, NULL);
-
- gtk_window_set_title (GTK_WINDOW (view->window), title);
-
- g_free (pretty_name);
- g_free (title);
-}
-
-static void
-cursor_set_callback (GtkTextBuffer *buffer,
- const GtkTextIter *location,
- GtkTextMark *mark,
- gpointer user_data)
-{
- GtkTextView *text_view;
-
- /* Redraw tab windows if the cursor moves
- * on the mapped widget (windows may not exist before realization...
- */
-
- text_view = GTK_TEXT_VIEW (user_data);
-
- if (GTK_WIDGET_MAPPED (text_view) &&
- mark == gtk_text_buffer_get_insert (buffer))
- {
- GdkWindow *tab_window;
-
- tab_window = gtk_text_view_get_window (text_view,
- GTK_TEXT_WINDOW_TOP);
-
- gdk_window_invalidate_rect (tab_window, NULL, FALSE);
-
- tab_window = gtk_text_view_get_window (text_view,
- GTK_TEXT_WINDOW_BOTTOM);
-
- gdk_window_invalidate_rect (tab_window, NULL, FALSE);
- }
-}
-
-static gint
-tab_stops_expose (GtkWidget *widget,
- GdkEventExpose *event,
- gpointer user_data)
-{
- gint first_x;
- gint last_x;
- gint i;
- GdkWindow *top_win;
- GdkWindow *bottom_win;
- GtkTextView *text_view;
- GtkTextWindowType type;
- GdkDrawable *target;
- gint *positions = NULL;
- gint size;
- GtkTextAttributes *attrs;
- GtkTextIter insert;
- GtkTextBuffer *buffer;
- gboolean in_pixels;
-
- text_view = GTK_TEXT_VIEW (widget);
-
- /* See if this expose is on the tab stop window */
- top_win = gtk_text_view_get_window (text_view,
- GTK_TEXT_WINDOW_TOP);
-
- bottom_win = gtk_text_view_get_window (text_view,
- GTK_TEXT_WINDOW_BOTTOM);
-
- if (event->window == top_win)
- {
- type = GTK_TEXT_WINDOW_TOP;
- target = top_win;
- }
- else if (event->window == bottom_win)
- {
- type = GTK_TEXT_WINDOW_BOTTOM;
- target = bottom_win;
- }
- else
- return FALSE;
-
- first_x = event->area.x;
- last_x = first_x + event->area.width;
-
- gtk_text_view_window_to_buffer_coords (text_view,
- type,
- first_x,
- 0,
- &first_x,
- NULL);
-
- gtk_text_view_window_to_buffer_coords (text_view,
- type,
- last_x,
- 0,
- &last_x,
- NULL);
-
- buffer = gtk_text_view_get_buffer (text_view);
-
- gtk_text_buffer_get_iter_at_mark (buffer,
- &insert,
- gtk_text_buffer_get_mark (buffer,
- "insert"));
-
- attrs = gtk_text_attributes_new ();
-
- gtk_text_iter_get_attributes (&insert, attrs);
-
- if (attrs->tabs)
- {
- size = pango_tab_array_get_size (attrs->tabs);
-
- pango_tab_array_get_tabs (attrs->tabs,
- NULL,
- &positions);
-
- in_pixels = pango_tab_array_get_positions_in_pixels (attrs->tabs);
- }
- else
- {
- size = 0;
- in_pixels = FALSE;
- }
-
- gtk_text_attributes_unref (attrs);
-
- i = 0;
- while (i < size)
- {
- gint pos;
-
- if (!in_pixels)
- positions[i] = PANGO_PIXELS (positions[i]);
-
- gtk_text_view_buffer_to_window_coords (text_view,
- type,
- positions[i],
- 0,
- &pos,
- NULL);
-
- gdk_draw_line (target,
- widget->style->fg_gc [widget->state],
- pos, 0,
- pos, 15);
-
- ++i;
- }
-
- g_free (positions);
-
- return TRUE;
-}
-
-static void
-get_lines (GtkTextView *text_view,
- gint first_y,
- gint last_y,
- GArray *buffer_coords,
- GArray *numbers,
- gint *countp)
-{
- GtkTextIter iter;
- gint count;
- gint size;
-
- g_array_set_size (buffer_coords, 0);
- g_array_set_size (numbers, 0);
-
- /* Get iter at first y */
- gtk_text_view_get_line_at_y (text_view, &iter, first_y, NULL);
-
- /* For each iter, get its location and add it to the arrays.
- * Stop when we pass last_y
- */
- count = 0;
- size = 0;
-
- while (!gtk_text_iter_is_end (&iter))
- {
- gint y, height;
- gint line_num;
-
- gtk_text_view_get_line_yrange (text_view, &iter, &y, &height);
-
- g_array_append_val (buffer_coords, y);
- line_num = gtk_text_iter_get_line (&iter);
- g_array_append_val (numbers, line_num);
-
- ++count;
-
- if ((y + height) >= last_y)
- break;
-
- gtk_text_iter_forward_line (&iter);
- }
-
- *countp = count;
-}
-
-static gint
-line_numbers_expose (GtkWidget *widget,
- GdkEventExpose *event,
- gpointer user_data)
-{
- gint count;
- GArray *numbers;
- GArray *pixels;
- gint first_y;
- gint last_y;
- gint i;
- GdkWindow *left_win;
- GdkWindow *right_win;
- PangoLayout *layout;
- GtkTextView *text_view;
- GtkTextWindowType type;
- GdkDrawable *target;
-
- text_view = GTK_TEXT_VIEW (widget);
-
- /* See if this expose is on the line numbers window */
- left_win = gtk_text_view_get_window (text_view,
- GTK_TEXT_WINDOW_LEFT);
-
- right_win = gtk_text_view_get_window (text_view,
- GTK_TEXT_WINDOW_RIGHT);
-
- if (event->window == left_win)
- {
- type = GTK_TEXT_WINDOW_LEFT;
- target = left_win;
- }
- else if (event->window == right_win)
- {
- type = GTK_TEXT_WINDOW_RIGHT;
- target = right_win;
- }
- else
- return FALSE;
-
- first_y = event->area.y;
- last_y = first_y + event->area.height;
-
- gtk_text_view_window_to_buffer_coords (text_view,
- type,
- 0,
- first_y,
- NULL,
- &first_y);
-
- gtk_text_view_window_to_buffer_coords (text_view,
- type,
- 0,
- last_y,
- NULL,
- &last_y);
-
- numbers = g_array_new (FALSE, FALSE, sizeof (gint));
- pixels = g_array_new (FALSE, FALSE, sizeof (gint));
-
- get_lines (text_view,
- first_y,
- last_y,
- pixels,
- numbers,
- &count);
-
- /* Draw fully internationalized numbers! */
-
- layout = gtk_widget_create_pango_layout (widget, "");
-
- i = 0;
- while (i < count)
- {
- gint pos;
- gchar *str;
-
- gtk_text_view_buffer_to_window_coords (text_view,
- type,
- 0,
- g_array_index (pixels, gint, i),
- NULL,
- &pos);
-
- str = g_strdup_printf ("%d", g_array_index (numbers, gint, i));
-
- pango_layout_set_text (layout, str, -1);
-
- gtk_paint_layout (widget->style,
- target,
- GTK_WIDGET_STATE (widget),
- NULL,
- widget,
- NULL,
- 2, pos + 2,
- layout);
-
- g_free (str);
-
- ++i;
- }
-
- g_array_free (pixels, TRUE);
- g_array_free (numbers, TRUE);
-
- g_object_unref (G_OBJECT (layout));
-
- return TRUE;
-}
-
-static View *
-create_view (Buffer *buffer)
-{
- View *view;
-
- GtkWidget *sw;
- GtkWidget *vbox;
-
- view = g_new0 (View, 1);
- views = g_slist_prepend (views, view);
-
- view->buffer = buffer;
- buffer_ref (buffer);
-
- view->window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- g_object_set_data (G_OBJECT (view->window), "view", view);
-
- gtk_signal_connect (GTK_OBJECT (view->window), "delete_event",
- GTK_SIGNAL_FUNC (delete_event_cb), NULL);
-
- view->accel_group = gtk_accel_group_new ();
- view->item_factory = gtk_item_factory_new (GTK_TYPE_MENU_BAR, "<main>", view->accel_group);
- g_object_set_data (G_OBJECT (view->item_factory), "view", view);
-
- gtk_item_factory_create_items (view->item_factory, G_N_ELEMENTS (menu_items), menu_items, view);
-
- gtk_window_add_accel_group (GTK_WINDOW (view->window), view->accel_group);
-
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (view->window), vbox);
-
- gtk_box_pack_start (GTK_BOX (vbox),
- gtk_item_factory_get_widget (view->item_factory, "<main>"),
- FALSE, FALSE, 0);
-
- sw = gtk_scrolled_window_new (NULL, NULL);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sw),
- GTK_POLICY_AUTOMATIC,
- GTK_POLICY_AUTOMATIC);
-
- view->text_view = gtk_text_view_new_with_buffer (buffer->buffer);
- gtk_text_view_set_wrap_mode (GTK_TEXT_VIEW (view->text_view),
- GTK_WRAP_WORD);
-
- /* Draw tab stops in the top and bottom windows. */
-
- gtk_text_view_set_border_window_size (GTK_TEXT_VIEW (view->text_view),
- GTK_TEXT_WINDOW_TOP,
- 15);
-
- gtk_text_view_set_border_window_size (GTK_TEXT_VIEW (view->text_view),
- GTK_TEXT_WINDOW_BOTTOM,
- 15);
-
- gtk_signal_connect (GTK_OBJECT (view->text_view),
- "expose_event",
- GTK_SIGNAL_FUNC (tab_stops_expose),
- NULL);
-
- g_signal_connect_data (G_OBJECT (view->buffer->buffer),
- "mark_set",
- GTK_SIGNAL_FUNC (cursor_set_callback),
- view->text_view, NULL, FALSE, FALSE);
-
- /* Draw line numbers in the side windows; we should really be
- * more scientific about what width we set them to.
- */
- gtk_text_view_set_border_window_size (GTK_TEXT_VIEW (view->text_view),
- GTK_TEXT_WINDOW_RIGHT,
- 30);
-
- gtk_text_view_set_border_window_size (GTK_TEXT_VIEW (view->text_view),
- GTK_TEXT_WINDOW_LEFT,
- 30);
-
- gtk_signal_connect (GTK_OBJECT (view->text_view),
- "expose_event",
- GTK_SIGNAL_FUNC (line_numbers_expose),
- NULL);
-
- gtk_box_pack_start (GTK_BOX (vbox), sw, TRUE, TRUE, 0);
- gtk_container_add (GTK_CONTAINER (sw), view->text_view);
-
- gtk_window_set_default_size (GTK_WINDOW (view->window), 500, 500);
-
- gtk_widget_grab_focus (view->text_view);
-
- view_set_title (view);
- view_init_menus (view);
-
- view_add_example_widgets (view);
-
- gtk_widget_show_all (view->window);
- return view;
-}
-
-static void
-view_add_example_widgets (View *view)
-{
- GtkTextChildAnchor *anchor;
- Buffer *buffer;
-
- return;
-
- buffer = view->buffer;
-
- anchor = g_object_get_data (G_OBJECT (buffer->buffer),
- "anchor");
-
- if (anchor && !gtk_text_child_anchor_get_deleted (anchor))
- {
- GtkWidget *widget;
-
- widget = gtk_image_new_from_stock (GTK_STOCK_DIALOG_WARNING,
- GTK_ICON_SIZE_DIALOG);
-
- widget = gtk_button_new_with_label ("Foo");
-
- gtk_text_view_add_child_at_anchor (GTK_TEXT_VIEW (view->text_view),
- widget,
- anchor);
-
- gtk_widget_show (widget);
- }
-}
-
-static gboolean
-file_exists (const char *filename)
-{
- struct stat statbuf;
-
- return stat (filename, &statbuf) == 0;
-}
-void
-test_init ()
-{
- if (file_exists ("../gdk-pixbuf/.libs/libpixbufloader-pnm.so"))
- {
- putenv ("GDK_PIXBUF_MODULEDIR=../gdk-pixbuf/.libs");
- putenv ("GTK_IM_MODULE_FILE=./gtk.immodules");
- }
-}
-
-int
-main (int argc, char** argv)
-{
- Buffer *buffer;
- View *view;
- int i;
-
- test_init ();
- gtk_set_locale ();
- gtk_init (&argc, &argv);
-
- buffer = create_buffer ();
- view = create_view (buffer);
- buffer_unref (buffer);
-
- push_active_window (GTK_WINDOW (view->window));
- for (i=1; i < argc; i++)
- {
- char *filename;
-
- /* Quick and dirty canonicalization - better should be in GLib
- */
-
- if (!g_path_is_absolute (argv[i]))
- {
- char *cwd = g_get_current_dir ();
- filename = g_strconcat (cwd, "/", argv[i], NULL);
- g_free (cwd);
- }
- else
- filename = argv[i];
-
- open_ok_func (filename, view);
-
- if (filename != argv[i])
- g_free (filename);
- }
- pop_active_window ();
-
- gtk_main ();
-
- return 0;
-}
-
-
diff --git a/gtk/testtextbuffer.c b/gtk/testtextbuffer.c
deleted file mode 100644
index bc94c69c4c..0000000000
--- a/gtk/testtextbuffer.c
+++ /dev/null
@@ -1,732 +0,0 @@
-/* Simplistic test suite */
-
-#include <stdio.h>
-
-#include <gtk/gtk.h>
-#include "gtktextbtree.h"
-
-static void fill_buffer (GtkTextBuffer *buffer);
-
-static void run_tests (GtkTextBuffer *buffer);
-
-int
-main (int argc, char** argv)
-{
- GtkTextBuffer *buffer;
- int n;
- gunichar ch;
- GtkTextIter start, end;
-
- gtk_init (&argc, &argv);
-
- /* Check UTF8 unknown char thing */
- g_assert (g_utf8_strlen (gtk_text_unknown_char_utf8, 3) == 1);
- ch = g_utf8_get_char (gtk_text_unknown_char_utf8);
- g_assert (ch == GTK_TEXT_UNKNOWN_CHAR);
-
- /* First, we turn on btree debugging. */
- gtk_debug_flags |= GTK_DEBUG_TEXT;
-
- /* Create a buffer */
- buffer = gtk_text_buffer_new (NULL);
-
- /* Check that buffer starts with one empty line and zero chars */
-
- n = gtk_text_buffer_get_line_count (buffer);
- if (n != 1)
- g_error ("%d lines, expected 1", n);
-
- n = gtk_text_buffer_get_char_count (buffer);
- if (n != 1)
- g_error ("%d chars, expected 1", n);
-
- /* Run gruesome alien test suite on buffer */
- run_tests (buffer);
-
- /* Put stuff in the buffer */
-
- fill_buffer (buffer);
-
- /* Subject stuff-bloated buffer to further torment */
- run_tests (buffer);
-
- /* Delete all stuff from the buffer */
- gtk_text_buffer_get_bounds (buffer, &start, &end);
- gtk_text_buffer_delete (buffer, &start, &end);
-
- /* Check buffer for emptiness (note that a single
- empty line always remains in the buffer) */
- n = gtk_text_buffer_get_line_count (buffer);
- if (n != 1)
- g_error ("%d lines, expected 1", n);
-
- n = gtk_text_buffer_get_char_count (buffer);
- if (n != 1)
- g_error ("%d chars, expected 1", n);
-
- run_tests (buffer);
-
- g_object_unref (G_OBJECT (buffer));
-
- g_print ("All tests passed.\n");
-
- return 0;
-}
-
-static gint
-count_toggles_at_iter (GtkTextIter *iter,
- GtkTextTag *of_tag)
-{
- GSList *tags;
- GSList *tmp;
- gint count = 0;
-
- /* get toggle-ons and toggle-offs */
- tags = gtk_text_iter_get_toggled_tags (iter, TRUE);
- tags = g_slist_concat (tags,
- gtk_text_iter_get_toggled_tags (iter, FALSE));
-
- tmp = tags;
- while (tmp != NULL)
- {
- if (of_tag == NULL)
- ++count;
- else if (of_tag == tmp->data)
- ++count;
-
- tmp = g_slist_next (tmp);
- }
-
- g_slist_free (tags);
-
- return count;
-}
-
-static gint
-count_toggles_in_buffer (GtkTextBuffer *buffer,
- GtkTextTag *of_tag)
-{
- GtkTextIter iter;
- gint count = 0;
-
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 0);
- do
- {
- count += count_toggles_at_iter (&iter, of_tag);
- }
- while (gtk_text_iter_forward_char (&iter));
-
- /* Do the end iterator, because forward_char won't return TRUE
- * on it.
- */
- count += count_toggles_at_iter (&iter, of_tag);
-
- return count;
-}
-
-static void
-check_specific_tag (GtkTextBuffer *buffer,
- const gchar *tag_name)
-{
- GtkTextIter iter;
- GtkTextTag *tag;
- gboolean state;
- gint count;
- gint buffer_count;
- gint last_offset;
-
- tag = gtk_text_tag_table_lookup (gtk_text_buffer_get_tag_table (buffer),
- tag_name);
-
- buffer_count = count_toggles_in_buffer (buffer, tag);
-
- state = FALSE;
- count = 0;
-
- last_offset = -1;
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 0);
- if (gtk_text_iter_toggles_tag (&iter, tag) ||
- gtk_text_iter_forward_to_tag_toggle (&iter, tag))
- {
- do
- {
- gint this_offset;
-
- ++count;
-
- this_offset = gtk_text_iter_get_offset (&iter);
-
- if (this_offset <= last_offset)
- g_error ("forward_to_tag_toggle moved in wrong direction");
-
- last_offset = this_offset;
-
- if (gtk_text_iter_begins_tag (&iter, tag))
- {
- if (state)
- g_error ("Tag %p is already on, and was toggled on?", tag);
- state = TRUE;
- }
- else if (gtk_text_iter_ends_tag (&iter, tag))
- {
- if (!state)
- g_error ("Tag %p toggled off, but wasn't toggled on?", tag);
- state = FALSE;
- }
- else
- g_error ("forward_to_tag_toggle went to a location without a toggle");
- }
- while (gtk_text_iter_forward_to_tag_toggle (&iter, tag));
- }
-
- if (count != buffer_count)
- g_error ("Counted %d tags iterating by char, %d iterating by tag toggle\n",
- buffer_count, count);
-
- state = FALSE;
- count = 0;
-
- gtk_text_buffer_get_end_iter (buffer, &iter);
- last_offset = gtk_text_iter_get_offset (&iter);
- if (gtk_text_iter_toggles_tag (&iter, tag) ||
- gtk_text_iter_backward_to_tag_toggle (&iter, tag))
- {
- do
- {
- gint this_offset;
-
- ++count;
-
- this_offset = gtk_text_iter_get_offset (&iter);
-
- if (this_offset >= last_offset)
- g_error ("backward_to_tag_toggle moved in wrong direction");
-
- last_offset = this_offset;
-
- if (gtk_text_iter_begins_tag (&iter, tag))
- {
- if (!state)
- g_error ("Tag %p wasn't on when we got to the on toggle going backward?", tag);
- state = FALSE;
- }
- else if (gtk_text_iter_ends_tag (&iter, tag))
- {
- if (state)
- g_error ("Tag %p off toggle, but we were already inside a tag?", tag);
- state = TRUE;
- }
- else
- g_error ("backward_to_tag_toggle went to a location without a toggle");
- }
- while (gtk_text_iter_backward_to_tag_toggle (&iter, tag));
- }
-
- if (count != buffer_count)
- g_error ("Counted %d tags iterating by char, %d iterating by tag toggle\n",
- buffer_count, count);
-
-}
-
-static void
-run_tests (GtkTextBuffer *buffer)
-{
- GtkTextIter iter;
- GtkTextIter start;
- GtkTextIter end;
- GtkTextIter mark;
- gint i, j;
- gint num_chars;
- GtkTextMark *bar_mark;
- GtkTextTag *tag;
- GHashTable *tag_states;
- gint count;
- gint buffer_count;
-
- gtk_text_buffer_get_bounds (buffer, &start, &end);
-
- /* Check that walking the tree via chars and via iterators produces
- * the same number of indexable locations.
- */
- num_chars = gtk_text_buffer_get_char_count (buffer);
- iter = start;
- bar_mark = gtk_text_buffer_create_mark (buffer, "bar", &iter, FALSE);
- i = 0;
- while (i < num_chars)
- {
- GtkTextIter current;
- GtkTextMark *foo_mark;
-
- gtk_text_buffer_get_iter_at_offset (buffer, &current, i);
-
- if (!gtk_text_iter_equal (&iter, &current))
- {
- g_error ("get_char_index didn't return current iter");
- }
-
- j = gtk_text_iter_get_offset (&iter);
-
- if (i != j)
- {
- g_error ("iter converted to %d not %d", j, i);
- }
-
- /* get/set mark */
- gtk_text_buffer_get_iter_at_mark (buffer, &mark, bar_mark);
-
- if (!gtk_text_iter_equal (&iter, &mark))
- {
- gtk_text_iter_spew (&iter, "iter");
- gtk_text_iter_spew (&mark, "mark");
- g_error ("Mark not moved to the right place.");
- }
-
- foo_mark = gtk_text_buffer_create_mark (buffer, "foo", &iter, FALSE);
- gtk_text_buffer_get_iter_at_mark (buffer, &mark, foo_mark);
- gtk_text_buffer_delete_mark (buffer, foo_mark);
-
- if (!gtk_text_iter_equal (&iter, &mark))
- {
- gtk_text_iter_spew (&iter, "iter");
- gtk_text_iter_spew (&mark, "mark");
- g_error ("Mark not created in the right place.");
- }
-
- if (gtk_text_iter_is_end (&iter))
- g_error ("iterators ran out before chars (offset %d of %d)",
- i, num_chars);
-
- gtk_text_iter_forward_char (&iter);
-
- gtk_text_buffer_move_mark (buffer, bar_mark, &iter);
-
- ++i;
- }
-
- if (!gtk_text_iter_equal (&iter, &end))
- g_error ("Iterating over all chars didn't end with the end iter");
-
- /* Do the tree-walk backward
- */
- num_chars = gtk_text_buffer_get_char_count (buffer);
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, -1);
-
- gtk_text_buffer_move_mark (buffer, bar_mark, &iter);
-
- i = num_chars;
-
- if (!gtk_text_iter_equal (&iter, &end))
- g_error ("iter at char -1 is not equal to the end iterator");
-
- while (i >= 0)
- {
- GtkTextIter current;
- GtkTextMark *foo_mark;
-
- gtk_text_buffer_get_iter_at_offset (buffer, &current, i);
-
- if (!gtk_text_iter_equal (&iter, &current))
- {
- g_error ("get_char_index didn't return current iter while going backward");
- }
- j = gtk_text_iter_get_offset (&iter);
-
- if (i != j)
- {
- g_error ("going backward, iter converted to %d not %d", j, i);
- }
-
- /* get/set mark */
- gtk_text_buffer_get_iter_at_mark (buffer, &mark, bar_mark);
-
- if (!gtk_text_iter_equal (&iter, &mark))
- {
- gtk_text_iter_spew (&iter, "iter");
- gtk_text_iter_spew (&mark, "mark");
- g_error ("Mark not moved to the right place.");
- }
-
- foo_mark = gtk_text_buffer_create_mark (buffer, "foo", &iter, FALSE);
- gtk_text_buffer_get_iter_at_mark (buffer, &mark, foo_mark);
- gtk_text_buffer_delete_mark (buffer, foo_mark);
-
- if (!gtk_text_iter_equal (&iter, &mark))
- {
- gtk_text_iter_spew (&iter, "iter");
- gtk_text_iter_spew (&mark, "mark");
- g_error ("Mark not created in the right place.");
- }
-
- if (i > 0)
- {
- if (!gtk_text_iter_backward_char (&iter))
- g_error ("iterators ran out before char indexes");
-
- gtk_text_buffer_move_mark (buffer, bar_mark, &iter);
- }
- else
- {
- if (gtk_text_iter_backward_char (&iter))
- g_error ("went backward from 0?");
- }
-
- --i;
- }
-
- if (!gtk_text_iter_equal (&iter, &start))
- g_error ("Iterating backward over all chars didn't end with the start iter");
-
- /*
- * Check that get_line_count returns the same number of lines
- * as walking the tree by line
- */
- i = 1; /* include current (first) line */
- gtk_text_buffer_get_iter_at_line (buffer, &iter, 0);
- while (gtk_text_iter_forward_line (&iter))
- ++i;
-
- if (i != gtk_text_buffer_get_line_count (buffer))
- g_error ("Counted %d lines, buffer has %d", i,
- gtk_text_buffer_get_line_count (buffer));
-
- /*
- * Check that moving over tag toggles thinks about working.
- */
-
- buffer_count = count_toggles_in_buffer (buffer, NULL);
-
- tag_states = g_hash_table_new (NULL, NULL);
- count = 0;
-
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 0);
- if (gtk_text_iter_toggles_tag (&iter, NULL) ||
- gtk_text_iter_forward_to_tag_toggle (&iter, NULL))
- {
- do
- {
- GSList *tags;
- GSList *tmp;
- gboolean found_some = FALSE;
-
- /* get toggled-on tags */
- tags = gtk_text_iter_get_toggled_tags (&iter, TRUE);
-
- if (tags)
- found_some = TRUE;
-
- tmp = tags;
- while (tmp != NULL)
- {
- ++count;
-
- tag = tmp->data;
-
- if (g_hash_table_lookup (tag_states, tag))
- g_error ("Tag %p is already on, and was toggled on?", tag);
-
- g_hash_table_insert (tag_states, tag, GINT_TO_POINTER (TRUE));
-
- tmp = g_slist_next (tmp);
- }
-
- g_slist_free (tags);
-
- /* get toggled-off tags */
- tags = gtk_text_iter_get_toggled_tags (&iter, FALSE);
-
- if (tags)
- found_some = TRUE;
-
- tmp = tags;
- while (tmp != NULL)
- {
- ++count;
-
- tag = tmp->data;
-
- if (!g_hash_table_lookup (tag_states, tag))
- g_error ("Tag %p is already off, and was toggled off?", tag);
-
- g_hash_table_remove (tag_states, tag);
-
- tmp = g_slist_next (tmp);
- }
-
- g_slist_free (tags);
-
- if (!found_some)
- g_error ("No tags found going forward to tag toggle.");
-
- }
- while (gtk_text_iter_forward_to_tag_toggle (&iter, NULL));
- }
-
- g_hash_table_destroy (tag_states);
-
- if (count != buffer_count)
- g_error ("Counted %d tags iterating by char, %d iterating by tag toggle\n",
- buffer_count, count);
-
- /* Go backward; here TRUE in the hash means we saw
- * an off toggle last.
- */
-
- tag_states = g_hash_table_new (NULL, NULL);
- count = 0;
-
- gtk_text_buffer_get_end_iter (buffer, &iter);
- if (gtk_text_iter_toggles_tag (&iter, NULL) ||
- gtk_text_iter_backward_to_tag_toggle (&iter, NULL))
- {
- do
- {
- GSList *tags;
- GSList *tmp;
- gboolean found_some = FALSE;
-
- /* get toggled-off tags */
- tags = gtk_text_iter_get_toggled_tags (&iter, FALSE);
-
- if (tags)
- found_some = TRUE;
-
- tmp = tags;
- while (tmp != NULL)
- {
- ++count;
-
- tag = tmp->data;
-
- if (g_hash_table_lookup (tag_states, tag))
- g_error ("Tag %p has two off-toggles in a row?", tag);
-
- g_hash_table_insert (tag_states, tag, GINT_TO_POINTER (TRUE));
-
- tmp = g_slist_next (tmp);
- }
-
- g_slist_free (tags);
-
- /* get toggled-on tags */
- tags = gtk_text_iter_get_toggled_tags (&iter, TRUE);
-
- if (tags)
- found_some = TRUE;
-
- tmp = tags;
- while (tmp != NULL)
- {
- ++count;
-
- tag = tmp->data;
-
- if (!g_hash_table_lookup (tag_states, tag))
- g_error ("Tag %p was toggled on, but saw no off-toggle?", tag);
-
- g_hash_table_remove (tag_states, tag);
-
- tmp = g_slist_next (tmp);
- }
-
- g_slist_free (tags);
-
- if (!found_some)
- g_error ("No tags found going backward to tag toggle.");
- }
- while (gtk_text_iter_backward_to_tag_toggle (&iter, NULL));
- }
-
- g_hash_table_destroy (tag_states);
-
- if (count != buffer_count)
- g_error ("Counted %d tags iterating by char, %d iterating by tag toggle\n",
- buffer_count, count);
-
- check_specific_tag (buffer, "fg_red");
- check_specific_tag (buffer, "bg_green");
- check_specific_tag (buffer, "front_tag");
- check_specific_tag (buffer, "center_tag");
- check_specific_tag (buffer, "end_tag");
-}
-
-
-static char *book_closed_xpm[] = {
-"16 16 6 1",
-" c None s None",
-". c black",
-"X c red",
-"o c yellow",
-"O c #808080",
-"# c white",
-" ",
-" .. ",
-" ..XX. ",
-" ..XXXXX. ",
-" ..XXXXXXXX. ",
-".ooXXXXXXXXX. ",
-"..ooXXXXXXXXX. ",
-".X.ooXXXXXXXXX. ",
-".XX.ooXXXXXX.. ",
-" .XX.ooXXX..#O ",
-" .XX.oo..##OO. ",
-" .XX..##OO.. ",
-" .X.#OO.. ",
-" ..O.. ",
-" .. ",
-" "};
-
-static void
-fill_buffer (GtkTextBuffer *buffer)
-{
- GtkTextTag *tag;
- GdkColor color, color2;
- GtkTextIter iter;
- GtkTextIter iter2;
- GdkPixbuf *pixbuf;
- int i;
-
- color.red = color.green = 0;
- color.blue = 0xffff;
- color2.red = 0xfff;
- color2.blue = 0x0;
- color2.green = 0;
-
- gtk_text_buffer_create_tag (buffer, "fg_blue",
- "foreground_gdk", &color,
- "background_gdk", &color2,
- "font", "-*-courier-bold-r-*-*-30-*-*-*-*-*-*-*",
- NULL);
-
- color.blue = color.green = 0;
- color.red = 0xffff;
-
- gtk_text_buffer_create_tag (buffer, "fg_red",
- "rise", -4,
- "foreground_gdk", &color,
- NULL);
-
- color.blue = color.red = 0;
- color.green = 0xffff;
-
- gtk_text_buffer_create_tag (buffer, "bg_green",
- "background_gdk", &color,
- "font", "-*-courier-bold-r-*-*-10-*-*-*-*-*-*-*",
- NULL);
-
- pixbuf = gdk_pixbuf_new_from_xpm_data (book_closed_xpm);
-
- g_assert (pixbuf != NULL);
-
- i = 0;
- while (i < 10)
- {
- gchar *str;
-
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 0);
-
- gtk_text_buffer_insert_pixbuf (buffer, &iter, pixbuf);
-
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 1);
-
- gtk_text_buffer_insert_pixbuf (buffer, &iter, pixbuf);
-
- str = g_strdup_printf ("%d Hello World!\nwoo woo woo woo woo woo woo woo\n",
- i);
-
- gtk_text_buffer_insert (buffer, &iter, str, -1);
-
- g_free (str);
-
- gtk_text_buffer_insert (buffer, &iter,
- "(Hello World!)\nfoo foo Hello this is some text we are using to text word wrap. It has punctuation! gee; blah - hmm, great.\nnew line\n\n"
- /* This is UTF8 stuff, Emacs doesn't
- really know how to display it */
- "Spanish (Español) ¡Hola! / French (Français) Bonjour, Salut / German (Deutsch Süd) Grüß Gott (testing Latin-1 chars encoded in UTF8)\nThai (we can't display this, just making sure we don't crash) (ภาษาไทย) สวัสดีครับ, สวัสดีค่ะ\n",
- -1);
-
- gtk_text_buffer_insert_pixbuf (buffer, &iter, pixbuf);
- gtk_text_buffer_insert_pixbuf (buffer, &iter, pixbuf);
-
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 4);
-
- gtk_text_buffer_insert_pixbuf (buffer, &iter, pixbuf);
-
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 7);
-
- gtk_text_buffer_insert_pixbuf (buffer, &iter, pixbuf);
-
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 8);
-
- gtk_text_buffer_insert_pixbuf (buffer, &iter, pixbuf);
-
- gtk_text_buffer_get_iter_at_line_offset (buffer, &iter, 0, 8);
- iter2 = iter;
- gtk_text_iter_forward_chars (&iter2, 10);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "fg_blue", &iter, &iter2);
-
- gtk_text_iter_forward_chars (&iter, 7);
- gtk_text_iter_forward_chars (&iter2, 10);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "bg_green", &iter, &iter2);
-
- gtk_text_iter_forward_chars (&iter, 12);
- gtk_text_iter_forward_chars (&iter2, 10);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "bg_green", &iter, &iter2);
-
- gtk_text_iter_forward_chars (&iter, 10);
- gtk_text_iter_forward_chars (&iter2, 15);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "fg_red", &iter, &iter2);
- gtk_text_buffer_apply_tag_by_name (buffer, "fg_blue", &iter, &iter2);
-
- gtk_text_iter_forward_chars (&iter, 20);
- gtk_text_iter_forward_chars (&iter2, 20);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "fg_red", &iter, &iter2);
- gtk_text_buffer_apply_tag_by_name (buffer, "fg_blue", &iter, &iter2);
-
- gtk_text_iter_backward_chars (&iter, 25);
- gtk_text_iter_forward_chars (&iter2, 5);
-
- gtk_text_buffer_apply_tag_by_name (buffer, "fg_red", &iter, &iter2);
- gtk_text_buffer_apply_tag_by_name (buffer, "fg_blue", &iter, &iter2);
-
- gtk_text_iter_forward_chars (&iter, 15);
- gtk_text_iter_backward_chars (&iter2, 10);
-
- gtk_text_buffer_remove_tag_by_name (buffer, "fg_red", &iter, &iter2);
- gtk_text_buffer_remove_tag_by_name (buffer, "fg_blue", &iter, &iter2);
-
- ++i;
- }
-
- /* Put in tags that are just at the beginning, and just near the end,
- * and just near the middle.
- */
- tag = gtk_text_buffer_create_tag (buffer, "front_tag", NULL);
- gtk_text_buffer_get_iter_at_offset (buffer, &iter, 3);
- gtk_text_buffer_get_iter_at_offset (buffer, &iter2, 300);
-
- gtk_text_buffer_apply_tag (buffer, tag, &iter, &iter2);
-
- tag = gtk_text_buffer_create_tag (buffer, "end_tag", NULL);
- gtk_text_buffer_get_end_iter (buffer, &iter2);
- gtk_text_iter_backward_chars (&iter2, 12);
- iter = iter2;
- gtk_text_iter_backward_chars (&iter, 157);
-
- gtk_text_buffer_apply_tag (buffer, tag, &iter, &iter2);
-
- tag = gtk_text_buffer_create_tag (buffer, "center_tag", NULL);
- gtk_text_buffer_get_iter_at_offset (buffer, &iter,
- gtk_text_buffer_get_char_count (buffer)/2);
- gtk_text_iter_backward_chars (&iter, 37);
- iter2 = iter;
- gtk_text_iter_forward_chars (&iter2, 57);
-
- gtk_text_buffer_apply_tag (buffer, tag, &iter, &iter2);
-
- gdk_pixbuf_unref (pixbuf);
-}
diff --git a/gtk/testthreads.c b/gtk/testthreads.c
deleted file mode 100644
index 2d1e62f1d2..0000000000
--- a/gtk/testthreads.c
+++ /dev/null
@@ -1,162 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-/*
- * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
- * file for a list of people on the GTK+ Team. See the ChangeLog
- * files for a list of changes. These files are distributed with
- * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
- */
-
-#include <stdio.h>
-#include <unistd.h>
-#include <gtk/gtk.h>
-#include "config.h"
-
-#ifdef USE_PTHREADS
-#include <pthread.h>
-
-static int nthreads = 0;
-static pthread_mutex_t nthreads_mutex = PTHREAD_MUTEX_INITIALIZER;
-
-void
-close_cb (GtkWidget *w, gint *flag)
-{
- *flag = 1;
-}
-
-gint
-delete_cb (GtkWidget *w, GdkEvent *event, gint *flag)
-{
- *flag = 1;
- return TRUE;
-}
-
-void *
-counter (void *data)
-{
- gchar *name = data;
- gint flag = 0;
- gint counter = 0;
- gchar buffer[32];
-
- GtkWidget *window;
- GtkWidget *vbox;
- GtkWidget *label;
- GtkWidget *button;
-
- gdk_threads_enter();
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title (GTK_WINDOW (window), name);
- gtk_widget_set_usize (window, 100, 50);
-
- vbox = gtk_vbox_new (FALSE, 0);
-
- gtk_signal_connect (GTK_OBJECT (window), "delete_event",
- GTK_SIGNAL_FUNC (delete_cb), &flag);
-
- gtk_container_add (GTK_CONTAINER (window), vbox);
-
- label = gtk_label_new ("0");
- gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, FALSE, 0);
-
- button = gtk_button_new_with_label ("Close");
- gtk_signal_connect (GTK_OBJECT (button), "clicked",
- GTK_SIGNAL_FUNC (close_cb), &flag);
- gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
-
- gtk_widget_show_all (window);
-
- /* Since flag is only checked or set inside the GTK lock,
- * we don't have to worry about locking it explicitly
- */
- while (!flag)
- {
- sprintf(buffer, "%d", counter);
- gtk_label_set_text (GTK_LABEL (label), buffer);
- gdk_threads_leave();
- counter++;
- /* Give someone else a chance to get the lock next time.
- * Only necessary because we don't do anything else while
- * releasing the lock.
- */
- sleep(0);
-
- gdk_threads_enter();
- }
-
- gtk_widget_destroy (window);
-
- pthread_mutex_lock (&nthreads_mutex);
- nthreads--;
- if (nthreads == 0)
- gtk_main_quit();
- pthread_mutex_unlock (&nthreads_mutex);
-
- gdk_threads_leave();
-
- return NULL;
-}
-
-#endif
-
-int
-main (int argc, char **argv)
-{
-#ifdef USE_PTHREADS
- int i;
-
- if (!gdk_threads_init())
- {
- fprintf(stderr, "Could not initialize threads\n");
- exit(1);
- }
-
- gtk_init (&argc, &argv);
-
- pthread_mutex_lock (&nthreads_mutex);
-
- for (i=0; i<5; i++)
- {
- char buffer[5][10];
- pthread_t thread;
-
- sprintf(buffer[i], "Thread %i", i);
- if (pthread_create (&thread, NULL, counter, buffer[i]))
- {
- fprintf(stderr, "Couldn't create thread\n");
- exit(1);
- }
- nthreads++;
- }
-
- pthread_mutex_unlock (&nthreads_mutex);
-
- gdk_threads_enter();
- gtk_main();
- gdk_threads_leave();
- fprintf(stderr, "Done\n");
-#else /* !USE_PTHREADS */
- fprintf (stderr, "GTK+ not compiled with threads support\n");
- exit (1);
-#endif /* USE_PTHREADS */
-
- return 0;
-}
diff --git a/m4macros/gtk-2.0.m4 b/m4macros/gtk-2.0.m4
index 6b8d91e1b9..b3763444dc 100644
--- a/m4macros/gtk-2.0.m4
+++ b/m4macros/gtk-2.0.m4
@@ -1,69 +1,65 @@
-# Configure paths for GTK+
-# Owen Taylor 97-11-3
+# Configure paths for GLIB
+# Owen Taylor 1997-2001
-dnl AM_PATH_GTK_2_0([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND [, MODULES]]]])
-dnl Test for GTK, and define GTK_CFLAGS and GTK_LIBS
+dnl AM_PATH_GLIB_2_0([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND [, MODULES]]]])
+dnl Test for GLIB, and define GLIB_CFLAGS and GLIB_LIBS, if "gmodule" or
+dnl gthread is specified in MODULES, pass to glib-config
dnl
-AC_DEFUN(AM_PATH_GTK_2_0,
+AC_DEFUN(AM_PATH_GLIB_2_0,
[dnl
-dnl Get the cflags and libraries from the gtk-config-2.0 script
+dnl Get the cflags and libraries from the glib-config-2.0 script
dnl
-AC_ARG_WITH(gtk-prefix,[ --with-gtk-prefix=PFX Prefix where GTK is installed (optional)],
- gtk_config_prefix="$withval", gtk_config_prefix="")
-AC_ARG_WITH(gtk-exec-prefix,[ --with-gtk-exec-prefix=PFX Exec prefix where GTK is installed (optional)],
- gtk_config_exec_prefix="$withval", gtk_config_exec_prefix="")
-AC_ARG_ENABLE(gtktest, [ --disable-gtktest Do not try to compile and run a test GTK program],
- , enable_gtktest=yes)
+AC_ARG_ENABLE(glibtest, [ --disable-glibtest Do not try to compile and run a test GLIB program],
+ , enable_glibtest=yes)
+ pkg_config_args=gtk+-2.0
for module in . $4
do
case "$module" in
gthread)
- gtk_config_args="$gtk_config_args gthread"
+ pkg_config_args="$pkg_config_args gthread-2.0"
;;
esac
done
- if test x$gtk_config_exec_prefix != x ; then
- gtk_config_args="$gtk_config_args --exec-prefix=$gtk_config_exec_prefix"
- if test x${GTK_CONFIG_2_0+set} != xset ; then
- GTK_CONFIG_2_0=$gtk_config_exec_prefix/bin/gtk-config-2.0
- fi
- fi
- if test x$gtk_config_prefix != x ; then
- gtk_config_args="$gtk_config_args --prefix=$gtk_config_prefix"
- if test x${GTK_CONFIG_2_0+set} != xset ; then
- GTK_CONFIG_2_0=$gtk_config_prefix/bin/gtk-config-2.0
- fi
+ min_glib_version=ifelse([$1], ,1.3.3,$1)
+ AC_MSG_CHECKING(for GLIB - version >= $min_glib_version)
+
+ no_glib=""
+
+ AC_PATH_PROG(PKG_CONFIG, pkg-config, no)
+
+ if test x$PKG_CONFIG != xno ; then
+ if pkg-config --atleast-pkgconfig-version 0.5 ; then
+ :
+ else
+ echo *** pkg-config too old; version 0.5 or better required.
+ no_glib=yes
+ PKG_CONFIG=no
+ fi
fi
- AC_PATH_PROG(GTK_CONFIG_2_0, gtk-config-2.0, no)
- min_gtk_version=ifelse([$1], ,1.3.1,$1)
- AC_MSG_CHECKING(for GTK - version >= $min_gtk_version)
- no_gtk=""
- if test "$GTK_CONFIG_2_0" = "no" ; then
- no_gtk=yes
- else
- GTK_CFLAGS=`$GTK_CONFIG_2_0 $gtk_config_args --cflags`
- GTK_LIBS=`$GTK_CONFIG_2_0 $gtk_config_args --libs`
- gtk_config_major_version=`$GTK_CONFIG_2_0 $gtk_config_args --version | \
+ if test x"$no_glib" = x ; then
+ GLIB_CFLAGS=`$PKG_CONFIG $pkg_config_args --cflags`
+ GLIB_LIBS=`$PKG_CONFIG $pkg_config_args --libs`
+ glib_config_major_version=`$PKG_CONFIG glib-2.0 --modversion | \
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'`
- gtk_config_minor_version=`$GTK_CONFIG_2_0 $gtk_config_args --version | \
+ glib_config_minor_version=`$PKG_CONFIG glib-2.0 --modversion | \
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'`
- gtk_config_micro_version=`$GTK_CONFIG_2_0 $gtk_config_args --version | \
+ glib_config_micro_version=`$PKG_CONFIG glib-2.0 --modversion | \
sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'`
- if test "x$enable_gtktest" = "xyes" ; then
+ if test "x$enable_glibtest" = "xyes" ; then
ac_save_CFLAGS="$CFLAGS"
ac_save_LIBS="$LIBS"
- CFLAGS="$CFLAGS $GTK_CFLAGS"
- LIBS="$GTK_LIBS $LIBS"
+ CFLAGS="$CFLAGS $GLIB_CFLAGS"
+ LIBS="$GLIB_LIBS $LIBS"
dnl
-dnl Now check if the installed GTK is sufficiently new. (Also sanity
-dnl checks the results of gtk-config-2.0 to some extent
+dnl Now check if the installed GLIB is sufficiently new. (Also sanity
+dnl checks the results of glib-config-2.0 to some extent
dnl
- rm -f conf.gtktest
+ rm -f conf.glibtest
AC_TRY_RUN([
-#include <gtk/gtk.h>
+#include <glib.h>
#include <stdio.h>
#include <stdlib.h>
@@ -73,98 +69,93 @@ main ()
int major, minor, micro;
char *tmp_version;
- system ("touch conf.gtktest");
+ system ("touch conf.glibtest");
/* HP/UX 9 (%@#!) writes to sscanf strings */
- tmp_version = g_strdup("$min_gtk_version");
+ tmp_version = g_strdup("$min_glib_version");
if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, &micro) != 3) {
- printf("%s, bad version string\n", "$min_gtk_version");
+ printf("%s, bad version string\n", "$min_glib_version");
exit(1);
}
- if ((gtk_major_version != $gtk_config_major_version) ||
- (gtk_minor_version != $gtk_config_minor_version) ||
- (gtk_micro_version != $gtk_config_micro_version))
+ if ((glib_major_version != $glib_config_major_version) ||
+ (glib_minor_version != $glib_config_minor_version) ||
+ (glib_micro_version != $glib_config_micro_version))
{
- printf("\n*** 'gtk-config-2.0 --version' returned %d.%d.%d, but GTK+ (%d.%d.%d)\n",
- $gtk_config_major_version, $gtk_config_minor_version, $gtk_config_micro_version,
- gtk_major_version, gtk_minor_version, gtk_micro_version);
- printf ("*** was found! If gtk-config-2.0 was correct, then it is best\n");
- printf ("*** to remove the old version of GTK+. You may also be able to fix the error\n");
+ printf("\n*** 'pkg-config --modversion glib-2.0' returned %d.%d.%d, but GLIB (%d.%d.%d)\n",
+ $glib_config_major_version, $glib_config_minor_version, $glib_config_micro_version,
+ glib_major_version, glib_minor_version, glib_micro_version);
+ printf ("*** was found! If pkg-config was correct, then it is best\n");
+ printf ("*** to remove the old version of GLib. You may also be able to fix the error\n");
printf("*** by modifying your LD_LIBRARY_PATH enviroment variable, or by editing\n");
printf("*** /etc/ld.so.conf. Make sure you have run ldconfig if that is\n");
printf("*** required on your system.\n");
- printf("*** If gtk-config-2.0 was wrong, set the environment variable GTK_CONFIG_2_0\n");
- printf("*** to point to the correct copy of gtk-config-2.0, and remove the file config.cache\n");
- printf("*** before re-running configure\n");
+ printf("*** If pkg-config was wrong, set the environment variable PKG_CONFIG_PATH\n");
+ printf("*** to point to the correct configuration files\n");
}
-#if defined (GTK_MAJOR_VERSION) && defined (GTK_MINOR_VERSION) && defined (GTK_MICRO_VERSION)
- else if ((gtk_major_version != GTK_MAJOR_VERSION) ||
- (gtk_minor_version != GTK_MINOR_VERSION) ||
- (gtk_micro_version != GTK_MICRO_VERSION))
+ else if ((glib_major_version != GLIB_MAJOR_VERSION) ||
+ (glib_minor_version != GLIB_MINOR_VERSION) ||
+ (glib_micro_version != GLIB_MICRO_VERSION))
{
- printf("*** GTK+ header files (version %d.%d.%d) do not match\n",
- GTK_MAJOR_VERSION, GTK_MINOR_VERSION, GTK_MICRO_VERSION);
+ printf("*** GLIB header files (version %d.%d.%d) do not match\n",
+ GLIB_MAJOR_VERSION, GLIB_MINOR_VERSION, GLIB_MICRO_VERSION);
printf("*** library (version %d.%d.%d)\n",
- gtk_major_version, gtk_minor_version, gtk_micro_version);
+ glib_major_version, glib_minor_version, glib_micro_version);
}
-#endif /* defined (GTK_MAJOR_VERSION) ... */
else
{
- if ((gtk_major_version > major) ||
- ((gtk_major_version == major) && (gtk_minor_version > minor)) ||
- ((gtk_major_version == major) && (gtk_minor_version == minor) && (gtk_micro_version >= micro)))
+ if ((glib_major_version > major) ||
+ ((glib_major_version == major) && (glib_minor_version > minor)) ||
+ ((glib_major_version == major) && (glib_minor_version == minor) && (glib_micro_version >= micro)))
{
return 0;
}
else
{
- printf("\n*** An old version of GTK+ (%d.%d.%d) was found.\n",
- gtk_major_version, gtk_minor_version, gtk_micro_version);
- printf("*** You need a version of GTK+ newer than %d.%d.%d. The latest version of\n",
+ printf("\n*** An old version of GLIB (%d.%d.%d) was found.\n",
+ glib_major_version, glib_minor_version, glib_micro_version);
+ printf("*** You need a version of GLIB newer than %d.%d.%d. The latest version of\n",
major, minor, micro);
- printf("*** GTK+ is always available from ftp://ftp.gtk.org.\n");
+ printf("*** GLIB is always available from ftp://ftp.gtk.org.\n");
printf("***\n");
printf("*** If you have already installed a sufficiently new version, this error\n");
- printf("*** probably means that the wrong copy of the gtk-config-2.0 shell script is\n");
+ printf("*** probably means that the wrong copy of the pkg-config shell script is\n");
printf("*** being found. The easiest way to fix this is to remove the old version\n");
- printf("*** of GTK+, but you can also set the GTK_CONFIG_2_0 environment to point to the\n");
- printf("*** correct copy of gtk-config-2.0. (In this case, you will have to\n");
+ printf("*** of GLIB, but you can also set the PKG_CONFIG environment to point to the\n");
+ printf("*** correct copy of pkg-config. (In this case, you will have to\n");
printf("*** modify your LD_LIBRARY_PATH enviroment variable, or edit /etc/ld.so.conf\n");
printf("*** so that the correct libraries are found at run-time))\n");
}
}
return 1;
}
-],, no_gtk=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
+],, no_glib=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
CFLAGS="$ac_save_CFLAGS"
LIBS="$ac_save_LIBS"
fi
fi
- if test "x$no_gtk" = x ; then
- AC_MSG_RESULT(yes (version $gtk_config_major_version.$gtk_config_minor_version.$gtk_config_micro_version))
+ if test "x$no_glib" = x ; then
+ AC_MSG_RESULT(yes (version $glib_config_major_version.$glib_config_minor_version.$glib_config_micro_version))
ifelse([$2], , :, [$2])
else
AC_MSG_RESULT(no)
- if test "$GTK_CONFIG_2_0" = "no" ; then
- echo "*** The gtk-config-2.0 script installed by GTK could not be found"
- echo "*** If GTK was installed in PREFIX, make sure PREFIX/bin is in"
- echo "*** your path, or set the GTK_CONFIG_2_0 environment variable to the"
- echo "*** full path to gtk-config-2.0."
+ if test "$PKG_CONFIG" = "no" ; then
+ echo "*** A new enough version of pkg-config was not found."
+ echo "*** See http://pkgconfig.sourceforge.net"
else
- if test -f conf.gtktest ; then
+ if test -f conf.glibtest ; then
:
else
- echo "*** Could not run GTK test program, checking why..."
- CFLAGS="$CFLAGS $GTK_CFLAGS"
- LIBS="$LIBS $GTK_LIBS"
+ echo "*** Could not run GLIB test program, checking why..."
+ CFLAGS="$CFLAGS $GLIB_CFLAGS"
+ LIBS="$LIBS $GLIB_LIBS"
AC_TRY_LINK([
-#include <gtk/gtk.h>
+#include <glib.h>
#include <stdio.h>
-], [ return ((gtk_major_version) || (gtk_minor_version) || (gtk_micro_version)); ],
+], [ return ((glib_major_version) || (glib_minor_version) || (glib_micro_version)); ],
[ echo "*** The test program compiled, but did not run. This usually means"
- echo "*** that the run-time linker is not finding GTK or finding the wrong"
- echo "*** version of GTK. If it is not finding GTK, you'll need to set your"
+ echo "*** that the run-time linker is not finding GLIB or finding the wrong"
+ echo "*** version of GLIB. If it is not finding GLIB, you'll need to set your"
echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
echo "*** to the installed location Also, make sure you have run ldconfig if that"
echo "*** is required on your system"
@@ -177,18 +168,18 @@ main ()
echo "***"
echo "*** rpm --erase --nodeps gtk gtk-devel" ],
[ echo "*** The test program failed to compile or link. See the file config.log for the"
- echo "*** exact error that occured. This usually means GTK was incorrectly installed"
- echo "*** or that you have moved GTK since it was installed. In the latter case, you"
- echo "*** may want to edit the gtk-config-2.0 script: $GTK_CONFIG_2_0" ])
+ echo "*** exact error that occured. This usually means GLIB was incorrectly installed"
+ echo "*** or that you have moved GLIB since it was installed. In the latter case, you"
+ echo "*** may want to edit the pkg-config script: $PKG_CONFIG" ])
CFLAGS="$ac_save_CFLAGS"
LIBS="$ac_save_LIBS"
fi
fi
- GTK_CFLAGS=""
- GTK_LIBS=""
+ GLIB_CFLAGS=""
+ GLIB_LIBS=""
ifelse([$3], , :, [$3])
fi
- AC_SUBST(GTK_CFLAGS)
- AC_SUBST(GTK_LIBS)
- rm -f conf.gtktest
+ AC_SUBST(GLIB_CFLAGS)
+ AC_SUBST(GLIB_LIBS)
+ rm -f conf.glibtest
])
diff --git a/modules/input/Makefile.am b/modules/input/Makefile.am
index 354fd810d0..0cd34e963e 100644
--- a/modules/input/Makefile.am
+++ b/modules/input/Makefile.am
@@ -58,5 +58,15 @@ im_inuktitut_la_SOURCES = iminuktitut.c
im_ipa_la_LDFLAGS = -rpath $(moduledir) -avoid-version -module
im_ipa_la_SOURCES = imipa.c
+# We create a dummy theme for the default GTK+ theme
+install-data-local:
+ $(mkinstalldirs) $(DESTDIR)$(sysconfdir)/gtk-2.0
+ $(top_builddir)/gtk/gtk-query-immodules-2.0 > $(DESTDIR)$(sysconfdir)/gtk-2.0/gtk.immodules
+
module_LTLIBRARIES = im-cyrillic-translit.la $(IM_XIM_MODULE) im-viqr.la im-thai-broken.la \
im-inuktitut.la im-ipa.la
+
+gtk.immodules: Makefile.am $(module_LTLIBRARIES)
+ $(top_builddir)/gtk/gtk-query-immodules-2.0 .libs/*.so > gtk.immodules
+
+all-local: gtk.immodules
diff --git a/tests/.cvsignore b/tests/.cvsignore
index 0186a11be5..450c6d654e 100644
--- a/tests/.cvsignore
+++ b/tests/.cvsignore
@@ -4,8 +4,16 @@ makefile.mingw
makefile.msc
.deps
.libs
+simple
+testcalendar
+testgtk
+testinput
+testrgb
+testselection
+testtext
testtreeview
testtreecolumns
testsocket
testsocket_child
testtreefocus
+treestoretest
diff --git a/tests/Makefile.am b/tests/Makefile.am
index d60330472b..5c000571e4 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -31,24 +31,72 @@ LDADDS = @STRIP_BEGIN@ \
@STRIP_END@
noinst_PROGRAMS = \
+ simple \
+ testcalendar \
+ testdnd \
+ testgtk \
+ testinput \
+ testrgb \
+ testselection \
## testsocket \
## testsocket_child \
+ testtext \
+ testtextbuffer \
testtreeview \
testtreefocus \
testtreecolumns \
- testtreesort
+ testtreesort \
+ treestoretest
#testsocket_DEPENDENCIES = $(DEPS)
#testsocket_child_DEPENDENCIES = $(DEPS)
+simple_DEPENDENCIES = $(TEST_DEPS)
+testcalendar_DEPENDENCIES = $(TEST_DEPS)
+testdnd_DEPENDENCIES = $(TEST_DEPS)
+testgtk_DEPENDENCIES = $(TEST_DEPS)
+testinput_DEPENDENCIES = $(TEST_DEPS)
+testrgb_DEPENDENCIES = $(TEST_DEPS)
+testselection_DEPENDENCIES = $(TEST_DEPS)
+testtext_DEPENDENCIES = $(TEST_DEPS)
+testtextbuffer_DEPENDENCIES = $(TEST_DEPS)
testtreeview_DEPENDENCIES = $(DEPS)
testtreefocus_DEPENDENCIES = $(DEPS)
testtreecolumns_DEPENDENCIES = $(DEPS)
testtreesort_DEPENDENCIES = $(DEPS)
+treestoretest_DEPENDENCIES = $(TEST_DEPS)
#testsocket_LDADD = $(LDADDS)
#testsocket_child_LDADD = $(LDADDS)
+simple_LDADD = $(LDADDS)
+testcalendar_LDADD = $(LDADDS)
+testdnd_LDADD = $(LDADDS)
+testgtk_LDADD = $(LDADDS)
+testinput_LDADD = $(LDADDS)
+testrgb_LDADD = $(LDADDS)
+testselection_LDADD = $(LDADDS)
+testtextbuffer_LDADD = $(LDADDS)
testtreeview_LDADD = $(LDADDS)
testtreefocus_LDADD = $(LDADDS)
testtreecolumns_LDADD = $(LDADDS)
testtreesort_LDADD = $(LDADDS)
+testtext_LDADD = $(LDADDS)
+treestoretest_LDADD = $(LDADDS)
+
+EXTRA_DIST += @STRIP_BEGIN@ \
+ testgtk.1 \
+ testgtkrc \
+ testgtkrc2 \
+ circles.xbm \
+ 3DRings.xpm \
+ FilesQueue.xpm \
+ Modeller.xpm \
+ check-y.xpm \
+ check-n.xpm \
+ marble.xpm \
+ test.xpm \
+ check-y.xpm \
+ check-n.xpm \
+ test.xpm \
+@STRIP_END@
+
diff --git a/tests/testgtk.c b/tests/testgtk.c
index f1cfb011a7..3f73136479 100644
--- a/tests/testgtk.c
+++ b/tests/testgtk.c
@@ -39,7 +39,7 @@
#endif
#define GTK_ENABLE_BROKEN
-#include "gtk.h"
+#include "gtk/gtk.h"
#include "gdk/gdk.h"
#include "gdk/gdkkeysyms.h"
diff --git a/tests/testinput.c b/tests/testinput.c
index 4801c31250..eb256bddfb 100644
--- a/tests/testinput.c
+++ b/tests/testinput.c
@@ -25,7 +25,7 @@
*/
#include <stdio.h>
-#include "gtk.h"
+#include "gtk/gtk.h"
/* Backing pixmap for drawing area */
diff --git a/tests/testrgb.c b/tests/testrgb.c
index ccf246b74e..12f088f605 100644
--- a/tests/testrgb.c
+++ b/tests/testrgb.c
@@ -38,7 +38,7 @@
#endif
#include <string.h>
-#include "gtk.h"
+#include "gtk/gtk.h"
static void
quit_func (GtkWidget *widget, gpointer dummy)
diff --git a/tests/testselection.c b/tests/testselection.c
index 4f7f6b7e0b..99d68f06c7 100644
--- a/tests/testselection.c
+++ b/tests/testselection.c
@@ -27,7 +27,7 @@
#include <stdio.h>
#include <string.h>
#define GTK_ENABLE_BROKEN
-#include "gtk.h"
+#include "gtk/gtk.h"
typedef enum {
SEL_TYPE_NONE,
diff --git a/tests/testtextbuffer.c b/tests/testtextbuffer.c
index bc94c69c4c..a5525a5c14 100644
--- a/tests/testtextbuffer.c
+++ b/tests/testtextbuffer.c
@@ -1,9 +1,10 @@
/* Simplistic test suite */
+
#include <stdio.h>
#include <gtk/gtk.h>
-#include "gtktextbtree.h"
+#include "../gtk/gtktexttypes.h" /* Private header, for UNKNOWN_CHAR */
static void fill_buffer (GtkTextBuffer *buffer);