2008-03-20 12:46:45 +00:00
|
|
|
/*
|
2008-07-07 13:08:07 +00:00
|
|
|
* pluginsymbols.c - this file is part of Geany, a fast and lightweight IDE
|
2008-03-20 12:46:45 +00:00
|
|
|
*
|
2012-06-18 01:13:05 +02:00
|
|
|
* Copyright 2008-2012 Enrico Tröger <enrico(dot)troeger(at)uvena(dot)de>
|
|
|
|
* Copyright 2008-2012 Nick Treleaven <nick(dot)treleaven(at)btinternet(dot)com>
|
2008-03-20 12:46:45 +00:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program 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 General Public License for more details.
|
|
|
|
*
|
2012-08-24 19:25:57 +02:00
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
2008-03-20 12:46:45 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/* Note: this file is for Doxygen only. */
|
|
|
|
|
|
|
|
/**
|
2008-07-07 13:08:07 +00:00
|
|
|
* @file pluginsymbols.c
|
2015-08-23 15:23:35 +02:00
|
|
|
* Symbols declared from within plugins, all of this is <b>deprecated</b>.
|
|
|
|
*
|
|
|
|
* @deprecated This is the legacy way of making plugins for Geany. Refer to @ref howto for the
|
|
|
|
* reworked process and @ref legacy to learn how to port your plugin to that new world.
|
|
|
|
* Meanwhile Geany will still load plugins programmed against this interface (even the items that
|
|
|
|
* are marked deprecated individually such as @ref plugin_fields).
|
2008-03-20 12:46:45 +00:00
|
|
|
*
|
|
|
|
* Geany looks for these symbols (arrays, pointers and functions) when initializing
|
|
|
|
* plugins. Some of them are optional, i.e. they can be omitted; others are required
|
|
|
|
* and must be defined. Some symbols should only be declared using specific macros in
|
|
|
|
* @link plugindata.h @endlink.
|
|
|
|
*/
|
|
|
|
|
2011-11-02 15:03:17 +00:00
|
|
|
/** Use the PLUGIN_VERSION_CHECK() macro instead. Required by Geany.
|
2015-12-17 09:35:06 +01:00
|
|
|
*
|
|
|
|
* @param abi ABI version Geany was compiled with
|
|
|
|
* @return The API version the plugin was compiled with, or -1 if the plugin is incompatible. */
|
|
|
|
gint plugin_version_check(gint abi);
|
2008-03-20 12:46:45 +00:00
|
|
|
|
2008-05-23 17:08:58 +00:00
|
|
|
/** Use the PLUGIN_SET_INFO() macro to define it. Required by Geany.
|
|
|
|
* This function is called before the plugin is initialized, so Geany
|
|
|
|
* can read the plugin's name.
|
|
|
|
* @param info The data struct which should be initialized by this function. */
|
|
|
|
void plugin_set_info(PluginInfo *info);
|
|
|
|
|
2015-12-17 09:35:06 +01:00
|
|
|
/** Basic information about a plugin, which is set in plugin_set_info().
|
|
|
|
* @deprecated Use @ref GeanyPlugin.info instead.*/
|
2008-10-13 12:38:32 +00:00
|
|
|
const PluginInfo *plugin_info;
|
|
|
|
|
|
|
|
/** Basic information for the plugin and identification. */
|
|
|
|
const GeanyPlugin *geany_plugin;
|
2008-03-20 12:46:45 +00:00
|
|
|
|
2008-05-19 12:35:35 +00:00
|
|
|
/** Geany owned data pointers.
|
|
|
|
* Example: @c assert(geany_data->app->configdir != NULL); */
|
2008-10-13 12:38:32 +00:00
|
|
|
const GeanyData *geany_data;
|
2008-03-20 12:46:45 +00:00
|
|
|
|
2008-05-19 12:35:35 +00:00
|
|
|
/** Geany owned function pointers, split into groups.
|
2008-12-04 13:26:48 +00:00
|
|
|
* Example: @code #include "geanyfunctions.h"
|
|
|
|
* ...
|
|
|
|
* document_new_file(NULL, NULL, NULL); @endcode
|
2010-01-25 15:53:54 +00:00
|
|
|
* This is equivalent of @c geany_functions->p_document->document_new_file(NULL, NULL, NULL); */
|
2008-10-13 12:38:32 +00:00
|
|
|
const GeanyFunctions *geany_functions;
|
2008-05-19 12:35:35 +00:00
|
|
|
|
2015-12-17 09:35:06 +01:00
|
|
|
/** Plugin owned fields, including flags.
|
|
|
|
* @deprecated Use @ref ui_add_document_sensitive() instead.*/
|
2008-10-13 12:38:32 +00:00
|
|
|
PluginFields *plugin_fields;
|
2008-03-20 12:46:45 +00:00
|
|
|
|
|
|
|
/** An array for connecting GeanyObject events, which should be terminated with
|
2010-06-25 16:50:27 +00:00
|
|
|
* @c {NULL, NULL, FALSE, NULL}. See @link pluginsignals.c Signal documentation @endlink.
|
2009-07-29 17:40:20 +00:00
|
|
|
* @see plugin_signal_connect(). */
|
2008-05-23 12:29:32 +00:00
|
|
|
PluginCallback plugin_callbacks[];
|
2008-03-20 12:46:45 +00:00
|
|
|
|
2009-08-24 11:35:13 +00:00
|
|
|
/** Plugins must use the PLUGIN_KEY_GROUP() macro to define it.
|
|
|
|
* To setup a variable number of keybindings, e.g. based on the
|
|
|
|
* plugin's configuration file settings, use plugin_set_key_group() instead. */
|
|
|
|
KeyBindingGroup *plugin_key_group;
|
2008-03-20 12:46:45 +00:00
|
|
|
|
|
|
|
|
2009-09-24 16:28:59 +00:00
|
|
|
/** Called before showing the plugin preferences dialog for multiple plugins.
|
|
|
|
* Can be omitted when not needed.
|
|
|
|
* The dialog will show all plugins that support this symbol together.
|
2008-05-28 13:05:09 +00:00
|
|
|
* @param dialog The plugin preferences dialog widget - this should only be used to
|
|
|
|
* connect the @c "response" signal. If settings should be read from the dialog, the
|
2015-04-18 08:25:59 +02:00
|
|
|
* response will be either @c GTK_RESPONSE_OK or @c GTK_RESPONSE_APPLY.
|
2015-09-16 22:52:23 +02:00
|
|
|
*
|
|
|
|
* @return @transfer{floating} A container widget holding preference widgets.
|
|
|
|
*
|
2010-07-09 15:13:14 +00:00
|
|
|
* @note Using @link stash.h Stash @endlink can make implementing preferences easier.
|
2009-09-24 16:28:59 +00:00
|
|
|
* @see plugin_configure_single(). */
|
|
|
|
GtkWidget *plugin_configure(GtkDialog *dialog);
|
|
|
|
|
|
|
|
/** Called when a plugin should show a preferences dialog, if plugin_configure() has not been
|
|
|
|
* implemented.
|
2009-09-27 12:06:08 +00:00
|
|
|
* @warning It's better to implement plugin_configure() instead, but this is simpler.
|
|
|
|
* This does not integrate as well with the multiple-plugin dialog.
|
2009-09-24 16:28:59 +00:00
|
|
|
* @param parent Pass this as the parent widget if showing a dialog.
|
|
|
|
* @see plugin_configure(). */
|
|
|
|
void plugin_configure_single(GtkWidget *parent);
|
2008-03-20 12:46:45 +00:00
|
|
|
|
|
|
|
/** Called after loading the plugin.
|
|
|
|
* @param data The same as #geany_data. */
|
2008-05-26 17:09:43 +00:00
|
|
|
void plugin_init(GeanyData *data);
|
2008-03-20 12:46:45 +00:00
|
|
|
|
|
|
|
/** Called before unloading the plugin. Required for normal plugins - it should undo
|
2008-05-26 17:09:43 +00:00
|
|
|
* everything done in plugin_init() - e.g. destroy menu items, free memory. */
|
|
|
|
void plugin_cleanup();
|
2008-03-20 12:46:45 +00:00
|
|
|
|
2009-01-28 19:30:18 +00:00
|
|
|
/** Called whenever the plugin should show its documentation (if any). This may open a dialog,
|
2012-05-06 08:14:14 +02:00
|
|
|
* a browser with a website or a local installed HTML help file(see utils_open_browser())
|
2009-01-28 19:30:18 +00:00
|
|
|
* or something else.
|
|
|
|
* Can be omitted when not needed. */
|
|
|
|
void plugin_help();
|