File: dictplugin.h

package info (click to toggle)
qstardict 3.0.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,872 kB
  • sloc: cpp: 6,962; xml: 77; makefile: 6; sh: 2
file content (294 lines) | stat: -rw-r--r-- 9,643 bytes parent folder | download | duplicates (2)
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
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
/*****************************************************************************
 * dictplugin.h - QStarDict, a StarDict clone written using Qt               *
 * Copyright (C) 2008 Alexander Rodin                                        *
 *                                                                           *
 * 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 DICTPLUGIN_H
#define DICTPLUGIN_H

#include <QtPlugin>
#include <QStringList>
#include <QDir>
#include <QCoreApplication>
#include <QVariant>

namespace QStarDict
{

/**
 * This is a base class for all dictionary plugins classes.
 */
class DictPlugin
{
    public:
        /**
         * This enum describes a features of dictionary plugin.
         */
        enum Feature
        {
            /**
             * No features.
             */
            None          = 0x00,
            /**
             * Dictionary plugin can search for similar words using
             * fuzzy algoritms.
             */
            SearchSimilar = 0x01,
            /**
             * Dictionary plugin has a settings dialog.
             */
            SettingsDialog = 0x02,
        };
        Q_DECLARE_FLAGS(Features, Feature)

        /**
         * This class represents information about dictionary.
         */
        class DictInfo
        {
            public:
                /**
                 * Construct empty DictInfo object.
                 */
                DictInfo()
                    : m_wordsCount(-1L)
                { }
                /**
                 * Construct DictInfo object from data.
                 * @param plugin A plugin name
                 * @param name A dictionary name
                 * @param author A dictionary author
                 * @param desription A dictionary description
                 * @param wordsCount A count of words that available in dictionary
                 */
                DictInfo(const QString &plugin,
                         const QString &name,
                         const QString &author = QString(),
                         const QString &description = QString(),
                         long wordsCount = -1L)
                    : m_plugin(plugin),
                      m_name(name),
                      m_author(author),
                      m_description(description),
                      m_wordsCount(wordsCount)
                { }

                const QString &plugin() const
                { return m_plugin; }
                const QString &name() const
                { return m_name; }
                const QString &author() const
                { return m_author; }
                const QString &description() const
                { return m_description; }
                long wordsCount() const
                { return m_wordsCount; }

                void setPlugin(const QString &plugin)
                { m_plugin = plugin; }
                void setName(const QString &name)
                { m_name = name; }
                void setAuthor(const QString &author)
                { m_author = author; }
                void setDescription(const QString &description)
                { m_description = description; }
                void setWordsCount(long wordsCount)
                { m_wordsCount = wordsCount; }

            private:
                QString m_plugin;
                QString m_name;
                QString m_author;
                QString m_description;
                long m_wordsCount;
        };

        /**
         * This class represent a translation.
         */
        class Translation
        {
            public:
                /**
                 * Construct an empty translation.
                 */
                Translation()
                { }

                /**
                 * Construct a translation from data.
                 * @param title A translation title
                 * @param dictName A full dictionary name
                 * @param translation A translation
                 */
                Translation(const QString &title,
                        const QString &dictName,
                        const QString &translation)
                    : m_title(title),
                      m_dictName(dictName),
                      m_translation(translation)
                { }

                /**
                 * Return the translation title.
                 */
                const QString &title() const
                { return m_title; }

                /**
                 * Return the dictionary name.
                 */
                const QString &dictName() const
                { return m_dictName; }

                /**
                 * Return the translation.
                 */
                const QString &translation() const
                { return m_translation; }

                /**
                 * Set a translation title.
                 */
                void setTitle(const QString &title)
                { m_title = title; }

                /**
                 * Set a dictionary name.
                 */
                void setDictName(const QString &dictName)
                { m_dictName = dictName; }

                /**
                 * Set a translation.
                 */
                void setTranslation(const QString &translation)
                { m_translation = translation; }

            private:
                QString m_title;
                QString m_dictName;
                QString m_translation;
        };

        /**
         * Destructor.
         */
        virtual ~DictPlugin() { }

        /**
         * Return the plugin name.
         */
        virtual QString name() const = 0;

        /**
         * Return the plugin version.
         */
        virtual QString version() const = 0;

        /**
         * Return the plugin description.
         */
        virtual QString description() const = 0;

        /**
         * Return the plugin authors.
         */
        virtual QStringList authors() const = 0;

        /**
         * Return a features supported by dictionary plugin.
         */
        virtual Features features() const
        { return Features(None); }

        /**
         * Return a list of available dictionaries.
         */
        virtual QStringList availableDicts() const = 0;

        /**
         * Return a list of loaded dictionaries.
         */
        virtual QStringList loadedDicts() const = 0;

        /**
         * Set a list of loaded dictionaries.
         */
        virtual void setLoadedDicts(const QStringList &loadedDicts) = 0;

        /**
         * Return true if translation exists in dictionary,
         * otherwise returns false.
         */
        virtual bool isTranslatable(const QString &dict, const QString &word) = 0;
        /**
         * Return translation for word from dictionary. If word not found
         * returns empty string.
         */
        virtual Translation translate(const QString &dict, const QString &word) = 0;
        /**
         * Return a list of similar to "word" words from all loaded dictionaries.
         * Works only if SearchSimilar feature is enabled.
         */
        virtual QStringList findSimilarWords(const QString &dict, const QString &word)
        { Q_UNUSED(dict); return QStringList(word); }
        
        /**
         * Return a required resource. Scheme of URLs:
         *   plugin://plugin_name/...
         */
        virtual QVariant resource(int type, const QUrl &name)
        { Q_UNUSED(type) Q_UNUSED(name) return QVariant(); }

        /**
         * Return an information about dictionary. The dictionary may be not loaded
         * but available.
         */
        virtual DictInfo dictInfo(const QString &dict) = 0;

        /**
         * Run a settings dialog and return QDialog::DialogCode.
         */
        virtual int execSettingsDialog(QWidget *parent = 0)
        { Q_UNUSED(parent); return 0; }

    protected:
        /**
         * Return a directory that contains plugin's data.
         */
        QString workPath() const
        {
            QString path = QDir::homePath() + "/.config/qstardict/pluginsdata/" + name();

            if (! QDir::root().exists(path))
                QDir::root().mkpath(path);
            return path;
        }
};

Q_DECLARE_OPERATORS_FOR_FLAGS(DictPlugin::Features)

}

Q_DECLARE_INTERFACE(QStarDict::DictPlugin, "org.qstardict.DictPlugin/1.0")

#endif // DICTPLUGIN_H

// vim: tabstop=4 softtabstop=4 shiftwidth=4 expandtab cindent