mirror of
https://github.com/mappu/miqt.git
synced 2025-01-21 22:20:38 +00:00
a0c6344ecd
The expected type of the callback is already known from the AST - this change reduces dependency on cgo specifics and makes the generated C ABI entirely cgo-independent - in particular, there is no need to include `_cgo_export.h` any more.
99 lines
1.8 KiB
C++
99 lines
1.8 KiB
C++
#include <QBasicMutex>
|
|
#include <QMutex>
|
|
#include <QRecursiveMutex>
|
|
#include <qmutex.h>
|
|
#include "gen_qmutex.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
} /* extern C */
|
|
#endif
|
|
|
|
QBasicMutex* QBasicMutex_new() {
|
|
return new QBasicMutex();
|
|
}
|
|
|
|
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();
|
|
}
|
|
|
|
void QBasicMutex_Delete(QBasicMutex* self, bool isSubclass) {
|
|
if (isSubclass) {
|
|
delete dynamic_cast<QBasicMutex*>( self );
|
|
} else {
|
|
delete self;
|
|
}
|
|
}
|
|
|
|
QMutex* QMutex_new() {
|
|
return new QMutex();
|
|
}
|
|
|
|
void QMutex_virtbase(QMutex* src, QBasicMutex** outptr_QBasicMutex) {
|
|
*outptr_QBasicMutex = static_cast<QBasicMutex*>(src);
|
|
}
|
|
|
|
bool QMutex_TryLock(QMutex* self) {
|
|
return self->try_lock();
|
|
}
|
|
|
|
bool QMutex_TryLockWithTimeout(QMutex* self, int timeout) {
|
|
return self->tryLock(static_cast<int>(timeout));
|
|
}
|
|
|
|
void QMutex_Delete(QMutex* self, bool isSubclass) {
|
|
if (isSubclass) {
|
|
delete dynamic_cast<QMutex*>( self );
|
|
} else {
|
|
delete self;
|
|
}
|
|
}
|
|
|
|
QRecursiveMutex* QRecursiveMutex_new() {
|
|
return new QRecursiveMutex();
|
|
}
|
|
|
|
void QRecursiveMutex_Lock(QRecursiveMutex* self) {
|
|
self->lock();
|
|
}
|
|
|
|
bool QRecursiveMutex_TryLock(QRecursiveMutex* self) {
|
|
return self->tryLock();
|
|
}
|
|
|
|
void QRecursiveMutex_Unlock(QRecursiveMutex* self) {
|
|
self->unlock();
|
|
}
|
|
|
|
bool QRecursiveMutex_TryLock2(QRecursiveMutex* self) {
|
|
return self->try_lock();
|
|
}
|
|
|
|
bool QRecursiveMutex_TryLock1(QRecursiveMutex* self, int timeout) {
|
|
return self->tryLock(static_cast<int>(timeout));
|
|
}
|
|
|
|
void QRecursiveMutex_Delete(QRecursiveMutex* self, bool isSubclass) {
|
|
if (isSubclass) {
|
|
delete dynamic_cast<QRecursiveMutex*>( self );
|
|
} else {
|
|
delete self;
|
|
}
|
|
}
|
|
|