miqt/qt-restricted-extras/qscintilla/gen_qscilexerfortran.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

166 lines
4.9 KiB
C++

#include <QMetaObject>
#include <QObject>
#include <QString>
#include <QByteArray>
#include <cstring>
#include <qscilexerfortran.h>
#include "gen_qscilexerfortran.h"
#ifdef __cplusplus
extern "C" {
#endif
void miqt_exec_callback_QsciLexerFortran_SetFoldCompact(void*, intptr_t, bool);
#ifdef __cplusplus
} /* extern C */
#endif
class MiqtVirtualQsciLexerFortran : public virtual QsciLexerFortran {
public:
MiqtVirtualQsciLexerFortran(): QsciLexerFortran() {};
MiqtVirtualQsciLexerFortran(QObject* parent): QsciLexerFortran(parent) {};
virtual ~MiqtVirtualQsciLexerFortran() = default;
// cgo.Handle value for overwritten implementation
intptr_t handle__SetFoldCompact = 0;
// Subclass to allow providing a Go implementation
virtual void setFoldCompact(bool fold) override {
if (handle__SetFoldCompact == 0) {
QsciLexerFortran::setFoldCompact(fold);
return;
}
bool sigval1 = fold;
miqt_exec_callback_QsciLexerFortran_SetFoldCompact(this, handle__SetFoldCompact, sigval1);
}
// Wrapper to allow calling protected method
void virtualbase_SetFoldCompact(bool fold) {
QsciLexerFortran::setFoldCompact(fold);
}
};
QsciLexerFortran* QsciLexerFortran_new() {
return new MiqtVirtualQsciLexerFortran();
}
QsciLexerFortran* QsciLexerFortran_new2(QObject* parent) {
return new MiqtVirtualQsciLexerFortran(parent);
}
void QsciLexerFortran_virtbase(QsciLexerFortran* src, QsciLexerFortran77** outptr_QsciLexerFortran77) {
*outptr_QsciLexerFortran77 = static_cast<QsciLexerFortran77*>(src);
}
QMetaObject* QsciLexerFortran_MetaObject(const QsciLexerFortran* self) {
return (QMetaObject*) self->metaObject();
}
void* QsciLexerFortran_Metacast(QsciLexerFortran* self, const char* param1) {
return self->qt_metacast(param1);
}
struct miqt_string QsciLexerFortran_Tr(const char* s) {
QString _ret = QsciLexerFortran::tr(s);
// 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;
}
struct miqt_string QsciLexerFortran_TrUtf8(const char* s) {
QString _ret = QsciLexerFortran::trUtf8(s);
// 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;
}
const char* QsciLexerFortran_Language(const QsciLexerFortran* self) {
return (const char*) self->language();
}
const char* QsciLexerFortran_Lexer(const QsciLexerFortran* self) {
return (const char*) self->lexer();
}
const char* QsciLexerFortran_Keywords(const QsciLexerFortran* self, int set) {
return (const char*) self->keywords(static_cast<int>(set));
}
struct miqt_string QsciLexerFortran_Tr2(const char* s, const char* c) {
QString _ret = QsciLexerFortran::tr(s, c);
// 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;
}
struct miqt_string QsciLexerFortran_Tr3(const char* s, const char* c, int n) {
QString _ret = QsciLexerFortran::tr(s, c, static_cast<int>(n));
// 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;
}
struct miqt_string QsciLexerFortran_TrUtf82(const char* s, const char* c) {
QString _ret = QsciLexerFortran::trUtf8(s, c);
// 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;
}
struct miqt_string QsciLexerFortran_TrUtf83(const char* s, const char* c, int n) {
QString _ret = QsciLexerFortran::trUtf8(s, c, static_cast<int>(n));
// 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;
}
void QsciLexerFortran_override_virtual_SetFoldCompact(void* self, intptr_t slot) {
dynamic_cast<MiqtVirtualQsciLexerFortran*>( (QsciLexerFortran*)(self) )->handle__SetFoldCompact = slot;
}
void QsciLexerFortran_virtualbase_SetFoldCompact(void* self, bool fold) {
( (MiqtVirtualQsciLexerFortran*)(self) )->virtualbase_SetFoldCompact(fold);
}
void QsciLexerFortran_Delete(QsciLexerFortran* self, bool isSubclass) {
if (isSubclass) {
delete dynamic_cast<MiqtVirtualQsciLexerFortran*>( self );
} else {
delete self;
}
}