Tue Apr 25 10:25:28 2006 Søren Sandmann <sandmann@redhat.com> * tests/testgtk.c (create_alpha_window): Create 'composited' label. * tests/testgtk.c (on_composited_changed): New function, change the label to say whether the screen is composited or not. * gtk/gtkwindow.c (gtk_window_on_composited_changed): When composited status change, invalidate the window and propagate the signal;. * gtk/gtkwindow.c (gtk_window_map): Set the appropriate type hint if reset_type_hint is TRUE. * gtk/gtkwindow.c (gtk_window_set_type_hint): If hint is one of the old hints, store a shadow copy in the public window->type_hint bitfield, otherwise set this field to normal. Set the private field to the type hint. * gtk/gtkwindow.c (gtk_window_init): Initialize priv->type_hint. * gtk/gtkwindow.c (struct _GtkWindowPrivate): New field "reset_type_hint" indicating whether the type hint needs to be reset. New field type_hint containing a GdkWindowTypeHint. * gtk/gtkwidget.c (propagate_composited_changed): New function to propagate changes in composited status. (gtk_widget_class_init): Add composited_changed signal. * gtk/gtkwidget.h (struct _GtkWidgetClass): New signal composited-changed. * gtk/gtkwidget.c (gtk_widget_is_composited): New function. * gtk/gtktooltips.c (gtk_tooltips_draw_tips): Set transient for. * gtk/gtktooltips.c (gtk_tooltips_force_window): Set the type hint * gtk/gtkmenuitem.c (gtk_menu_item_position_menu): Compute whether the item belongs to a menubar. Set the type_hint appropriately depending on the outcome. * gtk/gtkmenu.c (gtk_menu_position): Set the default type hint here. * gtk/gtkmenu.c (gtk_menu_attach_to_widget): connect to hierarchy changed on the attach widget. * gtk/gtkmenu.c (attach_widget_hierarchy_changed): New function to set the transient_for property for menus. * gtk/gtkdnd.c (set_icon_stock_pixbuf): Set the appropriate type hint. * gtk/gtkcombo.c (gtk_combo_popup_list): Make the popup window transient for the toplevel. * gtk/gtkcombobox.c (gtk_combo_box_set_popup_widget): Set transient-for, for the popup window. * gdk/x11/gdkwindow-x11.c (gdk_window_get_type_hint): Support for new window types. * gdk/x11/gdkwindow-x11.c (gdk_window_set_type_hint): Add support for new window types. * gdk/x11/gdkscreen-x11.c (_gdk_x11_screen_process_owner_change): New function called whenever the compositing manager comes and goes. * gdk/x11/gdkscreen-x11.c (gdk_screen_is_composited): New function. * gdk/x11/gdkscreen-x11.c (_gdk_x11_screen_request_cm_notification, make_cm_atom, check_is_composited): New functions * gdk/x11/gdkevents-x11.c (gdk_event_translate): Call _gdk_x11_screen_process_owner_change when an XFixesSelectionNotifyEvent is received. * gdk/x11/gdkdisplay-x11.c (gdk_display_open): Call _gdk_x11_screen_request_cm_notification() on all screens. * gdk/quartz/gdkscreen-quartz.c (gdk_screen_is_composited): Dummy implementation. * gdk/gdkscreen.c (gdk_screen_class_init): New signal, 'composited-changed'. * gdk/gdkwindow.h: Add new EWMH window types. * gdk/win32/gdkscreen-win32.c (gdk_screen_is_composited)
		
			
				
	
	
		
			131 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			131 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* 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/. 
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef __GTK_MENU_ITEM_H__
 | 
						|
#define __GTK_MENU_ITEM_H__
 | 
						|
 | 
						|
 | 
						|
#include <gdk/gdk.h>
 | 
						|
#include <gtk/gtkitem.h>
 | 
						|
 | 
						|
 | 
						|
G_BEGIN_DECLS
 | 
						|
 | 
						|
#define	GTK_TYPE_MENU_ITEM		(gtk_menu_item_get_type ())
 | 
						|
#define GTK_MENU_ITEM(obj)		(G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_MENU_ITEM, GtkMenuItem))
 | 
						|
#define GTK_MENU_ITEM_CLASS(klass)	(G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_MENU_ITEM, GtkMenuItemClass))
 | 
						|
#define GTK_IS_MENU_ITEM(obj)		(G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_MENU_ITEM))
 | 
						|
#define GTK_IS_MENU_ITEM_CLASS(klass)	(G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_MENU_ITEM))
 | 
						|
#define GTK_MENU_ITEM_GET_CLASS(obj)    (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_MENU_ITEM, GtkMenuItemClass))
 | 
						|
 | 
						|
 | 
						|
typedef struct _GtkMenuItem	  GtkMenuItem;
 | 
						|
typedef struct _GtkMenuItemClass  GtkMenuItemClass;
 | 
						|
 | 
						|
struct _GtkMenuItem
 | 
						|
{
 | 
						|
  GtkItem item;
 | 
						|
  
 | 
						|
  GtkWidget *submenu;
 | 
						|
  GdkWindow *event_window;
 | 
						|
  
 | 
						|
  guint16 toggle_size;
 | 
						|
  guint16 accelerator_width;
 | 
						|
  gchar  *accel_path;
 | 
						|
  
 | 
						|
  guint show_submenu_indicator : 1;
 | 
						|
  guint submenu_placement : 1;
 | 
						|
  guint submenu_direction : 1;
 | 
						|
  guint right_justify: 1;
 | 
						|
  guint timer_from_keypress : 1;
 | 
						|
  guint from_menubar : 1;
 | 
						|
  guint timer;
 | 
						|
};
 | 
						|
 | 
						|
struct _GtkMenuItemClass
 | 
						|
{
 | 
						|
  GtkItemClass parent_class;
 | 
						|
  
 | 
						|
  /* If the following flag is true, then we should always hide
 | 
						|
   * the menu when the MenuItem is activated. Otherwise, the 
 | 
						|
   * it is up to the caller. For instance, when navigating
 | 
						|
   * a menu with the keyboard, <Space> doesn't hide, but
 | 
						|
   * <Return> does.
 | 
						|
   */
 | 
						|
  guint hide_on_activate : 1;
 | 
						|
  
 | 
						|
  void (* activate)             (GtkMenuItem *menu_item);
 | 
						|
  void (* activate_item)        (GtkMenuItem *menu_item);
 | 
						|
  void (* toggle_size_request)  (GtkMenuItem *menu_item,
 | 
						|
				 gint        *requisition);
 | 
						|
  void (* toggle_size_allocate) (GtkMenuItem *menu_item,
 | 
						|
				 gint         allocation);
 | 
						|
 | 
						|
  /* Padding for future expansion */
 | 
						|
  void (*_gtk_reserved1) (void);
 | 
						|
  void (*_gtk_reserved2) (void);
 | 
						|
  void (*_gtk_reserved3) (void);
 | 
						|
  void (*_gtk_reserved4) (void);
 | 
						|
};
 | 
						|
 | 
						|
 | 
						|
GType	   gtk_menu_item_get_type	      (void) G_GNUC_CONST;
 | 
						|
GtkWidget* gtk_menu_item_new                  (void);
 | 
						|
GtkWidget* gtk_menu_item_new_with_label       (const gchar         *label);
 | 
						|
GtkWidget* gtk_menu_item_new_with_mnemonic    (const gchar         *label);
 | 
						|
void       gtk_menu_item_set_submenu          (GtkMenuItem         *menu_item,
 | 
						|
					       GtkWidget           *submenu);
 | 
						|
GtkWidget* gtk_menu_item_get_submenu          (GtkMenuItem         *menu_item);
 | 
						|
void       gtk_menu_item_remove_submenu       (GtkMenuItem         *menu_item);
 | 
						|
void       gtk_menu_item_select               (GtkMenuItem         *menu_item);
 | 
						|
void       gtk_menu_item_deselect             (GtkMenuItem         *menu_item);
 | 
						|
void       gtk_menu_item_activate             (GtkMenuItem         *menu_item);
 | 
						|
void       gtk_menu_item_toggle_size_request  (GtkMenuItem         *menu_item,
 | 
						|
					       gint                *requisition);
 | 
						|
void       gtk_menu_item_toggle_size_allocate (GtkMenuItem         *menu_item,
 | 
						|
					       gint                 allocation);
 | 
						|
void       gtk_menu_item_set_right_justified  (GtkMenuItem         *menu_item,
 | 
						|
					       gboolean             right_justified);
 | 
						|
gboolean   gtk_menu_item_get_right_justified  (GtkMenuItem         *menu_item);
 | 
						|
void	   gtk_menu_item_set_accel_path	      (GtkMenuItem	   *menu_item,
 | 
						|
					       const gchar	   *accel_path);
 | 
						|
 | 
						|
/* private */
 | 
						|
void	  _gtk_menu_item_refresh_accel_path   (GtkMenuItem	   *menu_item,
 | 
						|
					       const gchar	   *prefix,
 | 
						|
					       GtkAccelGroup	   *accel_group,
 | 
						|
					       gboolean		    group_changed);
 | 
						|
gboolean  _gtk_menu_item_is_selectable        (GtkWidget           *menu_item);
 | 
						|
void      _gtk_menu_item_popup_submenu        (GtkWidget           *menu_item);
 | 
						|
 | 
						|
#ifndef GTK_DISABLE_DEPRECATED
 | 
						|
#define gtk_menu_item_right_justify(menu_item) gtk_menu_item_set_right_justified ((menu_item), TRUE)
 | 
						|
#endif /* GTK_DISABLE_DEPRECATED */
 | 
						|
 | 
						|
G_END_DECLS
 | 
						|
 | 
						|
#endif /* __GTK_MENU_ITEM_H__ */
 |