miqt/qt/script/gen_qscriptcontextinfo.cpp
Jacek Sieka a0c6344ecd Avoid dependency on exported go header
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.
2025-01-07 12:55:40 +01:00

126 lines
3.7 KiB
C++

#include <QList>
#include <QScriptContext>
#include <QScriptContextInfo>
#include <QString>
#include <QByteArray>
#include <cstring>
#include <qscriptcontextinfo.h>
#include "gen_qscriptcontextinfo.h"
#ifdef __cplusplus
extern "C" {
#endif
#ifdef __cplusplus
} /* extern C */
#endif
QScriptContextInfo* QScriptContextInfo_new(QScriptContext* context) {
return new QScriptContextInfo(context);
}
QScriptContextInfo* QScriptContextInfo_new2(QScriptContextInfo* other) {
return new QScriptContextInfo(*other);
}
QScriptContextInfo* QScriptContextInfo_new3() {
return new QScriptContextInfo();
}
void QScriptContextInfo_OperatorAssign(QScriptContextInfo* self, QScriptContextInfo* other) {
self->operator=(*other);
}
bool QScriptContextInfo_IsNull(const QScriptContextInfo* self) {
return self->isNull();
}
long long QScriptContextInfo_ScriptId(const QScriptContextInfo* self) {
qint64 _ret = self->scriptId();
return static_cast<long long>(_ret);
}
struct miqt_string QScriptContextInfo_FileName(const QScriptContextInfo* self) {
QString _ret = self->fileName();
// Convert QString from UTF-16 in C++ RAII memory to UTF-8 in manually-managed C memory
QByteArray _b = _ret.toUtf8();
struct miqt_string _ms;
_ms.len = _b.length();
_ms.data = static_cast<char*>(malloc(_ms.len));
memcpy(_ms.data, _b.data(), _ms.len);
return _ms;
}
int QScriptContextInfo_LineNumber(const QScriptContextInfo* self) {
return self->lineNumber();
}
int QScriptContextInfo_ColumnNumber(const QScriptContextInfo* self) {
return self->columnNumber();
}
struct miqt_string QScriptContextInfo_FunctionName(const QScriptContextInfo* self) {
QString _ret = self->functionName();
// Convert QString from UTF-16 in C++ RAII memory to UTF-8 in manually-managed C memory
QByteArray _b = _ret.toUtf8();
struct miqt_string _ms;
_ms.len = _b.length();
_ms.data = static_cast<char*>(malloc(_ms.len));
memcpy(_ms.data, _b.data(), _ms.len);
return _ms;
}
int QScriptContextInfo_FunctionType(const QScriptContextInfo* self) {
QScriptContextInfo::FunctionType _ret = self->functionType();
return static_cast<int>(_ret);
}
struct miqt_array /* of struct miqt_string */ QScriptContextInfo_FunctionParameterNames(const QScriptContextInfo* self) {
QStringList _ret = self->functionParameterNames();
// Convert QList<> from C++ memory to manually-managed C memory
struct miqt_string* _arr = static_cast<struct miqt_string*>(malloc(sizeof(struct miqt_string) * _ret.length()));
for (size_t i = 0, e = _ret.length(); i < e; ++i) {
QString _lv_ret = _ret[i];
// Convert QString from UTF-16 in C++ RAII memory to UTF-8 in manually-managed C memory
QByteArray _lv_b = _lv_ret.toUtf8();
struct miqt_string _lv_ms;
_lv_ms.len = _lv_b.length();
_lv_ms.data = static_cast<char*>(malloc(_lv_ms.len));
memcpy(_lv_ms.data, _lv_b.data(), _lv_ms.len);
_arr[i] = _lv_ms;
}
struct miqt_array _out;
_out.len = _ret.length();
_out.data = static_cast<void*>(_arr);
return _out;
}
int QScriptContextInfo_FunctionStartLineNumber(const QScriptContextInfo* self) {
return self->functionStartLineNumber();
}
int QScriptContextInfo_FunctionEndLineNumber(const QScriptContextInfo* self) {
return self->functionEndLineNumber();
}
int QScriptContextInfo_FunctionMetaIndex(const QScriptContextInfo* self) {
return self->functionMetaIndex();
}
bool QScriptContextInfo_OperatorEqual(const QScriptContextInfo* self, QScriptContextInfo* other) {
return (*self == *other);
}
bool QScriptContextInfo_OperatorNotEqual(const QScriptContextInfo* self, QScriptContextInfo* other) {
return (*self != *other);
}
void QScriptContextInfo_Delete(QScriptContextInfo* self, bool isSubclass) {
if (isSubclass) {
delete dynamic_cast<QScriptContextInfo*>( self );
} else {
delete self;
}
}