2024-08-25 16:08:24 +12:00
|
|
|
#include <QBasicMutex>
|
|
|
|
#include <QMutex>
|
|
|
|
#include <QMutexLocker>
|
|
|
|
#include <QRecursiveMutex>
|
2024-10-16 18:07:56 +13:00
|
|
|
#include <qmutex.h>
|
2024-08-29 19:01:51 +12:00
|
|
|
#include "gen_qmutex.h"
|
2024-09-15 10:29:05 +12:00
|
|
|
#include "_cgo_export.h"
|
2024-08-25 16:08:24 +12:00
|
|
|
|
2024-11-19 19:29:06 +13:00
|
|
|
void QBasicMutex_new(QBasicMutex** outptr_QBasicMutex) {
|
|
|
|
QBasicMutex* ret = new QBasicMutex();
|
|
|
|
*outptr_QBasicMutex = ret;
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
void QBasicMutex_Lock(QBasicMutex* self) {
|
|
|
|
self->lock();
|
|
|
|
}
|
|
|
|
|
|
|
|
void QBasicMutex_Unlock(QBasicMutex* self) {
|
|
|
|
self->unlock();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool QBasicMutex_TryLock(QBasicMutex* self) {
|
|
|
|
return self->tryLock();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool QBasicMutex_TryLock2(QBasicMutex* self) {
|
|
|
|
return self->try_lock();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool QBasicMutex_IsRecursive(QBasicMutex* self) {
|
|
|
|
return self->isRecursive();
|
|
|
|
}
|
|
|
|
|
2024-09-11 17:41:09 +12:00
|
|
|
bool QBasicMutex_IsRecursive2(const QBasicMutex* self) {
|
|
|
|
return self->isRecursive();
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
2024-11-19 19:29:06 +13:00
|
|
|
void QBasicMutex_Delete(QBasicMutex* self, bool isSubclass) {
|
|
|
|
if (isSubclass) {
|
|
|
|
delete dynamic_cast<QBasicMutex*>( self );
|
|
|
|
} else {
|
|
|
|
delete self;
|
|
|
|
}
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
2024-11-19 19:29:06 +13:00
|
|
|
void QMutex_new(QMutex** outptr_QMutex, QBasicMutex** outptr_QBasicMutex) {
|
|
|
|
QMutex* ret = new QMutex();
|
|
|
|
*outptr_QMutex = ret;
|
|
|
|
*outptr_QBasicMutex = static_cast<QBasicMutex*>(ret);
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
2024-11-19 19:29:06 +13:00
|
|
|
void QMutex_new2(int mode, QMutex** outptr_QMutex, QBasicMutex** outptr_QBasicMutex) {
|
|
|
|
QMutex* ret = new QMutex(static_cast<QMutex::RecursionMode>(mode));
|
|
|
|
*outptr_QMutex = ret;
|
|
|
|
*outptr_QBasicMutex = static_cast<QBasicMutex*>(ret);
|
2024-08-29 19:01:51 +12:00
|
|
|
}
|
|
|
|
|
2024-08-25 16:08:24 +12:00
|
|
|
void QMutex_Lock(QMutex* self) {
|
|
|
|
self->lock();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool QMutex_TryLock(QMutex* self) {
|
|
|
|
return self->tryLock();
|
|
|
|
}
|
|
|
|
|
|
|
|
void QMutex_Unlock(QMutex* self) {
|
|
|
|
self->unlock();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool QMutex_TryLock2(QMutex* self) {
|
|
|
|
return self->try_lock();
|
|
|
|
}
|
|
|
|
|
2024-09-11 17:41:09 +12:00
|
|
|
bool QMutex_IsRecursive(const QMutex* self) {
|
|
|
|
return self->isRecursive();
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
bool QMutex_TryLock1(QMutex* self, int timeout) {
|
|
|
|
return self->tryLock(static_cast<int>(timeout));
|
|
|
|
}
|
|
|
|
|
2024-11-19 19:29:06 +13:00
|
|
|
void QMutex_Delete(QMutex* self, bool isSubclass) {
|
|
|
|
if (isSubclass) {
|
|
|
|
delete dynamic_cast<QMutex*>( self );
|
|
|
|
} else {
|
|
|
|
delete self;
|
|
|
|
}
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
2024-11-19 19:29:06 +13:00
|
|
|
void QRecursiveMutex_new(QRecursiveMutex** outptr_QRecursiveMutex) {
|
|
|
|
QRecursiveMutex* ret = new QRecursiveMutex();
|
|
|
|
*outptr_QRecursiveMutex = ret;
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
2024-11-19 19:29:06 +13:00
|
|
|
void QRecursiveMutex_Delete(QRecursiveMutex* self, bool isSubclass) {
|
|
|
|
if (isSubclass) {
|
|
|
|
delete dynamic_cast<QRecursiveMutex*>( self );
|
|
|
|
} else {
|
|
|
|
delete self;
|
|
|
|
}
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
2024-11-19 19:29:06 +13:00
|
|
|
void QMutexLocker_new(QBasicMutex* m, QMutexLocker** outptr_QMutexLocker) {
|
|
|
|
QMutexLocker* ret = new QMutexLocker(m);
|
|
|
|
*outptr_QMutexLocker = ret;
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
2024-11-19 19:29:06 +13:00
|
|
|
void QMutexLocker_new2(QRecursiveMutex* m, QMutexLocker** outptr_QMutexLocker) {
|
|
|
|
QMutexLocker* ret = new QMutexLocker(m);
|
|
|
|
*outptr_QMutexLocker = ret;
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
void QMutexLocker_Unlock(QMutexLocker* self) {
|
|
|
|
self->unlock();
|
|
|
|
}
|
|
|
|
|
|
|
|
void QMutexLocker_Relock(QMutexLocker* self) {
|
|
|
|
self->relock();
|
|
|
|
}
|
|
|
|
|
2024-09-11 17:41:09 +12:00
|
|
|
QMutex* QMutexLocker_Mutex(const QMutexLocker* self) {
|
|
|
|
return self->mutex();
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|
2024-11-19 19:29:06 +13:00
|
|
|
void QMutexLocker_Delete(QMutexLocker* self, bool isSubclass) {
|
|
|
|
if (isSubclass) {
|
|
|
|
delete dynamic_cast<QMutexLocker*>( self );
|
|
|
|
} else {
|
|
|
|
delete self;
|
|
|
|
}
|
2024-08-25 16:08:24 +12:00
|
|
|
}
|
|
|
|
|