annotate generator/fileout.cpp @ 328:9327c7cca8f5 signals

todo file as we don't use bugzilla a lot.
author eldar1@eldar1-laptop
date Sun, 03 Jan 2010 12:40:51 +0000
parents e78566595089
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
e78566595089 initial import
mandel
parents:
diff changeset
1 /****************************************************************************
e78566595089 initial import
mandel
parents:
diff changeset
2 **
e78566595089 initial import
mandel
parents:
diff changeset
3 ** Copyright (C) 1992-2008 Nokia. All rights reserved.
e78566595089 initial import
mandel
parents:
diff changeset
4 **
e78566595089 initial import
mandel
parents:
diff changeset
5 ** This file is part of Qt Jambi.
e78566595089 initial import
mandel
parents:
diff changeset
6 **
e78566595089 initial import
mandel
parents:
diff changeset
7 ** * Commercial Usage
e78566595089 initial import
mandel
parents:
diff changeset
8 * Licensees holding valid Qt Commercial licenses may use this file in
e78566595089 initial import
mandel
parents:
diff changeset
9 * accordance with the Qt Commercial License Agreement provided with the
e78566595089 initial import
mandel
parents:
diff changeset
10 * Software or, alternatively, in accordance with the terms contained in
e78566595089 initial import
mandel
parents:
diff changeset
11 * a written agreement between you and Nokia.
e78566595089 initial import
mandel
parents:
diff changeset
12 *
e78566595089 initial import
mandel
parents:
diff changeset
13 *
e78566595089 initial import
mandel
parents:
diff changeset
14 * GNU General Public License Usage
e78566595089 initial import
mandel
parents:
diff changeset
15 * Alternatively, this file may be used under the terms of the GNU
e78566595089 initial import
mandel
parents:
diff changeset
16 * General Public License versions 2.0 or 3.0 as published by the Free
e78566595089 initial import
mandel
parents:
diff changeset
17 * Software Foundation and appearing in the file LICENSE.GPL included in
e78566595089 initial import
mandel
parents:
diff changeset
18 * the packaging of this file. Please review the following information
e78566595089 initial import
mandel
parents:
diff changeset
19 * to ensure GNU General Public Licensing requirements will be met:
e78566595089 initial import
mandel
parents:
diff changeset
20 * http://www.fsf.org/licensing/licenses/info/GPLv2.html and
e78566595089 initial import
mandel
parents:
diff changeset
21 * http://www.gnu.org/copyleft/gpl.html. In addition, as a special
e78566595089 initial import
mandel
parents:
diff changeset
22 * exception, Nokia gives you certain additional rights. These rights
e78566595089 initial import
mandel
parents:
diff changeset
23 * are described in the Nokia Qt GPL Exception version 1.2, included in
e78566595089 initial import
mandel
parents:
diff changeset
24 * the file GPL_EXCEPTION.txt in this package.
e78566595089 initial import
mandel
parents:
diff changeset
25 *
e78566595089 initial import
mandel
parents:
diff changeset
26 * Qt for Windows(R) Licensees
e78566595089 initial import
mandel
parents:
diff changeset
27 * As a special exception, Nokia, as the sole copyright holder for Qt
e78566595089 initial import
mandel
parents:
diff changeset
28 * Designer, grants users of the Qt/Eclipse Integration plug-in the
e78566595089 initial import
mandel
parents:
diff changeset
29 * right for the Qt/Eclipse Integration to link to functionality
e78566595089 initial import
mandel
parents:
diff changeset
30 * provided by Qt Designer and its related libraries.
e78566595089 initial import
mandel
parents:
diff changeset
31 *
e78566595089 initial import
mandel
parents:
diff changeset
32 *
e78566595089 initial import
mandel
parents:
diff changeset
33 * If you are unsure which license is appropriate for your use, please
e78566595089 initial import
mandel
parents:
diff changeset
34 * contact the sales department at qt-sales@nokia.com.
e78566595089 initial import
mandel
parents:
diff changeset
35
e78566595089 initial import
mandel
parents:
diff changeset
36 **
e78566595089 initial import
mandel
parents:
diff changeset
37 ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
e78566595089 initial import
mandel
parents:
diff changeset
38 ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
e78566595089 initial import
mandel
parents:
diff changeset
39 **
e78566595089 initial import
mandel
parents:
diff changeset
40 ****************************************************************************/
e78566595089 initial import
mandel
parents:
diff changeset
41
e78566595089 initial import
mandel
parents:
diff changeset
42 #include "fileout.h"
e78566595089 initial import
mandel
parents:
diff changeset
43 #include "reporthandler.h"
e78566595089 initial import
mandel
parents:
diff changeset
44
e78566595089 initial import
mandel
parents:
diff changeset
45 #include <QFileInfo>
e78566595089 initial import
mandel
parents:
diff changeset
46 #include <QDir>
e78566595089 initial import
mandel
parents:
diff changeset
47
e78566595089 initial import
mandel
parents:
diff changeset
48 bool FileOut::dummy = false;
e78566595089 initial import
mandel
parents:
diff changeset
49 bool FileOut::diff = false;
e78566595089 initial import
mandel
parents:
diff changeset
50
e78566595089 initial import
mandel
parents:
diff changeset
51 #ifdef Q_OS_LINUX
e78566595089 initial import
mandel
parents:
diff changeset
52 const char* colorDelete = "\033[31m";
e78566595089 initial import
mandel
parents:
diff changeset
53 const char* colorAdd = "\033[32m";
e78566595089 initial import
mandel
parents:
diff changeset
54 const char* colorInfo = "\033[36m";
e78566595089 initial import
mandel
parents:
diff changeset
55 const char* colorReset = "\033[0m";
e78566595089 initial import
mandel
parents:
diff changeset
56 #else
e78566595089 initial import
mandel
parents:
diff changeset
57 const char* colorDelete = "";
e78566595089 initial import
mandel
parents:
diff changeset
58 const char* colorAdd = "";
e78566595089 initial import
mandel
parents:
diff changeset
59 const char* colorInfo = "";
e78566595089 initial import
mandel
parents:
diff changeset
60 const char* colorReset = "";
e78566595089 initial import
mandel
parents:
diff changeset
61 #endif
e78566595089 initial import
mandel
parents:
diff changeset
62
e78566595089 initial import
mandel
parents:
diff changeset
63 FileOut::FileOut(QString n):
e78566595089 initial import
mandel
parents:
diff changeset
64 m_name(n),
e78566595089 initial import
mandel
parents:
diff changeset
65 stream(&tmp),
e78566595089 initial import
mandel
parents:
diff changeset
66 isDone(false)
e78566595089 initial import
mandel
parents:
diff changeset
67 {}
e78566595089 initial import
mandel
parents:
diff changeset
68
e78566595089 initial import
mandel
parents:
diff changeset
69 static int* lcsLength(QList<QByteArray> a, QList<QByteArray> b) {
e78566595089 initial import
mandel
parents:
diff changeset
70 const int height = a.size() + 1;
e78566595089 initial import
mandel
parents:
diff changeset
71 const int width = b.size() + 1;
e78566595089 initial import
mandel
parents:
diff changeset
72
e78566595089 initial import
mandel
parents:
diff changeset
73 int *res = new int[width * height];
e78566595089 initial import
mandel
parents:
diff changeset
74
e78566595089 initial import
mandel
parents:
diff changeset
75 for (int row=0; row<height; row++) {
e78566595089 initial import
mandel
parents:
diff changeset
76 res[width * row] = 0;
e78566595089 initial import
mandel
parents:
diff changeset
77 }
e78566595089 initial import
mandel
parents:
diff changeset
78 for (int col=0; col<width; col++) {
e78566595089 initial import
mandel
parents:
diff changeset
79 res[col] = 0;
e78566595089 initial import
mandel
parents:
diff changeset
80 }
e78566595089 initial import
mandel
parents:
diff changeset
81
e78566595089 initial import
mandel
parents:
diff changeset
82 for (int row=1; row<height; row++) {
e78566595089 initial import
mandel
parents:
diff changeset
83 for (int col=1; col<width; col++) {
e78566595089 initial import
mandel
parents:
diff changeset
84
e78566595089 initial import
mandel
parents:
diff changeset
85 if (a[row-1] == b[col-1])
e78566595089 initial import
mandel
parents:
diff changeset
86 res[width * row + col] = res[width * (row-1) + col-1] + 1;
e78566595089 initial import
mandel
parents:
diff changeset
87 else
e78566595089 initial import
mandel
parents:
diff changeset
88 res[width * row + col] = qMax(res[width * row + col-1],
e78566595089 initial import
mandel
parents:
diff changeset
89 res[width * (row-1) + col]);
e78566595089 initial import
mandel
parents:
diff changeset
90 }
e78566595089 initial import
mandel
parents:
diff changeset
91 }
e78566595089 initial import
mandel
parents:
diff changeset
92 return res;
e78566595089 initial import
mandel
parents:
diff changeset
93 }
e78566595089 initial import
mandel
parents:
diff changeset
94
e78566595089 initial import
mandel
parents:
diff changeset
95 enum Type {Add, Delete, Unchanged};
e78566595089 initial import
mandel
parents:
diff changeset
96
e78566595089 initial import
mandel
parents:
diff changeset
97 struct Unit
e78566595089 initial import
mandel
parents:
diff changeset
98 {
e78566595089 initial import
mandel
parents:
diff changeset
99 Unit(Type type, int pos) :
e78566595089 initial import
mandel
parents:
diff changeset
100 type(type),
e78566595089 initial import
mandel
parents:
diff changeset
101 start(pos),
e78566595089 initial import
mandel
parents:
diff changeset
102 end(pos)
e78566595089 initial import
mandel
parents:
diff changeset
103 {}
e78566595089 initial import
mandel
parents:
diff changeset
104
e78566595089 initial import
mandel
parents:
diff changeset
105 Type type;
e78566595089 initial import
mandel
parents:
diff changeset
106 int start;
e78566595089 initial import
mandel
parents:
diff changeset
107 int end;
e78566595089 initial import
mandel
parents:
diff changeset
108
e78566595089 initial import
mandel
parents:
diff changeset
109 void print(QList<QByteArray> a, QList<QByteArray> b){
e78566595089 initial import
mandel
parents:
diff changeset
110 {
e78566595089 initial import
mandel
parents:
diff changeset
111 if (type == Unchanged) {
e78566595089 initial import
mandel
parents:
diff changeset
112 if ((end - start) > 9) {
e78566595089 initial import
mandel
parents:
diff changeset
113 for (int i = start; i <= start+2; i++)
e78566595089 initial import
mandel
parents:
diff changeset
114 printf(" %s\n", a[i].data());
e78566595089 initial import
mandel
parents:
diff changeset
115 printf("%s=\n= %d more lines\n=%s\n", colorInfo, end - start - 6, colorReset);
e78566595089 initial import
mandel
parents:
diff changeset
116 for (int i = end-2; i <= end; i++)
e78566595089 initial import
mandel
parents:
diff changeset
117 printf(" %s\n", a[i].data());
e78566595089 initial import
mandel
parents:
diff changeset
118 }
e78566595089 initial import
mandel
parents:
diff changeset
119 else
e78566595089 initial import
mandel
parents:
diff changeset
120 for (int i = start; i <= end; i++)
e78566595089 initial import
mandel
parents:
diff changeset
121 printf(" %s\n", a[i].data());
e78566595089 initial import
mandel
parents:
diff changeset
122 }
e78566595089 initial import
mandel
parents:
diff changeset
123 else if(type == Add) {
e78566595089 initial import
mandel
parents:
diff changeset
124 printf("%s", colorAdd);
e78566595089 initial import
mandel
parents:
diff changeset
125 for (int i = start; i <= end; i++){
e78566595089 initial import
mandel
parents:
diff changeset
126 printf("+ %s\n", b[i].data());
e78566595089 initial import
mandel
parents:
diff changeset
127 }
e78566595089 initial import
mandel
parents:
diff changeset
128 printf("%s", colorReset);
e78566595089 initial import
mandel
parents:
diff changeset
129 }
e78566595089 initial import
mandel
parents:
diff changeset
130 else if (type == Delete) {
e78566595089 initial import
mandel
parents:
diff changeset
131 printf("%s", colorDelete);
e78566595089 initial import
mandel
parents:
diff changeset
132 for (int i = start; i <= end; i++) {
e78566595089 initial import
mandel
parents:
diff changeset
133 printf("- %s\n", a[i].data());
e78566595089 initial import
mandel
parents:
diff changeset
134 }
e78566595089 initial import
mandel
parents:
diff changeset
135 printf("%s", colorReset);
e78566595089 initial import
mandel
parents:
diff changeset
136 }
e78566595089 initial import
mandel
parents:
diff changeset
137 }
e78566595089 initial import
mandel
parents:
diff changeset
138 }
e78566595089 initial import
mandel
parents:
diff changeset
139 };
e78566595089 initial import
mandel
parents:
diff changeset
140
e78566595089 initial import
mandel
parents:
diff changeset
141 static QList<Unit*> *unitAppend(QList<Unit*> *res, Type type, int pos)
e78566595089 initial import
mandel
parents:
diff changeset
142 {
e78566595089 initial import
mandel
parents:
diff changeset
143 if (res == 0) {
e78566595089 initial import
mandel
parents:
diff changeset
144 res = new QList<Unit*>;
e78566595089 initial import
mandel
parents:
diff changeset
145 res->append(new Unit(type, pos));
e78566595089 initial import
mandel
parents:
diff changeset
146 return res;
e78566595089 initial import
mandel
parents:
diff changeset
147 }
e78566595089 initial import
mandel
parents:
diff changeset
148
e78566595089 initial import
mandel
parents:
diff changeset
149 Unit *last = res->last();
e78566595089 initial import
mandel
parents:
diff changeset
150 if (last->type == type) {
e78566595089 initial import
mandel
parents:
diff changeset
151 last->end = pos;
e78566595089 initial import
mandel
parents:
diff changeset
152 } else {
e78566595089 initial import
mandel
parents:
diff changeset
153 res->append(new Unit(type, pos));
e78566595089 initial import
mandel
parents:
diff changeset
154 }
e78566595089 initial import
mandel
parents:
diff changeset
155 return res;
e78566595089 initial import
mandel
parents:
diff changeset
156 }
e78566595089 initial import
mandel
parents:
diff changeset
157
e78566595089 initial import
mandel
parents:
diff changeset
158 static QList<Unit*> *diffHelper(int *lcs, QList<QByteArray> a, QList<QByteArray> b, int row, int col) {
e78566595089 initial import
mandel
parents:
diff changeset
159 if (row>0 && col>0 && (a[row-1] == b[col-1])) {
e78566595089 initial import
mandel
parents:
diff changeset
160 return unitAppend(diffHelper(lcs, a, b, row-1, col-1), Unchanged, row-1);
e78566595089 initial import
mandel
parents:
diff changeset
161 }
e78566595089 initial import
mandel
parents:
diff changeset
162 else {
e78566595089 initial import
mandel
parents:
diff changeset
163 int width = b.size()+1;
e78566595089 initial import
mandel
parents:
diff changeset
164 if ((col > 0) && ((row==0) ||
e78566595089 initial import
mandel
parents:
diff changeset
165 lcs[width * row + col-1] >= lcs[width * (row-1) + col]))
e78566595089 initial import
mandel
parents:
diff changeset
166 {
e78566595089 initial import
mandel
parents:
diff changeset
167 return unitAppend(diffHelper(lcs, a, b, row, col-1), Add, col-1);
e78566595089 initial import
mandel
parents:
diff changeset
168 }
e78566595089 initial import
mandel
parents:
diff changeset
169 else if((row > 0) && ((col==0) ||
e78566595089 initial import
mandel
parents:
diff changeset
170 lcs[width * row + col-1] < lcs[width * (row-1) + col])){
e78566595089 initial import
mandel
parents:
diff changeset
171 return unitAppend(diffHelper(lcs, a, b, row-1, col), Delete, row-1);;
e78566595089 initial import
mandel
parents:
diff changeset
172 }
e78566595089 initial import
mandel
parents:
diff changeset
173 }
e78566595089 initial import
mandel
parents:
diff changeset
174 delete lcs;
e78566595089 initial import
mandel
parents:
diff changeset
175 return 0;
e78566595089 initial import
mandel
parents:
diff changeset
176 }
e78566595089 initial import
mandel
parents:
diff changeset
177
e78566595089 initial import
mandel
parents:
diff changeset
178 static void diff(QList<QByteArray> a, QList<QByteArray> b) {
e78566595089 initial import
mandel
parents:
diff changeset
179 QList<Unit*> *res = diffHelper(lcsLength(a, b), a, b, a.size(), b.size());
e78566595089 initial import
mandel
parents:
diff changeset
180 for (int i=0; i < res->size(); i++) {
e78566595089 initial import
mandel
parents:
diff changeset
181 Unit *unit = res->at(i);
e78566595089 initial import
mandel
parents:
diff changeset
182 unit->print(a, b);
e78566595089 initial import
mandel
parents:
diff changeset
183 delete(unit);
e78566595089 initial import
mandel
parents:
diff changeset
184 }
e78566595089 initial import
mandel
parents:
diff changeset
185 delete(res);
e78566595089 initial import
mandel
parents:
diff changeset
186 }
e78566595089 initial import
mandel
parents:
diff changeset
187
e78566595089 initial import
mandel
parents:
diff changeset
188
e78566595089 initial import
mandel
parents:
diff changeset
189 bool FileOut::done() {
e78566595089 initial import
mandel
parents:
diff changeset
190 Q_ASSERT( !isDone );
e78566595089 initial import
mandel
parents:
diff changeset
191 isDone = true;
e78566595089 initial import
mandel
parents:
diff changeset
192 bool fileEqual = false;
e78566595089 initial import
mandel
parents:
diff changeset
193 QFile fileRead(m_name);
e78566595089 initial import
mandel
parents:
diff changeset
194 QFileInfo info(fileRead);
e78566595089 initial import
mandel
parents:
diff changeset
195 stream.flush();
e78566595089 initial import
mandel
parents:
diff changeset
196 QByteArray original;
e78566595089 initial import
mandel
parents:
diff changeset
197 if (info.exists() && (diff || (info.size() == tmp.size()))) {
e78566595089 initial import
mandel
parents:
diff changeset
198 if ( !fileRead.open(QIODevice::ReadOnly) ) {
e78566595089 initial import
mandel
parents:
diff changeset
199 ReportHandler::warning(QString("failed to open file '%1' for reading")
e78566595089 initial import
mandel
parents:
diff changeset
200 .arg(fileRead.fileName()));
e78566595089 initial import
mandel
parents:
diff changeset
201 return false;
e78566595089 initial import
mandel
parents:
diff changeset
202 }
e78566595089 initial import
mandel
parents:
diff changeset
203
e78566595089 initial import
mandel
parents:
diff changeset
204 original = fileRead.readAll();
e78566595089 initial import
mandel
parents:
diff changeset
205 fileRead.close();
e78566595089 initial import
mandel
parents:
diff changeset
206 fileEqual = (original == tmp);
e78566595089 initial import
mandel
parents:
diff changeset
207 }
e78566595089 initial import
mandel
parents:
diff changeset
208
e78566595089 initial import
mandel
parents:
diff changeset
209 if( !fileEqual ) {
e78566595089 initial import
mandel
parents:
diff changeset
210 if( !FileOut::dummy ) {
e78566595089 initial import
mandel
parents:
diff changeset
211 QDir dir(info.absolutePath());
e78566595089 initial import
mandel
parents:
diff changeset
212 if (!dir.mkpath(dir.absolutePath())) {
e78566595089 initial import
mandel
parents:
diff changeset
213 ReportHandler::warning(QString("unable to create directory '%1'")
e78566595089 initial import
mandel
parents:
diff changeset
214 .arg(dir.absolutePath()));
e78566595089 initial import
mandel
parents:
diff changeset
215 return false;
e78566595089 initial import
mandel
parents:
diff changeset
216 }
e78566595089 initial import
mandel
parents:
diff changeset
217
e78566595089 initial import
mandel
parents:
diff changeset
218 QFile fileWrite(m_name);
e78566595089 initial import
mandel
parents:
diff changeset
219 if (!fileWrite.open(QIODevice::WriteOnly)) {
e78566595089 initial import
mandel
parents:
diff changeset
220 ReportHandler::warning(QString("failed to open file '%1' for writing")
e78566595089 initial import
mandel
parents:
diff changeset
221 .arg(fileWrite.fileName()));
e78566595089 initial import
mandel
parents:
diff changeset
222 return false;
e78566595089 initial import
mandel
parents:
diff changeset
223 }
e78566595089 initial import
mandel
parents:
diff changeset
224 stream.setDevice(&fileWrite);
e78566595089 initial import
mandel
parents:
diff changeset
225 stream << tmp;
e78566595089 initial import
mandel
parents:
diff changeset
226 }
e78566595089 initial import
mandel
parents:
diff changeset
227 if (diff) {
e78566595089 initial import
mandel
parents:
diff changeset
228 printf("%sFile: %s%s\n", colorInfo, qPrintable(m_name), colorReset);
e78566595089 initial import
mandel
parents:
diff changeset
229
e78566595089 initial import
mandel
parents:
diff changeset
230 ::diff(original.split('\n'), tmp.split('\n'));
e78566595089 initial import
mandel
parents:
diff changeset
231
e78566595089 initial import
mandel
parents:
diff changeset
232 printf("\n");
e78566595089 initial import
mandel
parents:
diff changeset
233 }
e78566595089 initial import
mandel
parents:
diff changeset
234 return true;
e78566595089 initial import
mandel
parents:
diff changeset
235 }
e78566595089 initial import
mandel
parents:
diff changeset
236 return false;
e78566595089 initial import
mandel
parents:
diff changeset
237 }