1999-08-16 18:51:52 +00:00
|
|
|
<!-- ##### SECTION Title ##### -->
|
|
|
|
General
|
|
|
|
|
|
|
|
<!-- ##### SECTION Short_Description ##### -->
|
2002-11-23 23:02:10 +00:00
|
|
|
Library initialization and miscellaneous functions
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
<!-- ##### SECTION Long_Description ##### -->
|
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
This section describes the GDK initialization functions and miscellaneous
|
|
|
|
utility functions.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<!-- ##### SECTION See_Also ##### -->
|
|
|
|
<para>
|
|
|
|
|
|
|
|
</para>
|
|
|
|
|
2005-06-20 22:06:27 +00:00
|
|
|
<!-- ##### SECTION Stability_Level ##### -->
|
|
|
|
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
<!-- ##### SECTION Image ##### -->
|
|
|
|
|
|
|
|
|
1999-08-16 18:51:52 +00:00
|
|
|
<!-- ##### FUNCTION gdk_init ##### -->
|
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
Initializes the GDK library and connects to the X server.
|
|
|
|
If initialization fails, a warning message is output and the application
|
2001-11-28 19:05:58 +00:00
|
|
|
terminates with a call to <literal>exit(1)</literal>.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
Any arguments used by GDK are removed from the array and @argc and @argv are
|
|
|
|
updated accordingly.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
GTK+ initializes GDK in gtk_init() and so this function is not usually needed
|
|
|
|
by GTK+ applications.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
|
2000-02-01 04:27:56 +00:00
|
|
|
@argc: the number of command line arguments.
|
|
|
|
@argv: the array of command line arguments.
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
2000-02-01 04:27:56 +00:00
|
|
|
<!-- ##### FUNCTION gdk_init_check ##### -->
|
1999-08-16 18:51:52 +00:00
|
|
|
<para>
|
2001-11-28 19:05:58 +00:00
|
|
|
Initializes the GDK library and connects to the X server, returning %TRUE on
|
2000-02-01 04:27:56 +00:00
|
|
|
success.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
Any arguments used by GDK are removed from the array and @argc and @argv are
|
|
|
|
updated accordingly.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
GTK+ initializes GDK in gtk_init() and so this function is not usually needed
|
|
|
|
by GTK+ applications.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
|
2000-02-01 04:27:56 +00:00
|
|
|
@argc: the number of command line arguments.
|
|
|
|
@argv: the array of command line arguments.
|
2001-11-28 19:05:58 +00:00
|
|
|
@Returns: %TRUE if initialization succeeded.
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
2002-04-30 18:07:51 +00:00
|
|
|
<!-- ##### FUNCTION gdk_parse_args ##### -->
|
|
|
|
<para>
|
|
|
|
|
|
|
|
</para>
|
|
|
|
|
|
|
|
@argc:
|
|
|
|
@argv:
|
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_get_display_arg_name ##### -->
|
|
|
|
<para>
|
|
|
|
|
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
2002-04-30 18:07:51 +00:00
|
|
|
@Returns:
|
|
|
|
|
|
|
|
|
2000-02-01 04:27:56 +00:00
|
|
|
<!-- ##### FUNCTION gdk_set_locale ##### -->
|
1999-08-16 18:51:52 +00:00
|
|
|
<para>
|
2001-11-28 19:05:58 +00:00
|
|
|
Initializes the support for internationalization by calling the <function>setlocale()</function>
|
2000-02-01 04:27:56 +00:00
|
|
|
system call. This function is called by gtk_set_locale() and so GTK+
|
|
|
|
applications should use that instead.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
Markup fixes.
* gdk-pixbuf/tmpl/creating.sgml,
gdk-pixbuf/tmpl/gdk-pixbuf-xlib-from-drawables.sgml,
gdk-pixbuf/tmpl/gdk-pixbuf-xlib-init.sgml,
gdk-pixbuf/tmpl/gdk-pixbuf-xlib-rendering.sgml,
gdk-pixbuf/tmpl/refcounting.sgml: Markup fixes.
* gtk/building.sgml, gtk/resources.sgml: Markup fixes.
* gtk/gtk.types: Remove gtk_text_layout_get_type(). (???)
* gdk/tmpl/general.sgml: Use <envar>, not <envvar>.
* gdk-pixbuf-io.c, gdk-pixbuf-animation.c, gdk-pixbuf-data.c,
gdk-pixbuf-loader.c, gdk-pixbuf-scale.c, gdk-pixbuf-util.c,
gdk-pixdata.c: Markup fixes.
2001-12-17 23:06:47 +00:00
|
|
|
The locale to use is determined by the <envar>LANG</envar> environment variable,
|
2000-02-01 04:27:56 +00:00
|
|
|
so to run an application in a certain locale you can do something like this:
|
|
|
|
<informalexample>
|
|
|
|
<programlisting>
|
|
|
|
export LANG="fr"
|
|
|
|
... run application ...
|
|
|
|
</programlisting>
|
|
|
|
</informalexample>
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
If the locale is not supported by X then it is reset to the standard "C"
|
|
|
|
locale.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
2000-02-01 04:27:56 +00:00
|
|
|
@Returns: the resulting locale.
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_set_sm_client_id ##### -->
|
|
|
|
<para>
|
|
|
|
</para>
|
|
|
|
|
2002-04-30 18:07:51 +00:00
|
|
|
@sm_client_id:
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
2002-11-23 23:02:10 +00:00
|
|
|
<!-- ##### FUNCTION gdk_notify_startup_complete ##### -->
|
|
|
|
<para>
|
|
|
|
|
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
2002-11-23 23:02:10 +00:00
|
|
|
|
|
|
|
|
2007-04-29 18:14:00 +00:00
|
|
|
<!-- ##### FUNCTION gdk_notify_startup_complete_with_id ##### -->
|
|
|
|
<para>
|
|
|
|
|
|
|
|
</para>
|
|
|
|
|
|
|
|
@startup_id:
|
|
|
|
|
|
|
|
|
2001-10-03 18:19:48 +00:00
|
|
|
<!-- ##### FUNCTION gdk_get_program_class ##### -->
|
|
|
|
<para>
|
2001-10-07 18:59:46 +00:00
|
|
|
Gets the program class. Unless the program class has explicitly
|
|
|
|
been set with gdk_set_program_class() or with the <option>--class</option>
|
|
|
|
commandline option, the default value is the program name (determined
|
|
|
|
with g_get_prgname()) with the first character converted to uppercase.
|
2001-10-03 18:19:48 +00:00
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
2001-10-13 05:52:14 +00:00
|
|
|
@Returns: the program class.
|
2001-10-03 18:19:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_set_program_class ##### -->
|
|
|
|
<para>
|
2002-01-11 22:39:03 +00:00
|
|
|
Sets the program class. The X11 backend uses the program class to set
|
|
|
|
the class name part of the <literal>WM_CLASS</literal> property on
|
|
|
|
toplevel windows; see the ICCCM.
|
2001-10-03 18:19:48 +00:00
|
|
|
</para>
|
|
|
|
|
2001-10-07 18:59:46 +00:00
|
|
|
@program_class: a string.
|
2001-10-03 18:19:48 +00:00
|
|
|
|
|
|
|
|
2000-02-01 04:27:56 +00:00
|
|
|
<!-- ##### FUNCTION gdk_get_display ##### -->
|
1999-08-16 18:51:52 +00:00
|
|
|
<para>
|
Markup fixes.
* gdk-pixbuf/tmpl/creating.sgml,
gdk-pixbuf/tmpl/gdk-pixbuf-xlib-from-drawables.sgml,
gdk-pixbuf/tmpl/gdk-pixbuf-xlib-init.sgml,
gdk-pixbuf/tmpl/gdk-pixbuf-xlib-rendering.sgml,
gdk-pixbuf/tmpl/refcounting.sgml: Markup fixes.
* gtk/building.sgml, gtk/resources.sgml: Markup fixes.
* gtk/gtk.types: Remove gtk_text_layout_get_type(). (???)
* gdk/tmpl/general.sgml: Use <envar>, not <envvar>.
* gdk-pixbuf-io.c, gdk-pixbuf-animation.c, gdk-pixbuf-data.c,
gdk-pixbuf-loader.c, gdk-pixbuf-scale.c, gdk-pixbuf-util.c,
gdk-pixdata.c: Markup fixes.
2001-12-17 23:06:47 +00:00
|
|
|
Gets the name of the display, which usually comes from the <envar>DISPLAY</envar>
|
2001-11-28 19:05:58 +00:00
|
|
|
environment variable or the <option>--display</option> command line option.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
2000-02-01 04:27:56 +00:00
|
|
|
@Returns: the name of the display.
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
2000-02-01 04:27:56 +00:00
|
|
|
<!-- ##### FUNCTION gdk_flush ##### -->
|
1999-08-16 18:51:52 +00:00
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
Flushes the X output buffer and waits until all requests have been processed
|
|
|
|
by the server. This is rarely needed by applications. It's main use is for
|
|
|
|
trapping X errors with gdk_error_trap_push() and gdk_error_trap_pop().
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_screen_width ##### -->
|
|
|
|
<para>
|
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
2002-06-08 06:48:27 +00:00
|
|
|
@Returns:
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_screen_height ##### -->
|
|
|
|
<para>
|
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
2002-06-08 06:48:27 +00:00
|
|
|
@Returns:
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_screen_width_mm ##### -->
|
|
|
|
<para>
|
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
2002-06-08 06:48:27 +00:00
|
|
|
@Returns:
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_screen_height_mm ##### -->
|
|
|
|
<para>
|
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
2002-06-08 06:48:27 +00:00
|
|
|
@Returns:
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_pointer_grab ##### -->
|
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
Grabs the pointer (usually a mouse) so that all events are passed to this
|
|
|
|
application until the pointer is ungrabbed with gdk_pointer_ungrab(), or
|
|
|
|
the grab window becomes unviewable.
|
|
|
|
This overrides any previous pointer grab by this client.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
Pointer grabs are used for operations which need complete control over mouse
|
|
|
|
events, even if the mouse leaves the application.
|
|
|
|
For example in GTK+ it is used for Drag and Drop, for dragging the handle in
|
|
|
|
the #GtkHPaned and #GtkVPaned widgets, and for resizing columns in #GtkCList
|
|
|
|
widgets.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
Note that if the event mask of an X window has selected both button press and
|
|
|
|
button release events, then a button press event will cause an automatic
|
|
|
|
pointer grab until the button is released.
|
|
|
|
X does this automatically since most applications expect to receive button
|
|
|
|
press and release events in pairs.
|
|
|
|
It is equivalent to a pointer grab on the window with @owner_events set to
|
2001-11-28 19:05:58 +00:00
|
|
|
%TRUE.
|
2000-02-01 04:27:56 +00:00
|
|
|
</para>
|
2005-07-06 19:56:24 +00:00
|
|
|
<para>
|
|
|
|
If you set up anything at the time you take the grab that needs to be cleaned
|
|
|
|
up when the grab ends, you should handle the #GdkEventGrabBroken events that
|
|
|
|
are emitted when the grab ends unvoluntarily.
|
|
|
|
</para>
|
2000-02-01 04:27:56 +00:00
|
|
|
|
|
|
|
@window: the #GdkWindow which will own the grab (the grab window).
|
2001-11-28 19:05:58 +00:00
|
|
|
@owner_events: if %FALSE then all pointer events are reported with respect to
|
|
|
|
@window and are only reported if selected by @event_mask. If %TRUE then pointer
|
2000-02-01 04:27:56 +00:00
|
|
|
events for this application are reported as normal, but pointer events outside
|
|
|
|
this application are reported with respect to @window and only if selected by
|
|
|
|
@event_mask. In either mode, unreported events are discarded.
|
|
|
|
@event_mask: specifies the event mask, which is used in accordance with
|
2004-01-31 23:28:31 +00:00
|
|
|
@owner_events. Note that only pointer events (i.e. button and motion events)
|
|
|
|
may be selected.
|
2000-06-05 15:18:20 +00:00
|
|
|
@confine_to: If non-%NULL, the pointer will be confined to this
|
|
|
|
window during the grab. If the pointer is outside @confine_to, it will
|
|
|
|
automatically be moved to the closest edge of @confine_to and enter
|
|
|
|
and leave events will be generated as necessary.
|
2001-11-28 19:05:58 +00:00
|
|
|
@cursor: the cursor to display while the grab is active. If this is %NULL then
|
2000-02-01 04:27:56 +00:00
|
|
|
the normal cursors are used for @window and its descendants, and the cursor
|
|
|
|
for @window is used for all other windows.
|
2002-11-08 19:41:50 +00:00
|
|
|
@time_: the timestamp of the event which led to this pointer grab. This usually
|
2001-11-28 19:05:58 +00:00
|
|
|
comes from a #GdkEventButton struct, though %GDK_CURRENT_TIME can be used if
|
2000-02-01 04:27:56 +00:00
|
|
|
the time isn't known.
|
2001-11-28 19:05:58 +00:00
|
|
|
@Returns: %GDK_GRAB_SUCCESS if the grab was successful.
|
2000-02-01 04:27:56 +00:00
|
|
|
|
1999-08-16 18:51:52 +00:00
|
|
|
|
2000-09-07 18:17:06 +00:00
|
|
|
<!-- ##### ENUM GdkGrabStatus ##### -->
|
|
|
|
<para>
|
2001-11-28 19:05:58 +00:00
|
|
|
Returned by gdk_pointer_grab() and gdk_keyboard_grab() to indicate
|
|
|
|
success or the reason for the failure of the grab attempt.
|
2000-09-07 18:17:06 +00:00
|
|
|
</para>
|
|
|
|
|
2001-12-23 22:55:17 +00:00
|
|
|
@GDK_GRAB_SUCCESS: the resource was successfully grabbed.
|
2001-11-28 19:05:58 +00:00
|
|
|
@GDK_GRAB_ALREADY_GRABBED: the resource is actively grabbed by another client.
|
|
|
|
@GDK_GRAB_INVALID_TIME: the resource was grabbed more recently than the
|
2001-12-23 22:55:17 +00:00
|
|
|
specified time.
|
2001-11-28 19:05:58 +00:00
|
|
|
@GDK_GRAB_NOT_VIEWABLE: the grab window or the @confine_to window are not
|
|
|
|
viewable.
|
|
|
|
@GDK_GRAB_FROZEN: the resource is frozen by an active grab of another client.
|
2000-09-07 18:17:06 +00:00
|
|
|
|
2000-02-01 04:27:56 +00:00
|
|
|
<!-- ##### FUNCTION gdk_pointer_ungrab ##### -->
|
|
|
|
<para>
|
Changes multihead reorganizing code for win32 support, mostly from a patch
Wed Jun 5 18:34:47 2002 Owen Taylor <otaylor@redhat.com>
Changes multihead reorganizing code for win32 support,
mostly from a patch by Hans Breuer.
* gdk/gdkcolor.c gdk/x11/gdkcolor-x11.c gdk/gdkcursor.c
gdk/x11/gdkcursor-x11.c gdk/gdkevents.c gdk/x11/gdkevents-x11.c
gdk/gdkfont.c gdk/x11/gdkfont-x11.c gdk/gdkkeys.c
gdk/x11/gdkkeys-x11.c gdk/gdkimage.c gdk/x11/gdkimage-x11.c
gdk/gdkscreen.c gdk/x11/gdkmain-x11.c
gdk/gdkdisplay.c gdk/gdkevents-x11.c gdk/gdkpango.c
gdk/x11/gdkpango-x11.c gdk/gdkselection.c
gdk/x11/gdkselection-x11.c gdk/gdkwindow.c
gdk/x11/gdkwindow-x11.c gdk/gdkvisual.c gdk/x11/gdkvisual-x11.c:
Move port-independent singlehead wrapper functions into
port-independent part of GDK. (#80009)
* gdk/win32/gdkcolor-win32.c gdk/win32/gdkcursor-win32.c
gdk/win32/gdkevents-win32.c gdk/win32/gdkfont-win32.c
gdk/win32/gdkimage-win32.c gdk/win32/gdkkeys-win32.c
gdk/win32/gdkmain-win32.c gdk/win32/gdkproperty-win32.c
gdk/win32/gdkselection-win32.c gdk/win32/gkwindow-win32.c:
Turn singlehead functions into "multihead" functions that ignore
their GdkDisplay or GdkScreen arguments.
* gdk/win32/gdkdrawable-win32.c gdk/win32/gdkevents-win32.c
gdk/win32/gdkinput-win32.c gdk/win32/gdkprivate-win32.h:
Misc multihead-compatibility changes.
* gtk/gtk.def gdk/gdk.def: Update for multihead functions.
* gdk/gdkcolormap.h gdk/gdkvisual.h gdk/x11/gdkcolormap-x11.c
gdk/x11/gdkvisual-x11.c: Remove the screen fields
from the public parts of the colormap/visual structures, add accessors
instead.
* gdk/gdkpixbuf-render.c gdk/gdkpixmap.c gdk/gdkrgb.c
gdk/x11/gdkcolormap-x11.c gdk/x11/gdkimage-x11.c
gdk/x11/gdkimage-x11.c gdk/x11/gdkprivate-x11.h gtk/gtkgc.c
gtk/gtkstyle.c gtk/gtkwidget.c: Use accessors to get the screen
for colormaps, visuals; move the fields into the private
structures for the x11 backend.
* gdk/gdkdisplay.[ch] gdk/x11/gdkdisplay-x11.[ch]
gdk/gdkscreen.[ch] gdk/x11/gdkscreen-x11.c:
Remove virtualization of screen and display functions.
(#79990, patch from Erwann Chenede)
* gdk/win32/gdkdisplay-x11.c gdk/win32/gdkscreen-win32.c
gdk/win32/{Makefile.am, makefile.msc, makefile.mingw}:
New files containing stub implementations of Display,
Screen functions.
* gdk/x11/gdkscreen-x11.[ch] gdk/x11/gdkdisplay-x11.[ch]
gdk/x11/gdkx.h: Clean up function exports and what
headers they are in. (#79954)
* gdk/x11/gdkx.h: Fix macro that was referring to a non-existant
screen->screen_num. (In the patch for #79972, Erwann Chenede)
* gdk/gdkscreen.c gdk/gdkwindow.c gdk/x11/gdkinternals.h
gdk/x11/gdkscreen-x11.c: Fix gdk_screen_get_window_at_pointer()
to use window hooks. (#79972, patch partly from Erwann Chenede)
* gdk/x11/gdkdisplay-x11.c gdk/x11/gdkevents-x11.c: Fix
some warnings.
2002-06-06 00:26:42 +00:00
|
|
|
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
|
2002-11-08 19:41:50 +00:00
|
|
|
@time_:
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
2000-02-01 04:27:56 +00:00
|
|
|
<!-- ##### FUNCTION gdk_pointer_is_grabbed ##### -->
|
1999-08-16 18:51:52 +00:00
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
2002-06-08 06:48:27 +00:00
|
|
|
@Returns:
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
2001-04-17 18:12:46 +00:00
|
|
|
<!-- ##### FUNCTION gdk_set_double_click_time ##### -->
|
|
|
|
<para>
|
|
|
|
|
|
|
|
</para>
|
|
|
|
|
|
|
|
@msec:
|
|
|
|
|
|
|
|
|
1999-08-16 18:51:52 +00:00
|
|
|
<!-- ##### FUNCTION gdk_keyboard_grab ##### -->
|
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
Grabs the keyboard so that all events are passed to this
|
|
|
|
application until the keyboard is ungrabbed with gdk_keyboard_ungrab().
|
|
|
|
This overrides any previous keyboard grab by this client.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
2005-07-06 19:56:24 +00:00
|
|
|
<para>
|
|
|
|
If you set up anything at the time you take the grab that needs to be cleaned
|
|
|
|
up when the grab ends, you should handle the #GdkEventGrabBroken events that
|
|
|
|
are emitted when the grab ends unvoluntarily.
|
|
|
|
</para>
|
1999-08-16 18:51:52 +00:00
|
|
|
|
2000-02-01 04:27:56 +00:00
|
|
|
@window: the #GdkWindow which will own the grab (the grab window).
|
2001-11-28 19:05:58 +00:00
|
|
|
@owner_events: if %FALSE then all keyboard events are reported with respect to
|
|
|
|
@window. If %TRUE then keyboard events for this application are reported as
|
2000-02-01 04:27:56 +00:00
|
|
|
normal, but keyboard events outside this application are reported with respect
|
2000-04-09 20:23:49 +00:00
|
|
|
to @window. Both key press and key release events are always reported,
|
2000-02-01 04:27:56 +00:00
|
|
|
independant of the event mask set by the application.
|
2002-11-08 19:41:50 +00:00
|
|
|
@time_: a timestamp from a #GdkEvent, or %GDK_CURRENT_TIME if no timestamp is
|
2000-02-01 04:27:56 +00:00
|
|
|
available.
|
2001-11-28 19:05:58 +00:00
|
|
|
@Returns: %GDK_GRAB_SUCCESS if the grab was successful.
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_keyboard_ungrab ##### -->
|
|
|
|
<para>
|
|
|
|
</para>
|
|
|
|
|
2002-11-08 19:41:50 +00:00
|
|
|
@time_:
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_beep ##### -->
|
|
|
|
<para>
|
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_error_trap_push ##### -->
|
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
This function allows X errors to be trapped instead of the normal behavior
|
|
|
|
of exiting the application. It should only be used if it is not possible to
|
|
|
|
avoid the X error in any other way.
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
2000-02-01 04:27:56 +00:00
|
|
|
<example>
|
2002-11-23 23:02:10 +00:00
|
|
|
<title>Trapping an X error</title>
|
2000-02-01 04:27:56 +00:00
|
|
|
<programlisting>
|
2002-04-18 22:04:46 +00:00
|
|
|
gdk_error_trap_push (<!-- -->);
|
2000-02-01 04:27:56 +00:00
|
|
|
|
|
|
|
/* ... Call the X function which may cause an error here ... */
|
|
|
|
|
|
|
|
/* Flush the X queue to catch errors now. */
|
2002-04-18 22:04:46 +00:00
|
|
|
gdk_flush (<!-- -->);
|
2000-02-01 04:27:56 +00:00
|
|
|
|
2002-04-18 22:04:46 +00:00
|
|
|
if (gdk_error_trap_pop (<!-- -->))
|
2000-02-01 04:27:56 +00:00
|
|
|
{
|
|
|
|
/* ... Handle the error here ... */
|
|
|
|
}
|
|
|
|
</programlisting>
|
|
|
|
</example>
|
1999-08-16 18:51:52 +00:00
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### FUNCTION gdk_error_trap_pop ##### -->
|
|
|
|
<para>
|
2000-02-01 04:27:56 +00:00
|
|
|
Removes the X error trap installed with gdk_error_trap_push().
|
1999-08-16 18:51:52 +00:00
|
|
|
</para>
|
|
|
|
|
2010-05-08 05:18:53 +00:00
|
|
|
@void:
|
2000-02-01 04:27:56 +00:00
|
|
|
@Returns: the X error code, or 0 if no error occurred.
|
1999-08-16 18:51:52 +00:00
|
|
|
|
|
|
|
|
2000-09-07 18:17:06 +00:00
|
|
|
<!-- ##### MACRO GDK_WINDOWING_X11 ##### -->
|
|
|
|
<para>
|
2010-05-25 15:54:16 +00:00
|
|
|
This macro is defined if GDK is configured to use the X11 backend.
|
|
|
|
</para>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<!-- ##### MACRO GDK_WINDOWING_WIN32 ##### -->
|
|
|
|
<para>
|
|
|
|
This macro is defined if GDK is configured to use the win32 backend.
|
2000-09-07 18:17:06 +00:00
|
|
|
</para>
|
|
|
|
|
|
|
|
|
|
|
|
|