aboutsummaryrefslogtreecommitdiffstats
path: root/doc/reference/items/transformer.qdoc
blob: 68e34a0b1d98673f0659505028a73c7d80186e9e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
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
/****************************************************************************
**
** Copyright (C) 2015 The Qt Company Ltd.
** Contact: http://www.qt.io/licensing
**
** This file is part of the Qt Build Suite.
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms and
** conditions see http://www.qt.io/terms-conditions. For further information
** use the contact form at http://www.qt.io/contact-us.
**
** GNU Lesser General Public License Usage
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 2.1 or version 3 as published by the Free
** Software Foundation and appearing in the file LICENSE.LGPLv21 and
** LICENSE.LGPLv3 included in the packaging of this file.  Please review the
** following information to ensure the GNU Lesser General Public License
** requirements will be met: https://www.gnu.org/licenses/lgpl.html and
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, The Qt Company gives you certain additional
** rights.  These rights are described in The Qt Company LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
****************************************************************************/
/*!
    \contentspage list-of-items.html
    \page transformer-item.html
    \previouspage subproject-item.html
    \nextpage xpcservice-item.html
    \ingroup list-of-items

    \title Transformer Item
    \brief Creates files, typically from other files.

    A \e transformer takes zero or more inputs and produces one or more output artifacts
    from them. The following transformer creates one output file from one input file:
    \code
    Transformer {
        inputs: "raw_input.txt"
        Artifact {
            filePath: "processed_input.txt"
            fileTags: "processed_file"
        }
        prepare: {
            var cmd = new JavaScriptCommand();
            cmd.description = "Processing '" + input.filePath + "'";
            cmd.highlight = "codegen";
            cmd.sourceCode = function() {
                var file = new TextFile(input.filePath);
                var content = file.readAll();
                file.close()
                content = content.replace(/\r\n/g, "\n");
                file = new TextFile(output.filePath, TextFile.WriteOnly);
                file.truncate();
                file.write(content);
                file.close();
            }
            return cmd;
        }
    }
    \endcode
    This example exhibits some interesting features of transformers:
    \list
        \li If there is only one input file, the property \c input is available as syntactic sugar
            for \c inputs[0].
        \li The filenames of the output artifacts are available as \c outputs. If there is only one
            of these, it can be referred to it as \c output.
    \endlist

    A \c Transformer is always attached to a \c Product, possibly indirectly via a \c Module.

    \section1 Transformer Properties

    \table
    \header
        \li Property
        \li Type
        \li Default
        \li Description
    \row
        \li inputs
        \li stringList
        \li empty list
        \li The list of inputs to the transformer.
    \row
        \li prepare
        \li list of Javascript commands
        \li empty list
        \li The commands that the transformer runs. These typically read from the input files and
            write to the output files in some way.
    \row
        \li condition
        \li bool
        \li true
        \li If true, the transformer is enabled, otherwise it does nothing.
    \row
        \li explicitlyDependsOn
        \li stringList
        \li \c{undefined}
        \li A list of file tags. All output artifacts of this transformer will have a dependency
            to all artifacts with the given file tags.
    \row
        \li alwaysRun
        \li bool
        \li false
        \li If true, the transformer's commands are always executed, even if all output artifacts
            are up to date.
    \endtable

*/