Merge remote-tracking branch 'origin/master' into api_changes
[profile/ivi/qtbase.git] / src / src.pro
1 TEMPLATE = subdirs
2
3 # this order is important
4 unset(SRC_SUBDIRS)
5 win32:SRC_SUBDIRS += src_winmain
6 !wince*:include(tools/tools.pro)
7 SRC_SUBDIRS += src_corelib
8 SRC_SUBDIRS += src_network src_sql src_gui src_xml src_widgets src_testlib src_platformsupport
9 !wince*:SRC_SUBDIRS += src_printsupport
10 nacl: SRC_SUBDIRS -= src_network src_testlib
11 contains(QT_CONFIG, dbus):SRC_SUBDIRS += src_dbus
12 contains(QT_CONFIG, concurrent):SRC_SUBDIRS += src_concurrent
13
14 contains(QT_CONFIG, no-gui): SRC_SUBDIRS -= src_gui
15
16 contains(QT_CONFIG, opengl)|contains(QT_CONFIG, opengles1)|contains(QT_CONFIG, opengles2): SRC_SUBDIRS += src_opengl
17 SRC_SUBDIRS += src_plugins
18
19 src_winmain.subdir = $$QT_SOURCE_TREE/src/winmain
20 src_winmain.target = sub-winmain
21 src_corelib.subdir = $$QT_SOURCE_TREE/src/corelib
22 src_corelib.target = sub-corelib
23 src_xml.subdir = $$QT_SOURCE_TREE/src/xml
24 src_xml.target = sub-xml
25 src_dbus.subdir = $$QT_SOURCE_TREE/src/dbus
26 src_dbus.target = sub-dbus
27 src_gui.subdir = $$QT_SOURCE_TREE/src/gui
28 src_gui.target = sub-gui
29 src_sql.subdir = $$QT_SOURCE_TREE/src/sql
30 src_sql.target = sub-sql
31 src_network.subdir = $$QT_SOURCE_TREE/src/network
32 src_network.target = sub-network
33 src_opengl.subdir = $$QT_SOURCE_TREE/src/opengl
34 src_opengl.target = sub-opengl
35 src_plugins.subdir = $$QT_SOURCE_TREE/src/plugins
36 src_plugins.target = sub-plugins
37 src_widgets.subdir = $$QT_SOURCE_TREE/src/widgets
38 src_widgets.target = sub-widgets
39 !wince*: {
40     src_printsupport.subdir = $$QT_SOURCE_TREE/src/printsupport
41     src_printsupport.target = sub-printsupport
42 }
43 src_testlib.subdir = $$QT_SOURCE_TREE/src/testlib
44 src_testlib.target = sub-testlib
45 src_platformsupport.subdir = $$QT_SOURCE_TREE/src/platformsupport
46 src_platformsupport.target = sub-platformsupport
47 src_concurrent.subdir = $$QT_SOURCE_TREE/src/concurrent
48 src_concurrent.target = sub-concurrent
49
50
51 #CONFIG += ordered
52 !wince*:!ordered {
53    src_corelib.depends = src_tools_moc src_tools_rcc
54    src_gui.depends = src_corelib
55    src_printsupport.depends = src_corelib src_gui src_widgets
56    src_platformsupport.depends = src_corelib src_gui src_network
57    src_widgets.depends = src_corelib src_gui src_tools_uic
58    src_xml.depends = src_corelib
59    src_concurrent.depends = src_corelib
60    src_dbus.depends = src_corelib
61    src_network.depends = src_corelib
62    src_opengl.depends = src_gui src_widgets
63    src_sql.depends = src_corelib
64    src_testlib.depends = src_corelib src_gui src_widgets
65    src_plugins.depends = src_gui src_sql src_xml
66    qpa: src_plugins.depends = src_platformsupport
67    contains(QT_CONFIG, opengl)|contains(QT_CONFIG, opengles1)|contains(QT_CONFIG, opengles2) {
68       src_plugins.depends += src_opengl
69       src_declarative.depends += src_opengl
70       src_webkit.depends += src_opengl
71    }
72 }
73
74
75 # This creates a sub-src rule
76 sub_src_target.CONFIG = recursive
77 sub_src_target.recurse = $$TOOLS_SUBDIRS $$SRC_SUBDIRS
78 sub_src_target.target = sub-src
79 sub_src_target.recurse_target =
80 QMAKE_EXTRA_TARGETS += sub_src_target
81
82 # This gives us a top level debug/release
83 for(subname, SRC_SUBDIRS) {
84    subdir = $$subname
85    !isEmpty($${subname}.subdir):subdir = $$eval($${subname}.subdir)
86    subpro = $$subdir/$${basename(subdir)}.pro
87    !exists($$subpro):next()
88    subtarget = $$replace(subdir, [^A-Za-z0-9], _)
89    reg_src = $$replace(QT_SOURCE_TREE, \\\\, \\\\)
90    subdir = $$replace(subdir, $$reg_src, $$QT_BUILD_TREE)
91    subdir = $$replace(subdir, /, $$QMAKE_DIR_SEP)
92    subdir = $$replace(subdir, \\\\, $$QMAKE_DIR_SEP)
93    include($$subpro, SUB)
94    !isEqual(subname, src_tools_bootstrap):if(isEqual(SUB.TEMPLATE, lib) | isEqual(SUB.TEMPLATE, subdirs)):!separate_debug_info {
95        #debug
96        debug-$${subtarget}.depends = $${subdir}$${QMAKE_DIR_SEP}$(MAKEFILE) $$EXTRA_DEBUG_TARGETS
97        debug-$${subtarget}.commands = (cd $$subdir && $(MAKE) -f $(MAKEFILE) debug)
98        EXTRA_DEBUG_TARGETS += debug-$${subtarget}
99        QMAKE_EXTRA_TARGETS += debug-$${subtarget}
100        #release
101        release-$${subtarget}.depends = $${subdir}$${QMAKE_DIR_SEP}$(MAKEFILE) $$EXTRA_RELEASE_TARGETS
102        release-$${subtarget}.commands = (cd $$subdir && $(MAKE) -f $(MAKEFILE) release)
103        EXTRA_RELEASE_TARGETS += release-$${subtarget}
104        QMAKE_EXTRA_TARGETS += release-$${subtarget}
105     } else { #do not have a real debug target/release
106        #debug
107        debug-$${subtarget}.depends = $${subdir}$${QMAKE_DIR_SEP}$(MAKEFILE) $$EXTRA_DEBUG_TARGETS
108        debug-$${subtarget}.commands = (cd $$subdir && $(MAKE) -f $(MAKEFILE) first)
109        EXTRA_DEBUG_TARGETS += debug-$${subtarget}
110        QMAKE_EXTRA_TARGETS += debug-$${subtarget}
111        #release
112        release-$${subtarget}.depends = $${subdir}$${QMAKE_DIR_SEP}$(MAKEFILE) $$EXTRA_RELEASE_TARGETS
113        release-$${subtarget}.commands = (cd $$subdir && $(MAKE) -f $(MAKEFILE) first)
114        EXTRA_RELEASE_TARGETS += release-$${subtarget}
115        QMAKE_EXTRA_TARGETS += release-$${subtarget}
116    }
117 }
118 debug.depends = $$EXTRA_DEBUG_TARGETS
119 release.depends = $$EXTRA_RELEASE_TARGETS
120 QMAKE_EXTRA_TARGETS += debug release
121
122 SUBDIRS += $$SRC_SUBDIRS