2008-03-11 23:40:59 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* Copyright (C) 2008 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_SAVEINTERFACE_H_
|
|
|
|
#define _OKULAR_SAVEINTERFACE_H_
|
|
|
|
|
2015-04-15 23:54:32 +00:00
|
|
|
#include "../core/okularcore_export.h"
|
2008-03-11 23:40:59 +00:00
|
|
|
|
2018-08-31 09:23:45 +00:00
|
|
|
#include <QObject>
|
2008-03-11 23:40:59 +00:00
|
|
|
|
|
|
|
namespace Okular {
|
|
|
|
|
|
|
|
class AnnotationProxy;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @short Abstract interface for saving
|
|
|
|
*
|
|
|
|
* This interface defines a way to save (or help saving) the document opened
|
|
|
|
* by the Generator.
|
|
|
|
*
|
|
|
|
* How to use it in a custom Generator:
|
|
|
|
* @code
|
|
|
|
class MyGenerator : public Okular::Generator, public Okular::SaveInterface
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
Q_INTERFACES( Okular::SaveInterface )
|
|
|
|
|
|
|
|
...
|
|
|
|
};
|
|
|
|
* @endcode
|
|
|
|
* and - of course - implementing its methods.
|
|
|
|
*/
|
2014-10-27 21:35:06 +00:00
|
|
|
class OKULARCORE_EXPORT SaveInterface
|
2008-03-11 23:40:59 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* The possible options for the saving.
|
|
|
|
*/
|
|
|
|
enum SaveOption
|
|
|
|
{
|
|
|
|
NoOption = 0,
|
|
|
|
SaveChanges = 1 ///< The possibility to save with the current changes to the document.
|
|
|
|
};
|
|
|
|
Q_DECLARE_FLAGS( SaveOptions, SaveOption )
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Destroys the save interface.
|
|
|
|
*/
|
|
|
|
virtual ~SaveInterface() {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Query for the supported saving options.
|
|
|
|
*
|
|
|
|
* @note NoOption is never queried
|
|
|
|
*/
|
|
|
|
virtual bool supportsOption( SaveOption option ) const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Save to the specified @p fileName with the specified @p options.
|
|
|
|
*/
|
2009-10-19 23:00:52 +00:00
|
|
|
virtual bool save( const QString &fileName, SaveOptions options, QString *errorText ) = 0;
|
2012-05-13 22:50:41 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the annotation proxy. Generators can return NULL if native
|
|
|
|
* annotations are not supported.
|
|
|
|
*
|
|
|
|
* @note Returning NULL is equivalent to returning an AnnotationProxy
|
|
|
|
* that doesn't support any capability.
|
|
|
|
* @since 0.15 (KDE 4.9)
|
|
|
|
*/
|
|
|
|
virtual AnnotationProxy* annotationProxy() const = 0;
|
2008-03-11 23:40:59 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2012-05-13 22:50:41 +00:00
|
|
|
Q_DECLARE_INTERFACE( Okular::SaveInterface, "org.kde.okular.SaveInterface/0.3" )
|
2008-03-11 23:40:59 +00:00
|
|
|
Q_DECLARE_OPERATORS_FOR_FLAGS( Okular::SaveInterface::SaveOptions )
|
|
|
|
|
|
|
|
#endif
|