1 /* GTK - The GIMP Toolkit
2 * Copyright (C) 2006-2007 Async Open Source,
3 * Johan Dahlin <jdahlin@async.com.br>
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Library General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Library General Public License for more details.
15 * You should have received a copy of the GNU Library General Public
16 * License along with this library; if not, write to the
17 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 * Boston, MA 02111-1307, USA.
21 #if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
22 #error "Only <gtk/gtk.h> can be included directly."
25 #ifndef __GTK_BUILDER_H__
26 #define __GTK_BUILDER_H__
28 #include <gdkconfig.h>
29 #include <glib-object.h>
33 #define GTK_TYPE_BUILDER (gtk_builder_get_type ())
34 #define GTK_BUILDER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_BUILDER, GtkBuilder))
35 #define GTK_BUILDER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_BUILDER, GtkBuilderClass))
36 #define GTK_IS_BUILDER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_BUILDER))
37 #define GTK_IS_BUILDER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_BUILDER))
38 #define GTK_BUILDER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_BUILDER, GtkBuilderClass))
40 #define GTK_BUILDER_ERROR (gtk_builder_error_quark ())
42 typedef struct _GtkBuilder GtkBuilder;
43 typedef struct _GtkBuilderClass GtkBuilderClass;
44 typedef struct _GtkBuilderPrivate GtkBuilderPrivate;
48 * @GTK_BUILDER_ERROR_INVALID_TYPE_FUNCTION: A type-func attribute didn't name
49 * a function that returns a #GType.
50 * @GTK_BUILDER_ERROR_UNHANDLED_TAG: The input contained a tag that #GtkBuilder
52 * @GTK_BUILDER_ERROR_MISSING_ATTRIBUTE: An attribute that is required by
53 * #GtkBuilder was missing.
54 * @GTK_BUILDER_ERROR_INVALID_ATTRIBUTE: #GtkBuilder found an attribute that
55 * it doesn't understand.
56 * @GTK_BUILDER_ERROR_INVALID_TAG: #GtkBuilder found a tag that
57 * it doesn't understand.
58 * @GTK_BUILDER_ERROR_MISSING_PROPERTY_VALUE: A required property value was
60 * @GTK_BUILDER_ERROR_INVALID_VALUE: #GtkBuilder couldn't parse
61 * some attribute value.
62 * @GTK_BUILDER_ERROR_VERSION_MISMATCH: The input file requires a newer version
64 * @GTK_BUILDER_ERROR_DUPLICATE_ID: An object id occurred twice.
66 * Error codes that identify various errors that can occur while using
71 GTK_BUILDER_ERROR_INVALID_TYPE_FUNCTION,
72 GTK_BUILDER_ERROR_UNHANDLED_TAG,
73 GTK_BUILDER_ERROR_MISSING_ATTRIBUTE,
74 GTK_BUILDER_ERROR_INVALID_ATTRIBUTE,
75 GTK_BUILDER_ERROR_INVALID_TAG,
76 GTK_BUILDER_ERROR_MISSING_PROPERTY_VALUE,
77 GTK_BUILDER_ERROR_INVALID_VALUE,
78 GTK_BUILDER_ERROR_VERSION_MISMATCH,
79 GTK_BUILDER_ERROR_DUPLICATE_ID
82 GQuark gtk_builder_error_quark (void);
86 GObject parent_instance;
88 GtkBuilderPrivate *priv;
91 struct _GtkBuilderClass
93 GObjectClass parent_class;
95 GType (* get_type_from_name) (GtkBuilder *builder,
96 const char *type_name);
98 /* Padding for future expansion */
99 void (*_gtk_reserved1) (void);
100 void (*_gtk_reserved2) (void);
101 void (*_gtk_reserved3) (void);
102 void (*_gtk_reserved4) (void);
103 void (*_gtk_reserved5) (void);
104 void (*_gtk_reserved6) (void);
105 void (*_gtk_reserved7) (void);
106 void (*_gtk_reserved8) (void);
109 typedef void (*GtkBuilderConnectFunc) (GtkBuilder *builder,
111 const gchar *signal_name,
112 const gchar *handler_name,
113 GObject *connect_object,
117 GType gtk_builder_get_type (void) G_GNUC_CONST;
118 GtkBuilder* gtk_builder_new (void);
120 guint gtk_builder_add_from_file (GtkBuilder *builder,
121 const gchar *filename,
123 guint gtk_builder_add_from_string (GtkBuilder *builder,
127 guint gtk_builder_add_objects_from_file (GtkBuilder *builder,
128 const gchar *filename,
131 guint gtk_builder_add_objects_from_string (GtkBuilder *builder,
136 GObject* gtk_builder_get_object (GtkBuilder *builder,
138 GSList* gtk_builder_get_objects (GtkBuilder *builder);
139 void gtk_builder_connect_signals (GtkBuilder *builder,
141 void gtk_builder_connect_signals_full (GtkBuilder *builder,
142 GtkBuilderConnectFunc func,
144 void gtk_builder_set_translation_domain (GtkBuilder *builder,
145 const gchar *domain);
146 const gchar* gtk_builder_get_translation_domain (GtkBuilder *builder);
147 GType gtk_builder_get_type_from_name (GtkBuilder *builder,
148 const char *type_name);
150 gboolean gtk_builder_value_from_string (GtkBuilder *builder,
155 gboolean gtk_builder_value_from_string_type (GtkBuilder *builder,
162 * GTK_BUILDER_WARN_INVALID_CHILD_TYPE:
163 * @object: the #GtkBuildable on which the warning ocurred
164 * @type: the unexpected type value
166 * This macro should be used to emit a warning about and unexpected @type value
167 * in a #GtkBuildable add_child implementation.
169 #define GTK_BUILDER_WARN_INVALID_CHILD_TYPE(object, type) \
170 g_warning ("'%s' is not a valid child type of '%s'", type, g_type_name (G_OBJECT_TYPE (object)))
174 #endif /* __GTK_BUILDER_H__ */