geany/doc/pluginsymbols.c
Enrico Tröger 1526af4068 Update all copyright notices to mention only the first publish year
And so remove the current year to ease maintenance and since it is not
strictly necessary.
Also remove individual copyright holders (where appropriate) and replace
the name with "The Geany contributors". The detailed authorship
information is still available in the GIT history.

Also remove copyright notice and author names from READMEs.
2019-04-07 11:43:58 +02:00

117 lines
5.1 KiB
C

/*
* pluginsymbols.c - this file is part of Geany, a fast and lightweight IDE
*
* Copyright 2008 The Geany contributors
*
* 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.
*
* 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.
*/
/* Note: this file is for Doxygen only. */
/**
* @file pluginsymbols.c
* 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).
*
* 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.
*/
/** Use the PLUGIN_VERSION_CHECK() macro instead. Required by Geany.
*
* @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);
/** 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);
/** Basic information about a plugin, which is set in plugin_set_info().
* @deprecated Use @ref GeanyPlugin.info instead.*/
const PluginInfo *plugin_info;
/** Basic information for the plugin and identification. */
const GeanyPlugin *geany_plugin;
/** Geany owned data pointers.
* Example: @c assert(geany_data->app->configdir != NULL); */
const GeanyData *geany_data;
/** Geany owned function pointers, split into groups.
* Example: @code #include "geanyfunctions.h"
* ...
* document_new_file(NULL, NULL, NULL); @endcode
* This is equivalent of @c geany_functions->p_document->document_new_file(NULL, NULL, NULL); */
const GeanyFunctions *geany_functions;
/** Plugin owned fields, including flags.
* @deprecated Use @ref ui_add_document_sensitive() instead.*/
PluginFields *plugin_fields;
/** An array for connecting GeanyObject events, which should be terminated with
* @c {NULL, NULL, FALSE, NULL}. See @link pluginsignals.c Signal documentation @endlink.
* @see plugin_signal_connect(). */
PluginCallback plugin_callbacks[];
/** 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;
/** 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.
* @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
* response will be either @c GTK_RESPONSE_OK or @c GTK_RESPONSE_APPLY.
*
* @return @transfer{floating} A container widget holding preference widgets.
*
* @note Using @link stash.h Stash @endlink can make implementing preferences easier.
* @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.
* @warning It's better to implement plugin_configure() instead, but this is simpler.
* This does not integrate as well with the multiple-plugin dialog.
* @param parent Pass this as the parent widget if showing a dialog.
* @see plugin_configure(). */
void plugin_configure_single(GtkWidget *parent);
/** Called after loading the plugin.
* @param data The same as #geany_data. */
void plugin_init(GeanyData *data);
/** Called before unloading the plugin. Required for normal plugins - it should undo
* everything done in plugin_init() - e.g. destroy menu items, free memory. */
void plugin_cleanup();
/** Called whenever the plugin should show its documentation (if any). This may open a dialog,
* a browser with a website or a local installed HTML help file (see utils_open_browser())
* or something else.
* Can be omitted when not needed. */
void plugin_help();