*******************************************************************************/
-// Created by Bartosz Szatkowski
+/*! /file CommonDictInterface.h
+\brief Common interface for all dicts and plugins \see CommonDictInterface
+
+\author Bartosz Szatkowski <bulislaw@linux.com>
+*/
#ifndef COMMONDICTINTERFACE_H
#define COMMONDICTINTERFACE_H
#include <QObject>
#include <QList>
#include "translation.h"
+
+class DictDialog;
class Settings;
//! returns information about dictionary in html (name, authors, etc)
virtual QString infoNote() const = 0;
- //! return dialog that creates new dictionary and fills necesary options
- //! QDialog should returns Setting* object after being showed
- virtual QDialog* loadDialog() = 0;
+ /*! returns DictDialog object that creates dialogs
+ for adding new dictionary and change plugin settings*/
+ virtual DictDialog* dictDialog() = 0;
- //! return dialog with dictionary settings
- virtual QDialog* settingsDialog() = 0;
- //! return new, clean copy of plugin with setting set as in Settings*
+ //! returns new, clean copy of plugin with setting set as in Settings*
virtual CommonDictInterface* getNew(const Settings*) const = 0;
//! returns whether plugin can start searching
//! \returns unique value (unique for every dictionary not plugin
virtual uint hash() const = 0;
+ //! sets unique value (unique for every dictionary not plugin)
+ virtual void setHash(uint) = 0;
+
+ //! returns current plugin settings
+ virtual Settings* settings() = 0;
+
+ //! returns plugin icon
+ virtual QIcon* icon() = 0;
+
public Q_SLOTS:
/*! performs search in dictionary
\param word word to search in dictionary
- \param limit limit on number of results
+ \param limit limit on number of results,
+ if limit=0 all matching words are returned
After finishing search it have to emit
\see CommonDictInterface:finalTranslation finalTranslation
-
*/
- virtual QList<Translation*> searchWordList(QString word, int limit) = 0;
+ virtual QList<Translation*> searchWordList(QString word, int limit=0) = 0;
- //! stop current operation
+ //! stops current operation
virtual void stop() = 0;
Q_SIGNALS:
//! emited after dictionary is ready to use afer being loaded
void loaded(CommonDictInterface*);
+
+ //! emited after change dictionary settings
+ void settingsChanged();
};
Q_DECLARE_INTERFACE(CommonDictInterface, "CommonDictInterface/0.1");