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 <glib-object.h>
32 #define GTK_TYPE_BUILDER (gtk_builder_get_type ())
33 #define GTK_BUILDER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_BUILDER, GtkBuilder))
34 #define GTK_BUILDER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_BUILDER, GtkBuilderClass))
35 #define GTK_IS_BUILDER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_BUILDER))
36 #define GTK_IS_BUILDER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_BUILDER))
37 #define GTK_BUILDER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_BUILDER, GtkBuilderClass))
39 #define GTK_BUILDER_ERROR (gtk_builder_error_quark ())
41 typedef struct _GtkBuilder GtkBuilder;
42 typedef struct _GtkBuilderClass GtkBuilderClass;
43 typedef struct _GtkBuilderPrivate GtkBuilderPrivate;
47 * @GTK_BUILDER_ERROR_INVALID_TYPE_FUNCTION: A type-func attribute didn't name
48 * a function that returns a #GType.
49 * @GTK_BUILDER_ERROR_UNHANDLED_TAG: The input contained a tag that #GtkBuilder
51 * @GTK_BUILDER_ERROR_MISSING_ATTRIBUTE: An attribute that is required by
52 * #GtkBuilder was missing.
53 * @GTK_BUILDER_ERROR_INVALID_ATTRIBUTE: #GtkBuilder found an attribute that
54 * it doesn't understand.
55 * @GTK_BUILDER_ERROR_INVALID_TAG: #GtkBuilder found a tag that
56 * it doesn't understand.
57 * @GTK_BUILDER_ERROR_MISSING_PROPERTY_VALUE: A required property value was
59 * @GTK_BUILDER_ERROR_INVALID_VALUE: #GtkBuilder couldn't parse
60 * some attribute value.
61 * @GTK_BUILDER_ERROR_VERSION_MISMATCH: The input file requires a newer version
63 * @GTK_BUILDER_ERROR_DUPLICATE_ID: An object id occurred twice.
65 * Error codes that identify various errors that can occur while using
70 GTK_BUILDER_ERROR_INVALID_TYPE_FUNCTION,
71 GTK_BUILDER_ERROR_UNHANDLED_TAG,
72 GTK_BUILDER_ERROR_MISSING_ATTRIBUTE,
73 GTK_BUILDER_ERROR_INVALID_ATTRIBUTE,
74 GTK_BUILDER_ERROR_INVALID_TAG,
75 GTK_BUILDER_ERROR_MISSING_PROPERTY_VALUE,
76 GTK_BUILDER_ERROR_INVALID_VALUE,
77 GTK_BUILDER_ERROR_VERSION_MISMATCH,
78 GTK_BUILDER_ERROR_DUPLICATE_ID
81 GQuark gtk_builder_error_quark (void);
85 GObject parent_instance;
87 GtkBuilderPrivate *priv;
90 struct _GtkBuilderClass
92 GObjectClass parent_class;
94 GType (* get_type_from_name) (GtkBuilder *builder,
95 const char *type_name);
97 /* Padding for future expansion */
98 void (*_gtk_reserved1) (void);
99 void (*_gtk_reserved2) (void);
100 void (*_gtk_reserved3) (void);
101 void (*_gtk_reserved4) (void);
102 void (*_gtk_reserved5) (void);
103 void (*_gtk_reserved6) (void);
104 void (*_gtk_reserved7) (void);
105 void (*_gtk_reserved8) (void);
108 typedef void (*GtkBuilderConnectFunc) (GtkBuilder *builder,
110 const gchar *signal_name,
111 const gchar *handler_name,
112 GObject *connect_object,
116 GType gtk_builder_get_type (void) G_GNUC_CONST;
117 GtkBuilder* gtk_builder_new (void);
119 guint gtk_builder_add_from_file (GtkBuilder *builder,
120 const gchar *filename,
122 guint gtk_builder_add_from_resource (GtkBuilder *builder,
123 const gchar *resource_path,
125 guint gtk_builder_add_from_string (GtkBuilder *builder,
129 guint gtk_builder_add_objects_from_file (GtkBuilder *builder,
130 const gchar *filename,
133 guint gtk_builder_add_objects_from_resource(GtkBuilder *builder,
134 const gchar *resource_path,
137 guint gtk_builder_add_objects_from_string (GtkBuilder *builder,
142 GObject* gtk_builder_get_object (GtkBuilder *builder,
144 GSList* gtk_builder_get_objects (GtkBuilder *builder);
145 void gtk_builder_connect_signals (GtkBuilder *builder,
147 void gtk_builder_connect_signals_full (GtkBuilder *builder,
148 GtkBuilderConnectFunc func,
150 void gtk_builder_set_translation_domain (GtkBuilder *builder,
151 const gchar *domain);
152 const gchar* gtk_builder_get_translation_domain (GtkBuilder *builder);
153 GType gtk_builder_get_type_from_name (GtkBuilder *builder,
154 const char *type_name);
156 gboolean gtk_builder_value_from_string (GtkBuilder *builder,
161 gboolean gtk_builder_value_from_string_type (GtkBuilder *builder,
168 * GTK_BUILDER_WARN_INVALID_CHILD_TYPE:
169 * @object: the #GtkBuildable on which the warning ocurred
170 * @type: the unexpected type value
172 * This macro should be used to emit a warning about and unexpected @type value
173 * in a #GtkBuildable add_child implementation.
175 #define GTK_BUILDER_WARN_INVALID_CHILD_TYPE(object, type) \
176 g_warning ("'%s' is not a valid child type of '%s'", type, g_type_name (G_OBJECT_TYPE (object)))
180 #endif /* __GTK_BUILDER_H__ */