7#include <private/qqmlcomponent_p.h>
8#include <private/qqmldebugconnector_p.h>
9#include <private/qqmldebugserviceinterfaces_p.h>
10#include <private/qqmldelayedcallqueue_p.h>
11#include <private/qqmlengine_p.h>
12#include <private/qqmlloggingcategorybase_p.h>
13#include <private/qqmlplatform_p.h>
14#include <private/qqmlstringconverters_p.h>
16#include <private/qv4dateobject_p.h>
17#include <private/qv4domerrors_p.h>
18#include <private/qv4engine_p.h>
19#include <private/qv4functionobject_p.h>
20#include <private/qv4include_p.h>
21#include <private/qv4mm_p.h>
22#include <private/qv4qobjectwrapper_p.h>
23#include <private/qv4sequenceobject_p.h>
24#include <private/qv4stackframe_p.h>
26#include <QtQml/qqmlfile.h>
28#include <QtCore/qcoreapplication.h>
29#include <QtCore/qcryptographichash.h>
30#include <QtCore/qdatetime.h>
31#include <QtCore/qfileinfo.h>
32#include <QtCore/qloggingcategory.h>
33#include <QtCore/qpoint.h>
34#include <QtCore/qrect.h>
35#include <QtCore/qsize.h>
36#include <QtCore/qstring.h>
37#include <QtCore/qurl.h>
38#include <QtCore/qvarlengtharray.h>
42Q_STATIC_LOGGING_CATEGORY(lcRootProperties,
"qt.qml.rootObjectProperties");
48#define THROW_TYPE_ERROR_WITH_MESSAGE(msg)
50 return scope.engine->throwTypeError(QString::fromUtf8(msg));
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
210
211
212
213
214
215
216
217
218
221
222
223
224
225
226
227
228
229
230
231
232
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
268QtObject::QtObject(ExecutionEngine *engine)
271#if QT_CONFIG(translation)
272 connect(m_engine->jsEngine(), &QJSEngine::uiLanguageChanged,
273 this, &QtObject::uiLanguageChanged);
277QtObject::Contexts QtObject::getContexts()
const
279 QQmlEngine *engine = qmlEngine();
283 QQmlRefPointer<QQmlContextData> context = v4Engine()->callingQmlContext();
285 context = QQmlContextData::get(QQmlEnginePrivate::get(engine)->rootContext);
288 QQmlRefPointer<QQmlContextData> effectiveContext
289 = context->isPragmaLibraryContext() ?
nullptr : context;
290 return {context, effectiveContext};
293QtObject *QtObject::create(QQmlEngine *, QJSEngine *jsEngine)
295 QV4::ExecutionEngine *v4 = jsEngine->handle();
296 QV4::Scope scope(v4);
297 ScopedObject globalObject(scope, v4->globalObject);
298 ScopedString qtName(scope, v4->newString(QStringLiteral(
"Qt")));
299 QV4::ScopedValue result(scope, globalObject->get(qtName->toPropertyKey()));
300 return qobject_cast<QtObject *>(result->as<QV4::QObjectWrapper>()->object());
303QJSValue QtObject::include(
const QString &url,
const QJSValue &callback)
const
305 return QV4Include::method_include(v4Engine(), v4Engine()->resolvedUrl(url), callback);
310
311
312
313
314
315bool QtObject::isQtObject(
const QJSValue &value)
const
317 return qjsvalue_cast<QObject *>(value) !=
nullptr;
321
322
323
324
325
326
327
328QVariant QtObject::color(
const QString &name)
const
331 const QVariant v = QQmlStringConverters::colorFromString(name, &ok);
335 v4Engine()->throwError(QStringLiteral(
"\"%1\" is not a valid color name").arg(name));
336 return QVariant::fromValue(
nullptr);
340
341
342
343
344
345
346
347QVariant QtObject::rgba(
double r,
double g,
double b,
double a)
const
349 r = qBound(0.0, r, 1.0);
350 g = qBound(0.0, g, 1.0);
351 b = qBound(0.0, b, 1.0);
352 a = qBound(0.0, a, 1.0);
354 return QQml_colorProvider()->fromRgbF(r, g, b, a);
358
359
360
361
362
363
364
365QVariant QtObject::hsla(
double h,
double s,
double l,
double a)
const
368 h = qBound(0.0, h, 1.0);
369 s = qBound(0.0, s, 1.0);
370 l = qBound(0.0, l, 1.0);
371 a = qBound(0.0, a, 1.0);
373 return QQml_colorProvider()->fromHslF(h, s, l, a);
377
378
379
380
381
382
383
384
385QVariant QtObject::hsva(
double h,
double s,
double v,
double a)
const
388 h = qBound(0.0, h, 1.0);
389 s = qBound(0.0, s, 1.0);
390 v = qBound(0.0, v, 1.0);
391 a = qBound(0.0, a, 1.0);
393 return QQml_colorProvider()->fromHsvF(h, s, v, a);
397
398
399
400
401
402
403
404
405
406bool QtObject::colorEqual(
const QVariant &lhs,
const QVariant &rhs)
const
410 QVariant color1 = lhs;
411 if (color1.userType() == QMetaType::QString) {
412 color1 = QQmlStringConverters::colorFromString(color1.toString(), &ok);
414 v4Engine()->throwError(QStringLiteral(
"Qt.colorEqual(): Invalid color name"));
417 }
else if (color1.userType() != QMetaType::QColor) {
418 v4Engine()->throwError(QStringLiteral(
"Qt.colorEqual(): Invalid arguments"));
422 QVariant color2 = rhs;
423 if (color2.userType() == QMetaType::QString) {
424 color2 = QQmlStringConverters::colorFromString(color2.toString(), &ok);
426 v4Engine()->throwError(QStringLiteral(
"Qt.colorEqual(): Invalid color name"));
429 }
else if (color2.userType() != QMetaType::QColor) {
430 v4Engine()->throwError(QStringLiteral(
"Qt.colorEqual(): Invalid arguments"));
434 return color1 == color2;
438
439
440
441
442QRectF QtObject::rect(
double x,
double y,
double width,
double height)
const
444 return QRectF(x, y, width, height);
448
449
450
451
452QPointF QtObject::point(
double x,
double y)
const
454 return QPointF(x, y);
458
459
460
461
462QSizeF QtObject::size(
double w,
double h)
const
468
469
470
471
472
473
474
475
476QVariant QtObject::font(
const QJSValue &fontSpecifier)
const
478 if (!fontSpecifier.isObject()) {
479 v4Engine()->throwError(QStringLiteral(
"Qt.font(): Invalid arguments"));
484 const QVariant v = QQmlValueTypeProvider::createValueType(
485 fontSpecifier, QMetaType(QMetaType::QFont));
490 v4Engine()->throwError(QStringLiteral(
"Qt.font(): Invalid argument: "
491 "no valid font subproperties specified"));
498 result.setProperty(i, e->toScriptValue(parameter));
502void addParameters<
double>(QJSEngine *, QJSValue &result,
int i,
double parameter)
504 result.setProperty(i, QJSValue(parameter));
507template<
typename T,
typename ...Others>
508void addParameters(QJSEngine *e, QJSValue &result,
int i, T parameter, Others... others)
510 addParameters<T>(e, result, i, parameter);
511 addParameters<Others...>(e, result, ++i, others...);
514template<
typename ...T>
519 QJSValue params = e->newArray(
sizeof...(parameters));
520 addParameters(e, params, 0, parameters...);
521 const QVariant variant = QQmlValueTypeProvider::createValueType(params, type);
522 return variant.isValid() ? variant : QVariant(type);
526
527
528
529
530QVariant QtObject::vector2d(
double x,
double y)
const
532 return constructFromJSValue(jsEngine(), QMetaType(QMetaType::QVector2D), x, y);
536
537
538
539
540QVariant QtObject::vector3d(
double x,
double y,
double z)
const
542 return constructFromJSValue(jsEngine(), QMetaType(QMetaType::QVector3D), x, y, z);
546
547
548
549
550QVariant QtObject::vector4d(
double x,
double y,
double z,
double w)
const
552 return constructFromJSValue(jsEngine(), QMetaType(QMetaType::QVector4D), x, y, z, w);
556
557
558
559
560QVariant QtObject::quaternion(
double scalar,
double x,
double y,
double z)
const
562 return constructFromJSValue(jsEngine(), QMetaType(QMetaType::QQuaternion), scalar, x, y, z);
566
567
568
569
570QVariant QtObject::matrix4x4()
const
572 const QMetaType metaType(QMetaType::QMatrix4x4);
573 const QVariant variant = QQmlValueTypeProvider::createValueType(QJSValue(), metaType);
574 return variant.isValid() ? variant : QVariant(metaType);
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592QVariant QtObject::matrix4x4(
const QJSValue &value)
const
594 if (value.isObject()) {
595 QVariant v = QQmlValueTypeProvider::createValueType(
596 value, QMetaType(QMetaType::QMatrix4x4));
601 v4Engine()->throwError(QStringLiteral(
"Qt.matrix4x4(): Invalid argument: "
602 "not a valid matrix4x4 values array"));
607
608
609
610
611
612
613
614
615
616
617
618
619
620QVariant QtObject::matrix4x4(
double m11,
double m12,
double m13,
double m14,
621 double m21,
double m22,
double m23,
double m24,
622 double m31,
double m32,
double m33,
double m34,
623 double m41,
double m42,
double m43,
double m44)
const
625 return constructFromJSValue(jsEngine(), QMetaType(QMetaType::QMatrix4x4),
626 m11, m12, m13, m14, m21, m22, m23, m24,
627 m31, m32, m33, m34, m41, m42, m43, m44);
633 if (color.isString()) {
634 v = QQmlStringConverters::colorFromString(color.toString(), ok);
636 return QVariant::fromValue(
nullptr);
638 v = color.toVariant();
639 if (v.userType() != QMetaType::QColor) {
641 return QVariant::fromValue(
nullptr);
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666QVariant QtObject::lighter(
const QJSValue &color,
double factor)
const
669 const QVariant v = colorVariantFromJSValue(color, &ok);
670 return ok ? QQml_colorProvider()->lighter(v, factor) : v;
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691QVariant QtObject::darker(
const QJSValue &color,
double factor)
const
694 const QVariant v = colorVariantFromJSValue(color, &ok);
695 return ok ? QQml_colorProvider()->darker(v, factor) : v;
699
700
701
702
703
704
705
706
707QVariant QtObject::alpha(
const QJSValue &baseColor,
double value)
const
710 const QVariant v = colorVariantFromJSValue(baseColor, &ok);
711 return ok ? QQml_colorProvider()->alpha(v, value) : v;
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743QVariant QtObject::tint(
const QJSValue &baseColor,
const QJSValue &tintColor)
const
748 const QVariant v1 = colorVariantFromJSValue(baseColor, &ok);
753 const QVariant v2 = colorVariantFromJSValue(tintColor, &ok);
755 return ok ? QQml_colorProvider()->tint(v1, v2) : v2;
760QString formatDateTimeObjectUsingDateFormat(T formatThis, Qt::DateFormat format) {
764 case Qt::RFC2822Date:
765 case Qt::ISODateWithMs:
766 return formatThis.toString(format);
777 return dateTime.toLocalTime().time();
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
799 const QDate date = QDate::fromString(string, Qt::ISODate);
806 const QDateTime dateTime = QDateTime::fromString(string, Qt::ISODate);
807 if (dateTime.isValid()) {
808 qCWarning(lcRootProperties())
809 << string <<
"is a date/time string being passed to formatDate()."
810 <<
"You should only pass date strings to formatDate().";
811 return dateTime.date();
817 const QDateTime dateTime = DateObject::stringToDateTime(string, engine);
818 if (dateTime.isValid())
819 return DateObject::dateTimeToDate(dateTime);
822 engine->throwError(QStringLiteral(
"Invalid argument passed to formatDate(): %1").arg(string));
826QString QtObject::formatDate(QDate date,
const QString &format)
const
828 return date.toString(format);
831QString QtObject::formatDate(QDate date, Qt::DateFormat format)
const
833 return formatDateTimeObjectUsingDateFormat(date, format);
836QString QtObject::formatDate(
const QDateTime &dateTime,
const QString &format)
const
838 return DateObject::dateTimeToDate(dateTime).toString(format);
841QString QtObject::formatDate(
const QString &string,
const QString &format)
const
843 if (
const auto qDate = dateFromString(string, v4Engine()))
844 return formatDate(qDate.value(), format);
849QString QtObject::formatDate(
const QDateTime &dateTime, Qt::DateFormat format)
const
851 return formatDateTimeObjectUsingDateFormat(DateObject::dateTimeToDate(dateTime), format);
854QString QtObject::formatDate(
const QString &string, Qt::DateFormat format)
const
856 if (
const auto qDate = dateFromString(string, v4Engine()))
857 return formatDate(qDate.value(), format);
862#if QT_CONFIG(qml_locale)
863QString QtObject::formatDate(QDate date,
const QLocale &locale,
864 QLocale::FormatType formatType)
const
866 return locale.toString(date, formatType);
869QString QtObject::formatDate(
const QDateTime &dateTime,
const QLocale &locale,
870 QLocale::FormatType formatType)
const
872 return locale.toString(DateObject::dateTimeToDate(dateTime), formatType);
875QString QtObject::formatDate(
const QString &string,
const QLocale &locale,
876 QLocale::FormatType formatType)
const
878 if (
const auto qDate = dateFromString(string, v4Engine()))
879 return locale.toString(qDate.value(), formatType);
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
904 const QTime time = QTime::fromString(string, Qt::ISODate);
911 const QDateTime dateTime = QDateTime::fromString(string, Qt::ISODate);
912 if (dateTime.isValid()) {
913 qCWarning(lcRootProperties())
914 << string <<
"is a date/time string being passed to formatTime()."
915 <<
"You should only pass time strings to formatTime().";
916 return dateTime.time();
922 const QDateTime dateTime = DateObject::stringToDateTime(string, engine);
923 if (dateTime.isValid())
924 return dateTimeToTime(dateTime);
927 engine->throwError(QStringLiteral(
"Invalid argument passed to formatTime(): %1").arg(string));
931QString QtObject::formatTime(QTime time,
const QString &format)
const
933 return time.toString(format);
936QString QtObject::formatTime(
const QDateTime &dateTime,
const QString &format)
const
938 return dateTimeToTime(dateTime).toString(format);
941QString QtObject::formatTime(
const QString &time,
const QString &format)
const
944 if (
auto qTime = timeFromString(time, v4Engine()))
945 return formatTime(qTime.value(), format);
950QString QtObject::formatTime(QTime time, Qt::DateFormat format)
const
952 return formatDateTimeObjectUsingDateFormat(time, format);
955QString QtObject::formatTime(
const QDateTime &dateTime, Qt::DateFormat format)
const
957 return formatDateTimeObjectUsingDateFormat(dateTimeToTime(dateTime), format);
960QString QtObject::formatTime(
const QString &time, Qt::DateFormat format)
const
962 if (
auto qTime = timeFromString(time, v4Engine()))
963 return formatTime(qTime.value(), format);
968#if QT_CONFIG(qml_locale)
969QString QtObject::formatTime(QTime time,
const QLocale &locale,
970 QLocale::FormatType formatType)
const
972 return locale.toString(time, formatType);
975QString QtObject::formatTime(
const QDateTime &dateTime,
const QLocale &locale,
976 QLocale::FormatType formatType)
const
978 return locale.toString(dateTimeToTime(dateTime), formatType);
981QString QtObject::formatTime(
const QString &time,
const QLocale &locale,
982 QLocale::FormatType formatType)
const
984 if (
auto qTime = timeFromString(time, v4Engine()))
985 return locale.toString(qTime.value(), formatType);
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1092 const QDateTime dateTime = QDateTime::fromString(string, Qt::ISODate);
1093 if (dateTime.isValid())
1099 const QDateTime dateTime = DateObject::stringToDateTime(string, engine);
1100 if (dateTime.isValid())
1104 engine->throwError(QStringLiteral(
"Invalid argument passed to formatDateTime(): %1").arg(string));
1105 return std::nullopt;
1108QString QtObject::formatDateTime(
const QDateTime &dateTime,
const QString &format)
const
1110 return dateTime.toString(format);
1113QString QtObject::formatDateTime(
const QString &string,
const QString &format)
const
1116 if (
const auto qDateTime = dateTimeFromString(string, v4Engine()))
1117 return formatDateTime(qDateTime.value(), format);
1122QString QtObject::formatDateTime(
const QDateTime &dateTime, Qt::DateFormat format)
const
1124 return formatDateTimeObjectUsingDateFormat(dateTime, format);
1127QString QtObject::formatDateTime(
const QString &string, Qt::DateFormat format)
const
1130 if (
const auto qDateTime = dateTimeFromString(string, v4Engine()))
1131 return formatDateTime(qDateTime.value(), format);
1136#if QT_CONFIG(qml_locale)
1137QString QtObject::formatDateTime(
const QDateTime &dateTime,
const QLocale &locale,
1138 QLocale::FormatType formatType)
const
1140 return locale.toString(dateTime, formatType);
1143QString QtObject::formatDateTime(
const QString &string,
const QLocale &locale,
1144 QLocale::FormatType formatType)
const
1147 if (
const auto qDateTime = dateTimeFromString(string, v4Engine()))
1148 return formatDateTime(qDateTime.value(), locale, formatType);
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165bool QtObject::openUrlExternally(
const QUrl &url)
const
1167 return QQml_guiProvider()->openUrlExternally(resolvedUrl(url));
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180QUrl QtObject::url(
const QUrl &url)
const
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196QUrl QtObject::resolvedUrl(
const QUrl &url)
const
1198 if (QQmlRefPointer<QQmlContextData> ctxt = v4Engine()->callingQmlContext())
1199 return ctxt->resolvedUrl(url);
1200 if (QQmlEngine *engine = qmlEngine())
1201 return engine->baseUrl().resolved(url);
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215QUrl QtObject::resolvedUrl(
const QUrl &url, QObject *context)
const
1218 QQmlData *data = QQmlData::get(context);
1219 if (data && data->outerContext)
1220 return data->outerContext->resolvedUrl(url);
1223 if (QQmlEngine *engine = qmlEngine())
1224 return engine->baseUrl().resolved(url);
1229
1230
1231
1232
1233QStringList QtObject::fontFamilies()
const
1235 return QQml_guiProvider()->fontFamilies();
1239
1240
1241
1242QString QtObject::md5(
const QString &data)
const
1244 return QLatin1String(QCryptographicHash::hash(data.toUtf8(), QCryptographicHash::Md5).toHex());
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265QString QtObject::escapeHtml(
const QString &data)
const
1267 return data.toHtmlEscaped();
1271
1272
1273
1274
1275
1276QString QtObject::btoa(
const QString &data)
const
1278 qWarning(
"Qt.btoa(string): This method is deprecated. "
1279 "Its output differs from the common Web API. "
1280 "Use the overloads that take array-likes.");
1281 return QLatin1String(data.toUtf8().toBase64());
1285
1286
1287
1288
1289
1290
1291QString QtObject::atob(
const QString &data)
const
1293 qWarning(
"Qt.atob(string): This method is deprecated. "
1294 "Its output differs from the common Web API. "
1295 "Use the overloads that take array-likes.");
1296 return QString::fromUtf8(QByteArray::fromBase64(data.toLatin1()));
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316QByteArray QtObject::btoa(
const QByteArray &data)
const
1318 return data.toBase64();
1323 QV4::Scope scope(engine);
1324 THROW_DOM(DOMEXCEPTION_INVALID_CHARACTER_ERR,
"Invalid character");
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344QByteArray QtObject::atob(
const QByteArray &data)
const
1347 = QByteArray::fromBase64Encoding(data, QByteArray::AbortOnBase64DecodingErrors);
1348 if (result.decodingStatus == QByteArray::Base64DecodingStatus::Ok)
1349 return result.decoded;
1351 throwInvalidCharacter(v4Engine());
1352 return QByteArray();
1357 const auto fail = [&]() {
1358 throwInvalidCharacter(engine);
1359 return QByteArray();
1364 const auto append = [&](
auto value) {
1365 if (value < 0 || value >= 256)
1367 result.append(
char(value));
1371 for (
const QVariant &entry : data) {
1372 switch (entry.typeId()) {
1373 case QMetaType::Char:
1374 result.append(*
static_cast<
const char *>(entry.constData()));
1376 case QMetaType::Int: {
1377 if (!append(*
static_cast<
const int *>(entry.constData())))
1381 case QMetaType::Double: {
1382 if (!append(*
static_cast<
const double *>(entry.constData())))
1386 case QMetaType::QString: {
1387 const QString *string =
static_cast<
const QString *>(entry.constData());
1388 if (string->length() != 1)
1390 if (!append(string->at(0).unicode()))
1403
1404
1405
1406
1407
1408
1409QByteArray QtObject::btoa(
const QVariantList &data)
const
1411 return btoa(convertVariantList(data, v4Engine()));
1415
1416
1417
1418
1419
1420
1421QByteArray QtObject::atob(
const QVariantList &data)
const
1423 return atob(convertVariantList(data, v4Engine()));
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437void QtObject::quit()
const
1439 if (QQmlEngine *engine = qmlEngine())
1440 QQmlEnginePrivate::get(engine)->sendQuit();
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455void QtObject::exit(
int retCode)
const
1457 if (QQmlEngine *engine = qmlEngine())
1458 QQmlEnginePrivate::get(engine)->sendExit(retCode);
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496QObject *QtObject::createQmlObject(
const QString &qml, QObject *parent,
const QUrl &url)
const
1498 QQmlEngine *engine = qmlEngine();
1500 v4Engine()->throwError(QStringLiteral(
"Qt.createQmlObject(): "
1501 "Can only be called on a QML engine."));
1506 static ReturnedValue create(QV4::ExecutionEngine *v4,
const QList<QQmlError> &errors) {
1510 errorstr += QLatin1String(
"Qt.createQmlObject(): failed to create object: ");
1512 QV4::ScopedArrayObject qmlerrors(scope, v4->newArrayObject());
1513 QV4::ScopedObject qmlerror(scope);
1514 QV4::ScopedString s(scope);
1515 QV4::ScopedValue v(scope);
1516 for (
int ii = 0; ii < errors.size(); ++ii) {
1517 const QQmlError &error = errors.at(ii);
1518 errorstr += QLatin1String(
"\n ") + error.toString();
1519 qmlerror = v4->newObject();
1520 qmlerror->put((s = v4->newString(QStringLiteral(
"lineNumber"))), (v = QV4::Value::fromInt32(error.line())));
1521 qmlerror->put((s = v4->newString(QStringLiteral(
"columnNumber"))), (v = QV4::Value::fromInt32(error.column())));
1522 qmlerror->put((s = v4->newString(QStringLiteral(
"fileName"))), (v = v4->newString(error.url().toString())));
1523 qmlerror->put((s = v4->newString(QStringLiteral(
"message"))), (v = v4->newString(error.description())));
1524 qmlerrors->put(ii, qmlerror);
1527 v = v4->newString(errorstr);
1528 ScopedObject errorObject(scope, v4->newErrorObject(v));
1529 errorObject->put((s = v4->newString(QStringLiteral(
"qmlErrors"))), qmlerrors);
1530 return errorObject.asReturnedValue();
1534 QQmlRefPointer<QQmlContextData> context = v4Engine()->callingQmlContext();
1536 context = QQmlContextData::get(QQmlEnginePrivate::get(engine)->rootContext);
1539 QQmlContext *effectiveContext =
nullptr;
1540 if (context->isPragmaLibraryContext())
1541 effectiveContext = engine->rootContext();
1543 effectiveContext = context->asQQmlContext();
1544 Q_ASSERT(effectiveContext);
1549 QUrl resolvedUrl = url;
1550 if (url.isValid() && url.isRelative())
1551 resolvedUrl = context->resolvedUrl(url);
1554 v4Engine()->throwError(QStringLiteral(
"Qt.createQmlObject(): Missing parent object"));
1558 QQmlRefPointer<QQmlTypeData> typeData = v4Engine()->typeLoader()->getType(
1559 qml.toUtf8(), resolvedUrl, QQmlTypeLoader::Synchronous);
1561 if (!typeData->isCompleteOrError()) {
1562 v4Engine()->throwError(
1563 QStringLiteral(
"Qt.createQmlObject(): Failed to force synchronous loading "
1564 "of asynchronous URL '%1'").arg(resolvedUrl.toString()));
1568 QQmlComponent component(engine);
1569 QQmlComponentPrivate *componentPrivate = QQmlComponentPrivate::get(&component);
1570 componentPrivate->fromTypeData(typeData);
1571 componentPrivate->setProgress(1.0);
1573 Scope scope(v4Engine());
1574 if (component.isError()) {
1575 ScopedValue v(scope, Error::create(scope.engine, component.errors()));
1576 scope.engine->throwError(v);
1580 if (!component.isReady()) {
1581 v4Engine()->throwError(QStringLiteral(
"Qt.createQmlObject(): Component is not ready"));
1585 if (!effectiveContext->isValid()) {
1586 v4Engine()->throwError(QStringLiteral(
"Qt.createQmlObject(): Cannot create a component "
1587 "in an invalid context"));
1591 QObject *obj = component.beginCreate(effectiveContext);
1593 QQmlData::get(obj,
true)->explicitIndestructibleSet =
false;
1594 QQmlData::get(obj)->indestructible =
false;
1596 obj->setParent(parent);
1598 QList<QQmlPrivate::AutoParentFunction> functions = QQmlMetaType::parentFunctions();
1599 for (
int ii = 0; ii < functions.size(); ++ii) {
1600 if (QQmlPrivate::Parented == functions.at(ii)(obj, parent))
1604 component.completeCreate();
1606 v4Engine()->trimCompilationUnitsForUrl(resolvedUrl);
1607 if (component.isError()) {
1608 ScopedValue v(scope, Error::create(scope.engine, component.errors()));
1609 scope.engine->throwError(v);
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1688QQmlComponent *QtObject::createComponent(
const QUrl &url, QObject *parent)
const
1690 return createComponent(url, QQmlComponent::PreferSynchronous, parent);
1696 engine->throwError(QStringLiteral(
"Invalid compilation mode %1").arg(
int(mode)));
1700QQmlComponent *QtObject::createComponent(
const QUrl &url, QQmlComponent::CompilationMode mode,
1701 QObject *parent)
const
1703 if (mode != QQmlComponent::Asynchronous && mode != QQmlComponent::PreferSynchronous) {
1704 throw_invalid_compilation_mode(v4Engine(), mode);
1711 QQmlEngine *engine = qmlEngine();
1715 auto [context, effectiveContext] = getContexts();
1719 QQmlComponent *c =
new QQmlComponent(engine, context->resolvedUrl(url), mode, parent);
1720 QQmlComponentPrivate::get(c)->setCreationContext(std::move(effectiveContext));
1721 QQmlData::get(c,
true)->explicitIndestructibleSet =
false;
1722 QQmlData::get(c)->indestructible =
false;
1726QQmlComponent *QtObject::createComponent(
const QString &moduleUri,
const QString &typeName,
1727 QObject *parent)
const
1729 return createComponent(moduleUri, typeName, QQmlComponent::PreferSynchronous, parent);
1732QQmlComponent *QtObject::createComponent(
const QString &moduleUri,
const QString &typeName, QQmlComponent::CompilationMode mode, QObject *parent)
const
1734 if (mode != QQmlComponent::Asynchronous && mode != QQmlComponent::PreferSynchronous) {
1735 throw_invalid_compilation_mode(v4Engine(), mode);
1739 QQmlEngine *engine = qmlEngine();
1743 if (moduleUri.isEmpty() || typeName.isEmpty())
1746 auto [context, effectiveContext] = getContexts();
1750 QQmlComponent *c =
new QQmlComponent(engine, moduleUri, typeName, mode, parent);
1751 if (c->isError() && !parent && moduleUri.endsWith(u".qml")) {
1752 v4Engine()->throwTypeError(
1753 QStringLiteral(
"Invalid arguments; did you swap mode and parent"));
1755 QQmlComponentPrivate::get(c)->setCreationContext(std::move(effectiveContext));
1756 QQmlData::get(c,
true)->explicitIndestructibleSet =
false;
1757 QQmlData::get(c)->indestructible =
false;
1761#if QT_CONFIG(translation)
1762QString QtObject::uiLanguage()
const
1764 if (
const QJSEngine *e = jsEngine())
1765 return e->uiLanguage();
1769void QtObject::setUiLanguage(
const QString &uiLanguage)
1771 if (QJSEngine *e = jsEngine())
1772 e->setUiLanguage(uiLanguage);
1775QBindable<QString> QtObject::uiLanguageBindable()
1777 if (QJSEngine *e = jsEngine())
1778 return QBindable<QString>(&QJSEnginePrivate::get(e)->uiLanguage);
1779 return QBindable<QString>();
1783#if QT_CONFIG(qml_locale)
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804
1805
1806QLocale QtObject::locale()
const
1811QLocale QtObject::locale(
const QString &name)
const
1813 return QLocale(name);
1817void Heap::QQmlBindingFunction::init(
const QV4::JavaScriptFunctionObject *bindingFunction)
1819 Scope scope(bindingFunction->engine());
1820 ScopedContext context(scope, bindingFunction->scope());
1821 JavaScriptFunctionObject::init(context, bindingFunction->function());
1822 this->bindingFunction.set(internalClass->engine, bindingFunction->d());
1826 const FunctionObject *f,
const Value *,
const Value *,
int)
1829 return f->engine()->throwTypeError(QStringLiteral(
"Bindings must not be called directly."));
1834 QV4::CppStackFrame *frame = engine()->currentStackFrame;
1835 if (frame->v4Function)
1836 return QQmlSourceLocation(frame->source(), frame->lineNumber(), 0);
1838 return bindingFunction()->function->sourceLocation();
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884QJSValue QtObject::binding(
const QJSValue &function)
const
1886 const QV4::JavaScriptFunctionObject *f
1887 = QJSValuePrivate::asManagedType<JavaScriptFunctionObject>(&function);
1888 QV4::ExecutionEngine *e = v4Engine();
1890 return QJSValuePrivate::fromReturnedValue(
1893 "binding(): argument (binding expression) must be a function")));
1896 return QJSValuePrivate::fromReturnedValue(
1897 Encode(e->memoryManager->allocate<QQmlBindingFunction>(f)));
1900void QtObject::callLater(QQmlV4FunctionPtr args)
1902 m_engine->delayedCallQueue()->addUniquelyAndExecuteLater(m_engine, args);
1906
1907
1908
1909
1910
1911
1912double QtObject::enumStringToValue(
const QJSManagedValue &enumType,
const QString &string)
1914 return retrieveFromEnum<
double>(
1916 [&](
const QQmlType &type, QQmlTypeLoader *typeLoader,
int enumIndex,
bool *ok) {
1917 return type.scopedEnumValue(typeLoader, enumIndex, string, ok);
1918 }, [&](
const QQmlType &type, QQmlTypeLoader *typeLoader,
int enumIndex,
bool *ok) {
1919 return type.unscopedEnumValue(typeLoader, enumIndex, string, ok);
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935QString QtObject::enumValueToString(
const QJSManagedValue &enumType,
double value)
1938 if (std::isnan(value)) {
1939 m_engine->throwReferenceError(
"Invalid second argument, entry"_L1);
1943 return retrieveFromEnum<QString>(
1945 [&](
const QQmlType &type, QQmlTypeLoader *typeLoader,
int enumIndex,
bool *ok) {
1946 return type.scopedEnumKey(typeLoader, enumIndex, QtPrivate::qSaturateRound(value), ok);
1947 }, [&](
const QQmlType &type, QQmlTypeLoader *typeLoader,
int enumIndex,
bool *ok) {
1948 return type.unscopedEnumKey(typeLoader, enumIndex, QtPrivate::qSaturateRound(value), ok);
1953
1954
1955
1956
1957
1958
1959
1960QStringList QtObject::enumValueToStrings(
const QJSManagedValue &enumType,
double value)
1963 if (std::isnan(value)) {
1964 m_engine->throwReferenceError(
"Invalid second argument, entry"_L1);
1968 return retrieveFromEnum<QStringList>(
1970 [&](
const QQmlType &type, QQmlTypeLoader *typeLoader,
int enumIndex,
bool *ok) {
1971 return type.scopedEnumKeys(typeLoader, enumIndex, QtPrivate::qSaturateRound(value), ok);
1972 }, [&](
const QQmlType &type, QQmlTypeLoader *typeLoader,
int enumIndex,
bool *ok) {
1973 return type.unscopedEnumKeys(typeLoader, enumIndex, QtPrivate::qSaturateRound(value), ok);
1977QQmlPlatform *QtObject::platform()
1980 m_platform =
new QQmlPlatform(
this);
1984QQmlApplication *QtObject::application()
1988 m_application = QQml_guiProvider()->application(
this);
1990 return m_application;
1993QObject *QtObject::inputMethod()
const
1995 return QQml_guiProvider()->inputMethod();
1998QObject *QtObject::styleHints()
const
2000 return QQml_guiProvider()->styleHints();
2006 QV4::Scope scope(internalClass->engine);
2007 QV4::ScopedObject o(scope,
this);
2009 o->defineDefaultProperty(QStringLiteral(
"debug"), QV4::ConsoleObject::method_log);
2010 o->defineDefaultProperty(QStringLiteral(
"log"), QV4::ConsoleObject::method_log);
2011 o->defineDefaultProperty(QStringLiteral(
"info"), QV4::ConsoleObject::method_info);
2012 o->defineDefaultProperty(QStringLiteral(
"warn"), QV4::ConsoleObject::method_warn);
2013 o->defineDefaultProperty(QStringLiteral(
"error"), QV4::ConsoleObject::method_error);
2014 o->defineDefaultProperty(QStringLiteral(
"assert"), QV4::ConsoleObject::method_assert);
2016 o->defineDefaultProperty(QStringLiteral(
"count"), QV4::ConsoleObject::method_count);
2017 o->defineDefaultProperty(QStringLiteral(
"profile"), QV4::ConsoleObject::method_profile);
2018 o->defineDefaultProperty(QStringLiteral(
"profileEnd"), QV4::ConsoleObject::method_profileEnd);
2019 o->defineDefaultProperty(QStringLiteral(
"time"), QV4::ConsoleObject::method_time);
2020 o->defineDefaultProperty(QStringLiteral(
"timeEnd"), QV4::ConsoleObject::method_timeEnd);
2021 o->defineDefaultProperty(QStringLiteral(
"trace"), QV4::ConsoleObject::method_trace);
2022 o->defineDefaultProperty(QStringLiteral(
"exception"), QV4::ConsoleObject::method_exception);
2037 for (CppStackFrame *f = engine->currentStackFrame; f && i < 10; f = f->parentFrame(), ++i) {
2040 if (f->isJSTypesFrame() &&
static_cast<JSTypesStackFrame *>(f)->isTailCalling()) {
2041 stackFrame = QStringLiteral(
"[elided tail calls]");
2043 const int line = f->lineNumber();
2044 if (line != f->missingLineNumber()) {
2045 stackFrame = QStringLiteral(
"%1 (%2:%3)").arg(
2046 f->function(), f->source(), QString::number(qAbs(line)));
2048 stackFrame = QStringLiteral(
"%1 (%2)").arg(
2049 f->function(), f->source());
2054 stack += QLatin1Char(
'\n');
2055 stack += stackFrame;
2062 ScopedValue val(scope);
2064 alreadySeen.insert(array->d());
2066 ScopedObject detached(scope);
2067 if (Sequence *reference = array->as<Sequence>())
2068 detached = ReferenceObject::detached(reference->d());
2072 result += QLatin1Char(
'[');
2073 const uint length = detached->getLength();
2074 for (uint i = 0; i < length; ++i) {
2076 result += QLatin1Char(
',');
2077 val = detached->get(i);
2078 if (val->isManaged() && val->managed()->isArrayLike())
2079 if (!alreadySeen.contains(val->objectValue()->d()))
2080 result += serializeArray(val->objectValue(), v4, alreadySeen);
2082 result += QLatin1String(
"[Circular]");
2084 result += val->toQStringNoThrow();
2086 result += QLatin1Char(
']');
2088 alreadySeen.remove(array->d());
2095 const QLoggingCategory *loggingCategory =
nullptr;
2097 QV4::Scope scope(b);
2098 QV4::ExecutionEngine *v4 = scope.engine;
2102 if (
const QObjectWrapper* wrapper = argv[0].as<QObjectWrapper>()) {
2103 if (QQmlLoggingCategoryBase *category
2104 = qobject_cast<QQmlLoggingCategoryBase *>(wrapper->object())) {
2105 if (category->category())
2106 loggingCategory = category->category();
2108 THROW_GENERIC_ERROR(
"A QmlLoggingCatgory was provided without a valid name");
2115 for (
int i = start, ei = argc; i < ei; ++i) {
2117 result.append(QLatin1Char(
' '));
2119 QSet<QV4::Heap::Object *> alreadySeenElements;
2120 if (argv[i].isManaged() && argv[i].managed()->isArrayLike())
2121 result.append(serializeArray(argv[i].objectValue(), v4, alreadySeenElements));
2123 result.append(argv[i].toQStringNoThrow());
2127 result += QLatin1Char(
'\n') + jsStack(v4);
2129 if (!loggingCategory)
2130 loggingCategory = v4->qmlEngine() ? &lcQml() : &lcJs();
2131 QV4::CppStackFrame *frame = v4->currentStackFrame;
2132 const QByteArray baSource = frame ? frame->source().toUtf8() : QByteArray();
2133 const QByteArray baFunction = frame ? frame->function().toUtf8() : QByteArray();
2134 QMessageLogger logger(baSource.constData(), frame ? frame->lineNumber() : 0,
2135 baFunction.constData(), loggingCategory->categoryName());
2139 if (loggingCategory->isDebugEnabled())
2140 logger.debug(
"%s", result.toUtf8().constData());
2143 if (loggingCategory->isInfoEnabled())
2144 logger.info(
"%s", result.toUtf8().constData());
2147 if (loggingCategory->isWarningEnabled())
2148 logger.warning(
"%s", result.toUtf8().constData());
2151 if (loggingCategory->isCriticalEnabled())
2152 logger.critical(
"%s", result.toUtf8().constData());
2158 return Encode::undefined();
2163ReturnedValue
ConsoleObject::method_error(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2165 return writeToConsole(b, argv, argc, Error);
2168ReturnedValue
ConsoleObject::method_log(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2173 return writeToConsole(b, argv, argc, Log);
2176ReturnedValue
ConsoleObject::method_info(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2178 return writeToConsole(b, argv, argc, Info);
2181ReturnedValue
ConsoleObject::method_profile(
const FunctionObject *b,
const Value *,
const Value *,
int)
2183 QV4::Scope scope(b);
2184 QV4::ExecutionEngine *v4 = scope.engine;
2186 QV4::CppStackFrame *frame = v4->currentStackFrame;
2187 const QByteArray baSource = frame->source().toUtf8();
2188 const QByteArray baFunction = frame->function().toUtf8();
2189 QMessageLogger logger(baSource.constData(), frame->lineNumber(), baFunction.constData());
2190 QQmlProfilerService *service = QQmlDebugConnector::service<QQmlProfilerService>();
2192 logger.warning(
"Cannot start profiling because debug service is disabled. Start with -qmljsdebugger=port:XXXXX.");
2194 service->startProfiling(v4->jsEngine());
2195 logger.debug(
"Profiling started.");
2198 return QV4::Encode::undefined();
2201ReturnedValue
ConsoleObject::method_profileEnd(
const FunctionObject *b,
const Value *,
const Value *,
int)
2203 QV4::Scope scope(b);
2204 QV4::ExecutionEngine *v4 = scope.engine;
2206 QV4::CppStackFrame *frame = v4->currentStackFrame;
2207 const QByteArray baSource = frame->source().toUtf8();
2208 const QByteArray baFunction = frame->function().toUtf8();
2209 QMessageLogger logger(baSource.constData(), frame->lineNumber(), baFunction.constData());
2211 QQmlProfilerService *service = QQmlDebugConnector::service<QQmlProfilerService>();
2213 logger.warning(
"Ignoring console.profileEnd(): the debug service is disabled.");
2215 service->stopProfiling(v4->jsEngine());
2216 logger.debug(
"Profiling ended.");
2219 return QV4::Encode::undefined();
2222ReturnedValue
ConsoleObject::method_time(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2224 QV4::Scope scope(b);
2226 THROW_GENERIC_ERROR(
"console.time(): Invalid arguments");
2228 QString name = argv[0].toQStringNoThrow();
2229 scope.engine->startTimer(name);
2230 return QV4::Encode::undefined();
2233ReturnedValue
ConsoleObject::method_timeEnd(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2235 QV4::Scope scope(b);
2237 THROW_GENERIC_ERROR(
"console.timeEnd(): Invalid arguments");
2239 QString name = argv[0].toQStringNoThrow();
2241 qint64 elapsed = scope.engine->stopTimer(name, &wasRunning);
2243 qDebug(
"%s: %llims", qPrintable(name), elapsed);
2245 return QV4::Encode::undefined();
2248ReturnedValue
ConsoleObject::method_count(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2253 name = argv[0].toQStringNoThrow();
2256 QV4::ExecutionEngine *v4 = scope.engine;
2258 QV4::CppStackFrame *frame = v4->currentStackFrame;
2260 QString scriptName = frame->source();
2262 int value = v4->consoleCountHelper(scriptName, frame->lineNumber(), 0);
2263 QString message = name + QLatin1String(
": ") + QString::number(value);
2265 QMessageLogger(qPrintable(scriptName), frame->lineNumber(),
2266 qPrintable(frame->function()))
2267 .debug(
"%s", qPrintable(message));
2269 return QV4::Encode::undefined();
2272ReturnedValue
ConsoleObject::method_trace(
const FunctionObject *b,
const Value *,
const Value *,
int argc)
2274 QV4::Scope scope(b);
2276 THROW_GENERIC_ERROR(
"console.trace(): Invalid arguments");
2278 QV4::ExecutionEngine *v4 = scope.engine;
2280 QString stack = jsStack(v4);
2282 QV4::CppStackFrame *frame = v4->currentStackFrame;
2283 QMessageLogger(frame->source().toUtf8().constData(), frame->lineNumber(),
2284 frame->function().toUtf8().constData())
2285 .debug(v4->qmlEngine() ? lcQml() : lcJs(),
"%s", qPrintable(stack));
2287 return QV4::Encode::undefined();
2290ReturnedValue
ConsoleObject::method_warn(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2292 return writeToConsole(b, argv, argc, Warn);
2295ReturnedValue
ConsoleObject::method_assert(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2297 QV4::Scope scope(b);
2299 THROW_GENERIC_ERROR(
"console.assert(): Missing argument");
2301 QV4::ExecutionEngine *v4 = scope.engine;
2303 if (!argv[0].toBoolean()) {
2305 for (
int i = 1, ei = argc; i < ei; ++i) {
2307 message.append(QLatin1Char(
' '));
2309 message.append(argv[i].toQStringNoThrow());
2312 QString stack = jsStack(v4);
2314 QV4::CppStackFrame *frame = v4->currentStackFrame;
2315 QMessageLogger(frame->source().toUtf8().constData(), frame->lineNumber(),
2316 frame->function().toUtf8().constData())
2317 .critical(
"%s\n%s",qPrintable(message), qPrintable(stack));
2320 return QV4::Encode::undefined();
2323ReturnedValue
ConsoleObject::method_exception(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2325 QV4::Scope scope(b);
2327 THROW_GENERIC_ERROR(
"console.exception(): Missing argument");
2329 return writeToConsole(b, argv, argc, Error,
true);
2332void QV4::GlobalExtensions::init(Object *globalObject, QJSEngine::Extensions extensions)
2334 ExecutionEngine *v4 = globalObject->engine();
2337 if (extensions.testFlag(QJSEngine::TranslationExtension)) {
2338 #if QT_CONFIG(translation)
2339 globalObject->defineDefaultProperty(QStringLiteral(
"qsTranslate"), QV4::GlobalExtensions::method_qsTranslate);
2340 globalObject->defineDefaultProperty(QStringLiteral(
"QT_TRANSLATE_NOOP"), QV4::GlobalExtensions::method_qsTranslateNoOp);
2341 globalObject->defineDefaultProperty(QStringLiteral(
"qsTr"), QV4::GlobalExtensions::method_qsTr);
2342 globalObject->defineDefaultProperty(QStringLiteral(
"QT_TR_NOOP"), QV4::GlobalExtensions::method_qsTrNoOp);
2343 globalObject->defineDefaultProperty(QStringLiteral(
"qsTrId"), QV4::GlobalExtensions::method_qsTrId);
2344 globalObject->defineDefaultProperty(QStringLiteral(
"QT_TRID_NOOP"), QV4::GlobalExtensions::method_qsTrIdNoOp);
2347 ScopedString qtName(scope, v4->newString(QStringLiteral(
"Qt")));
2348 ScopedObject qt(scope, globalObject->get(qtName));
2350 v4->createQtObject();
2353 scope.engine->stringPrototype()->defineDefaultProperty(QStringLiteral(
"arg"), QV4::GlobalExtensions::method_string_arg);
2357 if (extensions.testFlag(QJSEngine::ConsoleExtension)) {
2358 globalObject->defineDefaultProperty(QStringLiteral(
"print"), QV4::ConsoleObject::method_log);
2361 QV4::ScopedObject console(scope, globalObject->engine()->memoryManager->allocate<QV4::ConsoleObject>());
2362 globalObject->defineDefaultProperty(QStringLiteral(
"console"), console);
2365 if (extensions.testFlag(QJSEngine::GarbageCollectionExtension)) {
2366 globalObject->defineDefaultProperty(QStringLiteral(
"gc"), QV4::GlobalExtensions::method_gc);
2371#if QT_CONFIG(translation)
2373
2374
2375
2376
2377
2378
2379
2380
2381
2382
2383
2384
2385
2386
2387
2388
2389
2390
2391
2392ReturnedValue GlobalExtensions::method_qsTranslate(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2394 QV4::Scope scope(b);
2396 THROW_GENERIC_ERROR(
"qsTranslate() requires at least two arguments");
2397 if (!argv[0].isString())
2398 THROW_GENERIC_ERROR(
"qsTranslate(): first argument (context) must be a string");
2399 if (!argv[1].isString())
2400 THROW_GENERIC_ERROR(
"qsTranslate(): second argument (sourceText) must be a string");
2401 if ((argc > 2) && !argv[2].isString())
2402 THROW_GENERIC_ERROR(
"qsTranslate(): third argument (disambiguation) must be a string");
2404 QString context = argv[0].toQStringNoThrow();
2405 QString text = argv[1].toQStringNoThrow();
2407 if (argc > 2) comment = argv[2].toQStringNoThrow();
2410 if (argc > i && argv[i].isString()) {
2411 qWarning(
"qsTranslate(): specifying the encoding as fourth argument is deprecated");
2417 n = argv[i].toInt32();
2419 if (QQmlEnginePrivate *ep = (scope.engine->qmlEngine() ? QQmlEnginePrivate::get(scope.engine->qmlEngine()) :
nullptr))
2420 if (ep->propertyCapture)
2421 ep->propertyCapture->captureTranslation();
2423 QString result = QCoreApplication::translate(context.toUtf8().constData(),
2424 text.toUtf8().constData(),
2425 comment.toUtf8().constData(),
2428 return Encode(scope.engine->newString(result));
2432
2433
2434
2435
2436
2437
2438
2439
2440
2441
2442
2443
2444
2445
2446
2447
2448
2449
2450
2451
2452
2453ReturnedValue GlobalExtensions::method_qsTranslateNoOp(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2455 QV4::Scope scope(b);
2457 return QV4::Encode::undefined();
2459 return argv[1].asReturnedValue();
2462QString GlobalExtensions::currentTranslationContext(ExecutionEngine *engine)
2465 CppStackFrame *frame = engine->currentStackFrame;
2468 while (frame && context.isEmpty()) {
2469 if (ExecutableCompilationUnit *unit = frame->v4Function->executableCompilationUnit()) {
2470 auto translationContextIndex = unit->unitData()->translationContextIndex();
2471 if (translationContextIndex)
2472 context = unit->stringAt(*translationContextIndex);
2473 if (!context.isEmpty())
2475 QString fileName = unit->fileName();
2476 QUrl url(unit->fileName());
2477 if (url.isValid() && url.isRelative()) {
2478 context = url.fileName();
2480 context = QQmlFile::urlToLocalFileOrQrc(fileName);
2481 if (context.isEmpty() && fileName.startsWith(QLatin1String(
":/")))
2484 context = QFileInfo(context).completeBaseName();
2486 frame = frame->parentFrame();
2489 if (context.isEmpty()) {
2490 if (QQmlRefPointer<QQmlContextData> ctxt = engine->callingQmlContext()) {
2491 QString path = ctxt->urlString();
2492 int lastSlash = path.lastIndexOf(QLatin1Char(
'/'));
2493 int lastDot = path.lastIndexOf(QLatin1Char(
'.'));
2494 int length = lastDot - (lastSlash + 1);
2495 context = (lastSlash > -1) ? path.mid(lastSlash + 1, (length > -1) ? length : -1) : QString();
2503
2504
2505
2506
2507
2508
2509
2510
2511
2512
2513
2514
2515
2516
2517
2518
2519
2520
2521
2522
2523
2524
2525
2526
2527
2528
2529
2530
2531
2532
2533
2534
2535
2536
2537
2538
2539ReturnedValue GlobalExtensions::method_qsTr(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2541 QV4::Scope scope(b);
2543 THROW_GENERIC_ERROR(
"qsTr() requires at least one argument");
2544 if (!argv[0].isString())
2545 THROW_GENERIC_ERROR(
"qsTr(): first argument (sourceText) must be a string");
2546 if ((argc > 1) && !argv[1].isString())
2547 THROW_GENERIC_ERROR(
"qsTr(): second argument (disambiguation) must be a string");
2548 if ((argc > 2) && !argv[2].isNumber())
2549 THROW_GENERIC_ERROR(
"qsTr(): third argument (n) must be a number");
2551 const QString context = currentTranslationContext(scope.engine);
2552 const QString text = argv[0].toQStringNoThrow();
2553 const QString comment = argc > 1 ? argv[1].toQStringNoThrow() : QString();
2554 const int n = argc > 2 ? argv[2].toInt32() : -1;
2556 if (QQmlEnginePrivate *ep = (scope.engine->qmlEngine() ? QQmlEnginePrivate::get(scope.engine->qmlEngine()) :
nullptr))
2557 if (ep->propertyCapture)
2558 ep->propertyCapture->captureTranslation();
2560 QString result = QCoreApplication::translate(context.toUtf8().constData(), text.toUtf8().constData(),
2561 comment.toUtf8().constData(), n);
2563 return Encode(scope.engine->newString(result));
2567
2568
2569
2570
2571
2572
2573
2574
2575
2576
2577
2578
2579
2580
2581
2582
2583
2584
2585
2586
2587
2588ReturnedValue GlobalExtensions::method_qsTrNoOp(
const FunctionObject *,
const Value *,
const Value *argv,
int argc)
2591 return QV4::Encode::undefined();
2593 return argv[0].asReturnedValue();
2597
2598
2599
2600
2601
2602
2603
2604
2605
2606
2607
2608
2609
2610
2611
2612
2613
2614
2615
2616
2617
2618
2619
2620
2621
2622
2623
2624
2625
2626
2627ReturnedValue GlobalExtensions::method_qsTrId(
const FunctionObject *b,
const Value *,
const Value *argv,
int argc)
2629 QV4::Scope scope(b);
2631 THROW_GENERIC_ERROR(
"qsTrId() requires at least one argument");
2632 if (!argv[0].isString())
2633 THROW_TYPE_ERROR_WITH_MESSAGE(
"qsTrId(): first argument (id) must be a string");
2634 if (argc > 1 && !argv[1].isNumber())
2635 THROW_TYPE_ERROR_WITH_MESSAGE(
"qsTrId(): second argument (n) must be a number");
2639 n = argv[1].toInt32();
2641 if (QQmlEnginePrivate *ep = (scope.engine->qmlEngine() ? QQmlEnginePrivate::get(scope.engine->qmlEngine()) :
nullptr))
2642 if (ep->propertyCapture)
2643 ep->propertyCapture->captureTranslation();
2645 return Encode(scope.engine->newString(qtTrId(argv[0].toQStringNoThrow().toUtf8().constData(), n)));
2649
2650
2651
2652
2653
2654
2655
2656
2657
2658
2659
2660
2661
2662
2663
2664ReturnedValue GlobalExtensions::method_qsTrIdNoOp(
const FunctionObject *,
const Value *,
const Value *argv,
int argc)
2667 return QV4::Encode::undefined();
2669 return argv[0].asReturnedValue();
2674
2675
2676
2677
2678
2679
2680
2681
2682ReturnedValue GlobalExtensions::method_gc(
const FunctionObject *b,
const Value *,
const Value *,
int)
2684 auto mm = b->engine()->memoryManager;
2687 return QV4::Encode::undefined();
2690ReturnedValue GlobalExtensions::method_string_arg(
const FunctionObject *b,
const Value *thisObject,
const Value *argv,
int argc)
2692 QV4::Scope scope(b);
2694 THROW_GENERIC_ERROR(
"String.arg(): Invalid arguments");
2696 QString value = thisObject->toQString();
2700 QV4::ScopedValue arg(scope, argv[0]);
2701 if (arg->isInteger())
2702 value = value.arg(arg->integerValue());
2703 else if (arg->isDouble())
2704 value = value.arg(arg->doubleValue());
2705 else if (arg->isBoolean())
2706 value = value.arg(arg->booleanValue());
2708 value = value.arg(arg->toQString());
2709 RETURN_RESULT(scope.engine->newString(value));
2713 constexpr int PreallocArgCount = 10;
2716 QVarLengthArray<QString, PreallocArgCount> argStrings(argc);
2717 QVarLengthArray<QtPrivate::QStringViewArg, PreallocArgCount> args(argc);
2718 QVarLengthArray<
const QtPrivate::ArgBase *, PreallocArgCount> argBases(argc);
2720 for (
int i = 0; i < argc; ++i) {
2721 QV4::ScopedValue arg(scope, argv[i]);
2723 if (arg->isInteger())
2724 argStrings[i] = QString::number(arg->integerValue());
2725 else if (arg->isDouble())
2726 argStrings[i] = QString::number(arg->doubleValue());
2727 else if (arg->isBoolean())
2728 argStrings[i] = QString::number(arg->booleanValue());
2730 argStrings[i] = arg->toQString();
2732 args[i] = QtPrivate::QStringViewArg(argStrings[i]);
2733 argBases[i] = &args[i];
2736 QString result = QtPrivate::argToQString(value, argc, argBases.data());
2737 RETURN_RESULT(scope.engine->newString(result));
2741
2742
2743
2744
2745
2746
2747
2748
2749
2750
2751
2752
2753
2754
2755
2756
2757
2758
2759
2763#include "moc_qqmlbuiltinfunctions_p.cpp"
Combined button and popup list for selecting options.
Q_LOGGING_CATEGORY(lcEventDispatcher, "qt.eventdispatcher")
DEFINE_OBJECT_VTABLE(QQmlBindingFunction)
static QByteArray convertVariantList(const QVariantList &data, QV4::ExecutionEngine *engine)
static QTime dateTimeToTime(const QDateTime &dateTime)
static QString serializeArray(Object *array, ExecutionEngine *v4, QSet< QV4::Heap::Object * > &alreadySeen)
void addParameters(QJSEngine *e, QJSValue &result, int i, T parameter, Others... others)
static QVariant constructFromJSValue(QJSEngine *e, QMetaType type, T... parameters)
void addParameters< double >(QJSEngine *, QJSValue &result, int i, double parameter)
static std::optional< QDate > dateFromString(const QString &string, QV4::ExecutionEngine *engine)
\qmlmethod string Qt::formatDate(datetime date, variant format, variant localeFormatOption)
static QV4::ReturnedValue throwInvalidCharacter(QV4::ExecutionEngine *engine)
DEFINE_OBJECT_VTABLE(ConsoleObject)
static ReturnedValue writeToConsole(const FunctionObject *b, const Value *argv, int argc, ConsoleLogTypes logType, bool printStack=false)
void addParameters(QJSEngine *e, QJSValue &result, int i, T parameter)
static QString jsStack(QV4::ExecutionEngine *engine)
static std::optional< QTime > timeFromString(const QString &string, QV4::ExecutionEngine *engine)
\qmlmethod string Qt::formatTime(datetime time, variant format, variant localeFormatOption)
static std::optional< QDateTime > dateTimeFromString(const QString &string, QV4::ExecutionEngine *engine)
\qmlmethod string Qt::formatDateTime(datetime dateTime, variant format, variant localeFormatOption)
static Q_DECL_COLD_FUNCTION void throw_invalid_compilation_mode(QV4::ExecutionEngine *engine, QQmlComponent::CompilationMode mode)
static QVariant colorVariantFromJSValue(const QJSValue &color, bool *ok)
Q_DECLARE_LOGGING_CATEGORY(lcQml)
Q_DECLARE_LOGGING_CATEGORY(lcJs)
QQmlSourceLocation currentLocation() const