2024-08-25 16:08:24 +12:00
|
|
|
#include <QByteArray>
|
|
|
|
#include <QCryptographicHash>
|
|
|
|
#include <QIODevice>
|
2024-10-16 18:07:56 +13:00
|
|
|
#include <qcryptographichash.h>
|
2024-08-29 19:01:51 +12:00
|
|
|
#include "gen_qcryptographichash.h"
|
2024-12-11 19:55:47 +13:00
|
|
|
|
2025-01-07 11:30:33 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
} /* extern C */
|
2024-12-11 19:55:47 +13:00
|
|
|
#endif
|
2024-08-25 16:08:24 +12:00
|
|
|
|
2024-12-07 17:15:57 +13:00
|
|
|
QCryptographicHash* QCryptographicHash_new(int method) {
|
|
|
|
return new QCryptographicHash(static_cast<QCryptographicHash::Algorithm>(method));
|
2024-08-29 19:01:51 +12:00
|
|
|
}
|
|
|
|
|
2024-08-25 16:08:24 +12:00
|
|
|
void QCryptographicHash_Reset(QCryptographicHash* self) {
|
|
|
|
self->reset();
|
|
|
|
}
|
|
|
|
|
2024-08-29 19:01:51 +12:00
|
|
|
void QCryptographicHash_AddData(QCryptographicHash* self, const char* data, int length) {
|
2024-08-25 16:08:24 +12:00
|
|
|
self->addData(data, static_cast<int>(length));
|
|
|
|
}
|
|
|
|
|
2024-10-19 12:53:33 +13:00
|
|
|
void QCryptographicHash_AddDataWithData(QCryptographicHash* self, struct miqt_string data) {
|
|
|
|
QByteArray data_QByteArray(data.data, data.len);
|
|
|
|
self->addData(data_QByteArray);
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
bool QCryptographicHash_AddDataWithDevice(QCryptographicHash* self, QIODevice* device) {
|
|
|
|
return self->addData(device);
|
|
|
|
}
|
|
|
|
|
2024-10-19 12:53:33 +13:00
|
|
|
struct miqt_string QCryptographicHash_Result(const QCryptographicHash* self) {
|
|
|
|
QByteArray _qb = self->result();
|
|
|
|
struct miqt_string _ms;
|
|
|
|
_ms.len = _qb.length();
|
|
|
|
_ms.data = static_cast<char*>(malloc(_ms.len));
|
|
|
|
memcpy(_ms.data, _qb.data(), _ms.len);
|
|
|
|
return _ms;
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
2024-10-19 12:53:33 +13:00
|
|
|
struct miqt_string QCryptographicHash_Hash(struct miqt_string data, int method) {
|
|
|
|
QByteArray data_QByteArray(data.data, data.len);
|
|
|
|
QByteArray _qb = QCryptographicHash::hash(data_QByteArray, static_cast<QCryptographicHash::Algorithm>(method));
|
|
|
|
struct miqt_string _ms;
|
|
|
|
_ms.len = _qb.length();
|
|
|
|
_ms.data = static_cast<char*>(malloc(_ms.len));
|
|
|
|
memcpy(_ms.data, _qb.data(), _ms.len);
|
|
|
|
return _ms;
|
2024-08-29 19:01:51 +12:00
|
|
|
}
|
|
|
|
|
2024-09-18 12:12:02 +12:00
|
|
|
int QCryptographicHash_HashLength(int method) {
|
2024-08-29 19:01:51 +12:00
|
|
|
return QCryptographicHash::hashLength(static_cast<QCryptographicHash::Algorithm>(method));
|
|
|
|
}
|
|
|
|
|
2025-01-18 17:42:41 +13:00
|
|
|
void QCryptographicHash_Delete(QCryptographicHash* self) {
|
|
|
|
delete self;
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|