This file is indexed.

/usr/include/gnucash/gnc-plugin-manager.h is in gnucash-common 1:2.4.10-6.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
/*
 * gnc-plugin-manager.h -- Manage gnucash plugins.
 *
 * Copyright (C) 2003 Jan Arne Petersen
 * Author: Jan Arne Petersen <jpetersen@uni-bonn.de>
 *
 * 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, contact:
 *
 * Free Software Foundation           Voice:  +1-617-542-5942
 * 51 Franklin Street, Fifth Floor    Fax:    +1-617-542-2652
 * Boston, MA  02110-1301,  USA       gnu@gnu.org
 */

/** @addtogroup Plugins
    @{ */
/** @addtogroup PluginManager Plugin Management Functions
    @{ */
/** @file gnc-plugin-manager.h
    @brief  Plugin management functions for the GnuCash UI
    @author Copyright (C) 2003 Jan Arne Petersen <jpetersen@uni-bonn.de>

    The plugin manager maintains a list of all non-content plugins
    that have been instantiated by various parts of Gnucash.  The
    manager will provide this list upon request, it will also look up
    individual plugins on request.  The main client of this manager is
    the main gnucash window code.  All plugins registered here will
    automatically be installed in each top level gnucash window that
    is created.

    This code installs a hook to be called when the gnucash user
    interface shuts down, and at that time it will unref any plugins
    that are still in its plugin list.

    Note: This code maintains a list of plugins (which provide user
    interface items), not a list of plugin-pages (which provide window
    content).
*/

#ifndef __GNC_PLUGIN_MANAGER_H
#define __GNC_PLUGIN_MANAGER_H

#include "gnc-plugin.h"

G_BEGIN_DECLS

/** @name Basic Object Implementation */
/** @{ */

/* type macros */
#define GNC_TYPE_PLUGIN_MANAGER            (gnc_plugin_manager_get_type ())
#define GNC_PLUGIN_MANAGER(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), GNC_TYPE_PLUGIN_MANAGER, GncPluginManager))
#define GNC_PLUGIN_MANAGER_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), GNC_TYPE_PLUGIN_MANAGER, GncPluginManagerClass))
#define GNC_IS_PLUGIN_MANAGER(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GNC_TYPE_PLUGIN_MANAGER))
#define GNC_IS_PLUGIN_MANAGER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GNC_TYPE_PLUGIN_MANAGER))
#define GNC_PLUGIN_MANAGER_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj), GNC_TYPE_PLUGIN_MANAGER, GncPluginManagerClass))

/* typedefs & structures */
typedef struct
{
    GObject gobject;
} GncPluginManager;

typedef struct
{
    GObjectClass gobject;

    /* Signals */
    void (* plugin_added)
    (GncPluginManager *plugin_manager, GncPlugin *plugin);
    void (* plugin_removed)
    (GncPluginManager *plugin_manager, GncPlugin *plugin);
} GncPluginManagerClass;

/** Retrieve the GType value for the gnucash plugin manager.
 *
 *  @return The GType that corresponds to an object of this type.
 */
GType gnc_plugin_manager_get_type (void);

/** @} */



/** @name Management Functions */
/** @{ */

/** Retrieve a pointer to the plugin manager.  This object is a
 *  singleton, that can only be retrieved via this function.  Once you
 *  have a pointer to the manager, you can call it to add/remove
 *  plugins, etc.
 *
 *  @return A pointer to the plugin manager object.
 */
GncPluginManager *gnc_plugin_manager_get (void);


/** Add a plugin to the list maintained by the plugin manager.
 *
 *  @param manager A pointer to the plugin manager.  Retrieve this by
 *  calling gnc_plugin_manager_get().
 *
 *  @param plugin A pointer to the plugin to add.
 *
 *  @note This function assumes ownership of this plugin.  Do not unref
 *  the plugin after passing it off to the plugin manager.
 */
void gnc_plugin_manager_add_plugin (GncPluginManager *manager,
                                    GncPlugin *plugin);


/** Remove a plugin from the list maintained by the plugin manager.
 *
 *  @param manager A pointer to the plugin manager.  Retrieve this by
 *  calling gnc_plugin_manager_get().
 *
 *  @param plugin A pointer to the plugin to add.
 */
void gnc_plugin_manager_remove_plugin (GncPluginManager *manager,
                                       GncPlugin *plugin);


/** Get a list of all plugins being held by the plugin manager.  This
 *  function is used by the main gnucash window code to get the list
 *  of plugins that need to be added to a new top level window.
 *
 *  @param manager A pointer to the plugin manager.  Retrieve this by
 *  calling gnc_plugin_manager_get().
 *
 *  @return A list of plugins.  This list is owned by the caller, and
 *  the must be frees when the caller is finished with it.
 */
GList *gnc_plugin_manager_get_plugins (GncPluginManager *manager);


/** Find a plugin by name from the list of plugins being held by the
 * plugin manager.
 *
 *  @param manager A pointer to the plugin manager.  Retrieve this by
 *  calling gnc_plugin_manager_get().
 *
 *  @param name The name of the plugin to find.
 *
 *  @return A pointer to the requested plugin, or NULL if the plugin
 *  couldn't be found.
 */
GncPlugin *gnc_plugin_manager_get_plugin (GncPluginManager *manager,
        const gchar *name);
/** @} */


G_END_DECLS

#endif /* __GNC_PLUGIN_MANAGER_H */

/** @} */
/** @} */