Constify some more string pointers in the API (patch by
[geany-mirror.git] / src / geany.h
blob1005589e5bb112cbe9b29a32cb688b4a43aa0ba0
1 /*
2 * geany.h - this file is part of Geany, a fast and lightweight IDE
4 * Copyright 2005-2010 Enrico Tröger <enrico(dot)troeger(at)uvena(dot)de>
5 * Copyright 2006-2010 Nick Treleaven <nick(dot)treleaven(at)btinternet(dot)com>
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
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
21 * $Id$
24 /* Main header - should be included first in all source files.
25 * externs and function prototypes are implemented in main.c. */
27 #ifndef GEANY_H
28 #define GEANY_H
30 #ifdef HAVE_CONFIG_H
31 # include <config.h>
32 #endif
34 #include <gtk/gtk.h>
36 #include "tm_tagmanager.h"
38 #ifndef PLAT_GTK
39 # define PLAT_GTK 1 /* needed when including ScintillaWidget.h */
40 #endif
42 /* Compatibility for sharing macros between API and core, overridden in plugindata.h */
43 #define GEANY(symbol_name) symbol_name
46 /* for detailed description look in the documentation, things are not
47 * listed in the documentation should not be changed */
48 #define GEANY_FILEDEFS_SUBDIR "filedefs"
49 #define GEANY_TEMPLATES_SUBDIR "templates"
50 #define GEANY_CODENAME "Vellam"
51 #define GEANY_HOMEPAGE "http://www.geany.org/"
52 #define GEANY_USE_WIN32_DIALOG 0
53 #define GEANY_STRING_UNTITLED _("untitled")
54 #define GEANY_DEFAULT_DIALOG_HEIGHT 350
55 #define GEANY_WINDOW_DEFAULT_WIDTH 900
56 #define GEANY_WINDOW_DEFAULT_HEIGHT 600
60 /* Common forward declarations */
61 typedef struct GeanyDocument GeanyDocument;
62 typedef struct GeanyEditor GeanyEditor;
63 typedef struct GeanyFiletype GeanyFiletype;
66 /** Important application fields. */
67 typedef struct GeanyApp
69 gboolean debug_mode; /**< @c TRUE if debug messages should be printed. */
70 /** User configuration directory, usually @c ~/.config/geany.
71 * This is a full path read by @ref tm_get_real_path().
72 * @note Plugin configuration files should be saved as:
73 * @code g_build_path(G_DIR_SEPARATOR_S, geany->app->configdir, "plugins", "pluginname",
74 * "file.conf"); @endcode */
75 gchar *configdir;
76 gchar *datadir;
77 gchar *docdir;
78 const TMWorkspace *tm_workspace; /**< TagManager workspace/session tags. */
79 struct GeanyProject *project; /**< Currently active project or @c NULL if none is open. */
81 GeanyApp;
83 extern GeanyApp *app;
85 extern GObject *geany_object;
88 extern gboolean ignore_callback;
91 /* prototype is here so that all files can use it. */
92 void geany_debug(gchar const *format, ...) G_GNUC_PRINTF (1, 2);
95 #ifndef G_GNUC_WARN_UNUSED_RESULT
96 #define G_GNUC_WARN_UNUSED_RESULT
97 #endif
99 #endif