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
|
/*
Plugin.h - header file for plugin. It contains mandatory macros
and common function for plugins
Copyright (C) 2009 Zdenek Prikryl (zprikryl@redhat.com)
Copyright (C) 2009 RedHat inc.
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.
*/
#ifndef PLUGIN_H_
#define PLUGIN_H_
#include <string>
#include <map>
#define PLUGINS_MAGIC_NUMBER 3
#define PLUGINS_CONF_EXTENSION "conf"
#define PLUGINS_LIB_EXTENSION "so"
#define PLUGINS_LIB_PREFIX "lib"
/**
* An abstract class. The class defines a common plugin interface.
*/
class CPlugin
{
public:
/**
* A destructor.
*/
virtual ~CPlugin() {}
/**
* A method, which initializes a plugin. It is not mandatory method.
*/
virtual void Init() {}
/**
* A method, which deinitializes a plugin. It is not mandatory method.
*/
virtual void DeInit() {}
/**
* A method, which loads a plugin settings. It is not mandatory method.
* @param pPath A path to plugin configuration file.
*/
virtual void LoadSettings(const std::string& pPath) {}
};
/**
* An emun of plugin types.
*/
typedef enum { ANALYZER, /**< An analyzer plugin*/
ACTION, /**< An action plugin*/
REPORTER, /**< A reporter plugin*/
DATABASE /**< A database plugin*/
} plugin_type_t;
/**
* Text reprezentation of plugin types.
*/
const char* const plugin_type_str_t[] = {"Analyzer", "Action", "Reporter", "Database"};
/**
* A struct contains all needed data about particular plugin.
*/
typedef struct SPluginInfo
{
const plugin_type_t m_Type; /**< Plugin type.*/
const std::string m_sName; /**< Plugin name.*/
const std::string m_sVersion; /**< Plugin version.*/
const std::string m_sDescription; /**< Plugin description.*/
const std::string m_sEmail; /**< Plugin author's email.*/
const std::string m_sWWW; /**< Plugin's home page.*/
const std::string m_sGTKBuilder; /**< Plugin's gui description.*/
const int m_nMagicNumber; /**< Plugin magical number.*/
} plugin_info_t;
#define PLUGIN_IFACE extern "C"
#define PLUGIN_INFO(type, plugin_class, name, version, description, email, www, gtk_builder)\
PLUGIN_IFACE CPlugin* plugin_new()\
{\
return new plugin_class();\
}\
PLUGIN_IFACE const plugin_info_t plugin_info =\
{\
type,\
name,\
version,\
description,\
email,\
www,\
gtk_builder,\
PLUGINS_MAGIC_NUMBER,\
};
#endif /* PLUGIN_H_ */
|