mirror of
https://github.com/mappu/miqt.git
synced 2025-01-20 21:50: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.
107 lines
2.3 KiB
C++
107 lines
2.3 KiB
C++
#include <QReadLocker>
|
|
#include <QReadWriteLock>
|
|
#include <QWriteLocker>
|
|
#include <qreadwritelock.h>
|
|
#include "gen_qreadwritelock.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
} /* extern C */
|
|
#endif
|
|
|
|
QReadWriteLock* QReadWriteLock_new() {
|
|
return new QReadWriteLock();
|
|
}
|
|
|
|
QReadWriteLock* QReadWriteLock_new2(int recursionMode) {
|
|
return new QReadWriteLock(static_cast<QReadWriteLock::RecursionMode>(recursionMode));
|
|
}
|
|
|
|
void QReadWriteLock_LockForRead(QReadWriteLock* self) {
|
|
self->lockForRead();
|
|
}
|
|
|
|
bool QReadWriteLock_TryLockForRead(QReadWriteLock* self) {
|
|
return self->tryLockForRead();
|
|
}
|
|
|
|
bool QReadWriteLock_TryLockForReadWithTimeout(QReadWriteLock* self, int timeout) {
|
|
return self->tryLockForRead(static_cast<int>(timeout));
|
|
}
|
|
|
|
void QReadWriteLock_LockForWrite(QReadWriteLock* self) {
|
|
self->lockForWrite();
|
|
}
|
|
|
|
bool QReadWriteLock_TryLockForWrite(QReadWriteLock* self) {
|
|
return self->tryLockForWrite();
|
|
}
|
|
|
|
bool QReadWriteLock_TryLockForWriteWithTimeout(QReadWriteLock* self, int timeout) {
|
|
return self->tryLockForWrite(static_cast<int>(timeout));
|
|
}
|
|
|
|
void QReadWriteLock_Unlock(QReadWriteLock* self) {
|
|
self->unlock();
|
|
}
|
|
|
|
void QReadWriteLock_Delete(QReadWriteLock* self, bool isSubclass) {
|
|
if (isSubclass) {
|
|
delete dynamic_cast<QReadWriteLock*>( self );
|
|
} else {
|
|
delete self;
|
|
}
|
|
}
|
|
|
|
QReadLocker* QReadLocker_new(QReadWriteLock* readWriteLock) {
|
|
return new QReadLocker(readWriteLock);
|
|
}
|
|
|
|
void QReadLocker_Unlock(QReadLocker* self) {
|
|
self->unlock();
|
|
}
|
|
|
|
void QReadLocker_Relock(QReadLocker* self) {
|
|
self->relock();
|
|
}
|
|
|
|
QReadWriteLock* QReadLocker_ReadWriteLock(const QReadLocker* self) {
|
|
return self->readWriteLock();
|
|
}
|
|
|
|
void QReadLocker_Delete(QReadLocker* self, bool isSubclass) {
|
|
if (isSubclass) {
|
|
delete dynamic_cast<QReadLocker*>( self );
|
|
} else {
|
|
delete self;
|
|
}
|
|
}
|
|
|
|
QWriteLocker* QWriteLocker_new(QReadWriteLock* readWriteLock) {
|
|
return new QWriteLocker(readWriteLock);
|
|
}
|
|
|
|
void QWriteLocker_Unlock(QWriteLocker* self) {
|
|
self->unlock();
|
|
}
|
|
|
|
void QWriteLocker_Relock(QWriteLocker* self) {
|
|
self->relock();
|
|
}
|
|
|
|
QReadWriteLock* QWriteLocker_ReadWriteLock(const QWriteLocker* self) {
|
|
return self->readWriteLock();
|
|
}
|
|
|
|
void QWriteLocker_Delete(QWriteLocker* self, bool isSubclass) {
|
|
if (isSubclass) {
|
|
delete dynamic_cast<QWriteLocker*>( self );
|
|
} else {
|
|
delete self;
|
|
}
|
|
}
|
|
|