Scanner
Creates custom dependency scanners in modules. More...
Properties
- condition : bool
- inputs : stringList
- recursive : bool
- scan : script
- searchPaths : script
Detailed Description
A Scanner item can appear inside a Module item, and allows to extract dependencies for artifacts from the artifacts' file contents. For example, this is what a scanner for "qrc" files might look like:
import qbs.Xml Module { Scanner { inputs: 'qrc' scan: { var xml = new Xml.DomDocument(input.filePath); dependencies = []; // retrieve <file> entries from the XML document return dependencies; } } }
Property Documentation
condition : bool |
If true
, the scanner is enabled, otherwise it does nothing.
Default: true
inputs : stringList |
A list of file tags the input artifacts must match.
Default: Undefined
recursive : bool |
Determines whether to scan the returned dependencies using the same scanner.
Default: false
scan : script |
A script that reads the input artifact and returns a string list with dependencies.
The code in this script is treated as a function with the signature function(project, product, input, filePath)
, where input
is the artifact at which the scan originated, and filePath
is the currently scanned file. For non-recursive scans, filePath
is always equal to input.filePath
.
Default: Undefined
searchPaths : script |
A script that returns the paths where to look for dependencies.
The code in this script is treated as a function with the signature function(project, product, input)
.
Default: Undefined