2007-06-26 16:17:16 +00:00
|
|
|
/*
|
|
|
|
* demoplugin.c - this file is part of Geany, a fast and lightweight IDE
|
|
|
|
*
|
|
|
|
* Copyright 2007 Enrico Tröger <enrico.troeger@uvena.de>
|
|
|
|
* Copyright 2007 Nick Treleaven <nick.treleaven@btinternet.com>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* $Id$
|
|
|
|
*/
|
|
|
|
|
2007-10-24 12:04:15 +00:00
|
|
|
/**
|
|
|
|
* Demo plugin - example of a basic plugin for Geany. Adds a menu item to the
|
|
|
|
* Tools menu.
|
|
|
|
*
|
|
|
|
* Note: This is not installed by default, but (on *nix) you can build it as follows:
|
|
|
|
* cd plugins
|
|
|
|
* make demoplugin.so
|
|
|
|
*
|
|
|
|
* Then copy or symlink the plugins/demoplugin.so file to ~/.geany/plugins
|
|
|
|
* - it will be loaded at next startup.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#include "geany.h" // for the GeanyApp data type
|
|
|
|
#include "support.h" // for the _() translation macro (see also po/POTFILES.in)
|
2007-06-26 16:17:16 +00:00
|
|
|
|
2007-10-24 12:04:15 +00:00
|
|
|
#include "plugindata.h" // this defines the plugin API
|
|
|
|
#include "pluginmacros.h" // some useful macros to avoid typing geany_data so often
|
2007-06-26 16:17:16 +00:00
|
|
|
|
|
|
|
|
2007-10-24 12:04:15 +00:00
|
|
|
/* These items are set by Geany before init() is called. */
|
2007-07-27 10:37:22 +00:00
|
|
|
PluginFields *plugin_fields;
|
|
|
|
GeanyData *geany_data;
|
2007-06-26 16:17:16 +00:00
|
|
|
|
|
|
|
|
2007-10-24 12:04:15 +00:00
|
|
|
/* Check that Geany supports plugin API version 7 or later, and check
|
2007-06-27 15:56:42 +00:00
|
|
|
* for binary compatibility. */
|
2007-07-27 10:37:22 +00:00
|
|
|
VERSION_CHECK(7)
|
2007-06-26 16:17:16 +00:00
|
|
|
|
2007-11-20 18:15:46 +00:00
|
|
|
/* All plugins must set name, description, version and author. */
|
|
|
|
PLUGIN_INFO(_("Demo"), _("Example plugin."), VERSION, _("The Geany developer team"))
|
|
|
|
|
|
|
|
|
|
|
|
// text to be shown in the plugin dialog
|
|
|
|
static gchar *welcome_text = NULL;
|
2007-06-26 16:17:16 +00:00
|
|
|
|
2007-06-27 15:56:42 +00:00
|
|
|
|
2007-10-24 12:04:15 +00:00
|
|
|
/* Callback when the menu item is clicked. */
|
2007-06-26 16:17:16 +00:00
|
|
|
static void
|
|
|
|
item_activate(GtkMenuItem *menuitem, gpointer gdata)
|
|
|
|
{
|
|
|
|
GtkWidget *dialog;
|
|
|
|
|
|
|
|
dialog = gtk_message_dialog_new(
|
2007-10-24 12:04:15 +00:00
|
|
|
GTK_WINDOW(app->window),
|
2007-06-26 16:17:16 +00:00
|
|
|
GTK_DIALOG_DESTROY_WITH_PARENT,
|
|
|
|
GTK_MESSAGE_INFO,
|
|
|
|
GTK_BUTTONS_OK,
|
2007-11-20 18:15:46 +00:00
|
|
|
welcome_text);
|
2007-06-26 16:17:16 +00:00
|
|
|
gtk_message_dialog_format_secondary_text(GTK_MESSAGE_DIALOG(dialog),
|
2007-06-27 15:56:42 +00:00
|
|
|
_("(From the %s plugin)"), info()->name);
|
2007-06-26 16:17:16 +00:00
|
|
|
|
|
|
|
gtk_dialog_run(GTK_DIALOG(dialog));
|
|
|
|
gtk_widget_destroy(dialog);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-24 12:04:15 +00:00
|
|
|
/* Called by Geany to initialize the plugin.
|
|
|
|
* Note: data is the same as geany_data. */
|
2007-07-27 10:37:22 +00:00
|
|
|
void init(GeanyData *data)
|
2007-06-26 16:17:16 +00:00
|
|
|
{
|
2007-06-27 15:56:42 +00:00
|
|
|
GtkWidget *demo_item;
|
|
|
|
|
|
|
|
// Add an item to the Tools menu
|
|
|
|
demo_item = gtk_menu_item_new_with_mnemonic(_("_Demo Plugin"));
|
|
|
|
gtk_widget_show(demo_item);
|
2007-07-27 10:37:22 +00:00
|
|
|
gtk_container_add(GTK_CONTAINER(geany_data->tools_menu), demo_item);
|
2007-06-27 15:56:42 +00:00
|
|
|
g_signal_connect(G_OBJECT(demo_item), "activate", G_CALLBACK(item_activate), NULL);
|
|
|
|
|
2007-11-20 18:15:46 +00:00
|
|
|
welcome_text = g_strdup(_("Hello World!"));
|
|
|
|
|
2007-06-27 15:56:42 +00:00
|
|
|
// keep a pointer to the menu item, so we can remove it when the plugin is unloaded
|
2007-07-27 10:37:22 +00:00
|
|
|
plugin_fields->menu_item = demo_item;
|
2007-06-26 16:17:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-11-20 18:15:46 +00:00
|
|
|
/* Called by Geany to show the plugin's configure dialog. This function is always called after
|
|
|
|
* init() was called.
|
|
|
|
* You can omit this function if the plugin doesn't need to be configured.
|
|
|
|
* Note: parent is the parent window which can be used as the transient window for the created
|
|
|
|
* dialog. */
|
|
|
|
void configure(GtkWidget *parent)
|
|
|
|
{
|
|
|
|
GtkWidget *dialog, *label, *entry, *vbox;
|
|
|
|
|
|
|
|
// example configuration dialog
|
|
|
|
dialog = gtk_dialog_new_with_buttons(_("Demo"),
|
|
|
|
GTK_WINDOW(parent), GTK_DIALOG_DESTROY_WITH_PARENT,
|
|
|
|
GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, GTK_STOCK_OK, GTK_RESPONSE_ACCEPT, NULL);
|
|
|
|
vbox = ui->dialog_vbox_new(GTK_DIALOG(dialog));
|
|
|
|
gtk_widget_set_name(dialog, "GeanyDialog");
|
|
|
|
gtk_box_set_spacing(GTK_BOX(vbox), 6);
|
|
|
|
|
|
|
|
// add a label and a text entry t the dialog
|
|
|
|
label = gtk_label_new("Welcome text to show:");
|
|
|
|
gtk_widget_show(label);
|
|
|
|
gtk_misc_set_alignment(GTK_MISC(label), 0, 0.5);
|
|
|
|
entry = gtk_entry_new();
|
|
|
|
gtk_widget_show(entry);
|
|
|
|
if (welcome_text != NULL)
|
|
|
|
gtk_entry_set_text(GTK_ENTRY(entry), welcome_text);
|
|
|
|
|
|
|
|
gtk_container_add(GTK_CONTAINER(vbox), label);
|
|
|
|
gtk_container_add(GTK_CONTAINER(vbox), entry);
|
|
|
|
gtk_widget_show(vbox);
|
|
|
|
|
|
|
|
// run the dialog and check for the response code
|
|
|
|
if (gtk_dialog_run(GTK_DIALOG(dialog)) == GTK_RESPONSE_ACCEPT)
|
|
|
|
{
|
|
|
|
g_free(welcome_text);
|
|
|
|
welcome_text = g_strdup(gtk_entry_get_text(GTK_ENTRY(entry)));
|
|
|
|
// maybe the plugin should write here the settings into a file
|
|
|
|
// (e.g. using GLib's GKeyFile API)
|
|
|
|
// all plugin specific files should be created in:
|
|
|
|
// app->configdir G_DIR_SEPARATOR_S plugins G_DIR_SEPARATOR_S pluginname G_DIR_SEPARATOR_S
|
|
|
|
// e.g. this could be: ~/.geany/plugins/Demo/, please use app->configdir
|
|
|
|
}
|
|
|
|
gtk_widget_destroy(dialog);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-06-27 15:56:42 +00:00
|
|
|
/* Called by Geany before unloading the plugin.
|
2007-11-20 18:15:46 +00:00
|
|
|
* Here any UI changes should be removed, memory freed and any other finalization done.
|
|
|
|
* Be sure to leave Geany as it was before init(). */
|
2007-06-26 16:17:16 +00:00
|
|
|
void cleanup()
|
|
|
|
{
|
2007-06-27 15:56:42 +00:00
|
|
|
// remove the menu item added in init()
|
2007-07-27 10:37:22 +00:00
|
|
|
gtk_widget_destroy(plugin_fields->menu_item);
|
2007-11-20 18:15:46 +00:00
|
|
|
// release other allocated strings and objects
|
|
|
|
g_free(welcome_text);
|
2007-06-26 16:17:16 +00:00
|
|
|
}
|