mirror of
https://github.com/mappu/miqt.git
synced 2025-01-24 23:30:37 +00:00
578 lines
17 KiB
C++
578 lines
17 KiB
C++
#include <QFont>
|
|
#include <QGlyphRun>
|
|
#include <QList>
|
|
#include <QPaintDevice>
|
|
#include <QPainter>
|
|
#include <QPointF>
|
|
#include <QRawFont>
|
|
#include <QRectF>
|
|
#include <QString>
|
|
#include <QByteArray>
|
|
#include <cstring>
|
|
#include <QTextBlock>
|
|
#include <QTextFormat>
|
|
#include <QTextInlineObject>
|
|
#include <QTextLayout>
|
|
#define WORKAROUND_INNER_CLASS_DEFINITION_QTextLayout__FormatRange
|
|
#include <QTextLine>
|
|
#include <QTextOption>
|
|
#include <qtextlayout.h>
|
|
#include "gen_qtextlayout.h"
|
|
|
|
#ifndef _Bool
|
|
#define _Bool bool
|
|
#endif
|
|
#include "_cgo_export.h"
|
|
|
|
QTextInlineObject* QTextInlineObject_new() {
|
|
return new QTextInlineObject();
|
|
}
|
|
|
|
bool QTextInlineObject_IsValid(const QTextInlineObject* self) {
|
|
return self->isValid();
|
|
}
|
|
|
|
QRectF* QTextInlineObject_Rect(const QTextInlineObject* self) {
|
|
return new QRectF(self->rect());
|
|
}
|
|
|
|
double QTextInlineObject_Width(const QTextInlineObject* self) {
|
|
qreal _ret = self->width();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextInlineObject_Ascent(const QTextInlineObject* self) {
|
|
qreal _ret = self->ascent();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextInlineObject_Descent(const QTextInlineObject* self) {
|
|
qreal _ret = self->descent();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextInlineObject_Height(const QTextInlineObject* self) {
|
|
qreal _ret = self->height();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
int QTextInlineObject_TextDirection(const QTextInlineObject* self) {
|
|
Qt::LayoutDirection _ret = self->textDirection();
|
|
return static_cast<int>(_ret);
|
|
}
|
|
|
|
void QTextInlineObject_SetWidth(QTextInlineObject* self, double w) {
|
|
self->setWidth(static_cast<qreal>(w));
|
|
}
|
|
|
|
void QTextInlineObject_SetAscent(QTextInlineObject* self, double a) {
|
|
self->setAscent(static_cast<qreal>(a));
|
|
}
|
|
|
|
void QTextInlineObject_SetDescent(QTextInlineObject* self, double d) {
|
|
self->setDescent(static_cast<qreal>(d));
|
|
}
|
|
|
|
int QTextInlineObject_TextPosition(const QTextInlineObject* self) {
|
|
return self->textPosition();
|
|
}
|
|
|
|
int QTextInlineObject_FormatIndex(const QTextInlineObject* self) {
|
|
return self->formatIndex();
|
|
}
|
|
|
|
QTextFormat* QTextInlineObject_Format(const QTextInlineObject* self) {
|
|
return new QTextFormat(self->format());
|
|
}
|
|
|
|
void QTextInlineObject_Delete(QTextInlineObject* self, bool isSubclass) {
|
|
if (isSubclass) {
|
|
delete dynamic_cast<QTextInlineObject*>( self );
|
|
} else {
|
|
delete self;
|
|
}
|
|
}
|
|
|
|
QTextLayout* QTextLayout_new() {
|
|
return new QTextLayout();
|
|
}
|
|
|
|
QTextLayout* QTextLayout_new2(struct miqt_string text) {
|
|
QString text_QString = QString::fromUtf8(text.data, text.len);
|
|
return new QTextLayout(text_QString);
|
|
}
|
|
|
|
QTextLayout* QTextLayout_new3(struct miqt_string text, QFont* font) {
|
|
QString text_QString = QString::fromUtf8(text.data, text.len);
|
|
return new QTextLayout(text_QString, *font);
|
|
}
|
|
|
|
QTextLayout* QTextLayout_new4(QTextBlock* b) {
|
|
return new QTextLayout(*b);
|
|
}
|
|
|
|
QTextLayout* QTextLayout_new5(struct miqt_string text, QFont* font, QPaintDevice* paintdevice) {
|
|
QString text_QString = QString::fromUtf8(text.data, text.len);
|
|
return new QTextLayout(text_QString, *font, paintdevice);
|
|
}
|
|
|
|
void QTextLayout_SetFont(QTextLayout* self, QFont* f) {
|
|
self->setFont(*f);
|
|
}
|
|
|
|
QFont* QTextLayout_Font(const QTextLayout* self) {
|
|
return new QFont(self->font());
|
|
}
|
|
|
|
void QTextLayout_SetRawFont(QTextLayout* self, QRawFont* rawFont) {
|
|
self->setRawFont(*rawFont);
|
|
}
|
|
|
|
void QTextLayout_SetText(QTextLayout* self, struct miqt_string stringVal) {
|
|
QString stringVal_QString = QString::fromUtf8(stringVal.data, stringVal.len);
|
|
self->setText(stringVal_QString);
|
|
}
|
|
|
|
struct miqt_string QTextLayout_Text(const QTextLayout* self) {
|
|
QString _ret = self->text();
|
|
// 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 QTextLayout_SetTextOption(QTextLayout* self, QTextOption* option) {
|
|
self->setTextOption(*option);
|
|
}
|
|
|
|
QTextOption* QTextLayout_TextOption(const QTextLayout* self) {
|
|
const QTextOption& _ret = self->textOption();
|
|
// Cast returned reference into pointer
|
|
return const_cast<QTextOption*>(&_ret);
|
|
}
|
|
|
|
void QTextLayout_SetPreeditArea(QTextLayout* self, int position, struct miqt_string text) {
|
|
QString text_QString = QString::fromUtf8(text.data, text.len);
|
|
self->setPreeditArea(static_cast<int>(position), text_QString);
|
|
}
|
|
|
|
int QTextLayout_PreeditAreaPosition(const QTextLayout* self) {
|
|
return self->preeditAreaPosition();
|
|
}
|
|
|
|
struct miqt_string QTextLayout_PreeditAreaText(const QTextLayout* self) {
|
|
QString _ret = self->preeditAreaText();
|
|
// 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 QTextLayout_SetFormats(QTextLayout* self, struct miqt_array /* of QTextLayout__FormatRange* */ overrides) {
|
|
QList<QTextLayout::FormatRange> overrides_QList;
|
|
overrides_QList.reserve(overrides.len);
|
|
QTextLayout__FormatRange** overrides_arr = static_cast<QTextLayout__FormatRange**>(overrides.data);
|
|
for(size_t i = 0; i < overrides.len; ++i) {
|
|
overrides_QList.push_back(*(overrides_arr[i]));
|
|
}
|
|
self->setFormats(overrides_QList);
|
|
}
|
|
|
|
struct miqt_array /* of QTextLayout__FormatRange* */ QTextLayout_Formats(const QTextLayout* self) {
|
|
QList<QTextLayout::FormatRange> _ret = self->formats();
|
|
// Convert QList<> from C++ memory to manually-managed C memory
|
|
QTextLayout__FormatRange** _arr = static_cast<QTextLayout__FormatRange**>(malloc(sizeof(QTextLayout__FormatRange*) * _ret.length()));
|
|
for (size_t i = 0, e = _ret.length(); i < e; ++i) {
|
|
_arr[i] = new QTextLayout::FormatRange(_ret[i]);
|
|
}
|
|
struct miqt_array _out;
|
|
_out.len = _ret.length();
|
|
_out.data = static_cast<void*>(_arr);
|
|
return _out;
|
|
}
|
|
|
|
void QTextLayout_ClearFormats(QTextLayout* self) {
|
|
self->clearFormats();
|
|
}
|
|
|
|
void QTextLayout_SetCacheEnabled(QTextLayout* self, bool enable) {
|
|
self->setCacheEnabled(enable);
|
|
}
|
|
|
|
bool QTextLayout_CacheEnabled(const QTextLayout* self) {
|
|
return self->cacheEnabled();
|
|
}
|
|
|
|
void QTextLayout_SetCursorMoveStyle(QTextLayout* self, int style) {
|
|
self->setCursorMoveStyle(static_cast<Qt::CursorMoveStyle>(style));
|
|
}
|
|
|
|
int QTextLayout_CursorMoveStyle(const QTextLayout* self) {
|
|
Qt::CursorMoveStyle _ret = self->cursorMoveStyle();
|
|
return static_cast<int>(_ret);
|
|
}
|
|
|
|
void QTextLayout_BeginLayout(QTextLayout* self) {
|
|
self->beginLayout();
|
|
}
|
|
|
|
void QTextLayout_EndLayout(QTextLayout* self) {
|
|
self->endLayout();
|
|
}
|
|
|
|
void QTextLayout_ClearLayout(QTextLayout* self) {
|
|
self->clearLayout();
|
|
}
|
|
|
|
QTextLine* QTextLayout_CreateLine(QTextLayout* self) {
|
|
return new QTextLine(self->createLine());
|
|
}
|
|
|
|
int QTextLayout_LineCount(const QTextLayout* self) {
|
|
return self->lineCount();
|
|
}
|
|
|
|
QTextLine* QTextLayout_LineAt(const QTextLayout* self, int i) {
|
|
return new QTextLine(self->lineAt(static_cast<int>(i)));
|
|
}
|
|
|
|
QTextLine* QTextLayout_LineForTextPosition(const QTextLayout* self, int pos) {
|
|
return new QTextLine(self->lineForTextPosition(static_cast<int>(pos)));
|
|
}
|
|
|
|
bool QTextLayout_IsValidCursorPosition(const QTextLayout* self, int pos) {
|
|
return self->isValidCursorPosition(static_cast<int>(pos));
|
|
}
|
|
|
|
int QTextLayout_NextCursorPosition(const QTextLayout* self, int oldPos) {
|
|
return self->nextCursorPosition(static_cast<int>(oldPos));
|
|
}
|
|
|
|
int QTextLayout_PreviousCursorPosition(const QTextLayout* self, int oldPos) {
|
|
return self->previousCursorPosition(static_cast<int>(oldPos));
|
|
}
|
|
|
|
int QTextLayout_LeftCursorPosition(const QTextLayout* self, int oldPos) {
|
|
return self->leftCursorPosition(static_cast<int>(oldPos));
|
|
}
|
|
|
|
int QTextLayout_RightCursorPosition(const QTextLayout* self, int oldPos) {
|
|
return self->rightCursorPosition(static_cast<int>(oldPos));
|
|
}
|
|
|
|
void QTextLayout_Draw(const QTextLayout* self, QPainter* p, QPointF* pos) {
|
|
self->draw(p, *pos);
|
|
}
|
|
|
|
void QTextLayout_DrawCursor(const QTextLayout* self, QPainter* p, QPointF* pos, int cursorPosition) {
|
|
self->drawCursor(p, *pos, static_cast<int>(cursorPosition));
|
|
}
|
|
|
|
void QTextLayout_DrawCursor2(const QTextLayout* self, QPainter* p, QPointF* pos, int cursorPosition, int width) {
|
|
self->drawCursor(p, *pos, static_cast<int>(cursorPosition), static_cast<int>(width));
|
|
}
|
|
|
|
QPointF* QTextLayout_Position(const QTextLayout* self) {
|
|
return new QPointF(self->position());
|
|
}
|
|
|
|
void QTextLayout_SetPosition(QTextLayout* self, QPointF* p) {
|
|
self->setPosition(*p);
|
|
}
|
|
|
|
QRectF* QTextLayout_BoundingRect(const QTextLayout* self) {
|
|
return new QRectF(self->boundingRect());
|
|
}
|
|
|
|
double QTextLayout_MinimumWidth(const QTextLayout* self) {
|
|
qreal _ret = self->minimumWidth();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextLayout_MaximumWidth(const QTextLayout* self) {
|
|
qreal _ret = self->maximumWidth();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
struct miqt_array /* of QGlyphRun* */ QTextLayout_GlyphRuns(const QTextLayout* self) {
|
|
QList<QGlyphRun> _ret = self->glyphRuns();
|
|
// Convert QList<> from C++ memory to manually-managed C memory
|
|
QGlyphRun** _arr = static_cast<QGlyphRun**>(malloc(sizeof(QGlyphRun*) * _ret.length()));
|
|
for (size_t i = 0, e = _ret.length(); i < e; ++i) {
|
|
_arr[i] = new QGlyphRun(_ret[i]);
|
|
}
|
|
struct miqt_array _out;
|
|
_out.len = _ret.length();
|
|
_out.data = static_cast<void*>(_arr);
|
|
return _out;
|
|
}
|
|
|
|
void QTextLayout_SetFlags(QTextLayout* self, int flags) {
|
|
self->setFlags(static_cast<int>(flags));
|
|
}
|
|
|
|
int QTextLayout_NextCursorPosition2(const QTextLayout* self, int oldPos, int mode) {
|
|
return self->nextCursorPosition(static_cast<int>(oldPos), static_cast<QTextLayout::CursorMode>(mode));
|
|
}
|
|
|
|
int QTextLayout_PreviousCursorPosition2(const QTextLayout* self, int oldPos, int mode) {
|
|
return self->previousCursorPosition(static_cast<int>(oldPos), static_cast<QTextLayout::CursorMode>(mode));
|
|
}
|
|
|
|
void QTextLayout_Draw3(const QTextLayout* self, QPainter* p, QPointF* pos, struct miqt_array /* of QTextLayout__FormatRange* */ selections) {
|
|
QList<QTextLayout::FormatRange> selections_QList;
|
|
selections_QList.reserve(selections.len);
|
|
QTextLayout__FormatRange** selections_arr = static_cast<QTextLayout__FormatRange**>(selections.data);
|
|
for(size_t i = 0; i < selections.len; ++i) {
|
|
selections_QList.push_back(*(selections_arr[i]));
|
|
}
|
|
self->draw(p, *pos, selections_QList);
|
|
}
|
|
|
|
void QTextLayout_Draw4(const QTextLayout* self, QPainter* p, QPointF* pos, struct miqt_array /* of QTextLayout__FormatRange* */ selections, QRectF* clip) {
|
|
QList<QTextLayout::FormatRange> selections_QList;
|
|
selections_QList.reserve(selections.len);
|
|
QTextLayout__FormatRange** selections_arr = static_cast<QTextLayout__FormatRange**>(selections.data);
|
|
for(size_t i = 0; i < selections.len; ++i) {
|
|
selections_QList.push_back(*(selections_arr[i]));
|
|
}
|
|
self->draw(p, *pos, selections_QList, *clip);
|
|
}
|
|
|
|
struct miqt_array /* of QGlyphRun* */ QTextLayout_GlyphRuns1(const QTextLayout* self, int from) {
|
|
QList<QGlyphRun> _ret = self->glyphRuns(static_cast<int>(from));
|
|
// Convert QList<> from C++ memory to manually-managed C memory
|
|
QGlyphRun** _arr = static_cast<QGlyphRun**>(malloc(sizeof(QGlyphRun*) * _ret.length()));
|
|
for (size_t i = 0, e = _ret.length(); i < e; ++i) {
|
|
_arr[i] = new QGlyphRun(_ret[i]);
|
|
}
|
|
struct miqt_array _out;
|
|
_out.len = _ret.length();
|
|
_out.data = static_cast<void*>(_arr);
|
|
return _out;
|
|
}
|
|
|
|
struct miqt_array /* of QGlyphRun* */ QTextLayout_GlyphRuns2(const QTextLayout* self, int from, int length) {
|
|
QList<QGlyphRun> _ret = self->glyphRuns(static_cast<int>(from), static_cast<int>(length));
|
|
// Convert QList<> from C++ memory to manually-managed C memory
|
|
QGlyphRun** _arr = static_cast<QGlyphRun**>(malloc(sizeof(QGlyphRun*) * _ret.length()));
|
|
for (size_t i = 0, e = _ret.length(); i < e; ++i) {
|
|
_arr[i] = new QGlyphRun(_ret[i]);
|
|
}
|
|
struct miqt_array _out;
|
|
_out.len = _ret.length();
|
|
_out.data = static_cast<void*>(_arr);
|
|
return _out;
|
|
}
|
|
|
|
void QTextLayout_Delete(QTextLayout* self, bool isSubclass) {
|
|
if (isSubclass) {
|
|
delete dynamic_cast<QTextLayout*>( self );
|
|
} else {
|
|
delete self;
|
|
}
|
|
}
|
|
|
|
QTextLine* QTextLine_new() {
|
|
return new QTextLine();
|
|
}
|
|
|
|
bool QTextLine_IsValid(const QTextLine* self) {
|
|
return self->isValid();
|
|
}
|
|
|
|
QRectF* QTextLine_Rect(const QTextLine* self) {
|
|
return new QRectF(self->rect());
|
|
}
|
|
|
|
double QTextLine_X(const QTextLine* self) {
|
|
qreal _ret = self->x();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextLine_Y(const QTextLine* self) {
|
|
qreal _ret = self->y();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextLine_Width(const QTextLine* self) {
|
|
qreal _ret = self->width();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextLine_Ascent(const QTextLine* self) {
|
|
qreal _ret = self->ascent();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextLine_Descent(const QTextLine* self) {
|
|
qreal _ret = self->descent();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextLine_Height(const QTextLine* self) {
|
|
qreal _ret = self->height();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextLine_Leading(const QTextLine* self) {
|
|
qreal _ret = self->leading();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
void QTextLine_SetLeadingIncluded(QTextLine* self, bool included) {
|
|
self->setLeadingIncluded(included);
|
|
}
|
|
|
|
bool QTextLine_LeadingIncluded(const QTextLine* self) {
|
|
return self->leadingIncluded();
|
|
}
|
|
|
|
double QTextLine_NaturalTextWidth(const QTextLine* self) {
|
|
qreal _ret = self->naturalTextWidth();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextLine_HorizontalAdvance(const QTextLine* self) {
|
|
qreal _ret = self->horizontalAdvance();
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
QRectF* QTextLine_NaturalTextRect(const QTextLine* self) {
|
|
return new QRectF(self->naturalTextRect());
|
|
}
|
|
|
|
double QTextLine_CursorToX(const QTextLine* self, int* cursorPos) {
|
|
qreal _ret = self->cursorToX(static_cast<int*>(cursorPos));
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextLine_CursorToXWithCursorPos(const QTextLine* self, int cursorPos) {
|
|
qreal _ret = self->cursorToX(static_cast<int>(cursorPos));
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
int QTextLine_XToCursor(const QTextLine* self, double x) {
|
|
return self->xToCursor(static_cast<qreal>(x));
|
|
}
|
|
|
|
void QTextLine_SetLineWidth(QTextLine* self, double width) {
|
|
self->setLineWidth(static_cast<qreal>(width));
|
|
}
|
|
|
|
void QTextLine_SetNumColumns(QTextLine* self, int columns) {
|
|
self->setNumColumns(static_cast<int>(columns));
|
|
}
|
|
|
|
void QTextLine_SetNumColumns2(QTextLine* self, int columns, double alignmentWidth) {
|
|
self->setNumColumns(static_cast<int>(columns), static_cast<qreal>(alignmentWidth));
|
|
}
|
|
|
|
void QTextLine_SetPosition(QTextLine* self, QPointF* pos) {
|
|
self->setPosition(*pos);
|
|
}
|
|
|
|
QPointF* QTextLine_Position(const QTextLine* self) {
|
|
return new QPointF(self->position());
|
|
}
|
|
|
|
int QTextLine_TextStart(const QTextLine* self) {
|
|
return self->textStart();
|
|
}
|
|
|
|
int QTextLine_TextLength(const QTextLine* self) {
|
|
return self->textLength();
|
|
}
|
|
|
|
int QTextLine_LineNumber(const QTextLine* self) {
|
|
return self->lineNumber();
|
|
}
|
|
|
|
void QTextLine_Draw(const QTextLine* self, QPainter* painter, QPointF* position) {
|
|
self->draw(painter, *position);
|
|
}
|
|
|
|
struct miqt_array /* of QGlyphRun* */ QTextLine_GlyphRuns(const QTextLine* self) {
|
|
QList<QGlyphRun> _ret = self->glyphRuns();
|
|
// Convert QList<> from C++ memory to manually-managed C memory
|
|
QGlyphRun** _arr = static_cast<QGlyphRun**>(malloc(sizeof(QGlyphRun*) * _ret.length()));
|
|
for (size_t i = 0, e = _ret.length(); i < e; ++i) {
|
|
_arr[i] = new QGlyphRun(_ret[i]);
|
|
}
|
|
struct miqt_array _out;
|
|
_out.len = _ret.length();
|
|
_out.data = static_cast<void*>(_arr);
|
|
return _out;
|
|
}
|
|
|
|
double QTextLine_CursorToX2(const QTextLine* self, int* cursorPos, int edge) {
|
|
qreal _ret = self->cursorToX(static_cast<int*>(cursorPos), static_cast<QTextLine::Edge>(edge));
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
double QTextLine_CursorToX22(const QTextLine* self, int cursorPos, int edge) {
|
|
qreal _ret = self->cursorToX(static_cast<int>(cursorPos), static_cast<QTextLine::Edge>(edge));
|
|
return static_cast<double>(_ret);
|
|
}
|
|
|
|
int QTextLine_XToCursor2(const QTextLine* self, double x, int param2) {
|
|
return self->xToCursor(static_cast<qreal>(x), static_cast<QTextLine::CursorPosition>(param2));
|
|
}
|
|
|
|
struct miqt_array /* of QGlyphRun* */ QTextLine_GlyphRuns1(const QTextLine* self, int from) {
|
|
QList<QGlyphRun> _ret = self->glyphRuns(static_cast<int>(from));
|
|
// Convert QList<> from C++ memory to manually-managed C memory
|
|
QGlyphRun** _arr = static_cast<QGlyphRun**>(malloc(sizeof(QGlyphRun*) * _ret.length()));
|
|
for (size_t i = 0, e = _ret.length(); i < e; ++i) {
|
|
_arr[i] = new QGlyphRun(_ret[i]);
|
|
}
|
|
struct miqt_array _out;
|
|
_out.len = _ret.length();
|
|
_out.data = static_cast<void*>(_arr);
|
|
return _out;
|
|
}
|
|
|
|
struct miqt_array /* of QGlyphRun* */ QTextLine_GlyphRuns2(const QTextLine* self, int from, int length) {
|
|
QList<QGlyphRun> _ret = self->glyphRuns(static_cast<int>(from), static_cast<int>(length));
|
|
// Convert QList<> from C++ memory to manually-managed C memory
|
|
QGlyphRun** _arr = static_cast<QGlyphRun**>(malloc(sizeof(QGlyphRun*) * _ret.length()));
|
|
for (size_t i = 0, e = _ret.length(); i < e; ++i) {
|
|
_arr[i] = new QGlyphRun(_ret[i]);
|
|
}
|
|
struct miqt_array _out;
|
|
_out.len = _ret.length();
|
|
_out.data = static_cast<void*>(_arr);
|
|
return _out;
|
|
}
|
|
|
|
void QTextLine_Delete(QTextLine* self, bool isSubclass) {
|
|
if (isSubclass) {
|
|
delete dynamic_cast<QTextLine*>( self );
|
|
} else {
|
|
delete self;
|
|
}
|
|
}
|
|
|
|
QTextLayout__FormatRange* QTextLayout__FormatRange_new(QTextLayout__FormatRange* param1) {
|
|
return new QTextLayout::FormatRange(*param1);
|
|
}
|
|
|
|
void QTextLayout__FormatRange_OperatorAssign(QTextLayout__FormatRange* self, QTextLayout__FormatRange* param1) {
|
|
self->operator=(*param1);
|
|
}
|
|
|
|
void QTextLayout__FormatRange_Delete(QTextLayout__FormatRange* self, bool isSubclass) {
|
|
if (isSubclass) {
|
|
delete dynamic_cast<QTextLayout::FormatRange*>( self );
|
|
} else {
|
|
delete self;
|
|
}
|
|
}
|
|
|