QtQml.qtqml-modules-legacymodules

Legacy modules are modules whose specification qmldir file does not contain a module identifier directive. A legacy module may be either installed into the QML import path (as an installed legacy module) or imported by clients with a relative import (as a located legacy module). Clients are advised to avoid using legacy modules if possible. Module developers should ensure they create identified modules and not legacy modules.

Installed Legacy Modules

An installed, non-identified module is automatically given an identifier by the QML engine. This implicitly defined identifier is equal to the install path of the module (relative to the QML import path) where directory-separator characters are replaced with period characters.

A non-identified module which is installed into the QML import path has the following semantics:

  • it may be imported by clients via the implicit module identifier
  • clients must specify a version when importing the module
  • conflicting type names are resolved arbitrarily by the QML engine, and the way in which conflicts are resolved is not guaranteed to stay the same between different versions of QML
  • other legacy modules may modify or override type definitions provided by the installed legacy module

Located Legacy Modules

A non-identified module which is imported via a relative directory path import statement is loaded by the engine as a located legacy module. The following semantics apply to located legacy modules:

  • it may be imported by clients via a relative import path
  • it is not mandatory for clients to specify a version when importing the module
  • if no import version is supplied by the client in the import statement, no guarantees are given by the QML engine about which version of the definition of a given type name will be imported
  • conflicting type names are resolved arbitrarily by the QML engine, and the way in which conflicts are resolved is not guaranteed to stay the same between different versions of QML
  • other legacy modules may modify or override type definitions provided by the located legacy module

A located legacy module may reside on the local file system or on the network and can be referred to by a URL that specifies the file system path or network URL.