forked from AuroraMiddleware/gtk
347efc33b8
Fri Jul 10 00:02:04 1998 Tim Janik <timj@gtk.org> * gtk/gtkcontainer.h: * gtk/gtkcontainer.c: deleted most of the argument handling code, since that is now implemented in gtkarg.c. similar to gtk_object_args_collect, we now export a new function gtk_container_child_args_collect(). for consistency with the object arguments, a few functions got renamed: gtk_container_child_arg_get -> gtk_container_child_get, gtk_container_child_arg_set -> gtk_container_child_set, gtk_container_child_arg_getv -> gtk_container_child_getv, gtk_container_child_arg_setv -> gtk_container_child_setv, gtk_container_add_with_argv -> gtk_container_addv. note, gtk_container_add_with_args() remained, because its equivalent would be gtk_container_add(,, ...) which would break all existing code. (gtk_container_add_child_arg_type): similar to gtk_object_add_arg_type, we expect the `arg_name' argument to be a const static string now. (gtk_container_get_child_arg_type): function removed. Thu Jul 9 07:03:04 1998 Tim Janik <timj@gtk.org> * gtk/gtkargcollector.c: new file which holds gtk_arg_collect_value(). this is a static inline function that collects command line arguments from a va_list. this file can just be included in all places that need this functionality. * gtk/gtkarg.h: * gtk/gtkarg.c: new files which implement most of the argument handling stuff from gtkobject.c. also collected a few more gtk_arg_* utility functions from else places. * gtk/gtkobject.h: * gtk/gtkobject.c: moved most of the argument handling code into gtkarg.c. we now export gtk_object_args_collect() as a non-public method with a blind va_list pointer. (gtk_object_add_arg_type): the `arg_name' argument is required to be a const static string now. (gtk_object_get_arg_type): function got removed. * gtk/gtkwidget.c: (gtk_widget_set): (gtk_widget_new): adaptions for gtk_object_args_collect(). * gtk/gtktypeutils.c (gtk_type_init_builtin_types): changed the internal fundamental type name so as to have a valid prefix, e.g. "bool"-> "gboolean", "string"->"GtkString" and somesuch, left "void" as is, though that should probably be something like GtkNone since the type itself is called GTK_TYPE_NONE. even the internal type names need to avoid name clashes and must live in their own namespace, several code portions rely on that. we should relly have typedefs such as typedef gchar* GtkString; so the fundamental type names can be used for code dumpers just like with all the Gtk/Gdk types.
224 lines
7.8 KiB
C
224 lines
7.8 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 Library 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
|
|
* Library General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Library 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.
|
|
*/
|
|
#ifndef __GTK_CONTAINER_H__
|
|
#define __GTK_CONTAINER_H__
|
|
|
|
|
|
#include <gdk/gdk.h>
|
|
#include <gtk/gtkenums.h>
|
|
#include <gtk/gtkwidget.h>
|
|
#include <gtk/gtkadjustment.h>
|
|
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#pragma }
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
#define GTK_TYPE_CONTAINER (gtk_container_get_type ())
|
|
#define GTK_CONTAINER(obj) (GTK_CHECK_CAST ((obj), GTK_TYPE_CONTAINER, GtkContainer))
|
|
#define GTK_CONTAINER_CLASS(klass) (GTK_CHECK_CLASS_CAST ((klass), GTK_TYPE_CONTAINER, GtkContainerClass))
|
|
#define GTK_IS_CONTAINER(obj) (GTK_CHECK_TYPE ((obj), GTK_TYPE_CONTAINER))
|
|
#define GTK_IS_CONTAINER_CLASS(klass) (GTK_CHECK_CLASS_TYPE ((klass), GTK_TYPE_CONTAINER))
|
|
|
|
#define GTK_IS_RESIZE_CONTAINER(widget) (GTK_IS_CONTAINER (widget) && ((GtkContainer*) (widget))->resize_mode != GTK_RESIZE_PARENT)
|
|
|
|
|
|
typedef struct _GtkContainer GtkContainer;
|
|
typedef struct _GtkContainerClass GtkContainerClass;
|
|
|
|
struct _GtkContainer
|
|
{
|
|
GtkWidget widget;
|
|
|
|
GtkWidget *focus_child;
|
|
|
|
guint border_width : 16;
|
|
guint need_resize : 1;
|
|
guint resize_mode : 2;
|
|
|
|
|
|
/* The list of children that requested a resize
|
|
*/
|
|
GSList *resize_widgets;
|
|
};
|
|
|
|
struct _GtkContainerClass
|
|
{
|
|
GtkWidgetClass parent_class;
|
|
|
|
guint n_child_args;
|
|
|
|
void (* add) (GtkContainer *container,
|
|
GtkWidget *widget);
|
|
void (* remove) (GtkContainer *container,
|
|
GtkWidget *widget);
|
|
void (* check_resize) (GtkContainer *container);
|
|
void (* foreach) (GtkContainer *container,
|
|
GtkCallback callback,
|
|
gpointer callbabck_data);
|
|
gint (* focus) (GtkContainer *container,
|
|
GtkDirectionType direction);
|
|
void (* set_focus_child) (GtkContainer *container,
|
|
GtkWidget *widget);
|
|
GtkType (*child_type) (GtkContainer *container);
|
|
void (*set_child_arg) (GtkContainer *container,
|
|
GtkWidget *child,
|
|
GtkArg *arg,
|
|
guint arg_id);
|
|
void (*get_child_arg) (GtkContainer *container,
|
|
GtkWidget *child,
|
|
GtkArg *arg,
|
|
guint arg_id);
|
|
};
|
|
|
|
/* Application-level methods */
|
|
|
|
GtkType gtk_container_get_type (void);
|
|
void gtk_container_border_width (GtkContainer *container,
|
|
guint border_width);
|
|
void gtk_container_add (GtkContainer *container,
|
|
GtkWidget *widget);
|
|
void gtk_container_remove (GtkContainer *container,
|
|
GtkWidget *widget);
|
|
|
|
void gtk_container_set_resize_mode (GtkContainer *container,
|
|
GtkResizeMode resize_mode);
|
|
|
|
void gtk_container_check_resize (GtkContainer *container);
|
|
|
|
void gtk_container_foreach (GtkContainer *container,
|
|
GtkCallback callback,
|
|
gpointer callback_data);
|
|
void gtk_container_foreach_interp (GtkContainer *container,
|
|
GtkCallbackMarshal marshal,
|
|
gpointer callback_data,
|
|
GtkDestroyNotify notify);
|
|
void gtk_container_foreach_full (GtkContainer *container,
|
|
GtkCallback callback,
|
|
GtkCallbackMarshal marshal,
|
|
gpointer callback_data,
|
|
GtkDestroyNotify notify);
|
|
GList* gtk_container_children (GtkContainer *container);
|
|
gint gtk_container_focus (GtkContainer *container,
|
|
GtkDirectionType direction);
|
|
|
|
/* Widget-level methods */
|
|
|
|
void gtk_container_set_focus_child (GtkContainer *container,
|
|
GtkWidget *child);
|
|
void gtk_container_set_focus_vadjustment (GtkContainer *container,
|
|
GtkAdjustment *adjustment);
|
|
void gtk_container_set_focus_hadjustment (GtkContainer *container,
|
|
GtkAdjustment *adjustment);
|
|
void gtk_container_register_toplevel (GtkContainer *container);
|
|
void gtk_container_unregister_toplevel (GtkContainer *container);
|
|
void gtk_container_resize_children (GtkContainer *container);
|
|
|
|
GtkType gtk_container_child_type (GtkContainer *container);
|
|
|
|
/* the `arg_name' argument needs to be a const static string */
|
|
void gtk_container_add_child_arg_type (const gchar *arg_name,
|
|
GtkType arg_type,
|
|
guint arg_flags,
|
|
guint arg_id);
|
|
|
|
/* Allocate a GtkArg array of size nargs that hold the
|
|
* names and types of the args that can be used with
|
|
* gtk_container_child_getv/gtk_container_child_setv.
|
|
* if (arg_flags!=NULL),
|
|
* (*arg_flags) will be set to point to a newly allocated
|
|
* guint array that holds the flags of the args.
|
|
* It is the callers response to do a
|
|
* g_free (returned_args); g_free (*arg_flags).
|
|
*/
|
|
GtkArg* gtk_container_query_child_args (GtkType class_type,
|
|
guint32 **arg_flags,
|
|
guint *nargs);
|
|
|
|
/* gtk_container_child_getv() sets an arguments type and value, or just
|
|
* its type to GTK_TYPE_INVALID.
|
|
* if GTK_FUNDAMENTAL_TYPE (arg->type) == GTK_TYPE_STRING, it's the callers
|
|
* response to do a g_free (GTK_VALUE_STRING (arg));
|
|
*/
|
|
void gtk_container_child_getv (GtkContainer *container,
|
|
GtkWidget *child,
|
|
guint n_args,
|
|
GtkArg *args);
|
|
void gtk_container_child_setv (GtkContainer *container,
|
|
GtkWidget *child,
|
|
guint n_args,
|
|
GtkArg *args);
|
|
|
|
/* gtk_container_add_with_args() takes a variable argument list of the form:
|
|
* (..., gchar *arg_name, ARG_VALUES, [repeatedly name/value pairs,] NULL)
|
|
* where ARG_VALUES type depend on the argument and can consist of
|
|
* more than one c-function argument.
|
|
*/
|
|
void gtk_container_add_with_args (GtkContainer *container,
|
|
GtkWidget *widget,
|
|
...);
|
|
void gtk_container_addv (GtkContainer *container,
|
|
GtkWidget *widget,
|
|
guint n_args,
|
|
GtkArg *args);
|
|
void gtk_container_child_set (GtkContainer *container,
|
|
GtkWidget *child,
|
|
...);
|
|
|
|
|
|
/* Non-public methods */
|
|
|
|
void gtk_container_queue_resize (GtkContainer *container);
|
|
void gtk_container_clear_resize_widgets (GtkContainer *container);
|
|
void gtk_container_arg_set (GtkContainer *container,
|
|
GtkWidget *child,
|
|
GtkArg *arg,
|
|
GtkArgInfo *info);
|
|
void gtk_container_arg_get (GtkContainer *container,
|
|
GtkWidget *child,
|
|
GtkArg *arg,
|
|
GtkArgInfo *info);
|
|
gchar* gtk_container_child_args_collect (GtkType object_type,
|
|
GSList **arg_list_p,
|
|
GSList **info_list_p,
|
|
gpointer var_args_p);
|
|
|
|
|
|
/* Deprecated methods */
|
|
|
|
/* Completely non-functional */
|
|
void gtk_container_disable_resize (GtkContainer *container);
|
|
void gtk_container_enable_resize (GtkContainer *container);
|
|
|
|
/* Use gtk_container_set_resize_mode() instead */
|
|
void gtk_container_block_resize (GtkContainer *container);
|
|
void gtk_container_unblock_resize (GtkContainer *container);
|
|
|
|
/* Use gtk_container_check_resize() instead */
|
|
gint gtk_container_need_resize (GtkContainer *container);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
#endif /* __GTK_CONTAINER_H__ */
|