1308void IRBuilder::setBindingValue(QV4::CompiledData::Binding *binding, QQmlJS::AST::Statement *statement, QQmlJS::AST::Node *parentNode)
1310 QQmlJS::SourceLocation loc = statement->firstSourceLocation();
1311 binding->valueLocation.set(loc.startLine, loc.startColumn);
1312 binding->setType(QV4::CompiledData::Binding::Type_Invalid);
1313 if (_propertyDeclaration && _propertyDeclaration->isReadOnly())
1314 binding->setFlag(QV4::CompiledData::Binding::InitializerForReadOnlyDeclaration);
1316 QQmlJS::AST::ExpressionStatement *exprStmt = QQmlJS::AST::cast<QQmlJS::AST::ExpressionStatement *>(statement);
1318 QQmlJS::AST::ExpressionNode *
const expr = exprStmt->expression;
1319 if (QQmlJS::AST::StringLiteral *lit = QQmlJS::AST::cast<QQmlJS::AST::StringLiteral *>(expr)) {
1320 binding->setType(QV4::CompiledData::Binding::Type_String);
1321 binding->stringIndex = registerString(lit->value.toString());
1322 }
else if (QQmlJS::AST::TemplateLiteral *templateLit = QQmlJS::AST::cast<QQmlJS::AST::TemplateLiteral *>(expr);
1323 templateLit && templateLit->hasNoSubstitution) {
1326 binding->setType(QV4::CompiledData::Binding::Type_String);
1327 binding->stringIndex = registerString(templateLit->value.toString());
1328 }
else if (expr->kind == QQmlJS::AST::Node::Kind_TrueLiteral) {
1329 binding->setType(QV4::CompiledData::Binding::Type_Boolean);
1330 binding->value.b =
true;
1331 }
else if (expr->kind == QQmlJS::AST::Node::Kind_FalseLiteral) {
1332 binding->setType(QV4::CompiledData::Binding::Type_Boolean);
1333 binding->value.b =
false;
1334 }
else if (QQmlJS::AST::NumericLiteral *lit = QQmlJS::AST::cast<QQmlJS::AST::NumericLiteral *>(expr)) {
1335 binding->setType(QV4::CompiledData::Binding::Type_Number);
1336 binding->value.constantValueIndex = jsGenerator->registerConstant(QV4::Encode(lit->value));
1337 }
else if (QQmlJS::AST::CallExpression *call = QQmlJS::AST::cast<QQmlJS::AST::CallExpression *>(expr)) {
1338 if (QQmlJS::AST::IdentifierExpression *base = QQmlJS::AST::cast<QQmlJS::AST::IdentifierExpression *>(call->base)) {
1339 tryGeneratingTranslationBinding(base->name, call->arguments, binding);
1343 }
else if (QQmlJS::AST::cast<QQmlJS::AST::FunctionExpression *>(expr)) {
1344 binding->setFlag(QV4::CompiledData::Binding::IsFunctionExpression);
1345 }
else if (QQmlJS::AST::UnaryMinusExpression *unaryMinus = QQmlJS::AST::cast<QQmlJS::AST::UnaryMinusExpression *>(expr)) {
1346 if (QQmlJS::AST::NumericLiteral *lit = QQmlJS::AST::cast<QQmlJS::AST::NumericLiteral *>(unaryMinus->expression)) {
1347 binding->setType(QV4::CompiledData::Binding::Type_Number);
1348 binding->value.constantValueIndex = jsGenerator->registerConstant(QV4::Encode(-lit->value));
1350 }
else if (QQmlJS::AST::cast<QQmlJS::AST::NullExpression *>(expr)) {
1351 binding->setType(QV4::CompiledData::Binding::Type_Null);
1352 binding->value.nullMarker = 0;
1357 if (binding->type() == QV4::CompiledData::Binding::Type_Invalid) {
1358 binding->setType(QV4::CompiledData::Binding::Type_Script);
1360 CompiledFunctionOrExpression *expr = New<CompiledFunctionOrExpression>();
1361 expr->node = statement;
1362 expr->parentNode = parentNode;
1363 expr->nameIndex = registerString(QLatin1String(
"expression for ")
1364 + stringAt(binding->propertyNameIndex));
1365 const int index = bindingsTarget()->functionsAndExpressions->append(expr);
1366 binding->value.compiledScriptIndex = index;
1371 QQmlJS::AST::Node *nodeForString = statement;
1373 nodeForString = exprStmt->expression;
1374 const QStringView source = asStringRef(nodeForString);
1375 if (source == u"undefined")
1376 binding->stringIndex = registerString(u"undefined"_s);
1377 else if (qualifiedEnumDot(source) != -1)
1378 binding->stringIndex = registerString(source.toString());
1380 binding->stringIndex = emptyStringIndex;
1609bool IRBuilder::resolveQualifiedId(QQmlJS::AST::UiQualifiedId **nameToResolve, Object **object,
bool onAssignment)
1611 QQmlJS::AST::UiQualifiedId *qualifiedIdElement = *nameToResolve;
1613 if (qualifiedIdElement->name == QLatin1String(
"id") && qualifiedIdElement->next)
1614 COMPILE_EXCEPTION(qualifiedIdElement->identifierToken, tr(
"Invalid use of id property"));
1617 QString currentName = qualifiedIdElement->name.toString();
1618 if (qualifiedIdElement->next) {
1619 for (
const QV4::CompiledData::Import* import : std::as_const(_imports))
1620 if (import->qualifierIndex != emptyStringIndex
1621 && stringAt(import->qualifierIndex) == currentName) {
1622 qualifiedIdElement = qualifiedIdElement->next;
1623 currentName += QLatin1Char(
'.') + qualifiedIdElement->name;
1625 if (!qualifiedIdElement->name.data()->isUpper())
1626 COMPILE_EXCEPTION(qualifiedIdElement->firstSourceLocation(), tr(
"Expected type name"));
1633 while (qualifiedIdElement->next) {
1634 const quint32 propertyNameIndex = registerString(currentName);
1635 const bool isAttachedProperty = qualifiedIdElement->name.data()->isUpper();
1637 Binding *binding = (*object)->findBinding(propertyNameIndex);
1639 if (isAttachedProperty) {
1640 if (!binding->isAttachedProperty())
1642 }
else if (!binding->isGroupProperty()) {
1647 binding = New<Binding>();
1648 binding->propertyNameIndex = propertyNameIndex;
1649 binding->offset = qualifiedIdElement->identifierToken.offset;
1650 binding->location.set(qualifiedIdElement->identifierToken.startLine,
1651 qualifiedIdElement->identifierToken.startColumn);
1652 binding->valueLocation.set(qualifiedIdElement->next->identifierToken.startLine,
1653 qualifiedIdElement->next->identifierToken.startColumn);
1654 binding->clearFlags();
1657 binding->setFlag(QV4::CompiledData::Binding::IsOnAssignment);
1659 if (isAttachedProperty)
1660 binding->setType(QV4::CompiledData::Binding::Type_AttachedProperty);
1662 binding->setType(QV4::CompiledData::Binding::Type_GroupProperty);
1665 if (!defineQMLObject(&objIndex,
nullptr, binding->location,
nullptr,
nullptr))
1667 binding->value.objectIndex = objIndex;
1669 QString error = (*object)->appendBinding(binding,
false);
1670 if (!error.isEmpty()) {
1671 recordError(qualifiedIdElement->identifierToken, error);
1674 *object = _objects.at(objIndex);
1676 Q_ASSERT(binding->isAttachedProperty() || binding->isGroupProperty());
1677 *object = _objects.at(binding->value.objectIndex);
1680 qualifiedIdElement = qualifiedIdElement->next;
1681 if (qualifiedIdElement)
1682 currentName = qualifiedIdElement->name.toString();
1684 *nameToResolve = qualifiedIdElement;
1732void QmlUnitGenerator::generate(Document &output,
const QV4::CompiledData::DependentTypesHasher &dependencyHasher)
1734 using namespace QV4::CompiledData;
1736 output.jsGenerator.stringTable.registerString(output.jsModule.fileName);
1737 output.jsGenerator.stringTable.registerString(output.jsModule.finalUrl);
1739 Unit *jsUnit =
nullptr;
1741 if (!output.javaScriptCompilationUnit)
1742 output.javaScriptCompilationUnit.adopt(
new QV4::CompiledData::CompilationUnit);
1745 if (output.javaScriptCompilationUnit->unitData()) {
1746 jsUnit =
const_cast<Unit *>(output.javaScriptCompilationUnit->unitData());
1747 output.javaScriptCompilationUnit->dynamicStrings
1748 = output.jsGenerator.stringTable.allStrings();
1751 jsUnit = createdUnit = output.jsGenerator.generateUnit();
1754 for (Pragma *p : std::as_const(output.pragmas)) {
1756 case Pragma::Singleton:
1757 createdUnit->flags |= Unit::IsSingleton;
1759 case Pragma::Strict:
1760 createdUnit->flags |= Unit::IsStrict;
1762 case Pragma::ComponentBehavior:
1764 switch (p->componentBehavior) {
1766 createdUnit->flags |= Unit::ComponentsBound;
1768 case Pragma::Unbound:
1773 case Pragma::ListPropertyAssignBehavior:
1774 switch (p->listPropertyAssignBehavior) {
1775 case Pragma::Replace:
1776 createdUnit->flags |= Unit::ListPropertyAssignReplace;
1778 case Pragma::ReplaceIfNotDefault:
1779 createdUnit->flags |= Unit::ListPropertyAssignReplaceIfNotDefault;
1781 case Pragma::Append:
1786 case Pragma::FunctionSignatureBehavior:
1787 switch (p->functionSignatureBehavior) {
1788 case Pragma::Enforced:
1790 case Pragma::Ignored:
1791 createdUnit->flags |= Unit::FunctionSignaturesIgnored;
1795 case Pragma::NativeMethodBehavior:
1796 switch (p->nativeMethodBehavior) {
1797 case Pragma::AcceptThisObject:
1798 createdUnit->flags |= Unit::NativeMethodsAcceptThisObject;
1800 case Pragma::RejectThisObject:
1805 case Pragma::ValueTypeBehavior:
1806 if (Pragma::ValueTypeBehaviorValues(p->valueTypeBehavior)
1807 .testFlag(Pragma::Copy)) {
1808 createdUnit->flags |= Unit::ValueTypesCopied;
1810 if (Pragma::ValueTypeBehaviorValues(p->valueTypeBehavior)
1811 .testFlag(Pragma::Addressable)) {
1812 createdUnit->flags |= Unit::ValueTypesAddressable;
1814 if (Pragma::ValueTypeBehaviorValues(p->valueTypeBehavior)
1815 .testFlag(Pragma::Assertable)) {
1816 createdUnit->flags |= Unit::ValueTypesAssertable;
1819 case Pragma::Translator:
1820 if (createdUnit->translationTableSize)
1821 if (quint32_le *index = createdUnit->translationContextIndex())
1822 *index = p->translationContextIndex;
1827 if (dependencyHasher) {
1828 const QByteArray checksum = dependencyHasher();
1829 if (checksum.size() ==
sizeof(createdUnit->dependencyMD5Checksum)) {
1830 memcpy(createdUnit->dependencyMD5Checksum, checksum.constData(),
1831 sizeof(createdUnit->dependencyMD5Checksum));
1835 createdUnit->sourceFileIndex = output.jsGenerator.stringTable.getStringId(output.jsModule.fileName);
1836 createdUnit->finalUrlIndex = output.jsGenerator.stringTable.getStringId(output.jsModule.finalUrl);
1840 output.jsGenerator.stringTable.freeze();
1842 const uint importSize = uint(
sizeof(QV4::CompiledData::Import)) * output.imports.size();
1843 const uint objectOffsetTableSize = output.objects.size() * uint(
sizeof(quint32));
1845 QHash<
const Object*, quint32> objectOffsets;
1847 const unsigned int objectOffset =
sizeof(QV4::CompiledData::QmlUnit) + importSize;
1848 uint nextOffset = objectOffset + objectOffsetTableSize;
1849 for (Object *o : std::as_const(output.objects)) {
1850 objectOffsets.insert(o, nextOffset);
1851 nextOffset += QV4::CompiledData::Object::calculateSizeExcludingSignalsAndEnums(o->functionCount(), o->propertyCount(), o->aliasCount(), o->enumCount(), o->signalCount(), o->bindingCount(), o->namedObjectsInComponent.size(), o->inlineComponentCount(), o->requiredPropertyExtraDataCount());
1853 int signalTableSize = 0;
1854 for (
const Signal *s = o->firstSignal(); s; s = s->next)
1855 signalTableSize += QV4::CompiledData::Signal::calculateSize(s->parameters->count);
1857 nextOffset += signalTableSize;
1859 int enumTableSize = 0;
1860 for (
const Enum *e = o->firstEnum(); e; e = e->next)
1861 enumTableSize += QV4::CompiledData::Enum::calculateSize(e->enumValues->count);
1863 nextOffset += enumTableSize;
1866 const uint totalSize = nextOffset;
1867 char *data = (
char*)malloc(totalSize);
1868 memset(data, 0, totalSize);
1869 QV4::CompiledData::QmlUnit *qmlUnit =
reinterpret_cast<QV4::CompiledData::QmlUnit *>(data);
1870 qmlUnit->offsetToImports =
sizeof(*qmlUnit);
1871 qmlUnit->nImports = output.imports.size();
1872 qmlUnit->offsetToObjects = objectOffset;
1873 qmlUnit->nObjects = output.objects.size();
1876 char *importPtr = data + qmlUnit->offsetToImports;
1877 for (
const QV4::CompiledData::Import *imp : std::as_const(output.imports)) {
1878 QV4::CompiledData::Import *importToWrite =
reinterpret_cast<QV4::CompiledData::Import*>(importPtr);
1879 *importToWrite = *imp;
1880 importPtr +=
sizeof(QV4::CompiledData::Import);
1884 quint32_le *objectTable =
reinterpret_cast<quint32_le*>(data + qmlUnit->offsetToObjects);
1885 for (
int i = 0; i < output.objects.size(); ++i) {
1886 const Object *o = output.objects.at(i);
1887 char *
const objectPtr = data + objectOffsets.value(o);
1888 *objectTable++ = objectOffsets.value(o);
1890 QV4::CompiledData::Object *objectToWrite =
reinterpret_cast<QV4::CompiledData::Object*>(objectPtr);
1891 objectToWrite->inheritedTypeNameIndex = o->inheritedTypeNameIndex;
1892 objectToWrite->indexOfDefaultPropertyOrAlias = o->indexOfDefaultPropertyOrAlias;
1893 objectToWrite->setHasAliasAsDefaultProperty(o->defaultPropertyIsAlias);
1894 objectToWrite->setFlags(QV4::CompiledData::Object::Flags(o->flags));
1895 objectToWrite->idNameIndex = o->idNameIndex;
1896 objectToWrite->setObjectId(o->id);
1897 objectToWrite->location = o->location;
1898 objectToWrite->locationOfIdProperty = o->locationOfIdProperty;
1900 quint32 nextOffset =
sizeof(QV4::CompiledData::Object);
1902 objectToWrite->nFunctions = o->functionCount();
1903 objectToWrite->offsetToFunctions = nextOffset;
1904 nextOffset += objectToWrite->nFunctions *
sizeof(quint32);
1906 objectToWrite->nProperties = o->propertyCount();
1907 objectToWrite->offsetToProperties = nextOffset;
1908 nextOffset += objectToWrite->nProperties *
sizeof(QV4::CompiledData::Property);
1910 objectToWrite->nAliases = o->aliasCount();
1911 objectToWrite->offsetToAliases = nextOffset;
1912 nextOffset += objectToWrite->nAliases *
sizeof(QV4::CompiledData::Alias);
1914 objectToWrite->nEnums = o->enumCount();
1915 objectToWrite->offsetToEnums = nextOffset;
1916 nextOffset += objectToWrite->nEnums *
sizeof(quint32);
1918 objectToWrite->nSignals = o->signalCount();
1919 objectToWrite->offsetToSignals = nextOffset;
1920 nextOffset += objectToWrite->nSignals *
sizeof(quint32);
1922 objectToWrite->nBindings = o->bindingCount();
1923 objectToWrite->offsetToBindings = nextOffset;
1924 nextOffset += objectToWrite->nBindings *
sizeof(QV4::CompiledData::Binding);
1926 objectToWrite->nNamedObjectsInComponent = o->namedObjectsInComponent.size();
1927 objectToWrite->offsetToNamedObjectsInComponent = nextOffset;
1928 nextOffset += objectToWrite->nNamedObjectsInComponent *
sizeof(quint32);
1930 objectToWrite->nInlineComponents = o->inlineComponentCount();
1931 objectToWrite->offsetToInlineComponents = nextOffset;
1932 nextOffset += objectToWrite->nInlineComponents *
sizeof (QV4::CompiledData::InlineComponent);
1934 objectToWrite->nRequiredPropertyExtraData = o->requiredPropertyExtraDataCount();
1935 objectToWrite->offsetToRequiredPropertyExtraData = nextOffset;
1936 nextOffset += objectToWrite->nRequiredPropertyExtraData *
sizeof(QV4::CompiledData::RequiredPropertyExtraData);
1938 quint32_le *functionsTable =
reinterpret_cast<quint32_le *>(objectPtr + objectToWrite->offsetToFunctions);
1939 for (
const Function *f = o->firstFunction(); f; f = f->next)
1940 *functionsTable++ = o->runtimeFunctionIndices.at(f->index);
1942 char *propertiesPtr = objectPtr + objectToWrite->offsetToProperties;
1943 for (
const Property *p = o->firstProperty(); p; p = p->next) {
1944 QV4::CompiledData::Property *propertyToWrite =
reinterpret_cast<QV4::CompiledData::Property*>(propertiesPtr);
1945 *propertyToWrite = *p;
1946 propertiesPtr +=
sizeof(QV4::CompiledData::Property);
1949 char *aliasesPtr = objectPtr + objectToWrite->offsetToAliases;
1950 for (
const Alias *a = o->firstAlias(); a; a = a->next) {
1951 QV4::CompiledData::Alias *aliasToWrite =
reinterpret_cast<QV4::CompiledData::Alias*>(aliasesPtr);
1953 aliasesPtr +=
sizeof(QV4::CompiledData::Alias);
1956 char *bindingPtr = objectPtr + objectToWrite->offsetToBindings;
1957 bindingPtr = writeBindings(bindingPtr, o, &QV4::CompiledData::Binding::isValueBindingNoAlias);
1958 bindingPtr = writeBindings(bindingPtr, o, &QV4::CompiledData::Binding::isSignalHandler);
1959 bindingPtr = writeBindings(bindingPtr, o, &QV4::CompiledData::Binding::isAttachedProperty);
1960 bindingPtr = writeBindings(bindingPtr, o, &QV4::CompiledData::Binding::isGroupProperty);
1961 bindingPtr = writeBindings(bindingPtr, o, &QV4::CompiledData::Binding::isValueBindingToAlias);
1962 Q_ASSERT((bindingPtr - objectToWrite->offsetToBindings - objectPtr) /
sizeof(QV4::CompiledData::Binding) ==
unsigned(o->bindingCount()));
1964 quint32_le *signalOffsetTable =
reinterpret_cast<quint32_le *>(objectPtr + objectToWrite->offsetToSignals);
1965 quint32 signalTableSize = 0;
1966 char *signalPtr = objectPtr + nextOffset;
1967 for (
const Signal *s = o->firstSignal(); s; s = s->next) {
1968 *signalOffsetTable++ = signalPtr - objectPtr;
1969 QV4::CompiledData::Signal *signalToWrite =
reinterpret_cast<QV4::CompiledData::Signal*>(signalPtr);
1971 signalToWrite->nameIndex = s->nameIndex;
1972 signalToWrite->location = s->location;
1973 signalToWrite->nParameters = s->parameters->count;
1975 QV4::CompiledData::Parameter *parameterToWrite =
reinterpret_cast<QV4::CompiledData::Parameter*>(signalPtr +
sizeof(*signalToWrite));
1976 for (Parameter *param = s->parameters->first; param; param = param->next, ++parameterToWrite)
1977 *parameterToWrite = *param;
1979 int size = QV4::CompiledData::Signal::calculateSize(s->parameters->count);
1980 signalTableSize += size;
1983 nextOffset += signalTableSize;
1985 quint32_le *enumOffsetTable =
reinterpret_cast<quint32_le*>(objectPtr + objectToWrite->offsetToEnums);
1986 char *enumPtr = objectPtr + nextOffset;
1987 for (
const Enum *e = o->firstEnum(); e; e = e->next) {
1988 *enumOffsetTable++ = enumPtr - objectPtr;
1989 QV4::CompiledData::Enum *enumToWrite =
reinterpret_cast<QV4::CompiledData::Enum*>(enumPtr);
1991 enumToWrite->nameIndex = e->nameIndex;
1992 enumToWrite->location = e->location;
1993 enumToWrite->nEnumValues = e->enumValues->count;
1995 QV4::CompiledData::EnumValue *enumValueToWrite =
reinterpret_cast<QV4::CompiledData::EnumValue*>(enumPtr +
sizeof(*enumToWrite));
1996 for (EnumValue *enumValue = e->enumValues->first; enumValue; enumValue = enumValue->next, ++enumValueToWrite)
1997 *enumValueToWrite = *enumValue;
1999 int size = QV4::CompiledData::Enum::calculateSize(e->enumValues->count);
2003 quint32_le *namedObjectInComponentPtr =
reinterpret_cast<quint32_le *>(objectPtr + objectToWrite->offsetToNamedObjectsInComponent);
2004 for (
int i = 0; i < o->namedObjectsInComponent.size(); ++i) {
2005 *namedObjectInComponentPtr++ = o->namedObjectsInComponent.at(i);
2008 char *inlineComponentPtr = objectPtr + objectToWrite->offsetToInlineComponents;
2009 for (
auto it = o->inlineComponentsBegin(); it != o->inlineComponentsEnd(); ++it) {
2010 const InlineComponent *ic = it.ptr;
2011 QV4::CompiledData::InlineComponent *icToWrite =
reinterpret_cast<QV4::CompiledData::InlineComponent*>(inlineComponentPtr);
2013 inlineComponentPtr +=
sizeof(QV4::CompiledData::InlineComponent);
2016 char *requiredPropertyExtraDataPtr = objectPtr + objectToWrite->offsetToRequiredPropertyExtraData;
2017 for (
auto it = o->requiredPropertyExtraDataBegin(); it != o->requiredPropertyExtraDataEnd(); ++it) {
2018 const RequiredPropertyExtraData *extraData = it.ptr;
2019 QV4::CompiledData::RequiredPropertyExtraData *extraDataToWrite =
reinterpret_cast<QV4::CompiledData::RequiredPropertyExtraData*>(requiredPropertyExtraDataPtr);
2020 *extraDataToWrite = *extraData;
2021 requiredPropertyExtraDataPtr +=
sizeof(QV4::CompiledData::RequiredPropertyExtraData);
2025 if (!output.javaScriptCompilationUnit->unitData()) {
2027 jsUnit =
static_cast<QV4::CompiledData::Unit *>(realloc(jsUnit, jsUnit->unitSize + totalSize));
2028 jsUnit->offsetToQmlUnit = jsUnit->unitSize;
2029 jsUnit->unitSize += totalSize;
2030 memcpy(jsUnit->qmlUnit(), qmlUnit, totalSize);
2032 QV4::Compiler::JSUnitGenerator::generateUnitChecksum(jsUnit);
2033 qmlUnit = jsUnit->qmlUnit();
2036 static const bool showStats = qEnvironmentVariableIsSet(
"QML_SHOW_UNIT_STATS");
2038 qDebug() <<
"Generated QML unit that is" << totalSize <<
"bytes big contains:";
2039 qDebug() <<
" " << jsUnit->functionTableSize <<
"functions";
2040 qDebug() <<
" " << jsUnit->unitSize <<
"for JS unit";
2041 qDebug() <<
" " << importSize <<
"for imports";
2042 qDebug() <<
" " << nextOffset - objectOffset - objectOffsetTableSize <<
"for" << qmlUnit->nObjects <<
"objects";
2043 quint32 totalBindingCount = 0;
2044 for (quint32 i = 0; i < qmlUnit->nObjects; ++i)
2045 totalBindingCount += qmlUnit->objectAt(i)->nBindings;
2046 qDebug() <<
" " << totalBindingCount <<
"bindings";
2047 quint32 totalCodeSize = 0;
2048 for (quint32 i = 0; i < jsUnit->functionTableSize; ++i)
2049 totalCodeSize += jsUnit->functionAt(i)->codeSize;
2050 qDebug() <<
" " << totalCodeSize <<
"bytes total byte code";
2051 qDebug() <<
" " << jsUnit->stringTableSize <<
"strings";
2052 quint32 totalStringSize = 0;
2053 for (quint32 i = 0; i < jsUnit->stringTableSize; ++i)
2054 totalStringSize += QV4::CompiledData::String::calculateSize(jsUnit->stringAtInternal(i));
2055 qDebug() <<
" " << totalStringSize <<
"bytes total strings";
2058 output.javaScriptCompilationUnit->setUnitData(
2059 jsUnit, qmlUnit, output.jsModule.fileName, output.jsModule.finalUrl);