mirror of
https://github.com/status-im/dotherside.git
synced 2025-02-12 04:26:43 +00:00
Simplified the dos_qabstractitemmodel_create interface by using a struct
Removed most of the function parameters by putting them inside a struct
This commit is contained in:
parent
0bb4bc8d3c
commit
ffd9b493a9
@ -385,27 +385,11 @@ DOS_API DosQMetaObject *DOS_CALL dos_qabstractlistmodel_qmetaobject();
|
||||
/// \param callbackObject The pointer of QAbstractListModel in the binded language
|
||||
/// \param metaObject The QMetaObject for this QAbstractListModel
|
||||
/// \param dObjectCallback The callback for handling the properties read/write and slots execution
|
||||
/// \param rowCountCallback The callback for handling the QAbstractItemModel::rowCount() execution
|
||||
/// \param columnCountCallback The callback for handling the QAbstractItemModel::columnCount() execution
|
||||
/// \param dataCallback The callback for handling the QAbstractItemModel::data() execution
|
||||
/// \param setDataCallback The callback for handling the QAbstractItemModel::setData() execution
|
||||
/// \param roleNamesCallback The callback for handling the QAbstractItemModel::roleNames() execution
|
||||
/// \param flagsCallback The callback for handling the QAbstractItemModel::flags() execution
|
||||
/// \param headerDataCallback The callback for handling the QAbstractItemModel::headerData() execution
|
||||
/// \param indexCallback The callback for handling the QAbstractItemModel::index() execution
|
||||
/// \param parentCallback The callback for handling the QAbstractItemModel::parent() execution
|
||||
/// \param callbacks The QAbstractItemModel callbacks
|
||||
DOS_API DosQAbstractListModel *DOS_CALL dos_qabstractlistmodel_create(void *callbackObject,
|
||||
DosQMetaObject *metaObject,
|
||||
DObjectCallback dObjectCallback,
|
||||
RowCountCallback rowCountCallback,
|
||||
ColumnCountCallback columnCountCallback,
|
||||
DataCallback dataCallback,
|
||||
SetDataCallback setDataCallback,
|
||||
RoleNamesCallback roleNamesCallback,
|
||||
FlagsCallback flagsCallback,
|
||||
HeaderDataCallback headerDataCallback,
|
||||
IndexCallback indexCallback,
|
||||
ParentCallback parentCallback);
|
||||
DosQAbstractItemModelCallbacks* callbacks);
|
||||
|
||||
/// \brief Calls the default QAbstractListModel::index() function
|
||||
DOS_API DosQModelIndex* DOS_CALL dos_qabstractlistmodel_index(DosQAbstractListModel *vptr,
|
||||
@ -434,27 +418,11 @@ DOS_API DosQMetaObject *DOS_CALL dos_qabstracttablemodel_qmetaobject();
|
||||
/// \param callbackObject The pointer of QAbstractTableModel in the binded language
|
||||
/// \param metaObject The QMetaObject for this QAbstractTableModel
|
||||
/// \param dObjectCallback The callback for handling the properties read/write and slots execution
|
||||
/// \param rowCountCallback The callback for handling the QAbstractItemModel::rowCount() execution
|
||||
/// \param columnCountCallback The callback for handling the QAbstractItemModel::columnCount() execution
|
||||
/// \param dataCallback The callback for handling the QAbstractItemModel::data() execution
|
||||
/// \param setDataCallback The callback for handling the QAbstractItemModel::setData() execution
|
||||
/// \param roleNamesCallback The callback for handling the QAbstractItemModel::roleNames() execution
|
||||
/// \param flagsCallback The callback for handling the QAbstractItemModel::flags() execution
|
||||
/// \param headerDataCallback The callback for handling the QAbstractItemModel::headerData() execution
|
||||
/// \param indexCallback The callback for handling the QAbstractItemModel::index() execution
|
||||
/// \param parentCallback The callback for handling the QAbstractItemModel::parent() execution
|
||||
/// \param callbacks The QAbstractItemModel callbacks
|
||||
DOS_API DosQAbstractTableModel *DOS_CALL dos_qabstracttablemodel_create(void *callbackObject,
|
||||
DosQMetaObject *metaObject,
|
||||
DObjectCallback dObjectCallback,
|
||||
RowCountCallback rowCountCallback,
|
||||
ColumnCountCallback columnCountCallback,
|
||||
DataCallback dataCallback,
|
||||
SetDataCallback setDataCallback,
|
||||
RoleNamesCallback roleNamesCallback,
|
||||
FlagsCallback flagsCallback,
|
||||
HeaderDataCallback headerDataCallback,
|
||||
IndexCallback indexCallback,
|
||||
ParentCallback parentCallback);
|
||||
DosQAbstractItemModelCallbacks* callbacks);
|
||||
|
||||
/// \brief Calls the default QAbstractTableModel::index() function
|
||||
DOS_API DosQModelIndex* DOS_CALL dos_qabstracttablemodel_index(DosQAbstractTableModel *vptr,
|
||||
@ -475,32 +443,28 @@ DOS_API DosQModelIndex* DOS_CALL dos_qabstracttablemodel_parent(DosQAbstractTabl
|
||||
/// \note The returned QMetaObject should be freed using dos_qmetaobject_delete().
|
||||
DOS_API DosQMetaObject *DOS_CALL dos_qabstractitemmodel_qmetaobject();
|
||||
|
||||
|
||||
/// \brief Create a new QAbstractItemModel
|
||||
/// \param callbackObject The pointer of QAbstractItemModel in the binded language
|
||||
/// \param metaObject The QMetaObject for this QAbstractItemModel
|
||||
/// \param dObjectCallback The callback for handling the properties read/write and slots execution
|
||||
/// \param rowCountCallback The callback for handling the QAbstractItemModel::rowCount() execution
|
||||
/// \param columnCountCallback The callback for handling the QAbstractItemModel::columnCount() execution
|
||||
/// \param dataCallback The callback for handling the QAbstractItemModel::data() execution
|
||||
/// \param setDataCallback The callback for handling the QAbstractItemModel::setData() execution
|
||||
/// \param roleNamesCallback The callback for handling the QAbstractItemModel::roleNames() execution
|
||||
/// \param flagsCallback The callback for handling the QAbstractItemModel::flags() execution
|
||||
/// \param headerDataCallback The callback for handling the QAbstractItemModel::headerData() execution
|
||||
/// \param indexCallback The callback for handling the QAbstractItemModel::index() execution
|
||||
/// \param parentCallback The callback for handling the QAbstractItemModel::parent() execution
|
||||
/// \param callbacks The QAbstractItemModel callbacks
|
||||
/// \note The callbacks struct is copied so you can freely delete after calling this function
|
||||
DOS_API DosQAbstractItemModel *DOS_CALL dos_qabstractitemmodel_create(void *callbackObject,
|
||||
DosQMetaObject *metaObject,
|
||||
DObjectCallback dObjectCallback,
|
||||
RowCountCallback rowCountCallback,
|
||||
ColumnCountCallback columnCountCallback,
|
||||
DataCallback dataCallback,
|
||||
SetDataCallback setDataCallback,
|
||||
RoleNamesCallback roleNamesCallback,
|
||||
FlagsCallback flagsCallback,
|
||||
HeaderDataCallback headerDataCallback,
|
||||
IndexCallback indexCallback,
|
||||
ParentCallback parentCallback);
|
||||
DosQAbstractItemModelCallbacks* callbacks);
|
||||
|
||||
/// \brief Calls the QAbstractItemModel::setData function
|
||||
bool dos_qabstractitemmodel_setData(DosQAbstractItemModel *vptr, DosQModelIndex* index, DosQVariant* data, int role);
|
||||
|
||||
/// \brief Calls the QAbstractItemModel::roleNames function
|
||||
DosQHashIntQByteArray* dos_qabstractitemmodel_roleNames(DosQAbstractItemModel *vptr);
|
||||
|
||||
/// \brief Calls the QAbstractItemModel::flags function
|
||||
int dos_qabstractitemmodel_flags(DosQAbstractItemModel *vptr, DosQModelIndex* index);
|
||||
|
||||
/// \brief Calls the QAbstractItemModel::headerData function
|
||||
DosQVariant* dos_qabstractitemmodel_headerData(DosQAbstractItemModel *vptr, int section, int orientation, int role);
|
||||
|
||||
/// \brief Calls the QAbstractItemModel::beginInsertRows() function
|
||||
/// \param vptr The QAbstractItemModel
|
||||
|
@ -309,6 +309,24 @@ struct PropertyDefinitions {
|
||||
typedef struct PropertyDefinitions PropertyDefinitions;
|
||||
#endif
|
||||
|
||||
/// Incapsulate all the QAbstractItemModel callbacks
|
||||
struct DosQAbstractItemModelCallbacks
|
||||
{
|
||||
RowCountCallback rowCount;
|
||||
ColumnCountCallback columnCount;
|
||||
DataCallback data;
|
||||
SetDataCallback setData;
|
||||
RoleNamesCallback roleNames;
|
||||
FlagsCallback flags;
|
||||
HeaderDataCallback headerData;
|
||||
IndexCallback index;
|
||||
ParentCallback parent;
|
||||
};
|
||||
|
||||
#ifndef __cplusplus
|
||||
typedef struct DosQAbstractItemModelCallbacks DosQAbstractItemModelCallbacks;
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
@ -20,15 +20,7 @@ public:
|
||||
DosQAbstractGenericModel(void *modelObject,
|
||||
DosIQMetaObjectPtr metaObject,
|
||||
OnSlotExecuted onSlotExecuted,
|
||||
RowCountCallback rowCountCallback,
|
||||
ColumnCountCallback columnCountCallback,
|
||||
DataCallback dataCallback,
|
||||
SetDataCallback setDataCallback,
|
||||
RoleNamesCallback roleNamesCallback,
|
||||
FlagsCallback flagsCallback,
|
||||
HeaderDataCallback headerDataCallback,
|
||||
IndexCallback indexCallback,
|
||||
ParentCallback parentCallback);
|
||||
DosQAbstractItemModelCallbacks callbacks);
|
||||
|
||||
/// @see IDynamicQObject::emitSignal
|
||||
bool emitSignal(QObject *emitter, const QString &name, const std::vector<QVariant> &argumentsValues) override;
|
||||
@ -122,15 +114,7 @@ public:
|
||||
private:
|
||||
std::unique_ptr<DosIQObjectImpl> m_impl;
|
||||
void *m_modelObject;
|
||||
RowCountCallback m_rowCountCallback;
|
||||
ColumnCountCallback m_columnCountCallback;
|
||||
DataCallback m_dataCallback;
|
||||
SetDataCallback m_setDataCallback;
|
||||
RoleNamesCallback m_roleNamesCallback;
|
||||
FlagsCallback m_flagsCallback;
|
||||
HeaderDataCallback m_headerDataCallback;
|
||||
IndexCallback m_indexCallback;
|
||||
ParentCallback m_parentCallback;
|
||||
DosQAbstractItemModelCallbacks m_callbacks;
|
||||
};
|
||||
|
||||
class DosQAbstractItemModel : public DosQAbstractGenericModel<QAbstractItemModel>
|
||||
|
@ -596,29 +596,13 @@ void dos_qmetaobject_delete(::DosQMetaObject *vptr)
|
||||
::DosQAbstractListModel *dos_qabstracttablemodel_create(void *dObjectPointer,
|
||||
::DosQMetaObject *metaObjectPointer,
|
||||
::DObjectCallback dObjectCallback,
|
||||
::RowCountCallback rowCountCallback,
|
||||
::ColumnCountCallback columnCountCallback,
|
||||
::DataCallback dataCallback,
|
||||
::SetDataCallback setDataCallback,
|
||||
::RoleNamesCallback roleNamesCallaback,
|
||||
::FlagsCallback flagsCallback,
|
||||
::HeaderDataCallback headerDataCallback,
|
||||
::IndexCallback indexCallback,
|
||||
::ParentCallback parentCallback)
|
||||
::DosQAbstractItemModelCallbacks* callbacks)
|
||||
{
|
||||
auto metaObjectHolder = static_cast<DOS::DosIQMetaObjectHolder *>(metaObjectPointer);
|
||||
auto model = new DOS::DosQAbstractTableModel(dObjectPointer,
|
||||
metaObjectHolder->data(),
|
||||
DOS::OnSlotExecutedHandler(dObjectPointer, dObjectCallback),
|
||||
rowCountCallback,
|
||||
columnCountCallback,
|
||||
dataCallback,
|
||||
setDataCallback,
|
||||
roleNamesCallaback,
|
||||
flagsCallback,
|
||||
headerDataCallback,
|
||||
indexCallback,
|
||||
parentCallback);
|
||||
*callbacks);
|
||||
QQmlEngine::setObjectOwnership(model, QQmlEngine::CppOwnership);
|
||||
return static_cast<QObject *>(model);
|
||||
}
|
||||
@ -649,29 +633,13 @@ DosQModelIndex *dos_qabstracttablemodel_parent(DosQAbstractTableModel *vptr, Dos
|
||||
::DosQAbstractListModel *dos_qabstractlistmodel_create(void *dObjectPointer,
|
||||
::DosQMetaObject *metaObjectPointer,
|
||||
::DObjectCallback dObjectCallback,
|
||||
::RowCountCallback rowCountCallback,
|
||||
::ColumnCountCallback columnCountCallback,
|
||||
::DataCallback dataCallback,
|
||||
::SetDataCallback setDataCallback,
|
||||
::RoleNamesCallback roleNamesCallaback,
|
||||
::FlagsCallback flagsCallback,
|
||||
::HeaderDataCallback headerDataCallback,
|
||||
::IndexCallback indexCallback,
|
||||
::ParentCallback parentCallback)
|
||||
::DosQAbstractItemModelCallbacks* callbacks)
|
||||
{
|
||||
auto metaObjectHolder = static_cast<DOS::DosIQMetaObjectHolder *>(metaObjectPointer);
|
||||
auto model = new DOS::DosQAbstractListModel(dObjectPointer,
|
||||
metaObjectHolder->data(),
|
||||
DOS::OnSlotExecutedHandler(dObjectPointer, dObjectCallback),
|
||||
rowCountCallback,
|
||||
columnCountCallback,
|
||||
dataCallback,
|
||||
setDataCallback,
|
||||
roleNamesCallaback,
|
||||
flagsCallback,
|
||||
headerDataCallback,
|
||||
indexCallback,
|
||||
parentCallback);
|
||||
*callbacks);
|
||||
QQmlEngine::setObjectOwnership(model, QQmlEngine::CppOwnership);
|
||||
return static_cast<QObject *>(model);
|
||||
}
|
||||
@ -710,29 +678,13 @@ int dos_qabstractlistmodel_columnCount(DosQAbstractListModel *vptr, DosQModelInd
|
||||
::DosQAbstractItemModel *dos_qabstractitemmodel_create(void *dObjectPointer,
|
||||
::DosQMetaObject *metaObjectPointer,
|
||||
::DObjectCallback dObjectCallback,
|
||||
::RowCountCallback rowCountCallback,
|
||||
::ColumnCountCallback columnCountCallback,
|
||||
::DataCallback dataCallback,
|
||||
::SetDataCallback setDataCallback,
|
||||
::RoleNamesCallback roleNamesCallaback,
|
||||
::FlagsCallback flagsCallback,
|
||||
::HeaderDataCallback headerDataCallback,
|
||||
::IndexCallback indexCallback,
|
||||
::ParentCallback parentCallback)
|
||||
::DosQAbstractItemModelCallbacks* callbacks)
|
||||
{
|
||||
auto metaObjectHolder = static_cast<DOS::DosIQMetaObjectHolder *>(metaObjectPointer);
|
||||
auto model = new DOS::DosQAbstractItemModel(dObjectPointer,
|
||||
metaObjectHolder->data(),
|
||||
DOS::OnSlotExecutedHandler(dObjectPointer, dObjectCallback),
|
||||
rowCountCallback,
|
||||
columnCountCallback,
|
||||
dataCallback,
|
||||
setDataCallback,
|
||||
roleNamesCallaback,
|
||||
flagsCallback,
|
||||
headerDataCallback,
|
||||
indexCallback,
|
||||
parentCallback);
|
||||
*callbacks);
|
||||
QQmlEngine::setObjectOwnership(model, QQmlEngine::CppOwnership);
|
||||
return static_cast<QObject *>(model);
|
||||
}
|
||||
|
@ -19,26 +19,10 @@ template<class T>
|
||||
DosQAbstractGenericModel<T>::DosQAbstractGenericModel(void *modelObject,
|
||||
DosIQMetaObjectPtr metaObject,
|
||||
OnSlotExecuted onSlotExecuted,
|
||||
RowCountCallback rowCountCallback,
|
||||
ColumnCountCallback columnCountCallback,
|
||||
DataCallback dataCallback,
|
||||
SetDataCallback setDataCallback,
|
||||
RoleNamesCallback roleNamesCallback,
|
||||
FlagsCallback flagsCallback,
|
||||
HeaderDataCallback headerDataCallback,
|
||||
IndexCallback indexCallback,
|
||||
ParentCallback parentCallback)
|
||||
DosQAbstractItemModelCallbacks callbacks)
|
||||
: m_impl(new DosQObjectImpl(this, ::createParentMetaCall(this), std::move(metaObject), std::move(onSlotExecuted)))
|
||||
, m_modelObject(std::move(modelObject))
|
||||
, m_rowCountCallback(std::move(rowCountCallback))
|
||||
, m_columnCountCallback(std::move(columnCountCallback))
|
||||
, m_dataCallback(std::move(dataCallback))
|
||||
, m_setDataCallback(std::move(setDataCallback))
|
||||
, m_roleNamesCallback(std::move(roleNamesCallback))
|
||||
, m_flagsCallback(std::move(flagsCallback))
|
||||
, m_headerDataCallback(std::move(headerDataCallback))
|
||||
, m_indexCallback(std::move(indexCallback))
|
||||
, m_parentCallback(std::move(parentCallback))
|
||||
, m_callbacks(callbacks)
|
||||
{}
|
||||
|
||||
template<class T>
|
||||
@ -66,7 +50,7 @@ template<class T>
|
||||
int DosQAbstractGenericModel<T>::rowCount(const QModelIndex &parent) const
|
||||
{
|
||||
int result;
|
||||
m_rowCountCallback(m_modelObject, &parent, &result);
|
||||
m_callbacks.rowCount(m_modelObject, &parent, &result);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -74,7 +58,7 @@ template<class T>
|
||||
int DosQAbstractGenericModel<T>::columnCount(const QModelIndex &parent) const
|
||||
{
|
||||
int result;
|
||||
m_columnCountCallback(m_modelObject, &parent, &result);
|
||||
m_callbacks.columnCount(m_modelObject, &parent, &result);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -82,7 +66,7 @@ template<class T>
|
||||
QVariant DosQAbstractGenericModel<T>::data(const QModelIndex &index, int role) const
|
||||
{
|
||||
QVariant result;
|
||||
m_dataCallback(m_modelObject, &index, role, &result);
|
||||
m_callbacks.data(m_modelObject, &index, role, &result);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -90,7 +74,7 @@ template<class T>
|
||||
bool DosQAbstractGenericModel<T>::setData(const QModelIndex &index, const QVariant &value, int role)
|
||||
{
|
||||
bool result = false;
|
||||
m_setDataCallback(m_modelObject, &index, &value, role, &result);
|
||||
m_callbacks.setData(m_modelObject, &index, &value, role, &result);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -98,7 +82,7 @@ template<class T>
|
||||
Qt::ItemFlags DosQAbstractGenericModel<T>::flags(const QModelIndex &index) const
|
||||
{
|
||||
int result;
|
||||
m_flagsCallback(m_modelObject, &index, &result);
|
||||
m_callbacks.flags(m_modelObject, &index, &result);
|
||||
return Qt::ItemFlags(result);
|
||||
}
|
||||
|
||||
@ -106,7 +90,7 @@ template<class T>
|
||||
QVariant DosQAbstractGenericModel<T>::headerData(int section, Qt::Orientation orientation, int role) const
|
||||
{
|
||||
QVariant result;
|
||||
m_headerDataCallback(m_modelObject, section, orientation, role, &result);
|
||||
m_callbacks.headerData(m_modelObject, section, orientation, role, &result);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -114,7 +98,7 @@ template<class T>
|
||||
QModelIndex DosQAbstractGenericModel<T>::index(int row, int column, const QModelIndex &parent) const
|
||||
{
|
||||
QModelIndex result;
|
||||
m_indexCallback(m_modelObject, row, column, &parent, &result);
|
||||
m_callbacks.index(m_modelObject, row, column, &parent, &result);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -122,7 +106,7 @@ template<class T>
|
||||
QModelIndex DosQAbstractGenericModel<T>::parent(const QModelIndex &child) const
|
||||
{
|
||||
QModelIndex result;
|
||||
m_parentCallback(m_modelObject, &child, &result);
|
||||
m_callbacks.parent(m_modelObject, &child, &result);
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -136,7 +120,7 @@ template<class T>
|
||||
QHash<int, QByteArray> DosQAbstractGenericModel<T>::roleNames() const
|
||||
{
|
||||
QHash<int, QByteArray> result;
|
||||
m_roleNamesCallback(m_modelObject, &result);
|
||||
m_callbacks.roleNames(m_modelObject, &result);
|
||||
return result;
|
||||
}
|
||||
|
||||
|
@ -66,13 +66,21 @@ namespace
|
||||
}
|
||||
|
||||
MockQAbstractItemModel::MockQAbstractItemModel()
|
||||
: m_vptr(dos_qabstractitemmodel_create(this, metaObject(), &onSlotCalled, &onRowCountCalled,
|
||||
&onColumnCountCalled, &onDataCalled, &onSetDataCalled,
|
||||
&onRoleNamesCalled, &onFlagsCalled, &onHeaderDataCalled,
|
||||
&onIndexCalled, &onParentCalled), &dos_qobject_delete)
|
||||
: m_vptr(nullptr, &dos_qobject_delete)
|
||||
, m_names({"John", "Mary", "Andy", "Anna"})
|
||||
{
|
||||
DosQAbstractItemModelCallbacks callbacks;
|
||||
callbacks.rowCount = &onRowCountCalled;
|
||||
callbacks.columnCount = &onColumnCountCalled;
|
||||
callbacks.data = &onDataCalled;
|
||||
callbacks.setData = &onSetDataCalled;
|
||||
callbacks.roleNames = &onRoleNamesCalled;
|
||||
callbacks.flags = &onFlagsCalled;
|
||||
callbacks.headerData = &onHeaderDataCalled;
|
||||
callbacks.index = &onIndexCalled;
|
||||
callbacks.parent = &onParentCalled;
|
||||
|
||||
m_vptr.reset(dos_qabstractitemmodel_create(this, metaObject(), &onSlotCalled, &callbacks));
|
||||
}
|
||||
|
||||
DosQMetaObject *MockQAbstractItemModel::metaObject()
|
||||
|
Loading…
x
Reference in New Issue
Block a user