Syntax
This warning category is spelled [syntax]
by qmllint.
Nested inline components are not supported
What happened?
You defined an inline component inside another inline component.
Why is this bad?
The QML language does not allow nested inline components. Always define inline components inside the root item of the QML file.
Example
import QtQuick Item { component Correct: Item { component Evil: Item { ... } ... } }
To fix this warning, move all components to the root item of the QML file.
import QtQuick Item { component NotEvilAnymore: Item { ... } component Correct: Item { ... } }
Inline component declaration must be followed by a typename
What happened?
You defined an inline component with an invalid base type.
Why is this bad?
Inline components need a base type to inherit from.
Example
import QtQuick Item { property Item someProperty component InlineComponent: someProperty {} }
In this case, someProperty
is not a valid type name, as it is a property name. To fix this warning, use a valid Type as the component's base type:
import QtQuick Item { property Item someProperty component InlineComponent: Item { ... } }
Invalid alias expression: an initializer is needed
What happened?
You defined a property alias without its aliased property.
Why is this bad?
Alias properties always need to have their aliased property or id in their definition.
Example
import QtQuick Item { id: root property int someProperty property alias aliasProperty }
To fix this warning, replace the alias with a normal property, or add the missing aliased property:
import QtQuick Item { id: root property int someProperty property alias withAliasedProperty: root.someProperty }
Invalid alias expression: only ids and field member expressions can be aliased
What happened?
You defined a property alias that aliases an expression other than an ID or a field member expression.
A field member expression is an expression of the form someId.someProperty
.
Why is this bad?
Alias properties always need to have their aliased property in their definition, and can't bind to other expressions than IDs and field member expressions.
Example
import QtQuick Item { property int p property alias someProperty: p + 1 }
To fix this warning, replace the alias with a normal property or bind it to an id or field member expression:
import QtQuick Item { id: root property int p property int someProperty: p + 1 property alias alternative: root.p }
Id must be followed by an identifier
What happened?
You defined an id without a value.
Why is this bad?
The QML language does not allow empty ids.
Example
import QtQuick Item { id:; }
To fix this warning, bind the id to a valid name:
import QtQuick Item { id: root; }
Failed to parse id
What happened?
You bound an id to an expression other than a name.
Why is this bad?
The QML language only allows names as bindings to ids; more complex expressions can't be used.
Example
import QtQuick Item { property int a property int b function f() { if (true) return a return b } id: f() }
To fix this warning, bind the id to a valid name or declare a property and set up a binding:
import QtQuick Item { property int a property int b function f() { if (true) return a return b } id: someItem // it would be confusing to call it `f` like the function property int alternative: f() }
Declaring an object which is not a QML object as a list member
What happened?
You added an expression other than an object into a list of objects.
Why is this bad?
The QML language only allows objects in object lists.
Example
import QtQuick Item { property int hello property list<Item> myList: [ Item {}, hello{} ] }
To fix this warning, use a valid object type, or remove the item from the list:
import QtQuick Item { component Hello: Item {} property list<Item> myList: [ Item {}, Hello{} ] }
Enums declared inside of inline components are ignored
What happened?
You defined an enum inside an inline component.
Why is this bad?
The QML language only allows enum definitions inside the root item of the QML file. Enums declared inside an inline component are unusable, even inside the inline component. The same applies to enums declared inside non-root QML objects.
Example
import QtQuick Item { component MyInlineComponent: Item { enum MyEnum { Hello, World } } }
To fix this warning, move the enum declaration into the root element of the QML file:
import QtQuick Item { enum MyEnum { Hello, World } component MyInlineComponent: Item { } }
Unknown argument to pragma
What happened?
You specified an invalid argument to a pragma.
Why is this bad?
The pragma will have no effect.
Example
pragma ComponentBehavior: Buond
import QtQuick
Item {
}
You can fix this warning by removing the pragma or fixing a potential typo:
pragma ComponentBehavior: Bound
import QtQuick
Item {
}