Finish ds_from_script

This commit is contained in:
Arin Alexander 2019-01-30 01:55:32 +03:00
commit 89139c108a
11 changed files with 75 additions and 39 deletions

View File

@ -32,6 +32,7 @@
#include "lrcallbackdatasourceintf.h" #include "lrcallbackdatasourceintf.h"
#include "lrglobal.h" #include "lrglobal.h"
#include "lrdatasourceintf.h"
class QVariant; class QVariant;
class QString; class QString;
@ -40,12 +41,14 @@ namespace LimeReport{
class IDbCredentialsProvider{ class IDbCredentialsProvider{
public: public:
virtual ~IDbCredentialsProvider(){}
virtual QString getUserName(const QString& connectionName) = 0; virtual QString getUserName(const QString& connectionName) = 0;
virtual QString getPassword(const QString& connectionName) = 0; virtual QString getPassword(const QString& connectionName) = 0;
}; };
class IDataSourceManager{ class IDataSourceManager{
public: public:
virtual ~IDataSourceManager(){}
virtual void setReportVariable(const QString& name, const QVariant& value) = 0; virtual void setReportVariable(const QString& name, const QVariant& value) = 0;
virtual void setDefaultDatabasePath(const QString &defaultDatabasePath) = 0; virtual void setDefaultDatabasePath(const QString &defaultDatabasePath) = 0;
virtual void deleteVariable(const QString& name) = 0; virtual void deleteVariable(const QString& name) = 0;
@ -57,12 +60,14 @@ public:
virtual void clearUserVariables()=0; virtual void clearUserVariables()=0;
virtual ICallbackDatasource* createCallbackDatasource(const QString& name) = 0; virtual ICallbackDatasource* createCallbackDatasource(const QString& name) = 0;
virtual void registerDbCredentialsProvider(IDbCredentialsProvider* provider) = 0; virtual void registerDbCredentialsProvider(IDbCredentialsProvider* provider) = 0;
virtual QStringList variableNames() = 0; virtual QStringList variableNames() = 0;
virtual bool variableIsMandatory(const QString& name) = 0; virtual bool variableIsMandatory(const QString& name) = 0;
virtual VariableDataType variableDataType(const QString& name) = 0; virtual VariableDataType variableDataType(const QString& name) = 0;
virtual bool variableIsSystem(const QString& name) = 0; virtual bool variableIsSystem(const QString& name) = 0;
virtual IDataSource* dataSource(const QString& name) = 0;
virtual IDataSourceHolder* dataSourceHolder(const QString& name) = 0;
}; };
} }
#endif // LRDATASOURCEMANAGERINTF_H #endif // LRDATASOURCEMANAGERINTF_H

View File

@ -46,7 +46,9 @@ public:
virtual bool addFunction(const QString &name, const QString& script, virtual bool addFunction(const QString &name, const QString& script,
const QString &category="", const QString &description="") = 0; const QString &category="", const QString &description="") = 0;
virtual const QString& lastError() const = 0; virtual const QString& lastError() const = 0;
virtual ScriptValueType moveQObjectToScript(QObject* object, const QString objectName) = 0;
virtual ~IScriptEngineManager(){} virtual ~IScriptEngineManager(){}
}; };
} //namespace LimeReport } //namespace LimeReport

View File

@ -131,6 +131,7 @@ HEADERS += \
$$REPORT_PATH/lrvariablesholder.h \ $$REPORT_PATH/lrvariablesholder.h \
$$REPORT_PATH/lrgroupfunctions.h \ $$REPORT_PATH/lrgroupfunctions.h \
$$REPORT_PATH/lrreportengine.h \ $$REPORT_PATH/lrreportengine.h \
$$REPORT_PATH/lrdatasourceintf.h \
$$REPORT_PATH/lrdatasourcemanagerintf.h \ $$REPORT_PATH/lrdatasourcemanagerintf.h \
$$REPORT_PATH/lrscriptenginemanagerintf.h \ $$REPORT_PATH/lrscriptenginemanagerintf.h \
$$REPORT_PATH/lrsimplecrypt.h \ $$REPORT_PATH/lrsimplecrypt.h \

View File

@ -34,6 +34,7 @@ contains(CONFIG, staticlib){
EXTRA_FILES += \ EXTRA_FILES += \
$$PWD/lrglobal.h \ $$PWD/lrglobal.h \
$$PWD/lrdatasourceintf.h \
$$PWD/lrdatasourcemanagerintf.h \ $$PWD/lrdatasourcemanagerintf.h \
$$PWD/lrreportengine.h \ $$PWD/lrreportengine.h \
$$PWD/lrscriptenginemanagerintf.h \ $$PWD/lrscriptenginemanagerintf.h \

View File

@ -40,47 +40,12 @@
#include <QVariant> #include <QVariant>
#include "lrcollection.h" #include "lrcollection.h"
#include "lrcallbackdatasourceintf.h" #include "lrcallbackdatasourceintf.h"
#include "lrdatasourceintf.h"
namespace LimeReport{ namespace LimeReport{
class DataSourceManager; class DataSourceManager;
class IDataSource {
public:
enum DatasourceMode{DESIGN_MODE,RENDER_MODE};
typedef QSharedPointer<IDataSource> Ptr;
virtual ~IDataSource(){}
virtual bool next() = 0;
virtual bool hasNext() = 0;
virtual bool prior() = 0;
virtual void first() = 0;
virtual void last() = 0;
virtual bool bof() = 0;
virtual bool eof() = 0;
virtual QVariant data(const QString& columnName) = 0;
virtual QVariant dataByKeyField(const QString& columnName, const QString& keyColumnName, QVariant keyData) = 0;
virtual int columnCount() = 0;
virtual QString columnNameByIndex(int columnIndex) = 0;
virtual int columnIndexByName(QString name) = 0;
virtual bool isInvalid() const = 0;
virtual QString lastError() = 0;
virtual QAbstractItemModel* model() = 0;
};
class IDataSourceHolder {
public:
virtual IDataSource* dataSource(IDataSource::DatasourceMode mode = IDataSource::RENDER_MODE) = 0;
virtual QString lastError() const = 0;
virtual bool isInvalid() const = 0;
virtual bool isOwned() const = 0;
virtual bool isEditable() const = 0;
virtual bool isRemovable() const = 0;
virtual void invalidate(IDataSource::DatasourceMode mode, bool dbWillBeClosed = false) = 0;
virtual void update() = 0;
virtual void clearErrors() = 0;
virtual ~IDataSourceHolder(){}
};
class ModelHolder: public QObject, public IDataSourceHolder{ class ModelHolder: public QObject, public IDataSourceHolder{
Q_OBJECT Q_OBJECT
public: public:

View File

@ -0,0 +1,47 @@
#ifndef LRDATASOURCEINTF_H
#define LRDATASOURCEINTF_H
#include <QSharedPointer>
#include <QAbstractItemModel>
namespace LimeReport {
class IDataSource {
public:
enum DatasourceMode{DESIGN_MODE,RENDER_MODE};
typedef QSharedPointer<IDataSource> Ptr;
virtual ~IDataSource() {}
virtual bool next() = 0;
virtual bool hasNext() = 0;
virtual bool prior() = 0;
virtual void first() = 0;
virtual void last() = 0;
virtual bool bof() = 0;
virtual bool eof() = 0;
virtual QVariant data(const QString& columnName) = 0;
virtual QVariant dataByKeyField(const QString& columnName, const QString& keyColumnName, QVariant keyData) = 0;
virtual int columnCount() = 0;
virtual QString columnNameByIndex(int columnIndex) = 0;
virtual int columnIndexByName(QString name) = 0;
virtual bool isInvalid() const = 0;
virtual QString lastError() = 0;
virtual QAbstractItemModel* model() = 0;
};
class IDataSourceHolder {
public:
virtual ~IDataSourceHolder(){}
virtual IDataSource* dataSource(IDataSource::DatasourceMode mode = IDataSource::RENDER_MODE) = 0;
virtual QString lastError() const = 0;
virtual bool isInvalid() const = 0;
virtual bool isOwned() const = 0;
virtual bool isEditable() const = 0;
virtual bool isRemovable() const = 0;
virtual void invalidate(IDataSource::DatasourceMode mode, bool dbWillBeClosed = false) = 0;
virtual void update() = 0;
virtual void clearErrors() = 0;
};
} // namespace LimeReport
#endif // LRDATASOURCEINTF_H

View File

@ -38,6 +38,7 @@
#include "lrvariablesholder.h" #include "lrvariablesholder.h"
#include "lrgroupfunctions.h" #include "lrgroupfunctions.h"
#include "lrdatasourcemanagerintf.h" #include "lrdatasourcemanagerintf.h"
#include "lrdatasourceintf.h"
namespace LimeReport{ namespace LimeReport{

View File

@ -32,6 +32,7 @@
#include "lrcallbackdatasourceintf.h" #include "lrcallbackdatasourceintf.h"
#include "lrglobal.h" #include "lrglobal.h"
#include "lrdatasourceintf.h"
class QVariant; class QVariant;
class QString; class QString;
@ -40,12 +41,14 @@ namespace LimeReport{
class IDbCredentialsProvider{ class IDbCredentialsProvider{
public: public:
virtual ~IDbCredentialsProvider(){}
virtual QString getUserName(const QString& connectionName) = 0; virtual QString getUserName(const QString& connectionName) = 0;
virtual QString getPassword(const QString& connectionName) = 0; virtual QString getPassword(const QString& connectionName) = 0;
}; };
class IDataSourceManager{ class IDataSourceManager{
public: public:
virtual ~IDataSourceManager(){}
virtual void setReportVariable(const QString& name, const QVariant& value) = 0; virtual void setReportVariable(const QString& name, const QVariant& value) = 0;
virtual void setDefaultDatabasePath(const QString &defaultDatabasePath) = 0; virtual void setDefaultDatabasePath(const QString &defaultDatabasePath) = 0;
virtual void deleteVariable(const QString& name) = 0; virtual void deleteVariable(const QString& name) = 0;
@ -57,12 +60,14 @@ public:
virtual void clearUserVariables()=0; virtual void clearUserVariables()=0;
virtual ICallbackDatasource* createCallbackDatasource(const QString& name) = 0; virtual ICallbackDatasource* createCallbackDatasource(const QString& name) = 0;
virtual void registerDbCredentialsProvider(IDbCredentialsProvider* provider) = 0; virtual void registerDbCredentialsProvider(IDbCredentialsProvider* provider) = 0;
virtual QStringList variableNames() = 0; virtual QStringList variableNames() = 0;
virtual bool variableIsMandatory(const QString& name) = 0; virtual bool variableIsMandatory(const QString& name) = 0;
virtual VariableDataType variableDataType(const QString& name) = 0; virtual VariableDataType variableDataType(const QString& name) = 0;
virtual bool variableIsSystem(const QString& name) = 0; virtual bool variableIsSystem(const QString& name) = 0;
virtual IDataSource* dataSource(const QString& name) = 0;
virtual IDataSourceHolder* dataSourceHolder(const QString& name) = 0;
}; };
} }
#endif // LRDATASOURCEMANAGERINTF_H #endif // LRDATASOURCEMANAGERINTF_H

View File

@ -562,6 +562,13 @@ void ScriptEngineManager::clearTableOfContents(){
} }
} }
ScriptValueType ScriptEngineManager::moveQObjectToScript(QObject* object, const QString objectName)
{
ScriptValueType result = scriptEngine()->newQObject(object);
scriptEngine()->globalObject().setProperty(objectName, result);
return result;
}
void ScriptEngineManager::updateModel() void ScriptEngineManager::updateModel()
{ {

View File

@ -377,7 +377,7 @@ public:
QVariant evaluateScript(const QString &script); QVariant evaluateScript(const QString &script);
void addTableOfContentsItem(const QString& uniqKey, const QString& content, int indent); void addTableOfContentsItem(const QString& uniqKey, const QString& content, int indent);
void clearTableOfContents(); void clearTableOfContents();
ScriptValueType moveQObjectToScript(QObject* object, const QString objectName);
protected: protected:
void updateModel(); void updateModel();
bool containsFunction(const QString &functionName); bool containsFunction(const QString &functionName);

View File

@ -46,7 +46,9 @@ public:
virtual bool addFunction(const QString &name, const QString& script, virtual bool addFunction(const QString &name, const QString& script,
const QString &category="", const QString &description="") = 0; const QString &category="", const QString &description="") = 0;
virtual const QString& lastError() const = 0; virtual const QString& lastError() const = 0;
virtual ScriptValueType moveQObjectToScript(QObject* object, const QString objectName) = 0;
virtual ~IScriptEngineManager(){} virtual ~IScriptEngineManager(){}
}; };
} //namespace LimeReport } //namespace LimeReport