summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/opluginloader.h2
1 files changed, 0 insertions, 2 deletions
diff --git a/libopie2/opiecore/opluginloader.h b/libopie2/opiecore/opluginloader.h
index 7582d29..d97f586 100644
--- a/libopie2/opiecore/opluginloader.h
+++ b/libopie2/opiecore/opluginloader.h
@@ -1,207 +1,205 @@
1/* 1/*
2 * LGPLv2 or later 2 * LGPLv2 or later
3 * zecke@handhelds.org 3 * zecke@handhelds.org
4 */ 4 */
5#ifndef ODP_CORE_OPLUGIN_LOADER_H 5#ifndef ODP_CORE_OPLUGIN_LOADER_H
6#define ODP_CORE_OPLUGIN_LOADER_H 6#define ODP_CORE_OPLUGIN_LOADER_H
7 7
8#include <qpe/qlibrary.h> 8#include <qpe/qlibrary.h>
9 9
10#include <qptrdict.h> 10#include <qptrdict.h>
11#include <qstringlist.h> 11#include <qstringlist.h>
12 12
13namespace Opie { 13namespace Opie {
14namespace Core { 14namespace Core {
15class OConfig; 15class OConfig;
16namespace Internal { 16namespace Internal {
17class OPluginLibraryHolder; 17class OPluginLibraryHolder;
18} 18}
19 19
20// template class QPtrDict<QLibrary>;
21
22/** 20/**
23 * \brief A small item representing the Plugin Information 21 * \brief A small item representing the Plugin Information
24 * This class contains the information about a Plugin. It contains 22 * This class contains the information about a Plugin. It contains
25 * a translated name if available to the system, a config key, 23 * a translated name if available to the system, a config key,
26 * and the path location. 24 * and the path location.
27 * 25 *
28 * @since 1.2 26 * @since 1.2
29 * 27 *
30 */ 28 */
31class OPluginItem { 29class OPluginItem {
32public: 30public:
33 typedef QValueList<OPluginItem> List; 31 typedef QValueList<OPluginItem> List;
34 OPluginItem(); 32 OPluginItem();
35 OPluginItem( const QString& name, const QString& path, bool enabled = true, int pos = -1 ); 33 OPluginItem( const QString& name, const QString& path, bool enabled = true, int pos = -1 );
36 ~OPluginItem(); 34 ~OPluginItem();
37 35
38 bool isEmpty()const; 36 bool isEmpty()const;
39 37
40 bool operator==( const OPluginItem& )const; 38 bool operator==( const OPluginItem& )const;
41 bool operator!=( const OPluginItem& )const; 39 bool operator!=( const OPluginItem& )const;
42 40
43 41
44 QString name()const; 42 QString name()const;
45 QString path()const; 43 QString path()const;
46 bool isEnabled()const; 44 bool isEnabled()const;
47 int position()const; 45 int position()const;
48 46
49 void setName( const QString& ); 47 void setName( const QString& );
50 void setPath( const QString& ); 48 void setPath( const QString& );
51 void setEnabled( bool ); 49 void setEnabled( bool );
52 void setPosition( int ); 50 void setPosition( int );
53 51
54private: 52private:
55 QString m_name; 53 QString m_name;
56 QString m_path; 54 QString m_path;
57 bool m_enabled : 1; 55 bool m_enabled : 1;
58 int m_pos; 56 int m_pos;
59 struct Private; 57 struct Private;
60 Private *d; 58 Private *d;
61}; 59};
62 60
63/** 61/**
64 * \brief A generic class to easily load and manage plugins 62 * \brief A generic class to easily load and manage plugins
65 * 63 *
66 * This is the generic non sepcialised loader for plugins. Normally 64 * This is the generic non sepcialised loader for plugins. Normally
67 * you would prefer using the OPluginLoader directly. This class 65 * you would prefer using the OPluginLoader directly. This class
68 * exists to minimize the application binary size due the usage 66 * exists to minimize the application binary size due the usage
69 * of templates in the specialized API 67 * of templates in the specialized API
70 * 68 *
71 * @since 1.2 69 * @since 1.2
72 * @see OPluginLoader 70 * @see OPluginLoader
73 */ 71 */
74class OGenericPluginLoader { 72class OGenericPluginLoader {
75public: 73public:
76 typedef OPluginItem::List List; 74 typedef OPluginItem::List List;
77 OGenericPluginLoader( const QString &name, bool isSorted = false ); 75 OGenericPluginLoader( const QString &name, bool isSorted = false );
78 virtual ~OGenericPluginLoader(); 76 virtual ~OGenericPluginLoader();
79 77
80 void setAutoDelete( bool ); 78 void setAutoDelete( bool );
81 bool autoDelete()const; 79 bool autoDelete()const;
82 void clear(); 80 void clear();
83 81
84 QString name()const; 82 QString name()const;
85 bool isSorted()const; 83 bool isSorted()const;
86 bool isInSafeMode()const; 84 bool isInSafeMode()const;
87 85
88 86
89 List allAvailable(bool sorted = false )const; 87 List allAvailable(bool sorted = false )const;
90 List filtered(bool sorted = false )const; 88 List filtered(bool sorted = false )const;
91 89
92 90
93 virtual QUnknownInterface* load( const OPluginItem& item, const QUuid& ); 91 virtual QUnknownInterface* load( const OPluginItem& item, const QUuid& );
94 virtual void unload( QUnknownInterface* ); 92 virtual void unload( QUnknownInterface* );
95 93
96protected: 94protected:
97 friend class OPluginManager; // we need the static unlibify 95 friend class OPluginManager; // we need the static unlibify
98 void readConfig(); 96 void readConfig();
99 virtual List plugins( const QString& dir, bool sorted, bool disabled )const; 97 virtual List plugins( const QString& dir, bool sorted, bool disabled )const;
100 void setPluginDirs( const QStringList& ); 98 void setPluginDirs( const QStringList& );
101 void setPluginDir( const QString& ); 99 void setPluginDir( const QString& );
102 void setSafeMode(const QString& app = QString::null, bool b = false); 100 void setSafeMode(const QString& app = QString::null, bool b = false);
103 static QString unlibify( const QString& str ); 101 static QString unlibify( const QString& str );
104private: 102private:
105 QStringList languageList(); 103 QStringList languageList();
106 void installTranslators(const QString& type); 104 void installTranslators(const QString& type);
107 QString m_dir; 105 QString m_dir;
108 QStringList m_plugDirs; 106 QStringList m_plugDirs;
109 QStringList m_languages; 107 QStringList m_languages;
110 bool m_autoDelete : 1; 108 bool m_autoDelete : 1;
111 bool m_isSafeMode : 1; 109 bool m_isSafeMode : 1;
112 bool m_isSorted : 1; 110 bool m_isSorted : 1;
113 QPtrDict<QLibrary> m_library; 111 QPtrDict<QLibrary> m_library;
114 112
115 struct Private; 113 struct Private;
116 Private* d; 114 Private* d;
117}; 115};
118 116
119/** 117/**
120 * \brief The class to load your QCOM+ plugins 118 * \brief The class to load your QCOM+ plugins
121 * 119 *
122 * This class takes care of activation and even the order 120 * This class takes care of activation and even the order
123 * if you need it. It is normally good to place a .directory file 121 * if you need it. It is normally good to place a .directory file
124 * into your plugin directory if you need order of activation. 122 * into your plugin directory if you need order of activation.
125 * 123 *
126 * You'll create the OPluginLoader and then use it to load the filtered 124 * You'll create the OPluginLoader and then use it to load the filtered
127 * plugins. 125 * plugins.
128 * 126 *
129 * There is also a GUI for the configuration and a Manager to write the 127 * There is also a GUI for the configuration and a Manager to write the
130 * mentioned .directory file 128 * mentioned .directory file
131 * 129 *
132 * On crash the safe mode is activated for the next run. You can then decide 130 * On crash the safe mode is activated for the next run. You can then decide
133 * if you want to load plugins or come up with the Configuration on 131 * if you want to load plugins or come up with the Configuration on
134 * next start yourself then. 132 * next start yourself then.
135 * 133 *
136 * @since 1.2 134 * @since 1.2
137 */ 135 */
138class OPluginLoader : public OGenericPluginLoader { 136class OPluginLoader : public OGenericPluginLoader {
139public: 137public:
140 OPluginLoader( const QString& name, bool sorted = false ); 138 OPluginLoader( const QString& name, bool sorted = false );
141 virtual ~OPluginLoader(); 139 virtual ~OPluginLoader();
142 140
143 template<class IFace> 141 template<class IFace>
144 IFace* load( const OPluginItem& item, const QUuid& ); 142 IFace* load( const OPluginItem& item, const QUuid& );
145}; 143};
146 144
147/** 145/**
148 * \brief A class to manage order and activation of plugins 146 * \brief A class to manage order and activation of plugins
149 * 147 *
150 * Manage order and activation. This is used by the Opie::Ui::OPluginConfig 148 * Manage order and activation. This is used by the Opie::Ui::OPluginConfig
151 * This class controls the activation and order of plugins depending 149 * This class controls the activation and order of plugins depending
152 * on the OPluginLoader you supply. 150 * on the OPluginLoader you supply.
153 * You must call load() and save after construnction an instance 151 * You must call load() and save after construnction an instance
154 * 152 *
155 * @see Opie::Ui::OPluginConfig 153 * @see Opie::Ui::OPluginConfig
156 * 154 *
157 */ 155 */
158class OPluginManager { 156class OPluginManager {
159public: 157public:
160 typedef QValueList<OPluginManager*> List; 158 typedef QValueList<OPluginManager*> List;
161 OPluginManager( OGenericPluginLoader* ); 159 OPluginManager( OGenericPluginLoader* );
162 OPluginManager( const QString& name, const OPluginItem::List&, bool isSorted = false ); 160 OPluginManager( const QString& name, const OPluginItem::List&, bool isSorted = false );
163 virtual ~OPluginManager(); 161 virtual ~OPluginManager();
164 162
165 OPluginItem crashedPlugin()const; 163 OPluginItem crashedPlugin()const;
166 164
167 OPluginItem::List managedPlugins()const; 165 OPluginItem::List managedPlugins()const;
168 166
169 void setPosition( const OPluginItem& ); 167 void setPosition( const OPluginItem& );
170 void enable( const OPluginItem& ); 168 void enable( const OPluginItem& );
171 void disable( const OPluginItem& ); 169 void disable( const OPluginItem& );
172 void setEnabled( const OPluginItem&, bool = true); 170 void setEnabled( const OPluginItem&, bool = true);
173 171
174 virtual void load(); 172 virtual void load();
175 virtual void save(); 173 virtual void save();
176 174
177protected: 175protected:
178 QString configName()const; 176 QString configName()const;
179 void replace( const OPluginItem& ); 177 void replace( const OPluginItem& );
180private: 178private:
181 OGenericPluginLoader *m_loader; 179 OGenericPluginLoader *m_loader;
182 QString m_cfgName; 180 QString m_cfgName;
183 OPluginItem::List m_plugins; 181 OPluginItem::List m_plugins;
184 OPluginItem m_crashed; 182 OPluginItem m_crashed;
185 bool m_isSorted : 1; 183 bool m_isSorted : 1;
186}; 184};
187 185
188 186
189/** 187/**
190 * This is a template method allowing you to safely cast 188 * This is a template method allowing you to safely cast
191 * your load function 189 * your load function
192 * 190 *
193 * \code 191 * \code
194 * MyTypePlugin *plug = load->load<MyTypePlugin>( item, IID_MyPlugin ); 192 * MyTypePlugin *plug = load->load<MyTypePlugin>( item, IID_MyPlugin );
195 * \endcode 193 * \endcode
196 * 194 *
197 */ 195 */
198template<class IFace> 196template<class IFace>
199IFace* OPluginLoader::load( const OPluginItem& item, const QUuid& uid ) { 197IFace* OPluginLoader::load( const OPluginItem& item, const QUuid& uid ) {
200 return static_cast<IFace*>( OGenericPluginLoader::load( item, uid ) ); 198 return static_cast<IFace*>( OGenericPluginLoader::load( item, uid ) );
201} 199}
202 200
203} 201}
204} 202}
205 203
206 204
207#endif 205#endif