summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--qmake/generators/unix/unixmake2.cpp1
1 files changed, 1 insertions, 0 deletions
diff --git a/qmake/generators/unix/unixmake2.cpp b/qmake/generators/unix/unixmake2.cpp
index 7fbb9f4..d8a4a0d 100644
--- a/qmake/generators/unix/unixmake2.cpp
+++ b/qmake/generators/unix/unixmake2.cpp
@@ -1,1109 +1,1110 @@
1/**************************************************************************** 1/****************************************************************************
2** $Id$ 2** $Id$
3** 3**
4** Definition of ________ class. 4** Definition of ________ class.
5** 5**
6** Created : 970521 6** Created : 970521
7** 7**
8** Copyright (C) 1992-2002 Trolltech AS. All rights reserved. 8** Copyright (C) 1992-2002 Trolltech AS. All rights reserved.
9** 9**
10** This file is part of the network module of the Qt GUI Toolkit. 10** This file is part of the network module of the Qt GUI Toolkit.
11** 11**
12** This file may be distributed under the terms of the Q Public License 12** This file may be distributed under the terms of the Q Public License
13** as defined by Trolltech AS of Norway and appearing in the file 13** as defined by Trolltech AS of Norway and appearing in the file
14** LICENSE.QPL included in the packaging of this file. 14** LICENSE.QPL included in the packaging of this file.
15** 15**
16** This file may be distributed and/or modified under the terms of the 16** This file may be distributed and/or modified under the terms of the
17** GNU General Public License version 2 as published by the Free Software 17** GNU General Public License version 2 as published by the Free Software
18** Foundation and appearing in the file LICENSE.GPL included in the 18** Foundation and appearing in the file LICENSE.GPL included in the
19** packaging of this file. 19** packaging of this file.
20** 20**
21** Licensees holding valid Qt Enterprise Edition licenses may use this 21** Licensees holding valid Qt Enterprise Edition licenses may use this
22** file in accordance with the Qt Commercial License Agreement provided 22** file in accordance with the Qt Commercial License Agreement provided
23** with the Software. 23** with the Software.
24** 24**
25** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 25** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
26** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 26** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
27** 27**
28** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for 28** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for
29** information about Qt Commercial License Agreements. 29** information about Qt Commercial License Agreements.
30** See http://www.trolltech.com/qpl/ for QPL licensing information. 30** See http://www.trolltech.com/qpl/ for QPL licensing information.
31** See http://www.trolltech.com/gpl/ for GPL licensing information. 31** See http://www.trolltech.com/gpl/ for GPL licensing information.
32** 32**
33** Contact info@trolltech.com if any conditions of this licensing are 33** Contact info@trolltech.com if any conditions of this licensing are
34** not clear to you. 34** not clear to you.
35** 35**
36**********************************************************************/ 36**********************************************************************/
37 37
38#include "unixmake.h" 38#include "unixmake.h"
39#include "option.h" 39#include "option.h"
40#include <qregexp.h> 40#include <qregexp.h>
41#include <qfile.h> 41#include <qfile.h>
42#include <qdir.h> 42#include <qdir.h>
43#include <time.h> 43#include <time.h>
44 44
45 45
46UnixMakefileGenerator::UnixMakefileGenerator(QMakeProject *p) : MakefileGenerator(p), init_flag(FALSE), include_deps(FALSE) 46UnixMakefileGenerator::UnixMakefileGenerator(QMakeProject *p) : MakefileGenerator(p), init_flag(FALSE), include_deps(FALSE)
47{ 47{
48 48
49} 49}
50 50
51bool 51bool
52UnixMakefileGenerator::writeMakefile(QTextStream &t) 52UnixMakefileGenerator::writeMakefile(QTextStream &t)
53{ 53{
54 writeHeader(t); 54 writeHeader(t);
55 if(!project->variables()["QMAKE_FAILED_REQUIREMENTS"].isEmpty()) { 55 if(!project->variables()["QMAKE_FAILED_REQUIREMENTS"].isEmpty()) {
56 t << "all clean:" << "\n\t" 56 t << "all clean:" << "\n\t"
57 << "@echo \"Some of the required modules (" 57 << "@echo \"Some of the required modules ("
58 << var("QMAKE_FAILED_REQUIREMENTS") << ") are not available.\"" << "\n\t" 58 << var("QMAKE_FAILED_REQUIREMENTS") << ") are not available.\"" << "\n\t"
59 << "@echo \"Skipped.\"" << endl << endl; 59 << "@echo \"Skipped.\"" << endl << endl;
60 writeMakeQmake(t); 60 writeMakeQmake(t);
61 return TRUE; 61 return TRUE;
62 } 62 }
63 63
64 if (project->variables()["TEMPLATE"].first() == "app" || 64 if (project->variables()["TEMPLATE"].first() == "app" ||
65 project->variables()["TEMPLATE"].first() == "lib") { 65 project->variables()["TEMPLATE"].first() == "lib") {
66 writeMakeParts(t); 66 writeMakeParts(t);
67 return MakefileGenerator::writeMakefile(t); 67 return MakefileGenerator::writeMakefile(t);
68 } else if(project->variables()["TEMPLATE"].first() == "subdirs") { 68 } else if(project->variables()["TEMPLATE"].first() == "subdirs") {
69 writeSubdirs(t); 69 writeSubdirs(t);
70 return TRUE; 70 return TRUE;
71 } 71 }
72 return FALSE; 72 return FALSE;
73} 73}
74 74
75void 75void
76UnixMakefileGenerator::writeMakeParts(QTextStream &t) 76UnixMakefileGenerator::writeMakeParts(QTextStream &t)
77{ 77{
78 QString deps = fileFixify(Option::output.name()), prl; 78 QString deps = fileFixify(Option::output.name()), prl;
79 bool do_incremental = (project->isActiveConfig("incremental") && 79 bool do_incremental = (project->isActiveConfig("incremental") &&
80 !project->variables()["QMAKE_INCREMENTAL"].isEmpty() && 80 !project->variables()["QMAKE_INCREMENTAL"].isEmpty() &&
81 (!project->variables()["QMAKE_APP_FLAG"].isEmpty() || 81 (!project->variables()["QMAKE_APP_FLAG"].isEmpty() ||
82 !project->isActiveConfig("staticlib"))), 82 !project->isActiveConfig("staticlib"))),
83 src_incremental=FALSE, moc_incremental=FALSE; 83 src_incremental=FALSE, moc_incremental=FALSE;
84 84
85 t << "####### Compiler, tools and options" << endl << endl; 85 t << "####### Compiler, tools and options" << endl << endl;
86 t << "CC = "; 86 t << "CC = ";
87 if (project->isActiveConfig("thread") && 87 if (project->isActiveConfig("thread") &&
88 ! project->variables()["QMAKE_CC_THREAD"].isEmpty()) 88 ! project->variables()["QMAKE_CC_THREAD"].isEmpty())
89 t << var("QMAKE_CC_THREAD") << endl; 89 t << var("QMAKE_CC_THREAD") << endl;
90 else 90 else
91 t << var("QMAKE_CC") << endl; 91 t << var("QMAKE_CC") << endl;
92 92
93 t << "CXX = "; 93 t << "CXX = ";
94 if (project->isActiveConfig("thread") && 94 if (project->isActiveConfig("thread") &&
95 ! project->variables()["QMAKE_CXX_THREAD"].isEmpty()) 95 ! project->variables()["QMAKE_CXX_THREAD"].isEmpty())
96 t << var("QMAKE_CXX_THREAD") << endl; 96 t << var("QMAKE_CXX_THREAD") << endl;
97 else 97 else
98 t << var("QMAKE_CXX") << endl; 98 t << var("QMAKE_CXX") << endl;
99 99
100 t << "LEX = " << var("QMAKE_LEX") << endl; 100 t << "LEX = " << var("QMAKE_LEX") << endl;
101 t << "YACC = " << var("QMAKE_YACC") << endl; 101 t << "YACC = " << var("QMAKE_YACC") << endl;
102 t << "CFLAGS = " << var("QMAKE_CFLAGS") << " " 102 t << "CFLAGS = " << var("QMAKE_CFLAGS") << " "
103 << varGlue("PRL_EXPORT_DEFINES","-D"," -D","") << " " 103 << varGlue("PRL_EXPORT_DEFINES","-D"," -D","") << " "
104 << varGlue("DEFINES","-D"," -D","") << endl; 104 << varGlue("DEFINES","-D"," -D","") << endl;
105 t << "CXXFLAGS = " << var("QMAKE_CXXFLAGS") << " " 105 t << "CXXFLAGS = " << var("QMAKE_CXXFLAGS") << " "
106 << varGlue("PRL_EXPORT_DEFINES","-D"," -D","") << " " 106 << varGlue("PRL_EXPORT_DEFINES","-D"," -D","") << " "
107 << varGlue("DEFINES","-D"," -D","") << endl; 107 << varGlue("DEFINES","-D"," -D","") << endl;
108 t << "LEXFLAGS = " << var("QMAKE_LEXFLAGS") << endl; 108 t << "LEXFLAGS = " << var("QMAKE_LEXFLAGS") << endl;
109 t << "YACCFLAGS= " << var("QMAKE_YACCFLAGS") << endl; 109 t << "YACCFLAGS= " << var("QMAKE_YACCFLAGS") << endl;
110 t << "INCPATH = " << "-I" << specdir(); 110 t << "INCPATH = " << "-I" << specdir();
111 if(!project->isActiveConfig("no_include_pwd")) { 111 if(!project->isActiveConfig("no_include_pwd")) {
112 QString pwd = fileFixify(QDir::currentDirPath()); 112 QString pwd = fileFixify(QDir::currentDirPath());
113 if(pwd.isEmpty()) 113 if(pwd.isEmpty())
114 pwd = "."; 114 pwd = ".";
115 t << " -I" << pwd; 115 t << " -I" << pwd;
116 } 116 }
117 t << varGlue("INCLUDEPATH"," -I", " -I", "") << endl; 117 t << varGlue("INCLUDEPATH"," -I", " -I", "") << endl;
118 118
119 if(!project->isActiveConfig("staticlib")) { 119 if(!project->isActiveConfig("staticlib")) {
120 t << "LINK = "; 120 t << "LINK = ";
121 if (project->isActiveConfig("thread") && 121 if (project->isActiveConfig("thread") &&
122 ! project->variables()["QMAKE_LINK_THREAD"].isEmpty()) 122 ! project->variables()["QMAKE_LINK_THREAD"].isEmpty())
123 t << var("QMAKE_LINK_THREAD") << endl; 123 t << var("QMAKE_LINK_THREAD") << endl;
124 else 124 else
125 t << var("QMAKE_LINK") << endl; 125 t << var("QMAKE_LINK") << endl;
126 126
127 t << "LFLAGS = " << var("QMAKE_LFLAGS") << endl; 127 t << "LFLAGS = " << var("QMAKE_LFLAGS") << endl;
128 t << "LIBS = " << "$(SUBLIBS) " << var("QMAKE_LIBDIR_FLAGS") << " " << var("QMAKE_LIBS") << endl; 128 t << "LIBS = " << "$(SUBLIBS) " << var("QMAKE_LIBDIR_FLAGS") << " " << var("QMAKE_LIBS") << endl;
129 } 129 }
130 130
131 t << "AR = " << var("QMAKE_AR") << endl; 131 t << "AR = " << var("QMAKE_AR") << endl;
132 t << "RANLIB = " << var("QMAKE_RANLIB") << endl; 132 t << "RANLIB = " << var("QMAKE_RANLIB") << endl;
133 t << "MOC = " << var("QMAKE_MOC") << endl; 133 t << "MOC = " << var("QMAKE_MOC") << endl;
134 t << "UIC = "<< var("QMAKE_UIC") << endl; 134 t << "UIC = "<< var("QMAKE_UIC") << endl;
135 t << "QMAKE = "<< (project->isEmpty("QMAKE_QMAKE") ? QString("qmake") : var("QMAKE_QMAKE")) << endl; 135 t << "QMAKE = "<< (project->isEmpty("QMAKE_QMAKE") ? QString("qmake") : var("QMAKE_QMAKE")) << endl;
136 t << "TAR = "<< var("QMAKE_TAR") << endl; 136 t << "TAR = "<< var("QMAKE_TAR") << endl;
137 t << "GZIP = " << var("QMAKE_GZIP") << endl; 137 t << "GZIP = " << var("QMAKE_GZIP") << endl;
138 t << "COPY = " << var("QMAKE_COPY") << endl; 138 t << "COPY = " << var("QMAKE_COPY") << endl;
139 t << "COPY_FILE= " << var("QMAKE_COPY_FILE") << endl; 139 t << "COPY_FILE= " << var("QMAKE_COPY_FILE") << endl;
140 t << "COPY_DIR = " << var("QMAKE_COPY_DIR") << endl; 140 t << "COPY_DIR = " << var("QMAKE_COPY_DIR") << endl;
141 t << "DEL_FILE = " << var("QMAKE_DEL_FILE") << endl; 141 t << "DEL_FILE = " << var("QMAKE_DEL_FILE") << endl;
142 t << "SYMLINK = " << var("QMAKE_SYMBOLIC_LINK") << endl; 142 t << "SYMLINK = " << var("QMAKE_SYMBOLIC_LINK") << endl;
143 t << "DEL_DIR = " << var("QMAKE_DEL_DIR") << endl; 143 t << "DEL_DIR = " << var("QMAKE_DEL_DIR") << endl;
144 t << "MOVE = " << var("QMAKE_MOVE") << endl; 144 t << "MOVE = " << var("QMAKE_MOVE") << endl;
145 t << "PRO = " << fileFixify(project->projectFile() )<< endl;
145 t << "CHK_DIR_EXISTS= " << var("QMAKE_CHK_DIR_EXISTS") << endl; 146 t << "CHK_DIR_EXISTS= " << var("QMAKE_CHK_DIR_EXISTS") << endl;
146 t << "MKDIR = " << var("QMAKE_MKDIR") << endl; 147 t << "MKDIR = " << var("QMAKE_MKDIR") << endl;
147 t << endl; 148 t << endl;
148 149
149 t << "####### Output directory" << endl << endl; 150 t << "####### Output directory" << endl << endl;
150 if (! project->variables()["OBJECTS_DIR"].isEmpty()) 151 if (! project->variables()["OBJECTS_DIR"].isEmpty())
151 t << "OBJECTS_DIR = " << var("OBJECTS_DIR") << endl; 152 t << "OBJECTS_DIR = " << var("OBJECTS_DIR") << endl;
152 else 153 else
153 t << "OBJECTS_DIR = ./" << endl; 154 t << "OBJECTS_DIR = ./" << endl;
154 t << endl; 155 t << endl;
155 156
156 /* files */ 157 /* files */
157 t << "####### Files" << endl << endl; 158 t << "####### Files" << endl << endl;
158 t << "HEADERS = " << varList("HEADERS") << endl; 159 t << "HEADERS = " << varList("HEADERS") << endl;
159 t << "SOURCES = " << varList("SOURCES") << endl; 160 t << "SOURCES = " << varList("SOURCES") << endl;
160 if(do_incremental) { 161 if(do_incremental) {
161 QStringList &objs = project->variables()["OBJECTS"], &incrs = project->variables()["QMAKE_INCREMENTAL"], incrs_out; 162 QStringList &objs = project->variables()["OBJECTS"], &incrs = project->variables()["QMAKE_INCREMENTAL"], incrs_out;
162 t << "OBJECTS = "; 163 t << "OBJECTS = ";
163 for(QStringList::Iterator objit = objs.begin(); objit != objs.end(); ++objit) { 164 for(QStringList::Iterator objit = objs.begin(); objit != objs.end(); ++objit) {
164 bool increment = FALSE; 165 bool increment = FALSE;
165 for(QStringList::Iterator incrit = incrs.begin(); incrit != incrs.end(); ++incrit) { 166 for(QStringList::Iterator incrit = incrs.begin(); incrit != incrs.end(); ++incrit) {
166 if((*objit).find(QRegExp((*incrit), TRUE, TRUE)) != -1) { 167 if((*objit).find(QRegExp((*incrit), TRUE, TRUE)) != -1) {
167 increment = TRUE; 168 increment = TRUE;
168 incrs_out.append((*objit)); 169 incrs_out.append((*objit));
169 break; 170 break;
170 } 171 }
171 } 172 }
172 if(!increment) 173 if(!increment)
173 t << "\\\n\t\t" << (*objit); 174 t << "\\\n\t\t" << (*objit);
174 } 175 }
175 if(incrs_out.count() == objs.count()) { //we just switched places, no real incrementals to be done! 176 if(incrs_out.count() == objs.count()) { //we just switched places, no real incrementals to be done!
176 t << incrs_out.join(" \\\n\t\t") << endl; 177 t << incrs_out.join(" \\\n\t\t") << endl;
177 } else if(!incrs_out.count()) { 178 } else if(!incrs_out.count()) {
178 t << endl; 179 t << endl;
179 } else { 180 } else {
180 src_incremental = TRUE; 181 src_incremental = TRUE;
181 t << endl; 182 t << endl;
182 t << "INCREMENTAL_OBJECTS = " << incrs_out.join(" \\\n\t\t") << endl; 183 t << "INCREMENTAL_OBJECTS = " << incrs_out.join(" \\\n\t\t") << endl;
183 } 184 }
184 } else { 185 } else {
185 t << "OBJECTS = " << varList("OBJECTS") << endl; 186 t << "OBJECTS = " << varList("OBJECTS") << endl;
186 } 187 }
187 t << "FORMS = " << varList("FORMS") << endl; 188 t << "FORMS = " << varList("FORMS") << endl;
188 t << "UICDECLS = " << varList("UICDECLS") << endl; 189 t << "UICDECLS = " << varList("UICDECLS") << endl;
189 t << "UICIMPLS = " << varList("UICIMPLS") << endl; 190 t << "UICIMPLS = " << varList("UICIMPLS") << endl;
190 QString srcMoc = varList("SRCMOC"), objMoc = varList("OBJMOC"); 191 QString srcMoc = varList("SRCMOC"), objMoc = varList("OBJMOC");
191 t << "SRCMOC = " << srcMoc << endl; 192 t << "SRCMOC = " << srcMoc << endl;
192 if(do_incremental) { 193 if(do_incremental) {
193 QStringList &objs = project->variables()["OBJMOC"], 194 QStringList &objs = project->variables()["OBJMOC"],
194 &incrs = project->variables()["QMAKE_INCREMENTAL"], incrs_out; 195 &incrs = project->variables()["QMAKE_INCREMENTAL"], incrs_out;
195 t << "OBJMOC = "; 196 t << "OBJMOC = ";
196 for(QStringList::Iterator objit = objs.begin(); objit != objs.end(); ++objit) { 197 for(QStringList::Iterator objit = objs.begin(); objit != objs.end(); ++objit) {
197 bool increment = FALSE; 198 bool increment = FALSE;
198 for(QStringList::Iterator incrit = incrs.begin(); incrit != incrs.end(); ++incrit) { 199 for(QStringList::Iterator incrit = incrs.begin(); incrit != incrs.end(); ++incrit) {
199 if((*objit).find(QRegExp((*incrit), TRUE, TRUE)) != -1) { 200 if((*objit).find(QRegExp((*incrit), TRUE, TRUE)) != -1) {
200 increment = TRUE; 201 increment = TRUE;
201 incrs_out.append((*objit)); 202 incrs_out.append((*objit));
202 break; 203 break;
203 } 204 }
204 } 205 }
205 if(!increment) 206 if(!increment)
206 t << "\\\n\t\t" << (*objit); 207 t << "\\\n\t\t" << (*objit);
207 } 208 }
208 if(incrs_out.count() == objs.count()) { //we just switched places, no real incrementals to be done! 209 if(incrs_out.count() == objs.count()) { //we just switched places, no real incrementals to be done!
209 t << incrs_out.join(" \\\n\t\t") << endl; 210 t << incrs_out.join(" \\\n\t\t") << endl;
210 } else if(!incrs_out.count()) { 211 } else if(!incrs_out.count()) {
211 t << endl; 212 t << endl;
212 } else { 213 } else {
213 moc_incremental = TRUE; 214 moc_incremental = TRUE;
214 t << endl; 215 t << endl;
215 t << "INCREMENTAL_OBJMOC = " << incrs_out.join(" \\\n\t\t") << endl; 216 t << "INCREMENTAL_OBJMOC = " << incrs_out.join(" \\\n\t\t") << endl;
216 } 217 }
217 } else { 218 } else {
218 t << "OBJMOC = " << objMoc << endl; 219 t << "OBJMOC = " << objMoc << endl;
219 } 220 }
220 if(do_incremental && !moc_incremental && !src_incremental) 221 if(do_incremental && !moc_incremental && !src_incremental)
221 do_incremental = FALSE; 222 do_incremental = FALSE;
222 t << "DIST = " << valList(fileFixify(project->variables()["DISTFILES"])) << endl; 223 t << "DIST = " << valList(fileFixify(project->variables()["DISTFILES"])) << endl;
223 t << "QMAKE_TARGET = " << var("QMAKE_ORIG_TARGET") << endl; 224 t << "QMAKE_TARGET = " << var("QMAKE_ORIG_TARGET") << endl;
224 t << "DESTDIR = " << var("DESTDIR") << endl; 225 t << "DESTDIR = " << var("DESTDIR") << endl;
225 t << "TARGET = " << var("TARGET") << endl; 226 t << "TARGET = " << var("TARGET") << endl;
226 if(project->isActiveConfig("plugin") ) { 227 if(project->isActiveConfig("plugin") ) {
227 t << "TARGETD = " << var("TARGET") << endl; 228 t << "TARGETD = " << var("TARGET") << endl;
228 } else if (!project->isActiveConfig("staticlib") && project->variables()["QMAKE_APP_FLAG"].isEmpty()) { 229 } else if (!project->isActiveConfig("staticlib") && project->variables()["QMAKE_APP_FLAG"].isEmpty()) {
229 t << "TARGETA= " << var("TARGETA") << endl; 230 t << "TARGETA= " << var("TARGETA") << endl;
230 if (project->isEmpty("QMAKE_HPUX_SHLIB")) { 231 if (project->isEmpty("QMAKE_HPUX_SHLIB")) {
231 t << "TARGETD= " << var("TARGET_x.y.z") << endl; 232 t << "TARGETD= " << var("TARGET_x.y.z") << endl;
232 t << "TARGET0= " << var("TARGET_") << endl; 233 t << "TARGET0= " << var("TARGET_") << endl;
233 t << "TARGET1= " << var("TARGET_x") << endl; 234 t << "TARGET1= " << var("TARGET_x") << endl;
234 t << "TARGET2= " << var("TARGET_x.y") << endl; 235 t << "TARGET2= " << var("TARGET_x.y") << endl;
235 } else { 236 } else {
236 t << "TARGETD= " << var("TARGET_x") << endl; 237 t << "TARGETD= " << var("TARGET_x") << endl;
237 t << "TARGET0= " << var("TARGET_") << endl; 238 t << "TARGET0= " << var("TARGET_") << endl;
238 } 239 }
239 } 240 }
240 t << endl; 241 t << endl;
241 242
242 // blasted incldues 243 // blasted incldues
243 QStringList &qeui = project->variables()["QMAKE_EXTRA_UNIX_INCLUDES"]; 244 QStringList &qeui = project->variables()["QMAKE_EXTRA_UNIX_INCLUDES"];
244 QStringList::Iterator it; 245 QStringList::Iterator it;
245 for( it = qeui.begin(); it != qeui.end(); ++it) 246 for( it = qeui.begin(); it != qeui.end(); ++it)
246 t << "include " << (*it) << endl; 247 t << "include " << (*it) << endl;
247 248
248 /* rules */ 249 /* rules */
249 t << "first: all" << endl; 250 t << "first: all" << endl;
250 t << "####### Implicit rules" << endl << endl; 251 t << "####### Implicit rules" << endl << endl;
251 t << ".SUFFIXES: .c"; 252 t << ".SUFFIXES: .c";
252 QStringList::Iterator cppit; 253 QStringList::Iterator cppit;
253 for(cppit = Option::cpp_ext.begin(); cppit != Option::cpp_ext.end(); ++cppit) 254 for(cppit = Option::cpp_ext.begin(); cppit != Option::cpp_ext.end(); ++cppit)
254 t << " " << (*cppit); 255 t << " " << (*cppit);
255 t << endl << endl; 256 t << endl << endl;
256 for(cppit = Option::cpp_ext.begin(); cppit != Option::cpp_ext.end(); ++cppit) 257 for(cppit = Option::cpp_ext.begin(); cppit != Option::cpp_ext.end(); ++cppit)
257 t << (*cppit) << ".o:\n\t" << var("QMAKE_RUN_CXX_IMP") << endl << endl; 258 t << (*cppit) << ".o:\n\t" << var("QMAKE_RUN_CXX_IMP") << endl << endl;
258 t << ".c.o:\n\t" << var("QMAKE_RUN_CC_IMP") << endl << endl; 259 t << ".c.o:\n\t" << var("QMAKE_RUN_CC_IMP") << endl << endl;
259 260
260 if(include_deps) { 261 if(include_deps) {
261 QString cmd=var("QMAKE_CFLAGS_DEPS") + " "; 262 QString cmd=var("QMAKE_CFLAGS_DEPS") + " ";
262 cmd += varGlue("DEFINES","-D"," -D","") + varGlue("PRL_EXPORT_DEFINES"," -D"," -D",""); 263 cmd += varGlue("DEFINES","-D"," -D","") + varGlue("PRL_EXPORT_DEFINES"," -D"," -D","");
263 if(!project->isEmpty("QMAKE_ABSOLUTE_SOURCE_PATH")) 264 if(!project->isEmpty("QMAKE_ABSOLUTE_SOURCE_PATH"))
264 cmd += " -I" + project->first("QMAKE_ABSOLUTE_SOURCE_PATH") + " "; 265 cmd += " -I" + project->first("QMAKE_ABSOLUTE_SOURCE_PATH") + " ";
265 cmd += " $(INCPATH) " + varGlue("DEPENDPATH", "-I", " -I", ""); 266 cmd += " $(INCPATH) " + varGlue("DEPENDPATH", "-I", " -I", "");
266 QString odir; 267 QString odir;
267 if(!project->variables()["OBJECTS_DIR"].isEmpty()) 268 if(!project->variables()["OBJECTS_DIR"].isEmpty())
268 odir = project->first("OBJECTS_DIR"); 269 odir = project->first("OBJECTS_DIR");
269 t << "###### Dependencies" << endl << endl; 270 t << "###### Dependencies" << endl << endl;
270 t << odir << ".deps/%.d: %.cpp\n\t" 271 t << odir << ".deps/%.d: %.cpp\n\t"
271 << "@echo Creating depend for $<" << "\n\t" 272 << "@echo Creating depend for $<" << "\n\t"
272 << "@test -d $(@D) || mkdir -p $(@D)" << "\n\t" 273 << "@test -d $(@D) || mkdir -p $(@D)" << "\n\t"
273 << "@$(CXX) " << cmd << " $< | sed \"s,^\\($(*F).o\\):," << odir << "\\1:,g\" >$@" << endl << endl; 274 << "@$(CXX) " << cmd << " $< | sed \"s,^\\($(*F).o\\):," << odir << "\\1:,g\" >$@" << endl << endl;
274 275
275 t << odir << ".deps/%.d: %.c\n\t" 276 t << odir << ".deps/%.d: %.c\n\t"
276 << "@echo Creating depend for $<" << "\n\t" 277 << "@echo Creating depend for $<" << "\n\t"
277 << "@test -d $(@D) || mkdir -p $(@D)" << "\n\t" 278 << "@test -d $(@D) || mkdir -p $(@D)" << "\n\t"
278 << "@$(CC) " << cmd << " $< | sed \"s,^\\($(*F).o\\):," << odir << "\\1:,g\" >$@" << endl << endl; 279 << "@$(CC) " << cmd << " $< | sed \"s,^\\($(*F).o\\):," << odir << "\\1:,g\" >$@" << endl << endl;
279 280
280 281
281 QString src[] = { "SOURCES", "UICIMPLS", "SRCMOC", QString::null }; 282 QString src[] = { "SOURCES", "UICIMPLS", "SRCMOC", QString::null };
282 for(int x = 0; !src[x].isNull(); x++) { 283 for(int x = 0; !src[x].isNull(); x++) {
283 QStringList &l = project->variables()[src[x]]; 284 QStringList &l = project->variables()[src[x]];
284 for(QStringList::Iterator it = l.begin(); it != l.end(); ++it) { 285 for(QStringList::Iterator it = l.begin(); it != l.end(); ++it) {
285 if(!(*it).isEmpty()) { 286 if(!(*it).isEmpty()) {
286 QString d_file; 287 QString d_file;
287 if((*it).endsWith(".c")) { 288 if((*it).endsWith(".c")) {
288 d_file = (*it).left((*it).length() - 2); 289 d_file = (*it).left((*it).length() - 2);
289 } else { 290 } else {
290 for(QStringList::Iterator cppit = Option::cpp_ext.begin(); 291 for(QStringList::Iterator cppit = Option::cpp_ext.begin();
291 cppit != Option::cpp_ext.end(); ++cppit) { 292 cppit != Option::cpp_ext.end(); ++cppit) {
292 if((*it).endsWith((*cppit))) { 293 if((*it).endsWith((*cppit))) {
293 d_file = (*it).left((*it).length() - (*cppit).length()); 294 d_file = (*it).left((*it).length() - (*cppit).length());
294 break; 295 break;
295 } 296 }
296 } 297 }
297 } 298 }
298 if(!d_file.isEmpty()) { 299 if(!d_file.isEmpty()) {
299 d_file = odir + ".deps/" + d_file + ".d"; 300 d_file = odir + ".deps/" + d_file + ".d";
300 QStringList deps = findDependencies((*it)).grep(QRegExp(Option::moc_ext + "$")); 301 QStringList deps = findDependencies((*it)).grep(QRegExp(Option::moc_ext + "$"));
301 if(!deps.isEmpty()) 302 if(!deps.isEmpty())
302 t << d_file << ": " << deps.join(" ") << endl; 303 t << d_file << ": " << deps.join(" ") << endl;
303 t << "-include " << d_file << endl; 304 t << "-include " << d_file << endl;
304 } 305 }
305 } 306 }
306 } 307 }
307 } 308 }
308 } 309 }
309 310
310 t << "####### Build rules" << endl << endl; 311 t << "####### Build rules" << endl << endl;
311 if(!project->variables()["SUBLIBS"].isEmpty()) { 312 if(!project->variables()["SUBLIBS"].isEmpty()) {
312 QString libdir = "tmp/"; 313 QString libdir = "tmp/";
313 if(!project->isEmpty("SUBLIBS_DIR")) 314 if(!project->isEmpty("SUBLIBS_DIR"))
314 libdir = project->first("SUBLIBS_DIR"); 315 libdir = project->first("SUBLIBS_DIR");
315 t << "SUBLIBS= "; 316 t << "SUBLIBS= ";
316 QStringList &l = project->variables()["SUBLIBS"]; 317 QStringList &l = project->variables()["SUBLIBS"];
317 for(QStringList::Iterator it = l.begin(); it != l.end(); ++it) 318 for(QStringList::Iterator it = l.begin(); it != l.end(); ++it)
318 t << libdir << "lib" << (*it) << ".a "; 319 t << libdir << "lib" << (*it) << ".a ";
319 t << endl << endl; 320 t << endl << endl;
320 } 321 }
321 if(project->isActiveConfig("depend_prl") && !project->isEmpty("QMAKE_PRL_INTERNAL_FILES")) { 322 if(project->isActiveConfig("depend_prl") && !project->isEmpty("QMAKE_PRL_INTERNAL_FILES")) {
322 QStringList &l = project->variables()["QMAKE_PRL_INTERNAL_FILES"]; 323 QStringList &l = project->variables()["QMAKE_PRL_INTERNAL_FILES"];
323 QStringList::Iterator it; 324 QStringList::Iterator it;
324 for(it = l.begin(); it != l.end(); ++it) { 325 for(it = l.begin(); it != l.end(); ++it) {
325 QMakeProject proj; 326 QMakeProject proj;
326 if(proj.read((*it), QDir::currentDirPath()) && !proj.isEmpty("QMAKE_PRL_BUILD_DIR")) { 327 if(proj.read((*it), QDir::currentDirPath()) && !proj.isEmpty("QMAKE_PRL_BUILD_DIR")) {
327 QString dir; 328 QString dir;
328 int slsh = (*it).findRev(Option::dir_sep); 329 int slsh = (*it).findRev(Option::dir_sep);
329 if(slsh != -1) 330 if(slsh != -1)
330 dir = (*it).left(slsh + 1); 331 dir = (*it).left(slsh + 1);
331 QString targ = dir + proj.first("QMAKE_PRL_TARGET"); 332 QString targ = dir + proj.first("QMAKE_PRL_TARGET");
332 deps += " " + targ; 333 deps += " " + targ;
333 t << targ << ":" << "\n\t" 334 t << targ << ":" << "\n\t"
334 << "@echo \"Creating '" << targ << "'\"" << "\n\t" 335 << "@echo \"Creating '" << targ << "'\"" << "\n\t"
335 << "(cd " << proj.first("QMAKE_PRL_BUILD_DIR") << ";" 336 << "(cd " << proj.first("QMAKE_PRL_BUILD_DIR") << ";"
336 << "$(MAKE) )" << endl; 337 << "$(MAKE) )" << endl;
337 } 338 }
338 } 339 }
339 } 340 }
340 if(!project->variables()["QMAKE_APP_FLAG"].isEmpty()) { 341 if(!project->variables()["QMAKE_APP_FLAG"].isEmpty()) {
341 QString destdir = project->first("DESTDIR"); 342 QString destdir = project->first("DESTDIR");
342 if(do_incremental) { 343 if(do_incremental) {
343 //incremental target 344 //incremental target
344 QString incr_target = var("TARGET") + "_incremental"; 345 QString incr_target = var("TARGET") + "_incremental";
345 if(incr_target.find(Option::dir_sep) != -1) 346 if(incr_target.find(Option::dir_sep) != -1)
346 incr_target = incr_target.right(incr_target.length() - 347 incr_target = incr_target.right(incr_target.length() -
347 (incr_target.findRev(Option::dir_sep) + 1)); 348 (incr_target.findRev(Option::dir_sep) + 1));
348 QString incr_deps, incr_objs; 349 QString incr_deps, incr_objs;
349 if(project->first("QMAKE_INCREMENTAL_STYLE") == "ld") { 350 if(project->first("QMAKE_INCREMENTAL_STYLE") == "ld") {
350 QString incr_target_dir = var("OBJECTS_DIR") + incr_target + Option::obj_ext; 351 QString incr_target_dir = var("OBJECTS_DIR") + incr_target + Option::obj_ext;
351 //actual target 352 //actual target
352 t << incr_target_dir << ": $(OBJECTS)" << "\n\t" 353 t << incr_target_dir << ": $(OBJECTS)" << "\n\t"
353 << "ld -r -o "<< incr_target_dir << " $(OBJECTS)" << endl; 354 << "ld -r -o "<< incr_target_dir << " $(OBJECTS)" << endl;
354 //communicated below 355 //communicated below
355 deps.prepend(incr_target_dir + " "); 356 deps.prepend(incr_target_dir + " ");
356 incr_deps = "$(UICDECLS) $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC) $(OBJMOC)"; 357 incr_deps = "$(UICDECLS) $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC) $(OBJMOC)";
357 if(!incr_objs.isEmpty()) 358 if(!incr_objs.isEmpty())
358 incr_objs += " "; 359 incr_objs += " ";
359 incr_objs += incr_target_dir; 360 incr_objs += incr_target_dir;
360 } else { 361 } else {
361 //actual target 362 //actual target
362 QString incr_target_dir = var("DESTDIR") + "lib" + incr_target + "." + 363 QString incr_target_dir = var("DESTDIR") + "lib" + incr_target + "." +
363 project->variables()["QMAKE_EXTENSION_SHLIB"].first(); 364 project->variables()["QMAKE_EXTENSION_SHLIB"].first();
364 QString incr_lflags = var("QMAKE_LFLAGS_SHLIB") + " "; 365 QString incr_lflags = var("QMAKE_LFLAGS_SHLIB") + " ";
365 if(project->isActiveConfig("debug")) 366 if(project->isActiveConfig("debug"))
366 incr_lflags += var("QMAKE_LFLAGS_DEBUG"); 367 incr_lflags += var("QMAKE_LFLAGS_DEBUG");
367 else 368 else
368 incr_lflags += var("QMAKE_LFLAGS_RELEASE"); 369 incr_lflags += var("QMAKE_LFLAGS_RELEASE");
369 t << incr_target_dir << ": $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)" << "\n\t"; 370 t << incr_target_dir << ": $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)" << "\n\t";
370 if(!destdir.isEmpty()) 371 if(!destdir.isEmpty())
371 t << "\n\t" << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t"; 372 t << "\n\t" << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t";
372 t << "$(LINK) " << incr_lflags << " -o "<< incr_target_dir << 373 t << "$(LINK) " << incr_lflags << " -o "<< incr_target_dir <<
373 " $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)" << endl; 374 " $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)" << endl;
374 //communicated below 375 //communicated below
375 if(!destdir.isEmpty()) { 376 if(!destdir.isEmpty()) {
376 if(!incr_objs.isEmpty()) 377 if(!incr_objs.isEmpty())
377 incr_objs += " "; 378 incr_objs += " ";
378 incr_objs += "-L" + destdir; 379 incr_objs += "-L" + destdir;
379 } else { 380 } else {
380 if(!incr_objs.isEmpty()) 381 if(!incr_objs.isEmpty())
381 incr_objs += " "; 382 incr_objs += " ";
382 incr_objs += "-L" + QDir::currentDirPath(); 383 incr_objs += "-L" + QDir::currentDirPath();
383 } 384 }
384 if(!incr_objs.isEmpty()) 385 if(!incr_objs.isEmpty())
385 incr_objs += " "; 386 incr_objs += " ";
386 incr_objs += " -l" + incr_target; 387 incr_objs += " -l" + incr_target;
387 deps.prepend(incr_target_dir + " "); 388 deps.prepend(incr_target_dir + " ");
388 incr_deps = "$(UICDECLS) $(OBJECTS) $(OBJMOC)"; 389 incr_deps = "$(UICDECLS) $(OBJECTS) $(OBJMOC)";
389 } 390 }
390 t << "all: " << deps << " " << varGlue("ALL_DEPS",""," "," ") << "$(TARGET)" 391 t << "all: " << deps << " " << varGlue("ALL_DEPS",""," "," ") << "$(TARGET)"
391 << endl << endl; 392 << endl << endl;
392 393
393 //real target 394 //real target
394 t << var("TARGET") << ": " << var("PRE_TARGETDEPS") << " " << incr_deps 395 t << var("TARGET") << ": " << var("PRE_TARGETDEPS") << " " << incr_deps
395 << " " << var("POST_TARGETDEPS") << "\n\t"; 396 << " " << var("POST_TARGETDEPS") << "\n\t";
396 if(!destdir.isEmpty()) 397 if(!destdir.isEmpty())
397 t << "\n\t" << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t"; 398 t << "\n\t" << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t";
398 if(!project->isEmpty("QMAKE_PRE_LINK")) 399 if(!project->isEmpty("QMAKE_PRE_LINK"))
399 t << var("QMAKE_PRE_LINK") << "\n\t"; 400 t << var("QMAKE_PRE_LINK") << "\n\t";
400 t << "$(LINK) $(LFLAGS) -o $(TARGET) " << incr_deps << " " << incr_objs << " $(LIBS)"; 401 t << "$(LINK) $(LFLAGS) -o $(TARGET) " << incr_deps << " " << incr_objs << " $(LIBS)";
401 if(!project->isEmpty("QMAKE_POST_LINK")) 402 if(!project->isEmpty("QMAKE_POST_LINK"))
402 t << "\n\t" << var("QMAKE_POST_LINK"); 403 t << "\n\t" << var("QMAKE_POST_LINK");
403 t << endl << endl; 404 t << endl << endl;
404 } else { 405 } else {
405 t << "all: " << deps << " " << varGlue("ALL_DEPS",""," "," ") << "$(TARGET)" 406 t << "all: " << deps << " " << varGlue("ALL_DEPS",""," "," ") << "$(TARGET)"
406 << endl << endl; 407 << endl << endl;
407 408
408 t << "$(TARGET): " << var("PRE_TARGETDEPS") << " $(UICDECLS) $(OBJECTS) $(OBJMOC) " 409 t << "$(TARGET): " << var("PRE_TARGETDEPS") << " $(UICDECLS) $(OBJECTS) $(OBJMOC) "
409 << var("POST_TARGETDEPS") << "\n\t"; 410 << var("POST_TARGETDEPS") << "\n\t";
410 if(!destdir.isEmpty()) 411 if(!destdir.isEmpty())
411 t << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t"; 412 t << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t";
412 if(!project->isEmpty("QMAKE_PRE_LINK")) 413 if(!project->isEmpty("QMAKE_PRE_LINK"))
413 t << var("QMAKE_PRE_LINK") << "\n\t"; 414 t << var("QMAKE_PRE_LINK") << "\n\t";
414 t << "$(LINK) $(LFLAGS) -o $(TARGET) $(OBJECTS) $(OBJMOC) $(LIBS)"; 415 t << "$(LINK) $(LFLAGS) -o $(TARGET) $(OBJECTS) $(OBJMOC) $(LIBS)";
415 if(!project->isEmpty("QMAKE_POST_LINK")) 416 if(!project->isEmpty("QMAKE_POST_LINK"))
416 t << "\n\t" << var("QMAKE_POST_LINK"); 417 t << "\n\t" << var("QMAKE_POST_LINK");
417 t << endl << endl; 418 t << endl << endl;
418 } 419 }
419 } else if(!project->isActiveConfig("staticlib")) { 420 } else if(!project->isActiveConfig("staticlib")) {
420 QString destdir = project->first("DESTDIR"), incr_deps; 421 QString destdir = project->first("DESTDIR"), incr_deps;
421 if(do_incremental) { 422 if(do_incremental) {
422 QString s_ext = project->variables()["QMAKE_EXTENSION_SHLIB"].first(); 423 QString s_ext = project->variables()["QMAKE_EXTENSION_SHLIB"].first();
423 QString incr_target = var("QMAKE_ORIG_TARGET").replace( 424 QString incr_target = var("QMAKE_ORIG_TARGET").replace(
424 QRegExp("\\." + s_ext), "").replace(QRegExp("^lib"), "") + "_incremental"; 425 QRegExp("\\." + s_ext), "").replace(QRegExp("^lib"), "") + "_incremental";
425 if(incr_target.find(Option::dir_sep) != -1) 426 if(incr_target.find(Option::dir_sep) != -1)
426 incr_target = incr_target.right(incr_target.length() - 427 incr_target = incr_target.right(incr_target.length() -
427 (incr_target.findRev(Option::dir_sep) + 1)); 428 (incr_target.findRev(Option::dir_sep) + 1));
428 429
429 if(project->first("QMAKE_INCREMENTAL_STYLE") == "ld") { 430 if(project->first("QMAKE_INCREMENTAL_STYLE") == "ld") {
430 QString incr_target_dir = var("OBJECTS_DIR") + incr_target + Option::obj_ext; 431 QString incr_target_dir = var("OBJECTS_DIR") + incr_target + Option::obj_ext;
431 //actual target 432 //actual target
432 const QString link_deps = "$(UICDECLS) $(OBJECTS) $(OBJMOC)"; 433 const QString link_deps = "$(UICDECLS) $(OBJECTS) $(OBJMOC)";
433 t << incr_target_dir << ": " << link_deps << "\n\t" 434 t << incr_target_dir << ": " << link_deps << "\n\t"
434 << "ld -r -o " << incr_target_dir << " " << link_deps << endl; 435 << "ld -r -o " << incr_target_dir << " " << link_deps << endl;
435 //communicated below 436 //communicated below
436 QStringList &cmd = project->variables()["QMAKE_LINK_SHLIB_CMD"]; 437 QStringList &cmd = project->variables()["QMAKE_LINK_SHLIB_CMD"];
437 cmd.first().replace("$(OBJECTS) $(OBJMOC)", 438 cmd.first().replace("$(OBJECTS) $(OBJMOC)",
438 "$(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)"); //ick 439 "$(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)"); //ick
439 cmd.append(incr_target_dir); 440 cmd.append(incr_target_dir);
440 deps.prepend(incr_target_dir + " "); 441 deps.prepend(incr_target_dir + " ");
441 incr_deps = "$(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)"; 442 incr_deps = "$(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)";
442 } else { 443 } else {
443 //actual target 444 //actual target
444 QString incr_target_dir = var("DESTDIR") + "lib" + incr_target + "." + s_ext; 445 QString incr_target_dir = var("DESTDIR") + "lib" + incr_target + "." + s_ext;
445 QString incr_lflags = var("QMAKE_LFLAGS_SHLIB") + " "; 446 QString incr_lflags = var("QMAKE_LFLAGS_SHLIB") + " ";
446 if(!project->isEmpty("QMAKE_LFLAGS_INCREMENTAL")) 447 if(!project->isEmpty("QMAKE_LFLAGS_INCREMENTAL"))
447 incr_lflags += var("QMAKE_LFLAGS_INCREMENTAL") + " "; 448 incr_lflags += var("QMAKE_LFLAGS_INCREMENTAL") + " ";
448 if(project->isActiveConfig("debug")) 449 if(project->isActiveConfig("debug"))
449 incr_lflags += var("QMAKE_LFLAGS_DEBUG"); 450 incr_lflags += var("QMAKE_LFLAGS_DEBUG");
450 else 451 else
451 incr_lflags += var("QMAKE_LFLAGS_RELEASE"); 452 incr_lflags += var("QMAKE_LFLAGS_RELEASE");
452 t << incr_target_dir << ": $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)" << "\n\t"; 453 t << incr_target_dir << ": $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)" << "\n\t";
453 if(!destdir.isEmpty()) 454 if(!destdir.isEmpty())
454 t << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t"; 455 t << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t";
455 t << "$(LINK) " << incr_lflags << " -o "<< incr_target_dir << 456 t << "$(LINK) " << incr_lflags << " -o "<< incr_target_dir <<
456 " $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)" << endl; 457 " $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)" << endl;
457 //communicated below 458 //communicated below
458 QStringList &cmd = project->variables()["QMAKE_LINK_SHLIB_CMD"]; 459 QStringList &cmd = project->variables()["QMAKE_LINK_SHLIB_CMD"];
459 if(!destdir.isEmpty()) 460 if(!destdir.isEmpty())
460 cmd.append(" -L" + destdir); 461 cmd.append(" -L" + destdir);
461 cmd.append(" -l" + incr_target); 462 cmd.append(" -l" + incr_target);
462 deps.prepend(incr_target_dir + " "); 463 deps.prepend(incr_target_dir + " ");
463 incr_deps = "$(UICDECLS) $(OBJECTS) $(OBJMOC)"; 464 incr_deps = "$(UICDECLS) $(OBJECTS) $(OBJMOC)";
464 } 465 }
465 466
466 t << "all: " << " " << deps << " " << varGlue("ALL_DEPS",""," ","") 467 t << "all: " << " " << deps << " " << varGlue("ALL_DEPS",""," ","")
467 << " " << var("DESTDIR_TARGET") << endl << endl; 468 << " " << var("DESTDIR_TARGET") << endl << endl;
468 469
469 //real target 470 //real target
470 t << var("DESTDIR_TARGET") << ": " << var("PRE_TARGETDEPS") << " " 471 t << var("DESTDIR_TARGET") << ": " << var("PRE_TARGETDEPS") << " "
471 << incr_deps << " $(SUBLIBS) " << var("POST_TARGETDEPS"); 472 << incr_deps << " $(SUBLIBS) " << var("POST_TARGETDEPS");
472 } else { 473 } else {
473 t << "all: " << deps << " " << varGlue("ALL_DEPS",""," ","") << " " << 474 t << "all: " << deps << " " << varGlue("ALL_DEPS",""," ","") << " " <<
474 var("DESTDIR_TARGET") << endl << endl; 475 var("DESTDIR_TARGET") << endl << endl;
475 t << var("DESTDIR_TARGET") << ": " << var("PRE_TARGETDEPS") 476 t << var("DESTDIR_TARGET") << ": " << var("PRE_TARGETDEPS")
476 << " $(UICDECLS) $(OBJECTS) $(OBJMOC) $(SUBLIBS) " << var("POST_TARGETDEPS"); 477 << " $(UICDECLS) $(OBJECTS) $(OBJMOC) $(SUBLIBS) " << var("POST_TARGETDEPS");
477 } 478 }
478 if(!destdir.isEmpty()) 479 if(!destdir.isEmpty())
479 t << "\n\t" << "test -d " << destdir << " || mkdir -p " << destdir; 480 t << "\n\t" << "test -d " << destdir << " || mkdir -p " << destdir;
480 if(!project->isEmpty("QMAKE_PRE_LINK")) 481 if(!project->isEmpty("QMAKE_PRE_LINK"))
481 t << "\n\t" << var("QMAKE_PRE_LINK"); 482 t << "\n\t" << var("QMAKE_PRE_LINK");
482 483
483 if(project->isActiveConfig("plugin")) { 484 if(project->isActiveConfig("plugin")) {
484 t << "\n\t" 485 t << "\n\t"
485 << "-$(DEL_FILE) $(TARGET)" << "\n\t" 486 << "-$(DEL_FILE) $(TARGET)" << "\n\t"
486 << var("QMAKE_LINK_SHLIB_CMD"); 487 << var("QMAKE_LINK_SHLIB_CMD");
487 if(!destdir.isEmpty()) 488 if(!destdir.isEmpty())
488 t << "\n\t" 489 t << "\n\t"
489 << "-$(MOVE) $(TARGET) " << var("DESTDIR"); 490 << "-$(MOVE) $(TARGET) " << var("DESTDIR");
490 if(!project->isEmpty("QMAKE_POST_LINK")) 491 if(!project->isEmpty("QMAKE_POST_LINK"))
491 t << "\n\t" << var("QMAKE_POST_LINK") << "\n\t"; 492 t << "\n\t" << var("QMAKE_POST_LINK") << "\n\t";
492 t << endl << endl; 493 t << endl << endl;
493 } else if(project->isEmpty("QMAKE_HPUX_SHLIB")) { 494 } else if(project->isEmpty("QMAKE_HPUX_SHLIB")) {
494 t << "\n\t" 495 t << "\n\t"
495 << "-$(DEL_FILE) $(TARGET) $(TARGET0) $(TARGET1) $(TARGET2)" << "\n\t" 496 << "-$(DEL_FILE) $(TARGET) $(TARGET0) $(TARGET1) $(TARGET2)" << "\n\t"
496 << var("QMAKE_LINK_SHLIB_CMD") << "\n\t"; 497 << var("QMAKE_LINK_SHLIB_CMD") << "\n\t";
497 t << varGlue("QMAKE_LN_SHLIB","-"," "," $(TARGET) $(TARGET0)") << "\n\t" 498 t << varGlue("QMAKE_LN_SHLIB","-"," "," $(TARGET) $(TARGET0)") << "\n\t"
498 << varGlue("QMAKE_LN_SHLIB","-"," "," $(TARGET) $(TARGET1)") << "\n\t" 499 << varGlue("QMAKE_LN_SHLIB","-"," "," $(TARGET) $(TARGET1)") << "\n\t"
499 << varGlue("QMAKE_LN_SHLIB","-"," "," $(TARGET) $(TARGET2)"); 500 << varGlue("QMAKE_LN_SHLIB","-"," "," $(TARGET) $(TARGET2)");
500 if(!destdir.isEmpty()) 501 if(!destdir.isEmpty())
501 t << "\n\t" 502 t << "\n\t"
502 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET)\n\t" 503 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET)\n\t"
503 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET0)\n\t" 504 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET0)\n\t"
504 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET1)\n\t" 505 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET1)\n\t"
505 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET2)\n\t" 506 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET2)\n\t"
506 << "-$(MOVE) $(TARGET) $(TARGET0) $(TARGET1) $(TARGET2) " << var("DESTDIR"); 507 << "-$(MOVE) $(TARGET) $(TARGET0) $(TARGET1) $(TARGET2) " << var("DESTDIR");
507 if(!project->isEmpty("QMAKE_POST_LINK")) 508 if(!project->isEmpty("QMAKE_POST_LINK"))
508 t << "\n\t" << var("QMAKE_POST_LINK"); 509 t << "\n\t" << var("QMAKE_POST_LINK");
509 t << endl << endl; 510 t << endl << endl;
510 } else { 511 } else {
511 t << "\n\t" 512 t << "\n\t"
512 << "-$(DEL_FILE) $(TARGET) $(TARGET0)" << "\n\t" 513 << "-$(DEL_FILE) $(TARGET) $(TARGET0)" << "\n\t"
513 << var("QMAKE_LINK_SHLIB_CMD") << "\n\t"; 514 << var("QMAKE_LINK_SHLIB_CMD") << "\n\t";
514 t << varGlue("QMAKE_LN_SHLIB",""," "," $(TARGET) $(TARGET0)"); 515 t << varGlue("QMAKE_LN_SHLIB",""," "," $(TARGET) $(TARGET0)");
515 if(!destdir.isEmpty()) 516 if(!destdir.isEmpty())
516 t << "\n\t" 517 t << "\n\t"
517 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET)\n\t" 518 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET)\n\t"
518 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET0)\n\t" 519 << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET0)\n\t"
519 << "-$(MOVE) $(TARGET) $(TARGET0) " << var("DESTDIR"); 520 << "-$(MOVE) $(TARGET) $(TARGET0) " << var("DESTDIR");
520 if(!project->isEmpty("QMAKE_POST_LINK")) 521 if(!project->isEmpty("QMAKE_POST_LINK"))
521 t << "\n\t" << var("QMAKE_POST_LINK"); 522 t << "\n\t" << var("QMAKE_POST_LINK");
522 t << endl << endl; 523 t << endl << endl;
523 } 524 }
524 t << endl << endl; 525 t << endl << endl;
525 526
526 if (! project->isActiveConfig("plugin")) { 527 if (! project->isActiveConfig("plugin")) {
527 t << "staticlib: $(TARGETA)" << endl << endl; 528 t << "staticlib: $(TARGETA)" << endl << endl;
528 t << "$(TARGETA): " << var("PRE_TARGETDEPS") << " $(UICDECLS) $(OBJECTS) $(OBJMOC)"; 529 t << "$(TARGETA): " << var("PRE_TARGETDEPS") << " $(UICDECLS) $(OBJECTS) $(OBJMOC)";
529 if(do_incremental) 530 if(do_incremental)
530 t << " $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)"; 531 t << " $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)";
531 t << var("POST_TARGETDEPS") << "\n\t" 532 t << var("POST_TARGETDEPS") << "\n\t"
532 << "-$(DEL_FILE) $(TARGETA) " << "\n\t" 533 << "-$(DEL_FILE) $(TARGETA) " << "\n\t"
533 << var("QMAKE_AR_CMD"); 534 << var("QMAKE_AR_CMD");
534 if(do_incremental) 535 if(do_incremental)
535 t << " $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)"; 536 t << " $(INCREMENTAL_OBJECTS) $(INCREMENTAL_OBJMOC)";
536 if(!project->isEmpty("QMAKE_RANLIB")) 537 if(!project->isEmpty("QMAKE_RANLIB"))
537 t << "\n\t" << "$(RANLIB) $(TARGETA)"; 538 t << "\n\t" << "$(RANLIB) $(TARGETA)";
538 t << endl << endl; 539 t << endl << endl;
539 } 540 }
540 } else { 541 } else {
541 t << "all: " << deps << " " << varGlue("ALL_DEPS",""," "," ") << var("DESTDIR") << "$(TARGET) " 542 t << "all: " << deps << " " << varGlue("ALL_DEPS",""," "," ") << var("DESTDIR") << "$(TARGET) "
542 << varGlue("QMAKE_AR_SUBLIBS", var("DESTDIR"), " " + var("DESTDIR"), "") << "\n\n" 543 << varGlue("QMAKE_AR_SUBLIBS", var("DESTDIR"), " " + var("DESTDIR"), "") << "\n\n"
543 << "staticlib: " << var("DESTDIR") << "$(TARGET)" << "\n\n"; 544 << "staticlib: " << var("DESTDIR") << "$(TARGET)" << "\n\n";
544 if(project->isEmpty("QMAKE_AR_SUBLIBS")) { 545 if(project->isEmpty("QMAKE_AR_SUBLIBS")) {
545 t << var("DESTDIR") << "$(TARGET): " << var("PRE_TARGETDEPS") 546 t << var("DESTDIR") << "$(TARGET): " << var("PRE_TARGETDEPS")
546 << " $(UICDECLS) $(OBJECTS) $(OBJMOC) " << var("POST_TARGETDEPS") << "\n\t"; 547 << " $(UICDECLS) $(OBJECTS) $(OBJMOC) " << var("POST_TARGETDEPS") << "\n\t";
547 if(!project->isEmpty("DESTDIR")) { 548 if(!project->isEmpty("DESTDIR")) {
548 QString destdir = project->first("DESTDIR"); 549 QString destdir = project->first("DESTDIR");
549 t << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t"; 550 t << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t";
550 } 551 }
551 t << "-$(DEL_FILE) $(TARGET)" << "\n\t" 552 t << "-$(DEL_FILE) $(TARGET)" << "\n\t"
552 << var("QMAKE_AR_CMD") << "\n"; 553 << var("QMAKE_AR_CMD") << "\n";
553 if(!project->isEmpty("QMAKE_POST_LINK")) 554 if(!project->isEmpty("QMAKE_POST_LINK"))
554 t << "\t" << var("QMAKE_POST_LINK") << "\n"; 555 t << "\t" << var("QMAKE_POST_LINK") << "\n";
555 if(!project->isEmpty("QMAKE_RANLIB")) 556 if(!project->isEmpty("QMAKE_RANLIB"))
556 t << "\t" << "$(RANLIB) $(TARGET)" << "\n"; 557 t << "\t" << "$(RANLIB) $(TARGET)" << "\n";
557 if(!project->isEmpty("DESTDIR")) 558 if(!project->isEmpty("DESTDIR"))
558 t << "\t" << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET)" << "\n" 559 t << "\t" << "-$(DEL_FILE) " << var("DESTDIR") << "$(TARGET)" << "\n"
559 << "\t" << "-$(MOVE) $(TARGET) " << var("DESTDIR") << "\n"; 560 << "\t" << "-$(MOVE) $(TARGET) " << var("DESTDIR") << "\n";
560 } else { 561 } else {
561 int max_files = project->first("QMAKE_MAX_FILES_PER_AR").toInt(); 562 int max_files = project->first("QMAKE_MAX_FILES_PER_AR").toInt();
562 QStringList objs = project->variables()["OBJECTS"] + project->variables()["OBJMOC"], 563 QStringList objs = project->variables()["OBJECTS"] + project->variables()["OBJMOC"],
563 libs = project->variables()["QMAKE_AR_SUBLIBS"]; 564 libs = project->variables()["QMAKE_AR_SUBLIBS"];
564 libs.prepend("$(TARGET)"); 565 libs.prepend("$(TARGET)");
565 for(QStringList::Iterator libit = libs.begin(), objit = objs.begin(); 566 for(QStringList::Iterator libit = libs.begin(), objit = objs.begin();
566 libit != libs.end(); ++libit) { 567 libit != libs.end(); ++libit) {
567 QStringList build; 568 QStringList build;
568 for(int cnt = 0; cnt < max_files && objit != objs.end(); ++objit, cnt++) 569 for(int cnt = 0; cnt < max_files && objit != objs.end(); ++objit, cnt++)
569 build << (*objit); 570 build << (*objit);
570 QString ar; 571 QString ar;
571 if((*libit) == "$(TARGET)") { 572 if((*libit) == "$(TARGET)") {
572 t << var("DESTDIR") << "$(TARGET): " << var("PRE_TARGETDEPS") 573 t << var("DESTDIR") << "$(TARGET): " << var("PRE_TARGETDEPS")
573 << " $(UICDECLS) " << var("POST_TARGETDEPS") << valList(build) << "\n\t"; 574 << " $(UICDECLS) " << var("POST_TARGETDEPS") << valList(build) << "\n\t";
574 ar = project->variables()["QMAKE_AR_CMD"].first(); 575 ar = project->variables()["QMAKE_AR_CMD"].first();
575 ar = ar.replace("$(OBJMOC)", "").replace("$(OBJECTS)", 576 ar = ar.replace("$(OBJMOC)", "").replace("$(OBJECTS)",
576 build.join(" ")); 577 build.join(" "));
577 } else { 578 } else {
578 t << (*libit) << ": " << valList(build) << "\n\t"; 579 t << (*libit) << ": " << valList(build) << "\n\t";
579 ar = "$(AR) " + (*libit) + " " + build.join(" "); 580 ar = "$(AR) " + (*libit) + " " + build.join(" ");
580 } 581 }
581 if(!project->isEmpty("DESTDIR")) { 582 if(!project->isEmpty("DESTDIR")) {
582 QString destdir = project->first("DESTDIR"); 583 QString destdir = project->first("DESTDIR");
583 t << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t"; 584 t << "test -d " << destdir << " || mkdir -p " << destdir << "\n\t";
584 } 585 }
585 t << "-$(DEL_FILE) " << (*libit) << "\n\t" 586 t << "-$(DEL_FILE) " << (*libit) << "\n\t"
586 << ar << "\n"; 587 << ar << "\n";
587 if(!project->isEmpty("QMAKE_POST_LINK")) 588 if(!project->isEmpty("QMAKE_POST_LINK"))
588 t << "\t" << var("QMAKE_POST_LINK") << "\n"; 589 t << "\t" << var("QMAKE_POST_LINK") << "\n";
589 if(!project->isEmpty("QMAKE_RANLIB")) 590 if(!project->isEmpty("QMAKE_RANLIB"))
590 t << "\t" << "$(RANLIB) " << (*libit) << "\n"; 591 t << "\t" << "$(RANLIB) " << (*libit) << "\n";
591 if(!project->isEmpty("DESTDIR")) 592 if(!project->isEmpty("DESTDIR"))
592 t << "\t" << "-$(DEL_FILE) " << var("DESTDIR") << (*libit) << "\n" 593 t << "\t" << "-$(DEL_FILE) " << var("DESTDIR") << (*libit) << "\n"
593 << "\t" << "-$(MOVE) " << (*libit) << " " << var("DESTDIR") << "\n"; 594 << "\t" << "-$(MOVE) " << (*libit) << " " << var("DESTDIR") << "\n";
594 } 595 }
595 } 596 }
596 t << endl << endl; 597 t << endl << endl;
597 } 598 }
598 599
599 t << "mocables: $(SRCMOC)" << endl << endl; 600 t << "mocables: $(SRCMOC)" << endl << endl;
600 601
601 if(!project->isActiveConfig("no_mocdepend")) { 602 if(!project->isActiveConfig("no_mocdepend")) {
602 //this is an implicity depend on moc, so it will be built if necesary, however 603 //this is an implicity depend on moc, so it will be built if necesary, however
603 //moc itself shouldn't have this dependency - this is a little kludgy but it is 604 //moc itself shouldn't have this dependency - this is a little kludgy but it is
604 //better than the alternative for now. 605 //better than the alternative for now.
605 QString moc = project->first("QMAKE_MOC"), target = project->first("TARGET"); 606 QString moc = project->first("QMAKE_MOC"), target = project->first("TARGET");
606 fixEnvVariables(target); 607 fixEnvVariables(target);
607 fixEnvVariables(moc); 608 fixEnvVariables(moc);
608 if(target != moc) 609 if(target != moc)
609 t << "$(MOC): \n\t" 610 t << "$(MOC): \n\t"
610 << "( cd $(QTDIR)/src/moc ; $(MAKE) )" << endl << endl; 611 << "( cd $(QTDIR)/src/moc ; $(MAKE) )" << endl << endl;
611 } 612 }
612 613
613 writeMakeQmake(t); 614 writeMakeQmake(t);
614 615
615 if(!project->first("QMAKE_PKGINFO").isEmpty()) { 616 if(!project->first("QMAKE_PKGINFO").isEmpty()) {
616 QString pkginfo = project->first("QMAKE_PKGINFO"); 617 QString pkginfo = project->first("QMAKE_PKGINFO");
617 QString destdir = project->first("DESTDIR"); 618 QString destdir = project->first("DESTDIR");
618 t << pkginfo << ": " << "\n\t"; 619 t << pkginfo << ": " << "\n\t";
619 if(!destdir.isEmpty()) 620 if(!destdir.isEmpty())
620 t << "@test -d " << destdir << " || mkdir -p " << destdir << "\n\t"; 621 t << "@test -d " << destdir << " || mkdir -p " << destdir << "\n\t";
621 t << "@$(DEL_FILE) " << pkginfo << "\n\t" 622 t << "@$(DEL_FILE) " << pkginfo << "\n\t"
622 << "@echo \"APPL????\" >" << pkginfo << endl; 623 << "@echo \"APPL????\" >" << pkginfo << endl;
623 } 624 }
624 if(!project->first("QMAKE_INFO_PLIST").isEmpty()) { 625 if(!project->first("QMAKE_INFO_PLIST").isEmpty()) {
625 QString info_plist = project->first("QMAKE_INFO_PLIST"), 626 QString info_plist = project->first("QMAKE_INFO_PLIST"),
626 info_plist_out = project->first("QMAKE_INFO_PLIST_OUT"); 627 info_plist_out = project->first("QMAKE_INFO_PLIST_OUT");
627 QString destdir = project->first("DESTDIR"); 628 QString destdir = project->first("DESTDIR");
628 t << info_plist_out << ": " << "\n\t"; 629 t << info_plist_out << ": " << "\n\t";
629 if(!destdir.isEmpty()) 630 if(!destdir.isEmpty())
630 t << "@test -d " << destdir << " || mkdir -p " << destdir << "\n\t"; 631 t << "@test -d " << destdir << " || mkdir -p " << destdir << "\n\t";
631 t << "@$(DEL_FILE) " << info_plist_out << "\n\t" 632 t << "@$(DEL_FILE) " << info_plist_out << "\n\t"
632 << "@cp \"" << info_plist << "\" \"" << info_plist_out << "\"" << endl; 633 << "@cp \"" << info_plist << "\" \"" << info_plist_out << "\"" << endl;
633 if(!project->first("RC_FILE").isEmpty()) { 634 if(!project->first("RC_FILE").isEmpty()) {
634 QString dir = destdir + "../Resources/"; 635 QString dir = destdir + "../Resources/";
635 t << dir << "application.icns:" << "\n\t" 636 t << dir << "application.icns:" << "\n\t"
636 << "@test -d " << dir << " || mkdir -p " << dir << "\n\t" 637 << "@test -d " << dir << " || mkdir -p " << dir << "\n\t"
637 << "@cp " << var("RC_FILE") << " " << dir << "application.icns" << endl; 638 << "@cp " << var("RC_FILE") << " " << dir << "application.icns" << endl;
638 } 639 }
639 } 640 }
640 641
641 QString ddir = project->isEmpty("QMAKE_DISTDIR") ? project->first("QMAKE_ORIG_TARGET") : 642 QString ddir = project->isEmpty("QMAKE_DISTDIR") ? project->first("QMAKE_ORIG_TARGET") :
642 project->first("QMAKE_DISTDIR"); 643 project->first("QMAKE_DISTDIR");
643 QString ddir_c = fileFixify((project->isEmpty("OBJECTS_DIR") ? QString(".tmp/") : 644 QString ddir_c = fileFixify((project->isEmpty("OBJECTS_DIR") ? QString(".tmp/") :
644 project->first("OBJECTS_DIR")) + ddir); 645 project->first("OBJECTS_DIR")) + ddir);
645 t << "dist: " << "\n\t" 646 t << "dist: " << "\n\t"
646 << "@mkdir -p " << ddir_c << " && " 647 << "@mkdir -p " << ddir_c << " && "
647 << "$(COPY_FILE) --parents $(SOURCES) $(HEADERS) $(FORMS) $(DIST) " << ddir_c << Option::dir_sep << " && "; 648 << "$(COPY_FILE) --parents $(SOURCES) $(HEADERS) $(FORMS) $(DIST) " << ddir_c << Option::dir_sep << " && ";
648 if(!project->isEmpty("TRANSLATIONS")) 649 if(!project->isEmpty("TRANSLATIONS"))
649 t << "$(COPY_FILE) --parents " << var("TRANSLATIONS") << " " << ddir_c << Option::dir_sep << " && "; 650 t << "$(COPY_FILE) --parents " << var("TRANSLATIONS") << " " << ddir_c << Option::dir_sep << " && ";
650 if(!project->isEmpty("FORMS")) { 651 if(!project->isEmpty("FORMS")) {
651 QStringList &forms = project->variables()["FORMS"], ui_headers; 652 QStringList &forms = project->variables()["FORMS"], ui_headers;
652 for(QStringList::Iterator formit = forms.begin(); formit != forms.end(); ++formit) { 653 for(QStringList::Iterator formit = forms.begin(); formit != forms.end(); ++formit) {
653 QString ui_h = fileFixify((*formit) + Option::h_ext.first()); 654 QString ui_h = fileFixify((*formit) + Option::h_ext.first());
654 if(QFile::exists(ui_h) ) 655 if(QFile::exists(ui_h) )
655 ui_headers << ui_h; 656 ui_headers << ui_h;
656 } 657 }
657 if(!ui_headers.isEmpty()) 658 if(!ui_headers.isEmpty())
658 t << "$(COPY_FILE) --parents " << val(ui_headers) << " " << ddir_c << Option::dir_sep << " && "; 659 t << "$(COPY_FILE) --parents " << val(ui_headers) << " " << ddir_c << Option::dir_sep << " && ";
659 } 660 }
660 t << "( cd `dirname " << ddir_c << "` && " 661 t << "( cd `dirname " << ddir_c << "` && "
661 << "$(TAR) " << var("QMAKE_ORIG_TARGET") << ".tar " << ddir << " && " 662 << "$(TAR) " << var("QMAKE_ORIG_TARGET") << ".tar " << ddir << " && "
662 << "$(GZIP) " << var("QMAKE_ORIG_TARGET") << ".tar ) && " 663 << "$(GZIP) " << var("QMAKE_ORIG_TARGET") << ".tar ) && "
663 << "$(MOVE) `dirname " << ddir_c << "`" << Option::dir_sep << var("QMAKE_ORIG_TARGET") << ".tar.gz . && " 664 << "$(MOVE) `dirname " << ddir_c << "`" << Option::dir_sep << var("QMAKE_ORIG_TARGET") << ".tar.gz . && "
664 << "$(DEL_FILE) -r " << ddir_c 665 << "$(DEL_FILE) -r " << ddir_c
665 << endl << endl; 666 << endl << endl;
666 667
667 QString clean_targets; 668 QString clean_targets;
668 if(mocAware()) { 669 if(mocAware()) {
669 t << "mocclean:" << "\n"; 670 t << "mocclean:" << "\n";
670 if(!objMoc.isEmpty() || !srcMoc.isEmpty() || moc_incremental) { 671 if(!objMoc.isEmpty() || !srcMoc.isEmpty() || moc_incremental) {
671 if(!objMoc.isEmpty()) 672 if(!objMoc.isEmpty())
672 t << "\t-$(DEL_FILE) $(OBJMOC)" << '\n'; 673 t << "\t-$(DEL_FILE) $(OBJMOC)" << '\n';
673 if(!srcMoc.isEmpty()) 674 if(!srcMoc.isEmpty())
674 t << "\t-$(DEL_FILE) $(SRCMOC)" << '\n'; 675 t << "\t-$(DEL_FILE) $(SRCMOC)" << '\n';
675 if(moc_incremental) 676 if(moc_incremental)
676 t << "\t-$(DEL_FILE) $(INCREMENTAL_OBJMOC)" << '\n'; 677 t << "\t-$(DEL_FILE) $(INCREMENTAL_OBJMOC)" << '\n';
677 clean_targets += " mocclean"; 678 clean_targets += " mocclean";
678 } 679 }
679 t << endl; 680 t << endl;
680 } 681 }
681 t << "uiclean:" << "\n"; 682 t << "uiclean:" << "\n";
682 if (!var("UICIMPLS").isEmpty() || !var("UICDECLS").isEmpty()) { 683 if (!var("UICIMPLS").isEmpty() || !var("UICDECLS").isEmpty()) {
683 t << "\t-$(DEL_FILE) $(UICIMPLS) $(UICDECLS)" << "\n"; 684 t << "\t-$(DEL_FILE) $(UICIMPLS) $(UICDECLS)" << "\n";
684 clean_targets += " uiclean"; 685 clean_targets += " uiclean";
685 } 686 }
686 t << endl; 687 t << endl;
687 688
688 t << "yaccclean:" << "\n"; 689 t << "yaccclean:" << "\n";
689 if(!var("YACCSOURCES").isEmpty()) { 690 if(!var("YACCSOURCES").isEmpty()) {
690 QStringList clean, &l = project->variables()["YACCSOURCES"]; 691 QStringList clean, &l = project->variables()["YACCSOURCES"];
691 for(QStringList::Iterator it = l.begin(); it != l.end(); ++it) { 692 for(QStringList::Iterator it = l.begin(); it != l.end(); ++it) {
692 QFileInfo fi((*it)); 693 QFileInfo fi((*it));
693 QString dir; 694 QString dir;
694 if(fi.dirPath() != ".") 695 if(fi.dirPath() != ".")
695 dir = fi.dirPath() + Option::dir_sep; 696 dir = fi.dirPath() + Option::dir_sep;
696 dir = fileFixify(dir, QDir::currentDirPath(), Option::output_dir); 697 dir = fileFixify(dir, QDir::currentDirPath(), Option::output_dir);
697 if(!dir.isEmpty() && dir.right(Option::dir_sep.length()) != Option::dir_sep) 698 if(!dir.isEmpty() && dir.right(Option::dir_sep.length()) != Option::dir_sep)
698 dir += Option::dir_sep; 699 dir += Option::dir_sep;
699 clean << dir + fi.baseName(TRUE) + Option::yacc_mod + Option::cpp_ext.first(); 700 clean << dir + fi.baseName(TRUE) + Option::yacc_mod + Option::cpp_ext.first();
700 clean << dir + fi.baseName(TRUE) + Option::yacc_mod + Option::h_ext.first(); 701 clean << dir + fi.baseName(TRUE) + Option::yacc_mod + Option::h_ext.first();
701 } 702 }
702 if(!clean.isEmpty()) { 703 if(!clean.isEmpty()) {
703 t << "\t-$(DEL_FILE) " << clean.join(" ") << "\n"; 704 t << "\t-$(DEL_FILE) " << clean.join(" ") << "\n";
704 clean_targets += " yaccclean"; 705 clean_targets += " yaccclean";
705 } 706 }
706 } 707 }
707 708
708 t << "lexclean:" << "\n"; 709 t << "lexclean:" << "\n";
709 if(!var("LEXSOURCES").isEmpty()) { 710 if(!var("LEXSOURCES").isEmpty()) {
710 QStringList clean, &l = project->variables()["LEXSOURCES"]; 711 QStringList clean, &l = project->variables()["LEXSOURCES"];
711 for(QStringList::Iterator it = l.begin(); it != l.end(); ++it) { 712 for(QStringList::Iterator it = l.begin(); it != l.end(); ++it) {
712 QFileInfo fi((*it)); 713 QFileInfo fi((*it));
713 QString dir; 714 QString dir;
714 if(fi.dirPath() != ".") 715 if(fi.dirPath() != ".")
715 dir = fi.dirPath() + Option::dir_sep; 716 dir = fi.dirPath() + Option::dir_sep;
716 dir = fileFixify(dir, QDir::currentDirPath(), Option::output_dir); 717 dir = fileFixify(dir, QDir::currentDirPath(), Option::output_dir);
717 if(!dir.isEmpty() && dir.right(Option::dir_sep.length()) != Option::dir_sep) 718 if(!dir.isEmpty() && dir.right(Option::dir_sep.length()) != Option::dir_sep)
718 dir += Option::dir_sep; 719 dir += Option::dir_sep;
719 clean << dir + fi.baseName(TRUE) + Option::lex_mod + Option::cpp_ext.first(); 720 clean << dir + fi.baseName(TRUE) + Option::lex_mod + Option::cpp_ext.first();
720 } 721 }
721 if(!clean.isEmpty()) { 722 if(!clean.isEmpty()) {
722 t << "\t-$(DEL_FILE) " << clean.join(" ") << "\n"; 723 t << "\t-$(DEL_FILE) " << clean.join(" ") << "\n";
723 clean_targets += " lexclean"; 724 clean_targets += " lexclean";
724 } 725 }
725 } 726 }
726 727
727 if(do_incremental) { 728 if(do_incremental) {
728 t << "incrclean:" << "\n"; 729 t << "incrclean:" << "\n";
729 if(src_incremental) 730 if(src_incremental)
730 t << "\t-$(DEL_FILE) $(INCREMENTAL_OBJECTS)" << "\n"; 731 t << "\t-$(DEL_FILE) $(INCREMENTAL_OBJECTS)" << "\n";
731 if(moc_incremental) 732 if(moc_incremental)
732 t << "\t-$(DEL_FILE) $(INCREMENTAL_OBJMOC)" << '\n'; 733 t << "\t-$(DEL_FILE) $(INCREMENTAL_OBJMOC)" << '\n';
733 t << endl; 734 t << endl;
734 } 735 }
735 736
736 t << "clean:" << clean_targets << "\n\t"; 737 t << "clean:" << clean_targets << "\n\t";
737 if(!project->isEmpty("OBJECTS")) 738 if(!project->isEmpty("OBJECTS"))
738 t << "-$(DEL_FILE) $(OBJECTS) " << "\n\t"; 739 t << "-$(DEL_FILE) $(OBJECTS) " << "\n\t";
739 if(!project->isEmpty("IMAGES")) 740 if(!project->isEmpty("IMAGES"))
740 t << varGlue("QMAKE_IMAGE_COLLECTION", "\t-$(DEL_FILE) ", " ", "") << "\n\t"; 741 t << varGlue("QMAKE_IMAGE_COLLECTION", "\t-$(DEL_FILE) ", " ", "") << "\n\t";
741 if(src_incremental) 742 if(src_incremental)
742 t << "-$(DEL_FILE) $(INCREMENTAL_OBJECTS)" << "\n\t"; 743 t << "-$(DEL_FILE) $(INCREMENTAL_OBJECTS)" << "\n\t";
743 t << varGlue("QMAKE_CLEAN","-$(DEL_FILE) "," ","\n\t") 744 t << varGlue("QMAKE_CLEAN","-$(DEL_FILE) "," ","\n\t")
744 << "-$(DEL_FILE) *~ core *.core" << "\n" 745 << "-$(DEL_FILE) *~ core *.core" << "\n"
745 << varGlue("CLEAN_FILES","\t-$(DEL_FILE) "," ","") << endl << endl; 746 << varGlue("CLEAN_FILES","\t-$(DEL_FILE) "," ","") << endl << endl;
746 t << "####### Sub-libraries" << endl << endl; 747 t << "####### Sub-libraries" << endl << endl;
747 if ( !project->variables()["SUBLIBS"].isEmpty() ) { 748 if ( !project->variables()["SUBLIBS"].isEmpty() ) {
748 QString libdir = "tmp/"; 749 QString libdir = "tmp/";
749 if(!project->isEmpty("SUBLIBS_DIR")) 750 if(!project->isEmpty("SUBLIBS_DIR"))
750 libdir = project->first("SUBLIBS_DIR"); 751 libdir = project->first("SUBLIBS_DIR");
751 QStringList &l = project->variables()["SUBLIBS"]; 752 QStringList &l = project->variables()["SUBLIBS"];
752 for(it = l.begin(); it != l.end(); ++it) 753 for(it = l.begin(); it != l.end(); ++it)
753 t << libdir << "lib" << (*it) << ".a" << ":\n\t" 754 t << libdir << "lib" << (*it) << ".a" << ":\n\t"
754 << var(QString("MAKELIB") + (*it)) << endl << endl; 755 << var(QString("MAKELIB") + (*it)) << endl << endl;
755 } 756 }
756 757
757 QString destdir = project->first("DESTDIR"); 758 QString destdir = project->first("DESTDIR");
758 if(!destdir.isEmpty() && destdir.right(1) != Option::dir_sep) 759 if(!destdir.isEmpty() && destdir.right(1) != Option::dir_sep)
759 destdir += Option::dir_sep; 760 destdir += Option::dir_sep;
760 t << "distclean: " << "clean\n"; 761 t << "distclean: " << "clean\n";
761 if(project->first("TEMPLATE") == "app" && 762 if(project->first("TEMPLATE") == "app" &&
762 project->isActiveConfig("resource_fork") && !project->isActiveConfig("console")) 763 project->isActiveConfig("resource_fork") && !project->isActiveConfig("console"))
763 t << "\t-$(DEL_FILE) -r " << destdir.section(Option::dir_sep, 0, -4) << "\n"; 764 t << "\t-$(DEL_FILE) -r " << destdir.section(Option::dir_sep, 0, -4) << "\n";
764 else 765 else
765 t << "\t-$(DEL_FILE) " << destdir << "$(TARGET)" << " " << "$(TARGET)" << "\n"; 766 t << "\t-$(DEL_FILE) " << destdir << "$(TARGET)" << " " << "$(TARGET)" << "\n";
766 if(!project->isActiveConfig("staticlib") && project->variables()["QMAKE_APP_FLAG"].isEmpty() && 767 if(!project->isActiveConfig("staticlib") && project->variables()["QMAKE_APP_FLAG"].isEmpty() &&
767 !project->isActiveConfig("plugin")) 768 !project->isActiveConfig("plugin"))
768 t << "\t-$(DEL_FILE) " << destdir << "$(TARGET0) " << destdir << "$(TARGET1) " 769 t << "\t-$(DEL_FILE) " << destdir << "$(TARGET0) " << destdir << "$(TARGET1) "
769 << destdir << "$(TARGET2) $(TARGETA)" << "\n"; 770 << destdir << "$(TARGET2) $(TARGETA)" << "\n";
770 t << endl << endl; 771 t << endl << endl;
771 772
772 if ( !project->isEmpty("PRECOMPH") ) { 773 if ( !project->isEmpty("PRECOMPH") ) {
773 QString outdir = project->first("MOC_DIR"); 774 QString outdir = project->first("MOC_DIR");
774 QString qt_dot_h = Option::fixPathToLocalOS(project->first("PRECOMPH")); 775 QString qt_dot_h = Option::fixPathToLocalOS(project->first("PRECOMPH"));
775 t << "###### Combined headers" << endl << endl; 776 t << "###### Combined headers" << endl << endl;
776 //XXX 777 //XXX
777 t << outdir << "allmoc.cpp: " << qt_dot_h << " " 778 t << outdir << "allmoc.cpp: " << qt_dot_h << " "
778 << varList("HEADERS_ORIG") << "\n\t" 779 << varList("HEADERS_ORIG") << "\n\t"
779 << "echo '#include \"" << qt_dot_h << "\"' >" << outdir << "allmoc.cpp" << "\n\t" 780 << "echo '#include \"" << qt_dot_h << "\"' >" << outdir << "allmoc.cpp" << "\n\t"
780 << "$(CXX) -E -DQT_MOC_CPP -DQT_NO_STL $(CXXFLAGS) $(INCPATH) >" << outdir << "allmoc.h " 781 << "$(CXX) -E -DQT_MOC_CPP -DQT_NO_STL $(CXXFLAGS) $(INCPATH) >" << outdir << "allmoc.h "
781 << outdir << "allmoc.cpp" << "\n\t" 782 << outdir << "allmoc.cpp" << "\n\t"
782 << "$(MOC) -o " << outdir << "allmoc.cpp " << outdir << "allmoc.h" << "\n\t" 783 << "$(MOC) -o " << outdir << "allmoc.cpp " << outdir << "allmoc.h" << "\n\t"
783 << "perl -pi -e 's{#include \"allmoc.h\"}{#define QT_H_CPP\\n#include \"" 784 << "perl -pi -e 's{#include \"allmoc.h\"}{#define QT_H_CPP\\n#include \""
784 << qt_dot_h << "\"}' " << outdir << "allmoc.cpp" << "\n\t" 785 << qt_dot_h << "\"}' " << outdir << "allmoc.cpp" << "\n\t"
785 << "$(DEL_FILE) " << outdir << "allmoc.h" << endl << endl; 786 << "$(DEL_FILE) " << outdir << "allmoc.h" << endl << endl;
786 } 787 }
787 788
788 // blasted user defined targets 789 // blasted user defined targets
789 QStringList &qut = project->variables()["QMAKE_EXTRA_UNIX_TARGETS"]; 790 QStringList &qut = project->variables()["QMAKE_EXTRA_UNIX_TARGETS"];
790 for(it = qut.begin(); it != qut.end(); ++it) { 791 for(it = qut.begin(); it != qut.end(); ++it) {
791 QString targ = var((*it) + ".target"), 792 QString targ = var((*it) + ".target"),
792 cmd = var((*it) + ".commands"), deps; 793 cmd = var((*it) + ".commands"), deps;
793 if(targ.isEmpty()) 794 if(targ.isEmpty())
794 targ = (*it); 795 targ = (*it);
795 QStringList &deplist = project->variables()[(*it) + ".depends"]; 796 QStringList &deplist = project->variables()[(*it) + ".depends"];
796 for(QStringList::Iterator dep_it = deplist.begin(); dep_it != deplist.end(); ++dep_it) { 797 for(QStringList::Iterator dep_it = deplist.begin(); dep_it != deplist.end(); ++dep_it) {
797 QString dep = var((*dep_it) + ".target"); 798 QString dep = var((*dep_it) + ".target");
798 if(dep.isEmpty()) 799 if(dep.isEmpty())
799 dep = (*dep_it); 800 dep = (*dep_it);
800 deps += " " + dep; 801 deps += " " + dep;
801 } 802 }
802 t << targ << ":" << deps << "\n\t" 803 t << targ << ":" << deps << "\n\t"
803 << cmd << endl << endl; 804 << cmd << endl << endl;
804 } 805 }
805 t <<"FORCE:" << endl << endl; 806 t <<"FORCE:" << endl << endl;
806} 807}
807 808
808struct SubDir 809struct SubDir
809{ 810{
810 QString directory, profile, target, makefile; 811 QString directory, profile, target, makefile;
811}; 812};
812 813
813void 814void
814UnixMakefileGenerator::writeSubdirs(QTextStream &t, bool direct) 815UnixMakefileGenerator::writeSubdirs(QTextStream &t, bool direct)
815{ 816{
816 QPtrList<SubDir> subdirs; 817 QPtrList<SubDir> subdirs;
817 { 818 {
818 QStringList subdirs_in = project->variables()["SUBDIRS"]; 819 QStringList subdirs_in = project->variables()["SUBDIRS"];
819 for(QStringList::Iterator it = subdirs_in.begin(); it != subdirs_in.end(); ++it) { 820 for(QStringList::Iterator it = subdirs_in.begin(); it != subdirs_in.end(); ++it) {
820 QString file = (*it); 821 QString file = (*it);
821 fileFixify(file); 822 fileFixify(file);
822 SubDir *sd = new SubDir; 823 SubDir *sd = new SubDir;
823 subdirs.append(sd); 824 subdirs.append(sd);
824 sd->makefile = "$(MAKEFILE)"; 825 sd->makefile = "$(MAKEFILE)";
825 if((*it).right(4) == ".pro") { 826 if((*it).right(4) == ".pro") {
826 int slsh = file.findRev(Option::dir_sep); 827 int slsh = file.findRev(Option::dir_sep);
827 if(slsh != -1) { 828 if(slsh != -1) {
828 sd->directory = file.left(slsh+1); 829 sd->directory = file.left(slsh+1);
829 sd->profile = file.mid(slsh+1); 830 sd->profile = file.mid(slsh+1);
830 } else { 831 } else {
831 sd->profile = file; 832 sd->profile = file;
832 } 833 }
833 } else { 834 } else {
834 sd->directory = file; 835 sd->directory = file;
835 } 836 }
836 while(sd->directory.right(1) == Option::dir_sep) 837 while(sd->directory.right(1) == Option::dir_sep)
837 sd->directory = sd->directory.left(sd->directory.length() - 1); 838 sd->directory = sd->directory.left(sd->directory.length() - 1);
838 if(!sd->profile.isEmpty()) { 839 if(!sd->profile.isEmpty()) {
839 QString basename = sd->directory; 840 QString basename = sd->directory;
840 int new_slsh = basename.findRev(Option::dir_sep); 841 int new_slsh = basename.findRev(Option::dir_sep);
841 if(new_slsh != -1) 842 if(new_slsh != -1)
842 basename = basename.mid(new_slsh+1); 843 basename = basename.mid(new_slsh+1);
843 if(sd->profile != basename + ".pro") 844 if(sd->profile != basename + ".pro")
844 sd->makefile += "." + sd->profile.left(sd->profile.length() - 4); //no need for the .pro 845 sd->makefile += "." + sd->profile.left(sd->profile.length() - 4); //no need for the .pro
845 } 846 }
846 sd->target = "sub-" + (*it); 847 sd->target = "sub-" + (*it);
847 sd->target.replace('/', '-'); 848 sd->target.replace('/', '-');
848 sd->target.replace('.', '_'); 849 sd->target.replace('.', '_');
849 } 850 }
850 } 851 }
851 QPtrListIterator<SubDir> it(subdirs); 852 QPtrListIterator<SubDir> it(subdirs);
852 853
853 QString ofile = Option::output.name(); 854 QString ofile = Option::output.name();
854 if(ofile.findRev(Option::dir_sep) != -1) 855 if(ofile.findRev(Option::dir_sep) != -1)
855 ofile = ofile.right(ofile.length() - ofile.findRev(Option::dir_sep) -1); 856 ofile = ofile.right(ofile.length() - ofile.findRev(Option::dir_sep) -1);
856 t << "MAKEFILE =" << var("MAKEFILE") << endl; 857 t << "MAKEFILE =" << var("MAKEFILE") << endl;
857 t << "QMAKE =" << var("QMAKE") << endl; 858 t << "QMAKE =" << var("QMAKE") << endl;
858 t << "DEL_FILE = " << var("QMAKE_DEL_FILE") << endl; 859 t << "DEL_FILE = " << var("QMAKE_DEL_FILE") << endl;
859 t << "SUBTARGETS ="; // subdirectory targets are sub-directory 860 t << "SUBTARGETS ="; // subdirectory targets are sub-directory
860 for( it.toFirst(); it.current(); ++it) 861 for( it.toFirst(); it.current(); ++it)
861 t << " \\\n\t\t" << it.current()->target; 862 t << " \\\n\t\t" << it.current()->target;
862 t << endl << endl; 863 t << endl << endl;
863 t << "first: all\n\nall: " << ofile << " $(SUBTARGETS)" << endl << endl; 864 t << "first: all\n\nall: " << ofile << " $(SUBTARGETS)" << endl << endl;
864 865
865 // generate target rules 866 // generate target rules
866 for( it.toFirst(); it.current(); ++it) { 867 for( it.toFirst(); it.current(); ++it) {
867 bool have_dir = !(*it)->directory.isEmpty(); 868 bool have_dir = !(*it)->directory.isEmpty();
868 QString mkfile = (*it)->makefile, out; 869 QString mkfile = (*it)->makefile, out;
869 if(have_dir) 870 if(have_dir)
870 mkfile.prepend((*it)->directory + Option::dir_sep); 871 mkfile.prepend((*it)->directory + Option::dir_sep);
871 if(direct || (*it)->makefile != "$(MAKEFILE)") 872 if(direct || (*it)->makefile != "$(MAKEFILE)")
872 out = " -o " + (*it)->makefile; 873 out = " -o " + (*it)->makefile;
873 //qmake it 874 //qmake it
874 t << mkfile << ": " << "\n\t"; 875 t << mkfile << ": " << "\n\t";
875 if(have_dir) 876 if(have_dir)
876 t << "cd " << (*it)->directory << " && "; 877 t << "cd " << (*it)->directory << " && ";
877 t << "$(QMAKE) " << (*it)->profile << buildArgs() << out << endl; 878 t << "$(QMAKE) " << (*it)->profile << buildArgs() << out << endl;
878 //actually compile 879 //actually compile
879 t << (*it)->target << ": " << mkfile << " FORCE" << "\n\t"; 880 t << (*it)->target << ": " << mkfile << " FORCE" << "\n\t";
880 if(have_dir) 881 if(have_dir)
881 t << "cd " << (*it)->directory << " && "; 882 t << "cd " << (*it)->directory << " && ";
882 t << "$(MAKE) -f " << (*it)->makefile << endl << endl; 883 t << "$(MAKE) -f " << (*it)->makefile << endl << endl;
883 } 884 }
884 885
885 if (project->isActiveConfig("ordered")) { // generate dependencies 886 if (project->isActiveConfig("ordered")) { // generate dependencies
886 for( it.toFirst(); it.current(); ) { 887 for( it.toFirst(); it.current(); ) {
887 QString tar = it.current()->target; 888 QString tar = it.current()->target;
888 ++it; 889 ++it;
889 if (it.current()) 890 if (it.current())
890 t << it.current()->target << ": " << tar << endl; 891 t << it.current()->target << ": " << tar << endl;
891 } 892 }
892 t << endl; 893 t << endl;
893 } 894 }
894 895
895 writeMakeQmake(t); 896 writeMakeQmake(t);
896 897
897 if(project->isEmpty("SUBDIRS")) { 898 if(project->isEmpty("SUBDIRS")) {
898 t << "all qmake_all distclean install uiclean mocclean lexclean yaccclean clean: FORCE" << endl; 899 t << "all qmake_all distclean install uiclean mocclean lexclean yaccclean clean: FORCE" << endl;
899 } else { 900 } else {
900 t << "all: $(SUBTARGETS)" << endl; 901 t << "all: $(SUBTARGETS)" << endl;
901 t << "qmake_all:"; 902 t << "qmake_all:";
902 for( it.toFirst(); it.current(); ++it) { 903 for( it.toFirst(); it.current(); ++it) {
903 t << " "; 904 t << " ";
904 if(!(*it)->directory.isEmpty()) 905 if(!(*it)->directory.isEmpty())
905 t << (*it)->directory << Option::dir_sep; 906 t << (*it)->directory << Option::dir_sep;
906 t << (*it)->makefile; 907 t << (*it)->makefile;
907 } 908 }
908 for( it.toFirst(); it.current(); ++it) { 909 for( it.toFirst(); it.current(); ++it) {
909 t << "\n\t ( "; 910 t << "\n\t ( ";
910 if(!(*it)->directory.isEmpty()) 911 if(!(*it)->directory.isEmpty())
911 t << "[ -d " << (*it)->directory << " ] && cd " << (*it)->directory << " ; "; 912 t << "[ -d " << (*it)->directory << " ] && cd " << (*it)->directory << " ; ";
912 t << "grep \"^qmake_all:\" " << (*it)->makefile 913 t << "grep \"^qmake_all:\" " << (*it)->makefile
913 << " && $(MAKE) -f " << (*it)->makefile << " qmake_all" << "; ) || true"; 914 << " && $(MAKE) -f " << (*it)->makefile << " qmake_all" << "; ) || true";
914 } 915 }
915 t << endl; 916 t << endl;
916 t << "clean uninstall install uiclean mocclean lexclean yaccclean: qmake_all FORCE"; 917 t << "clean uninstall install uiclean mocclean lexclean yaccclean: qmake_all FORCE";
917 for( it.toFirst(); it.current(); ++it) { 918 for( it.toFirst(); it.current(); ++it) {
918 t << "\n\t ( "; 919 t << "\n\t ( ";
919 if(!(*it)->directory.isEmpty()) 920 if(!(*it)->directory.isEmpty())
920 t << "[ -d " << (*it)->directory << " ] && cd " << (*it)->directory << " ; "; 921 t << "[ -d " << (*it)->directory << " ] && cd " << (*it)->directory << " ; ";
921 t << "$(MAKE) -f " << (*it)->makefile << " $@" << "; ) || true"; 922 t << "$(MAKE) -f " << (*it)->makefile << " $@" << "; ) || true";
922 } 923 }
923 t << endl; 924 t << endl;
924 t << "distclean: qmake_all FORCE"; 925 t << "distclean: qmake_all FORCE";
925 for( it.toFirst(); it.current(); ++it) { 926 for( it.toFirst(); it.current(); ++it) {
926 t << "\n\t ( "; 927 t << "\n\t ( ";
927 if(!(*it)->directory.isEmpty()) 928 if(!(*it)->directory.isEmpty())
928 t << "[ -d " << (*it)->directory << " ] && cd " << (*it)->directory << " ; "; 929 t << "[ -d " << (*it)->directory << " ] && cd " << (*it)->directory << " ; ";
929 t << "$(MAKE) -f " << (*it)->makefile << " $@; $(DEL_FILE) " << (*it)->makefile << "; ) || true"; 930 t << "$(MAKE) -f " << (*it)->makefile << " $@; $(DEL_FILE) " << (*it)->makefile << "; ) || true";
930 } 931 }
931 t << endl << endl; 932 t << endl << endl;
932 } 933 }
933 t <<"FORCE:" << endl << endl; 934 t <<"FORCE:" << endl << endl;
934} 935}
935 936
936void UnixMakefileGenerator::init2() 937void UnixMakefileGenerator::init2()
937{ 938{
938 //version handling 939 //version handling
939 if(project->variables()["VERSION"].isEmpty()) 940 if(project->variables()["VERSION"].isEmpty())
940 project->variables()["VERSION"].append("1.0." + 941 project->variables()["VERSION"].append("1.0." +
941 (project->isEmpty("VER_PAT") ? QString("0") : 942 (project->isEmpty("VER_PAT") ? QString("0") :
942 project->first("VER_PAT")) ); 943 project->first("VER_PAT")) );
943 QStringList l = QStringList::split('.', project->first("VERSION")); 944 QStringList l = QStringList::split('.', project->first("VERSION"));
944 l << "0" << "0"; //make sure there are three 945 l << "0" << "0"; //make sure there are three
945 project->variables()["VER_MAJ"].append(l[0]); 946 project->variables()["VER_MAJ"].append(l[0]);
946 project->variables()["VER_MIN"].append(l[1]); 947 project->variables()["VER_MIN"].append(l[1]);
947 project->variables()["VER_PAT"].append(l[2]); 948 project->variables()["VER_PAT"].append(l[2]);
948 949
949 if ( !project->variables()["QMAKE_APP_FLAG"].isEmpty() ) { 950 if ( !project->variables()["QMAKE_APP_FLAG"].isEmpty() ) {
950#if 0 951#if 0
951 if ( project->isActiveConfig("dll") ) { 952 if ( project->isActiveConfig("dll") ) {
952 project->variables()["TARGET"] += project->variables()["TARGET.so"]; 953 project->variables()["TARGET"] += project->variables()["TARGET.so"];
953 if(project->variables()["QMAKE_LFLAGS_SHAPP"].isEmpty()) 954 if(project->variables()["QMAKE_LFLAGS_SHAPP"].isEmpty())
954 project->variables()["QMAKE_LFLAGS_SHAPP"] += project->variables()["QMAKE_LFLAGS_SHLIB"]; 955 project->variables()["QMAKE_LFLAGS_SHAPP"] += project->variables()["QMAKE_LFLAGS_SHLIB"];
955 if(!project->variables()["QMAKE_LFLAGS_SONAME"].isEmpty()) 956 if(!project->variables()["QMAKE_LFLAGS_SONAME"].isEmpty())
956 project->variables()["QMAKE_LFLAGS_SONAME"].first() += project->first("TARGET"); 957 project->variables()["QMAKE_LFLAGS_SONAME"].first() += project->first("TARGET");
957 } 958 }
958#endif 959#endif
959 project->variables()["TARGET"].first().prepend(project->first("DESTDIR")); 960 project->variables()["TARGET"].first().prepend(project->first("DESTDIR"));
960 if ( !project->variables()["QMAKE_CYGWIN_EXE"].isEmpty() ) 961 if ( !project->variables()["QMAKE_CYGWIN_EXE"].isEmpty() )
961 project->variables()["TARGET_EXT"].append(".exe"); 962 project->variables()["TARGET_EXT"].append(".exe");
962 } else if ( project->isActiveConfig("staticlib") ) { 963 } else if ( project->isActiveConfig("staticlib") ) {
963 project->variables()["TARGET"].first().prepend("lib"); 964 project->variables()["TARGET"].first().prepend("lib");
964 project->variables()["TARGET"].first() += ".a"; 965 project->variables()["TARGET"].first() += ".a";
965 if(project->variables()["QMAKE_AR_CMD"].isEmpty()) 966 if(project->variables()["QMAKE_AR_CMD"].isEmpty())
966 project->variables()["QMAKE_AR_CMD"].append("$(AR) $(TARGET) $(OBJECTS) $(OBJMOC)"); 967 project->variables()["QMAKE_AR_CMD"].append("$(AR) $(TARGET) $(OBJECTS) $(OBJMOC)");
967 } else { 968 } else {
968 project->variables()["TARGETA"].append(project->first("DESTDIR") + "lib" + project->first("TARGET") + ".a"); 969 project->variables()["TARGETA"].append(project->first("DESTDIR") + "lib" + project->first("TARGET") + ".a");
969 if ( !project->variables()["QMAKE_AR_CMD"].isEmpty() ) 970 if ( !project->variables()["QMAKE_AR_CMD"].isEmpty() )
970 project->variables()["QMAKE_AR_CMD"].first().replace("(TARGET)","(TARGETA)"); 971 project->variables()["QMAKE_AR_CMD"].first().replace("(TARGET)","(TARGETA)");
971 else 972 else
972 project->variables()["QMAKE_AR_CMD"].append("$(AR) $(TARGETA) $(OBJECTS) $(OBJMOC)"); 973 project->variables()["QMAKE_AR_CMD"].append("$(AR) $(TARGETA) $(OBJECTS) $(OBJMOC)");
973 if( project->isActiveConfig("plugin") ) { 974 if( project->isActiveConfig("plugin") ) {
974 project->variables()["TARGET_x.y.z"].append("lib" + 975 project->variables()["TARGET_x.y.z"].append("lib" +
975 project->first("TARGET") + "." + project->first("QMAKE_EXTENSION_SHLIB")); 976 project->first("TARGET") + "." + project->first("QMAKE_EXTENSION_SHLIB"));
976 if(project->isActiveConfig("lib_version_first")) 977 if(project->isActiveConfig("lib_version_first"))
977 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." + 978 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." +
978 project->first("VER_MAJ") + "." + 979 project->first("VER_MAJ") + "." +
979 project->first("QMAKE_EXTENSION_SHLIB")); 980 project->first("QMAKE_EXTENSION_SHLIB"));
980 else 981 else
981 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." + 982 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." +
982 project->first("QMAKE_EXTENSION_SHLIB") + 983 project->first("QMAKE_EXTENSION_SHLIB") +
983 "." + project->first("VER_MAJ")); 984 "." + project->first("VER_MAJ"));
984 985
985 project->variables()["TARGET"] = project->variables()["TARGET_x.y.z"]; 986 project->variables()["TARGET"] = project->variables()["TARGET_x.y.z"];
986 if(project->isActiveConfig("qt")) 987 if(project->isActiveConfig("qt"))
987 project->variables()["DEFINES"].append("QT_PLUGIN"); 988 project->variables()["DEFINES"].append("QT_PLUGIN");
988 } else if ( !project->isEmpty("QMAKE_HPUX_SHLIB") ) { 989 } else if ( !project->isEmpty("QMAKE_HPUX_SHLIB") ) {
989 project->variables()["TARGET_"].append("lib" + project->first("TARGET") + ".sl"); 990 project->variables()["TARGET_"].append("lib" + project->first("TARGET") + ".sl");
990 if(project->isActiveConfig("lib_version_first")) 991 if(project->isActiveConfig("lib_version_first"))
991 project->variables()["TARGET_x"].append("lib" + project->first("VER_MAJ") + "." + 992 project->variables()["TARGET_x"].append("lib" + project->first("VER_MAJ") + "." +
992 project->first("TARGET")); 993 project->first("TARGET"));
993 else 994 else
994 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." + 995 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." +
995 project->first("VER_MAJ")); 996 project->first("VER_MAJ"));
996 project->variables()["TARGET"] = project->variables()["TARGET_x"]; 997 project->variables()["TARGET"] = project->variables()["TARGET_x"];
997 } else if ( !project->isEmpty("QMAKE_AIX_SHLIB") ) { 998 } else if ( !project->isEmpty("QMAKE_AIX_SHLIB") ) {
998 project->variables()["TARGET_"].append("lib" + project->first("TARGET") + ".a"); 999 project->variables()["TARGET_"].append("lib" + project->first("TARGET") + ".a");
999 if(project->isActiveConfig("lib_version_first")) { 1000 if(project->isActiveConfig("lib_version_first")) {
1000 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." + 1001 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." +
1001 project->first("VER_MAJ") + "." + 1002 project->first("VER_MAJ") + "." +
1002 project->first("QMAKE_EXTENSION_SHLIB")); 1003 project->first("QMAKE_EXTENSION_SHLIB"));
1003 project->variables()["TARGET_x.y"].append("lib" + project->first("TARGET") + "." + 1004 project->variables()["TARGET_x.y"].append("lib" + project->first("TARGET") + "." +
1004 project->first("VER_MAJ") + 1005 project->first("VER_MAJ") +
1005 "." + project->first("VER_MIN") + "." + 1006 "." + project->first("VER_MIN") + "." +
1006 project->first("QMAKE_EXTENSION_SHLIB")); 1007 project->first("QMAKE_EXTENSION_SHLIB"));
1007 project->variables()["TARGET_x.y.z"].append("lib" + project->first("TARGET") + "." + 1008 project->variables()["TARGET_x.y.z"].append("lib" + project->first("TARGET") + "." +
1008 project->first("VER_MAJ") + "." + 1009 project->first("VER_MAJ") + "." +
1009 project->first("VER_MIN") + "." + 1010 project->first("VER_MIN") + "." +
1010 project->first("VER_PAT") + "." + 1011 project->first("VER_PAT") + "." +
1011 project->first("QMAKE_EXTENSION_SHLIB")); 1012 project->first("QMAKE_EXTENSION_SHLIB"));
1012 } else { 1013 } else {
1013 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." + 1014 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." +
1014 project->first("QMAKE_EXTENSION_SHLIB") + 1015 project->first("QMAKE_EXTENSION_SHLIB") +
1015 "." + project->first("VER_MAJ")); 1016 "." + project->first("VER_MAJ"));
1016 project->variables()["TARGET_x.y"].append("lib" + project->first("TARGET") + "." + 1017 project->variables()["TARGET_x.y"].append("lib" + project->first("TARGET") + "." +
1017 project->first("QMAKE_EXTENSION_SHLIB") + 1018 project->first("QMAKE_EXTENSION_SHLIB") +
1018 "." + project->first("VER_MAJ") + 1019 "." + project->first("VER_MAJ") +
1019 "." + project->first("VER_MIN")); 1020 "." + project->first("VER_MIN"));
1020 project->variables()["TARGET_x.y.z"].append("lib" + project->first("TARGET") + "." + 1021 project->variables()["TARGET_x.y.z"].append("lib" + project->first("TARGET") + "." +
1021 project->first("QMAKE_EXTENSION_SHLIB") + "." + 1022 project->first("QMAKE_EXTENSION_SHLIB") + "." +
1022 project->first("VER_MAJ") + "." + 1023 project->first("VER_MAJ") + "." +
1023 project->first("VER_MIN") + "." + 1024 project->first("VER_MIN") + "." +
1024 project->first("VER_PAT")); 1025 project->first("VER_PAT"));
1025 } 1026 }
1026 project->variables()["TARGET"] = project->variables()["TARGET_x.y.z"]; 1027 project->variables()["TARGET"] = project->variables()["TARGET_x.y.z"];
1027 } else { 1028 } else {
1028 project->variables()["TARGET_"].append("lib" + project->first("TARGET") + "." + 1029 project->variables()["TARGET_"].append("lib" + project->first("TARGET") + "." +
1029 project->first("QMAKE_EXTENSION_SHLIB")); 1030 project->first("QMAKE_EXTENSION_SHLIB"));
1030 if(project->isActiveConfig("lib_version_first")) { 1031 if(project->isActiveConfig("lib_version_first")) {
1031 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." + 1032 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." +
1032 project->first("VER_MAJ") + "." + 1033 project->first("VER_MAJ") + "." +
1033 project->first("QMAKE_EXTENSION_SHLIB")); 1034 project->first("QMAKE_EXTENSION_SHLIB"));
1034 project->variables()["TARGET_x.y"].append("lib" + project->first("TARGET") + "." + 1035 project->variables()["TARGET_x.y"].append("lib" + project->first("TARGET") + "." +
1035 project->first("VER_MAJ") + 1036 project->first("VER_MAJ") +
1036 "." + project->first("VER_MIN") + "." + 1037 "." + project->first("VER_MIN") + "." +
1037 project->first("QMAKE_EXTENSION_SHLIB")); 1038 project->first("QMAKE_EXTENSION_SHLIB"));
1038 project->variables()["TARGET_x.y.z"].append("lib" + project->first("TARGET") + "." + 1039 project->variables()["TARGET_x.y.z"].append("lib" + project->first("TARGET") + "." +
1039 project->first("VER_MAJ") + "." + 1040 project->first("VER_MAJ") + "." +
1040 project->first("VER_MIN") + "." + 1041 project->first("VER_MIN") + "." +
1041 project->first("VER_PAT") + "." + 1042 project->first("VER_PAT") + "." +
1042 project->variables()["QMAKE_EXTENSION_SHLIB"].first()); 1043 project->variables()["QMAKE_EXTENSION_SHLIB"].first());
1043 } else { 1044 } else {
1044 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." + 1045 project->variables()["TARGET_x"].append("lib" + project->first("TARGET") + "." +
1045 project->first("QMAKE_EXTENSION_SHLIB") + 1046 project->first("QMAKE_EXTENSION_SHLIB") +
1046 "." + project->first("VER_MAJ")); 1047 "." + project->first("VER_MAJ"));
1047 project->variables()["TARGET_x.y"].append("lib" + project->first("TARGET") + "." + 1048 project->variables()["TARGET_x.y"].append("lib" + project->first("TARGET") + "." +
1048 project->first("QMAKE_EXTENSION_SHLIB") 1049 project->first("QMAKE_EXTENSION_SHLIB")
1049 + "." + project->first("VER_MAJ") + 1050 + "." + project->first("VER_MAJ") +
1050 "." + project->first("VER_MIN")); 1051 "." + project->first("VER_MIN"));
1051 project->variables()["TARGET_x.y.z"].append("lib" + project->first("TARGET") + 1052 project->variables()["TARGET_x.y.z"].append("lib" + project->first("TARGET") +
1052 "." + 1053 "." +
1053 project->variables()[ 1054 project->variables()[
1054 "QMAKE_EXTENSION_SHLIB"].first() + "." + 1055 "QMAKE_EXTENSION_SHLIB"].first() + "." +
1055 project->first("VER_MAJ") + "." + 1056 project->first("VER_MAJ") + "." +
1056 project->first("VER_MIN") + "." + 1057 project->first("VER_MIN") + "." +
1057 project->first("VER_PAT")); 1058 project->first("VER_PAT"));
1058 } 1059 }
1059 project->variables()["TARGET"] = project->variables()["TARGET_x.y.z"]; 1060 project->variables()["TARGET"] = project->variables()["TARGET_x.y.z"];
1060 } 1061 }
1061 if(project->isEmpty("QMAKE_LN_SHLIB")) 1062 if(project->isEmpty("QMAKE_LN_SHLIB"))
1062 project->variables()["QMAKE_LN_SHLIB"].append("ln -s"); 1063 project->variables()["QMAKE_LN_SHLIB"].append("ln -s");
1063 project->variables()["DESTDIR_TARGET"].append("$(TARGET)"); 1064 project->variables()["DESTDIR_TARGET"].append("$(TARGET)");
1064 if ( !project->variables()["DESTDIR"].isEmpty() ) 1065 if ( !project->variables()["DESTDIR"].isEmpty() )
1065 project->variables()["DESTDIR_TARGET"].first().prepend(project->first("DESTDIR")); 1066 project->variables()["DESTDIR_TARGET"].first().prepend(project->first("DESTDIR"));
1066 if ( !project->variables()["QMAKE_LFLAGS_SONAME"].isEmpty()) { 1067 if ( !project->variables()["QMAKE_LFLAGS_SONAME"].isEmpty()) {
1067 if(project->isActiveConfig("plugin")) { 1068 if(project->isActiveConfig("plugin")) {
1068 if(!project->variables()["TARGET"].isEmpty() ) 1069 if(!project->variables()["TARGET"].isEmpty() )
1069 project->variables()["QMAKE_LFLAGS_SONAME"].first() += project->first("TARGET"); 1070 project->variables()["QMAKE_LFLAGS_SONAME"].first() += project->first("TARGET");
1070 } else { 1071 } else {
1071 if(!project->variables()["TARGET_x"].isEmpty() ) 1072 if(!project->variables()["TARGET_x"].isEmpty() )
1072 project->variables()["QMAKE_LFLAGS_SONAME"].first() += project->first("TARGET_x"); 1073 project->variables()["QMAKE_LFLAGS_SONAME"].first() += project->first("TARGET_x");
1073 } 1074 }
1074 } 1075 }
1075 if ( project->variables()["QMAKE_LINK_SHLIB_CMD"].isEmpty() ) 1076 if ( project->variables()["QMAKE_LINK_SHLIB_CMD"].isEmpty() )
1076 project->variables()["QMAKE_LINK_SHLIB_CMD"].append( 1077 project->variables()["QMAKE_LINK_SHLIB_CMD"].append(
1077 "$(LINK) $(LFLAGS) -o $(TARGET) $(OBJECTS) $(OBJMOC) $(LIBS)"); 1078 "$(LINK) $(LFLAGS) -o $(TARGET) $(OBJECTS) $(OBJMOC) $(LIBS)");
1078 } 1079 }
1079 if(project->isEmpty("QMAKE_SYMBOLIC_LINK")) 1080 if(project->isEmpty("QMAKE_SYMBOLIC_LINK"))
1080 project->variables()["QMAKE_SYMBOLIC_LINK"].append("ln -sf"); 1081 project->variables()["QMAKE_SYMBOLIC_LINK"].append("ln -sf");
1081 if ( !project->variables()["QMAKE_APP_FLAG"].isEmpty() ) { 1082 if ( !project->variables()["QMAKE_APP_FLAG"].isEmpty() ) {
1082 project->variables()["QMAKE_LFLAGS"] += project->variables()["QMAKE_LFLAGS_SHAPP"]; 1083 project->variables()["QMAKE_LFLAGS"] += project->variables()["QMAKE_LFLAGS_SHAPP"];
1083 } else if ( project->isActiveConfig("dll") ) { 1084 } else if ( project->isActiveConfig("dll") ) {
1084 project->variables()["QMAKE_CFLAGS"] += project->variables()["QMAKE_CFLAGS_SHLIB"]; 1085 project->variables()["QMAKE_CFLAGS"] += project->variables()["QMAKE_CFLAGS_SHLIB"];
1085 project->variables()["QMAKE_CXXFLAGS"] += project->variables()["QMAKE_CXXFLAGS_SHLIB"]; 1086 project->variables()["QMAKE_CXXFLAGS"] += project->variables()["QMAKE_CXXFLAGS_SHLIB"];
1086 if ( project->isActiveConfig("plugin") ) { 1087 if ( project->isActiveConfig("plugin") ) {
1087 project->variables()["QMAKE_LFLAGS"] += project->variables()["QMAKE_LFLAGS_PLUGIN"]; 1088 project->variables()["QMAKE_LFLAGS"] += project->variables()["QMAKE_LFLAGS_PLUGIN"];
1088 if( !project->isActiveConfig("plugin_no_soname") ) 1089 if( !project->isActiveConfig("plugin_no_soname") )
1089 project->variables()["QMAKE_LFLAGS"] += project->variables()["QMAKE_LFLAGS_SONAME"]; 1090 project->variables()["QMAKE_LFLAGS"] += project->variables()["QMAKE_LFLAGS_SONAME"];
1090 } else { 1091 } else {
1091 project->variables()["QMAKE_LFLAGS"] += project->variables()["QMAKE_LFLAGS_SHLIB"]; 1092 project->variables()["QMAKE_LFLAGS"] += project->variables()["QMAKE_LFLAGS_SHLIB"];
1092 project->variables()["QMAKE_LFLAGS"] += project->variables()["QMAKE_LFLAGS_SONAME"]; 1093 project->variables()["QMAKE_LFLAGS"] += project->variables()["QMAKE_LFLAGS_SONAME"];
1093 } 1094 }
1094 QString destdir = project->first("DESTDIR"); 1095 QString destdir = project->first("DESTDIR");
1095 if ( !destdir.isEmpty() && !project->variables()["QMAKE_RPATH"].isEmpty() ) { 1096 if ( !destdir.isEmpty() && !project->variables()["QMAKE_RPATH"].isEmpty() ) {
1096 QString rpath_destdir = destdir; 1097 QString rpath_destdir = destdir;
1097 if(QDir::isRelativePath(rpath_destdir)) { 1098 if(QDir::isRelativePath(rpath_destdir)) {
1098 QFileInfo fi(Option::fixPathToLocalOS(rpath_destdir)); 1099 QFileInfo fi(Option::fixPathToLocalOS(rpath_destdir));
1099 if(fi.convertToAbs()) //strange, shouldn't really happen 1100 if(fi.convertToAbs()) //strange, shouldn't really happen
1100 rpath_destdir = Option::fixPathToTargetOS(rpath_destdir, FALSE); 1101 rpath_destdir = Option::fixPathToTargetOS(rpath_destdir, FALSE);
1101 else 1102 else
1102 rpath_destdir = fi.filePath(); 1103 rpath_destdir = fi.filePath();
1103 } else { 1104 } else {
1104 rpath_destdir = Option::fixPathToTargetOS(rpath_destdir, FALSE); 1105 rpath_destdir = Option::fixPathToTargetOS(rpath_destdir, FALSE);
1105 } 1106 }
1106 project->variables()["QMAKE_LFLAGS"] += project->first("QMAKE_RPATH") + rpath_destdir; 1107 project->variables()["QMAKE_LFLAGS"] += project->first("QMAKE_RPATH") + rpath_destdir;
1107 } 1108 }
1108 } 1109 }
1109} 1110}