aboutsummaryrefslogtreecommitdiffstats
path: root/doc/reference/items/transformer.qdoc
blob: 93e257b716169edeb8f576f320c3e8ab4bdeda83 (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
/****************************************************************************
**
** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
** Contact: http://www.qt-project.org/legal
**
** 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 Digia.  For licensing terms and
** conditions see http://qt.digia.com/licensing.  For further information
** use the contact form at http://qt.digia.com/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 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file.  Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Digia gives you certain additional
** rights.  These rights are described in the Digia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
****************************************************************************/
/*!
    \contentspage list-of-items.html
    \previouspage subproject-item.html
    \page transformer-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 {
            fileName: "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.
    \endtable

*/