Return GdkColor via out parameter rather than return value
[geany-mirror.git] / src / stash.h
blobe92563656de419552b54359a7b0effb4dcbcacae
1 /*
2 * stash.h - this file is part of Geany, a fast and lightweight IDE
4 * Copyright 2008-2012 Nick Treleaven <nick(dot)treleaven(at)btinternet(dot)com>
5 * Copyright 2008-2012 Enrico Tröger <enrico(dot)troeger(at)uvena(dot)de>
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License along
18 * with this program; if not, write to the Free Software Foundation, Inc.,
19 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
22 #ifndef GEANY_STASH_H
23 #define GEANY_STASH_H 1
25 #include "gtkcompat.h"
27 G_BEGIN_DECLS
29 /** Opaque type for a group of settings. */
30 typedef struct StashGroup StashGroup;
32 /** Can be @c GtkWidget* or @c gchar* depending on whether the @a owner argument is used for
33 * stash_group_display() and stash_group_update(). */
34 typedef gconstpointer StashWidgetID;
36 GType stash_group_get_type(void);
38 StashGroup *stash_group_new(const gchar *name);
40 void stash_group_add_boolean(StashGroup *group, gboolean *setting,
41 const gchar *key_name, gboolean default_value);
43 void stash_group_add_integer(StashGroup *group, gint *setting,
44 const gchar *key_name, gint default_value);
46 void stash_group_add_string(StashGroup *group, gchar **setting,
47 const gchar *key_name, const gchar *default_value);
49 void stash_group_add_string_vector(StashGroup *group, gchar ***setting,
50 const gchar *key_name, const gchar **default_value);
52 void stash_group_load_from_key_file(StashGroup *group, GKeyFile *keyfile);
54 void stash_group_save_to_key_file(StashGroup *group, GKeyFile *keyfile);
56 void stash_group_free(StashGroup *group);
58 gboolean stash_group_load_from_file(StashGroup *group, const gchar *filename);
60 gint stash_group_save_to_file(StashGroup *group, const gchar *filename,
61 GKeyFileFlags flags);
63 /* *** GTK-related functions *** */
65 void stash_group_add_toggle_button(StashGroup *group, gboolean *setting,
66 const gchar *key_name, gboolean default_value, StashWidgetID widget_id);
68 void stash_group_add_radio_buttons(StashGroup *group, gint *setting,
69 const gchar *key_name, gint default_value,
70 StashWidgetID widget_id, gint enum_id, ...) G_GNUC_NULL_TERMINATED;
72 void stash_group_add_spin_button_integer(StashGroup *group, gint *setting,
73 const gchar *key_name, gint default_value, StashWidgetID widget_id);
75 void stash_group_add_combo_box(StashGroup *group, gint *setting,
76 const gchar *key_name, gint default_value, StashWidgetID widget_id);
78 void stash_group_add_combo_box_entry(StashGroup *group, gchar **setting,
79 const gchar *key_name, const gchar *default_value, StashWidgetID widget_id);
81 void stash_group_add_entry(StashGroup *group, gchar **setting,
82 const gchar *key_name, const gchar *default_value, StashWidgetID widget_id);
84 void stash_group_add_widget_property(StashGroup *group, gpointer setting,
85 const gchar *key_name, gpointer default_value, StashWidgetID widget_id,
86 const gchar *property_name, GType type);
88 void stash_group_display(StashGroup *group, GtkWidget *owner);
90 void stash_group_update(StashGroup *group, GtkWidget *owner);
92 void stash_group_free_settings(StashGroup *group);
95 #ifdef GEANY_PRIVATE
97 void stash_group_set_various(StashGroup *group, gboolean write_once);
99 void stash_group_set_use_defaults(StashGroup *group, gboolean use_defaults);
101 /* *** GTK-related functions *** */
103 void stash_tree_setup(GPtrArray *group_array, GtkTreeView *tree);
105 void stash_tree_display(GtkTreeView *tree);
107 void stash_tree_update(GtkTreeView *tree);
109 #endif /* GEANY_PRIVATE */
111 G_END_DECLS
113 #endif /* GEANY_STASH_H */