2007-01-02 17:14:37 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* Copyright (C) 2007 by Pino Toscano <pino@kde.org> *
|
|
|
|
* *
|
|
|
|
* 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. *
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _OKULAR_CONFIGINTERFACE_H_
|
|
|
|
#define _OKULAR_CONFIGINTERFACE_H_
|
|
|
|
|
2015-04-15 23:54:32 +00:00
|
|
|
#include "../core/okularcore_export.h"
|
2007-01-02 17:14:37 +00:00
|
|
|
|
2018-08-31 09:23:45 +00:00
|
|
|
#include <QObject>
|
2007-04-22 10:39:31 +00:00
|
|
|
|
2007-01-02 17:14:37 +00:00
|
|
|
class KConfigDialog;
|
|
|
|
|
|
|
|
namespace Okular
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @short Abstract interface for configuration control
|
|
|
|
*
|
|
|
|
* This interface defines a way to configure the Generator itself.
|
2007-01-02 17:25:26 +00:00
|
|
|
*
|
|
|
|
* How to use it in a custom Generator:
|
|
|
|
* @code
|
|
|
|
class MyGenerator : public Okular::Generator, public Okular::ConfigInterface
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
Q_INTERFACES( Okular::ConfigInterface )
|
|
|
|
|
|
|
|
...
|
|
|
|
};
|
|
|
|
* @endcode
|
|
|
|
* and - of course - implementing its methods.
|
2007-01-02 17:14:37 +00:00
|
|
|
*/
|
2014-10-27 21:35:06 +00:00
|
|
|
class OKULARCORE_EXPORT ConfigInterface
|
2007-01-02 17:14:37 +00:00
|
|
|
{
|
|
|
|
public:
|
2020-02-21 15:11:42 +00:00
|
|
|
ConfigInterface()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2007-01-02 17:25:26 +00:00
|
|
|
/**
|
|
|
|
* Destroys the config interface.
|
|
|
|
*/
|
2007-01-02 17:14:37 +00:00
|
|
|
virtual ~ConfigInterface()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2020-02-21 15:11:42 +00:00
|
|
|
ConfigInterface(const ConfigInterface &) = delete;
|
|
|
|
ConfigInterface &operator=(const ConfigInterface &) = delete;
|
|
|
|
|
2007-01-02 17:14:37 +00:00
|
|
|
/**
|
|
|
|
* This method is called to tell the generator to re-parse its configuration.
|
|
|
|
*
|
|
|
|
* Returns true if something has changed.
|
2007-07-12 18:14:01 +00:00
|
|
|
*
|
|
|
|
* @note this method can be called also when the generator is not the
|
|
|
|
* active generator, or when there was not changed in the config added
|
|
|
|
* by the generator itself. So the suggestion is to @b check whether
|
|
|
|
* something changed, and only in that case return @p true
|
2007-01-02 17:14:37 +00:00
|
|
|
*/
|
|
|
|
virtual bool reparseConfig() = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method allows the generator to add custom configuration pages to the
|
|
|
|
* config @p dialog of okular.
|
|
|
|
*/
|
|
|
|
virtual void addPages(KConfigDialog *dialog) = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
Q_DECLARE_INTERFACE(Okular::ConfigInterface, "org.kde.okular.ConfigInterface/0.1")
|
|
|
|
|
|
|
|
#endif
|