summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/opie-reader/Aportis.cpp1
-rw-r--r--noncore/apps/opie-reader/AportisCodec/AportisCodec.pro7
-rw-r--r--noncore/apps/opie-reader/BuffDoc.cpp2
-rw-r--r--noncore/apps/opie-reader/BuffDoc.h1
-rw-r--r--noncore/apps/opie-reader/CDrawBuffer.cpp1
-rw-r--r--noncore/apps/opie-reader/CExpander.h1
-rw-r--r--noncore/apps/opie-reader/CFilter.cpp1
-rw-r--r--noncore/apps/opie-reader/CFilter.h1
-rw-r--r--noncore/apps/opie-reader/CHM.cpp1
-rw-r--r--noncore/apps/opie-reader/CHM.h1
-rw-r--r--noncore/apps/opie-reader/CHM/CHM.pro4
-rw-r--r--noncore/apps/opie-reader/CloseDialog.h1
-rw-r--r--noncore/apps/opie-reader/FontControl.cpp1
-rw-r--r--noncore/apps/opie-reader/HTMLFilter/HTMLFilter.pro4
-rw-r--r--noncore/apps/opie-reader/Palm2QImage.cpp1
-rw-r--r--noncore/apps/opie-reader/PluckerCodec/PluckerCodec.pro4
-rw-r--r--noncore/apps/opie-reader/QTReader.cpp1
-rw-r--r--noncore/apps/opie-reader/QTReader.h1
-rw-r--r--noncore/apps/opie-reader/QTReaderApp.cpp2
-rw-r--r--noncore/apps/opie-reader/QTReaderApp.h1
-rw-r--r--noncore/apps/opie-reader/ToolbarPrefs.cpp1
-rw-r--r--noncore/apps/opie-reader/ToolbarPrefs.h2
-rw-r--r--noncore/apps/opie-reader/URLDialog.h1
-rw-r--r--noncore/apps/opie-reader/WeaselCodec/WeaselCodec.pro4
-rw-r--r--noncore/apps/opie-reader/ZText.h1
-rw-r--r--noncore/apps/opie-reader/codeclib/codeclib.pro4
-rw-r--r--noncore/apps/opie-reader/ebookcodec.h2
-rw-r--r--noncore/apps/opie-reader/iSiloCodec/iSiloCodec.pro4
-rw-r--r--noncore/apps/opie-reader/main.cpp1
-rw-r--r--noncore/apps/opie-reader/pdb.cpp1
-rw-r--r--noncore/apps/opie-reader/pdb.h1
-rw-r--r--noncore/apps/opie-reader/pdblib/pdblib.pro4
-rw-r--r--noncore/apps/opie-reader/plucker.cpp2
-rw-r--r--noncore/apps/opie-reader/plucker_base.cpp3
-rw-r--r--noncore/apps/opie-reader/pluckerbaselib/pluckerbaselib.pro4
-rw-r--r--noncore/apps/opie-reader/ppm_expander.cpp1
-rw-r--r--noncore/apps/opie-reader/ppm_expander.h1
-rw-r--r--noncore/apps/opie-reader/ppmsCodec/ppmsCodec.pro4
-rwxr-xr-xnoncore/apps/opie-reader/preferences.cpp1
-rw-r--r--noncore/apps/opie-reader/preferences.h1
-rw-r--r--noncore/apps/opie-reader/static.h0
-rw-r--r--noncore/apps/opie-reader/striphtml.cpp1
-rw-r--r--noncore/apps/opie-reader/useqpe.h0
-rw-r--r--noncore/apps/opie-reader/ztxt.cpp1
44 files changed, 21 insertions, 61 deletions
diff --git a/noncore/apps/opie-reader/Aportis.cpp b/noncore/apps/opie-reader/Aportis.cpp
index 7528e78..353996c 100644
--- a/noncore/apps/opie-reader/Aportis.cpp
+++ b/noncore/apps/opie-reader/Aportis.cpp
@@ -1,455 +1,454 @@
1#include <stdio.h> 1#include <stdio.h>
2#include <string.h> 2#include <string.h>
3#include "Aportis.h" 3#include "Aportis.h"
4#include "my_list.h" 4#include "my_list.h"
5#include "Bkmks.h" 5#include "Bkmks.h"
6#include "static.h"
7 6
8Aportis::Aportis() : peanutfile(false) { /*printf("constructing:%x\n",fin);*/ } 7Aportis::Aportis() : peanutfile(false) { /*printf("constructing:%x\n",fin);*/ }
9 8
10void Aportis::dePeanut(int& ch) 9void Aportis::dePeanut(int& ch)
11{ 10{
12 if (peanutfile && ch != EOF) 11 if (peanutfile && ch != EOF)
13 { 12 {
14 unsigned char c = ch; 13 unsigned char c = ch;
15 if (peanutfile) c ^= 0xa5; 14 if (peanutfile) c ^= 0xa5;
16 ch = c; 15 ch = c;
17 } 16 }
18} 17}
19 18
20CList<Bkmk>* Aportis::getbkmklist() 19CList<Bkmk>* Aportis::getbkmklist()
21{ 20{
22/* 21/*
23 if (peanutfile) 22 if (peanutfile)
24 { 23 {
25 if (nRecs2 > nRecs) 24 if (nRecs2 > nRecs)
26 { 25 {
27 CList<Bkmk>* t = new CList<Bkmk>; 26 CList<Bkmk>* t = new CList<Bkmk>;
28 for (int i = nRecs; i < nRecs2; i++) 27 for (int i = nRecs; i < nRecs2; i++)
29 { 28 {
30 char name[17]; 29 char name[17];
31 name[16] = '\0'; 30 name[16] = '\0';
32 // qDebug("Record:%d, Length:%u",i,recordlength(i)); 31 // qDebug("Record:%d, Length:%u",i,recordlength(i));
33 gotorecordnumber(i); 32 gotorecordnumber(i);
34 fread(name,1,16,fin); 33 fread(name,1,16,fin);
35 unsigned long lcn; 34 unsigned long lcn;
36 fread(&lcn,sizeof(lcn),1,fin); 35 fread(&lcn,sizeof(lcn),1,fin);
37 lcn ^= 0xa5a5a5a5; 36 lcn ^= 0xa5a5a5a5;
38 lcn = SwapLong(lcn); 37 lcn = SwapLong(lcn);
39 // qDebug("Bookmark:%s:%u", name,lcn); 38 // qDebug("Bookmark:%s:%u", name,lcn);
40 tchar tname[17]; 39 tchar tname[17];
41 memset(tname, 0, sizeof(tname)); 40 memset(tname, 0, sizeof(tname));
42 for (int i = 0; name[i] != 0; i++) 41 for (int i = 0; name[i] != 0; i++)
43 { 42 {
44 tname[i] = name[i] ^ 0xa5; 43 tname[i] = name[i] ^ 0xa5;
45 } 44 }
46 t->push_back(Bkmk(tname, NULL, lcn)); 45 t->push_back(Bkmk(tname, NULL, lcn));
47 } 46 }
48 return t; 47 return t;
49 } 48 }
50 else 49 else
51 { 50 {
52 return NULL; 51 return NULL;
53 } 52 }
54 } 53 }
55*/ 54*/
56 if (bCompressed != 4) return NULL; 55 if (bCompressed != 4) return NULL;
57 CList<Bkmk>* t = new CList<Bkmk>; 56 CList<Bkmk>* t = new CList<Bkmk>;
58 size_t cur = ftell(fin); 57 size_t cur = ftell(fin);
59 for (int i = 0; i < nRecs2; i++) 58 for (int i = 0; i < nRecs2; i++)
60 { 59 {
61 DWORD dwPos; 60 DWORD dwPos;
62 fseek(fin, 0x56 + 8*i, SEEK_SET); 61 fseek(fin, 0x56 + 8*i, SEEK_SET);
63 fread(&dwPos, 4, 1, fin); 62 fread(&dwPos, 4, 1, fin);
64 dwPos = SwapLong(dwPos); 63 dwPos = SwapLong(dwPos);
65 fseek(fin,dwPos,SEEK_SET); 64 fseek(fin,dwPos,SEEK_SET);
66 unsigned char ch; 65 unsigned char ch;
67 fread(&ch,1,1,fin); 66 fread(&ch,1,1,fin);
68 if (ch != 241) 67 if (ch != 241)
69 { 68 {
70 char name[17]; 69 char name[17];
71 name[16] = '\0'; 70 name[16] = '\0';
72 fseek(fin,dwPos,SEEK_SET); 71 fseek(fin,dwPos,SEEK_SET);
73 fread(name,1,16,fin); 72 fread(name,1,16,fin);
74 unsigned long lcn; 73 unsigned long lcn;
75 fread(&lcn,sizeof(lcn),1,fin); 74 fread(&lcn,sizeof(lcn),1,fin);
76 lcn = SwapLong(lcn); 75 lcn = SwapLong(lcn);
77#ifdef _UNICODE 76#ifdef _UNICODE
78 tchar tname[17]; 77 tchar tname[17];
79 memset(tname, 0, sizeof(tname)); 78 memset(tname, 0, sizeof(tname));
80 for (int i = 0; name[i] != 0; i++) 79 for (int i = 0; name[i] != 0; i++)
81 { 80 {
82 tname[i] = name[i]; 81 tname[i] = name[i];
83 } 82 }
84 t->push_back(Bkmk(tname, NULL, lcn)); 83 t->push_back(Bkmk(tname, NULL, lcn));
85#else 84#else
86 t->push_back(Bkmk(name,lcn)); 85 t->push_back(Bkmk(name,lcn));
87#endif 86#endif
88 } 87 }
89 } 88 }
90 fseek(fin, cur, SEEK_SET); 89 fseek(fin, cur, SEEK_SET);
91 return t; 90 return t;
92} 91}
93 92
94int Aportis::OpenFile(const char *src) 93int Aportis::OpenFile(const char *src)
95{ 94{
96 // printf("In openfile\n"); 95 // printf("In openfile\n");
97 int ret = 0; 96 int ret = 0;
98 html = false; 97 html = false;
99 mobiimagerec = 0; 98 mobiimagerec = 0;
100 if (!Cpdb::openpdbfile(src)) return -1; 99 if (!Cpdb::openpdbfile(src)) return -1;
101 100
102 if (head.creator == 0x64414552 // 'dAER' 101 if (head.creator == 0x64414552 // 'dAER'
103 || head.type == 0x74584554) // 'tXET') 102 || head.type == 0x74584554) // 'tXET')
104 { 103 {
105 } 104 }
106 else if (memcmp(&head.creator, "PPrs", 4) == 0 && memcmp(&head.type, "PNRd", 4) == 0) 105 else if (memcmp(&head.creator, "PPrs", 4) == 0 && memcmp(&head.type, "PNRd", 4) == 0)
107 { 106 {
108 peanutfile = true; 107 peanutfile = true;
109 } 108 }
110 else if (memcmp(&head.creator, "MOBI", 4) == 0 && memcmp(&head.type, "BOOK", 4) == 0) 109 else if (memcmp(&head.creator, "MOBI", 4) == 0 && memcmp(&head.type, "BOOK", 4) == 0)
111 { 110 {
112 html = true; 111 html = true;
113 unsigned char vsn; 112 unsigned char vsn;
114 fseek(fin, recordpos(0)+39, SEEK_SET); 113 fseek(fin, recordpos(0)+39, SEEK_SET);
115 fread(&vsn, 1, sizeof(vsn), fin); 114 fread(&vsn, 1, sizeof(vsn), fin);
116 qDebug("Mobi version:%x", vsn); 115 qDebug("Mobi version:%x", vsn);
117 if (vsn > 2) 116 if (vsn > 2)
118 { 117 {
119 fseek(fin, recordpos(0)+110, SEEK_SET); 118 fseek(fin, recordpos(0)+110, SEEK_SET);
120 fread(&mobiimagerec, 1, sizeof(mobiimagerec), fin); 119 fread(&mobiimagerec, 1, sizeof(mobiimagerec), fin);
121 mobiimagerec = ntohs(mobiimagerec)-1; 120 mobiimagerec = ntohs(mobiimagerec)-1;
122 } 121 }
123 } 122 }
124 else 123 else
125 { 124 {
126 return -2; 125 return -2;
127 } 126 }
128 127
129 nRecs2 = nRecs = SwapWord(head.recordList.numRecords) - 1; 128 nRecs2 = nRecs = SwapWord(head.recordList.numRecords) - 1;
130 129
131 struct stat _stat; 130 struct stat _stat;
132 stat(src,&_stat); 131 stat(src,&_stat);
133 dwLen = _stat.st_size; 132 dwLen = _stat.st_size;
134 133
135 //fseek(fin,0,SEEK_END); 134 //fseek(fin,0,SEEK_END);
136 //dwLen = ftell(fin); 135 //dwLen = ftell(fin);
137 136
138 if (peanutfile) 137 if (peanutfile)
139 { 138 {
140 139
141 PeanutHeader hdr0; 140 PeanutHeader hdr0;
142 gotorecordnumber(0); 141 gotorecordnumber(0);
143 fread(&hdr0, sizeof(hdr0), 1, fin); 142 fread(&hdr0, sizeof(hdr0), 1, fin);
144// qDebug("Version:%x", ntohs(hdr0.Version)); 143// qDebug("Version:%x", ntohs(hdr0.Version));
145 if (hdr0.Version && 0x0200) 144 if (hdr0.Version && 0x0200)
146 { 145 {
147 bCompressed = 2; 146 bCompressed = 2;
148 } 147 }
149 else 148 else
150 { 149 {
151 bCompressed = 1; 150 bCompressed = 1;
152 } 151 }
153 BlockSize = 4096; 152 BlockSize = 4096;
154 nRecs = SwapWord(hdr0.Records)-1; 153 nRecs = SwapWord(hdr0.Records)-1;
155 dwTLen = nRecs*BlockSize; 154 dwTLen = nRecs*BlockSize;
156 } 155 }
157 else 156 else
158 { 157 {
159 gotorecordnumber(0); 158 gotorecordnumber(0);
160 tDocRecord0 hdr0; 159 tDocRecord0 hdr0;
161 fread(&hdr0, sizeof(hdr0), 1, fin); 160 fread(&hdr0, sizeof(hdr0), 1, fin);
162 bCompressed = SwapWord(hdr0.wVersion); 161 bCompressed = SwapWord(hdr0.wVersion);
163 if (bCompressed!=1 && bCompressed!=2 && bCompressed != 4) { 162 if (bCompressed!=1 && bCompressed!=2 && bCompressed != 4) {
164 qDebug("ERROR:Unrecognised compression type in Aportis:%u", bCompressed); 163 qDebug("ERROR:Unrecognised compression type in Aportis:%u", bCompressed);
165 ret = bCompressed; 164 ret = bCompressed;
166 bCompressed = 2; 165 bCompressed = 2;
167 } 166 }
168 switch (bCompressed) 167 switch (bCompressed)
169 { 168 {
170 case 4: 169 case 4:
171 { 170 {
172 dwTLen = 0; 171 dwTLen = 0;
173 int i; 172 int i;
174 for (i = 0; i < nRecs; i++) 173 for (i = 0; i < nRecs; i++)
175 { 174 {
176 unsigned int bs = GetBS(i); 175 unsigned int bs = GetBS(i);
177 if (bs == 0) break; 176 if (bs == 0) break;
178 else dwTLen += bs; 177 else dwTLen += bs;
179 } 178 }
180 nRecs = i; 179 nRecs = i;
181 BlockSize = 0; 180 BlockSize = 0;
182 } 181 }
183 break; 182 break;
184 case 1: 183 case 1:
185 case 2: 184 case 2:
186 default: 185 default:
187 nRecs = SwapWord(hdr0.wNumRecs); 186 nRecs = SwapWord(hdr0.wNumRecs);
188 if (mobiimagerec == 0 || mobiimagerec > nRecs2) mobiimagerec = nRecs; 187 if (mobiimagerec == 0 || mobiimagerec > nRecs2) mobiimagerec = nRecs;
189 dwTLen = SwapLong(hdr0.dwStoryLen); 188 dwTLen = SwapLong(hdr0.dwStoryLen);
190 BlockSize = SwapWord(hdr0.wRecSize); 189 BlockSize = SwapWord(hdr0.wRecSize);
191 if (BlockSize == 0) 190 if (BlockSize == 0)
192 { 191 {
193 BlockSize = 4096; 192 BlockSize = 4096;
194 printf("WARNING: Blocksize not set in source file\n"); 193 printf("WARNING: Blocksize not set in source file\n");
195 } 194 }
196 } 195 }
197 } 196 }
198 197
199 qDebug("Mobi image rec:%u", mobiimagerec); 198 qDebug("Mobi image rec:%u", mobiimagerec);
200 199
201 // this is the main record buffer 200 // this is the main record buffer
202 // it knows how to stretch to accomodate the decompress 201 // it knows how to stretch to accomodate the decompress
203 currentrec = 0; 202 currentrec = 0;
204 cbptr = 0; 203 cbptr = 0;
205 outptr = 0; 204 outptr = 0;
206 refreshbuffer(); 205 refreshbuffer();
207 if (!html) 206 if (!html)
208 { 207 {
209 int c; 208 int c;
210 char htmltag[] = "<HTML>"; 209 char htmltag[] = "<HTML>";
211 char *p = htmltag; 210 char *p = htmltag;
212 while (1) 211 while (1)
213 { 212 {
214 c = getch(); 213 c = getch();
215 char ch = *p++; 214 char ch = *p++;
216 if (ch == 0) 215 if (ch == 0)
217 { 216 {
218 html = true; 217 html = true;
219 break; 218 break;
220 } 219 }
221 if (c != ch) 220 if (c != ch)
222 { 221 {
223 html = false; 222 html = false;
224 break; 223 break;
225 } 224 }
226 } 225 }
227 currentrec = 0; 226 currentrec = 0;
228 cbptr = 0; 227 cbptr = 0;
229 outptr = 0; 228 outptr = 0;
230 refreshbuffer(); 229 refreshbuffer();
231 } 230 }
232 /* 231 /*
233 for (int i = 0; i < nRecs2; i++) 232 for (int i = 0; i < nRecs2; i++)
234 { 233 {
235 qDebug("Record:%u - %u bytes at position %x", i, recordlength(i), recordpos(i)); 234 qDebug("Record:%u - %u bytes at position %x", i, recordlength(i), recordpos(i));
236 } 235 }
237 */ 236 */
238 237
239 qDebug("Number of records:[%u,%u]", nRecs, nRecs2); 238 qDebug("Number of records:[%u,%u]", nRecs, nRecs2);
240 return ret; 239 return ret;
241} 240}
242 241
243int Aportis::getch() 242int Aportis::getch()
244{ 243{
245 if (bCompressed == 1) 244 if (bCompressed == 1)
246 { 245 {
247 if ((dwRecLen == 0) && !refreshbuffer()) return EOF; 246 if ((dwRecLen == 0) && !refreshbuffer()) return EOF;
248 else 247 else
249 { 248 {
250 int c = getc(fin); 249 int c = getc(fin);
251 dePeanut(c); 250 dePeanut(c);
252 dwRecLen--; 251 dwRecLen--;
253 currentpos++; 252 currentpos++;
254 return c; 253 return c;
255 } 254 }
256 } 255 }
257 if (outptr != cbptr) 256 if (outptr != cbptr)
258 { 257 {
259 currentpos++; 258 currentpos++;
260 return (circbuf[outptr = (outptr + 1) % 2048]); 259 return (circbuf[outptr = (outptr + 1) % 2048]);
261 } 260 }
262 if ((dwRecLen == 0) && !refreshbuffer()) return EOF; 261 if ((dwRecLen == 0) && !refreshbuffer()) return EOF;
263 currentpos++; 262 currentpos++;
264 int c; 263 int c;
265 264
266 // take a char from the input buffer 265 // take a char from the input buffer
267 c = getc(fin); 266 c = getc(fin);
268 dePeanut(c); 267 dePeanut(c);
269 dwRecLen--; 268 dwRecLen--;
270 // separate the char into zones: 0, 1...8, 9...0x7F, 0x80...0xBF, 0xC0...0xFF 269 // separate the char into zones: 0, 1...8, 9...0x7F, 0x80...0xBF, 0xC0...0xFF
271 270
272 // codes 1...8 mean copy that many chars; for accented chars & binary 271 // codes 1...8 mean copy that many chars; for accented chars & binary
273 if (c == 0) 272 if (c == 0)
274 { 273 {
275 circbuf[outptr = cbptr = (cbptr+1)%2048] = c; 274 circbuf[outptr = cbptr = (cbptr+1)%2048] = c;
276 return c; 275 return c;
277 } 276 }
278 else if (c >= 0x09 && c <= 0x7F) 277 else if (c >= 0x09 && c <= 0x7F)
279 { 278 {
280 circbuf[outptr = cbptr = (cbptr+1)%2048] = c; 279 circbuf[outptr = cbptr = (cbptr+1)%2048] = c;
281 return c; 280 return c;
282 } 281 }
283 else if (c >= 0x01 && c <= 0x08) 282 else if (c >= 0x01 && c <= 0x08)
284 { 283 {
285 dwRecLen -= c; 284 dwRecLen -= c;
286 while(c--) 285 while(c--)
287 { 286 {
288 int c = getc(fin); 287 int c = getc(fin);
289 dePeanut(c); 288 dePeanut(c);
290 circbuf[cbptr = (cbptr+1)%2048] = c; 289 circbuf[cbptr = (cbptr+1)%2048] = c;
291 } 290 }
292 return circbuf[outptr = (outptr+1)%2048]; 291 return circbuf[outptr = (outptr+1)%2048];
293 } 292 }
294 else if (c >= 0x80 && c <= 0xBF) 293 else if (c >= 0x80 && c <= 0xBF)
295 { 294 {
296 int m,n; 295 int m,n;
297 c <<= 8; 296 c <<= 8;
298 int c1 = getc(fin); 297 int c1 = getc(fin);
299 dePeanut(c1); 298 dePeanut(c1);
300 c += c1; 299 c += c1;
301 dwRecLen--; 300 dwRecLen--;
302 m = (c & 0x3FFF) >> COUNT_BITS; 301 m = (c & 0x3FFF) >> COUNT_BITS;
303 n = c & ((1<<COUNT_BITS) - 1); 302 n = c & ((1<<COUNT_BITS) - 1);
304 n += 3; 303 n += 3;
305 while (n--) 304 while (n--)
306 { 305 {
307 cbptr = (cbptr+1)%2048; 306 cbptr = (cbptr+1)%2048;
308 circbuf[cbptr] = circbuf[(cbptr+2048-m)%2048]; 307 circbuf[cbptr] = circbuf[(cbptr+2048-m)%2048];
309 } 308 }
310 return circbuf[outptr = (outptr+1)%2048]; 309 return circbuf[outptr = (outptr+1)%2048];
311 } 310 }
312 else if (c >= 0xC0 && c <= 0xFF) 311 else if (c >= 0xC0 && c <= 0xFF)
313 { 312 {
314 circbuf[cbptr = (cbptr+1)%2048] = ' '; 313 circbuf[cbptr = (cbptr+1)%2048] = ' ';
315 circbuf[cbptr = (cbptr+1)%2048] = c^0x80; 314 circbuf[cbptr = (cbptr+1)%2048] = c^0x80;
316 return circbuf[outptr = (outptr+1)%2048]; 315 return circbuf[outptr = (outptr+1)%2048];
317 } 316 }
318} 317}
319 318
320unsigned int Aportis::GetBS(unsigned int bn) 319unsigned int Aportis::GetBS(unsigned int bn)
321{ 320{
322 DWORD dwPos; 321 DWORD dwPos;
323 WORD fs; 322 WORD fs;
324 323
325 fseek(fin, 0x56 + 8*bn, SEEK_SET); 324 fseek(fin, 0x56 + 8*bn, SEEK_SET);
326 fread(&dwPos, 4, 1, fin); 325 fread(&dwPos, 4, 1, fin);
327 dwPos = SwapLong(dwPos); 326 dwPos = SwapLong(dwPos);
328 fseek(fin,dwPos,SEEK_SET); 327 fseek(fin,dwPos,SEEK_SET);
329 328
330// gotorecordnumber(bn+1); 329// gotorecordnumber(bn+1);
331 unsigned char ch; 330 unsigned char ch;
332 fread(&ch,1,1,fin); 331 fread(&ch,1,1,fin);
333 if (ch == 241) 332 if (ch == 241)
334 { 333 {
335 fread(&fs,sizeof(fs),1,fin); 334 fread(&fs,sizeof(fs),1,fin);
336 fs = SwapWord(fs); 335 fs = SwapWord(fs);
337 } 336 }
338 else 337 else
339 fs = 0; 338 fs = 0;
340 return fs; 339 return fs;
341} 340}
342 341
343unsigned int Aportis::locate() 342unsigned int Aportis::locate()
344{ 343{
345 if (bCompressed == 4) 344 if (bCompressed == 4)
346 { 345 {
347 size_t cur = ftell(fin); 346 size_t cur = ftell(fin);
348 unsigned int clen = 0; 347 unsigned int clen = 0;
349 for (unsigned int i = 0; i < currentrec-1; i++) 348 for (unsigned int i = 0; i < currentrec-1; i++)
350 { 349 {
351 unsigned int bs = GetBS(i); 350 unsigned int bs = GetBS(i);
352 if (bs == 0) break; 351 if (bs == 0) break;
353 clen += bs; 352 clen += bs;
354 } 353 }
355 fseek(fin,cur,SEEK_SET); 354 fseek(fin,cur,SEEK_SET);
356 return clen+currentpos; 355 return clen+currentpos;
357 } 356 }
358 else 357 else
359 return (currentrec-1)*BlockSize+currentpos; 358 return (currentrec-1)*BlockSize+currentpos;
360} 359}
361 360
362void Aportis::locate(unsigned int n) 361void Aportis::locate(unsigned int n)
363{ 362{
364 unsigned int offset; 363 unsigned int offset;
365 // currentrec = (n >> OFFBITS); 364 // currentrec = (n >> OFFBITS);
366 switch (bCompressed) 365 switch (bCompressed)
367 { 366 {
368 case 4: 367 case 4:
369 { 368 {
370 DWORD clen = 0; 369 DWORD clen = 0;
371 offset = n; 370 offset = n;
372 unsigned int i; 371 unsigned int i;
373 for (i = 0; i < nRecs; i++) 372 for (i = 0; i < nRecs; i++)
374 { 373 {
375 unsigned int bs = GetBS(i); 374 unsigned int bs = GetBS(i);
376 if (bs == 0) break; 375 if (bs == 0) break;
377 clen += bs; 376 clen += bs;
378 if (clen > n) break; 377 if (clen > n) break;
379 offset = n - clen; 378 offset = n - clen;
380 } 379 }
381 currentrec = i; 380 currentrec = i;
382 } 381 }
383 break; 382 break;
384 case 1: 383 case 1:
385 case 2: 384 case 2:
386 default: 385 default:
387 currentrec = n / BlockSize; 386 currentrec = n / BlockSize;
388 offset = n % BlockSize; 387 offset = n % BlockSize;
389 } 388 }
390 389
391 outptr = cbptr; 390 outptr = cbptr;
392 refreshbuffer(); 391 refreshbuffer();
393 while (currentpos < offset && getch() != EOF); 392 while (currentpos < offset && getch() != EOF);
394} 393}
395 394
396bool Aportis::refreshbuffer() 395bool Aportis::refreshbuffer()
397{ 396{
398 if (currentrec < nRecs) 397 if (currentrec < nRecs)
399 { 398 {
400 dwRecLen = recordlength(currentrec+1); 399 dwRecLen = recordlength(currentrec+1);
401 gotorecordnumber(currentrec+1); 400 gotorecordnumber(currentrec+1);
402 if (bCompressed == 4) 401 if (bCompressed == 4)
403 { 402 {
404 unsigned char t[3]; 403 unsigned char t[3];
405 fread(t,1,3,fin); 404 fread(t,1,3,fin);
406 if (t[0] != 241) 405 if (t[0] != 241)
407 { 406 {
408 printf("You shouldn't be here!\n"); 407 printf("You shouldn't be here!\n");
409 return false; 408 return false;
410 } 409 }
411 dwRecLen -= 3; 410 dwRecLen -= 3;
412 } 411 }
413 /* 412 /*
414 int n = fread(t.buf, 1, dwRecLen, fin); 413 int n = fread(t.buf, 1, dwRecLen, fin);
415 t.len = n; 414 t.len = n;
416 // if(bCompressed) 415 // if(bCompressed)
417 t.Decompress(); 416 t.Decompress();
418 417
419 t.buf[t.Len()] = '\0'; 418 t.buf[t.Len()] = '\0';
420 */ 419 */
421 currentpos = 0; 420 currentpos = 0;
422 currentrec++; 421 currentrec++;
423 return true; 422 return true;
424 } 423 }
425 else { 424 else {
426 return false; 425 return false;
427 } 426 }
428} 427}
429 428
430#include <qimage.h> 429#include <qimage.h>
431 430
432QImage* Aportis::getPicture(unsigned long tgt) 431QImage* Aportis::getPicture(unsigned long tgt)
433{ 432{
434 unsigned short tgtrec = tgt+mobiimagerec; 433 unsigned short tgtrec = tgt+mobiimagerec;
435 if (tgtrec > nRecs2) return NULL; 434 if (tgtrec > nRecs2) return NULL;
436 size_t cur = ftell(fin); 435 size_t cur = ftell(fin);
437 unsigned short reclen = recordlength(tgtrec); 436 unsigned short reclen = recordlength(tgtrec);
438 gotorecordnumber(tgtrec); 437 gotorecordnumber(tgtrec);
439 UInt8* imgbuffer = new UInt8[reclen]; 438 UInt8* imgbuffer = new UInt8[reclen];
440 fread(imgbuffer, 1, reclen, fin); 439 fread(imgbuffer, 1, reclen, fin);
441 QByteArray arr; 440 QByteArray arr;
442 arr.assign((const char*)imgbuffer, reclen); 441 arr.assign((const char*)imgbuffer, reclen);
443 442
444 QImage* qimage = new QImage(arr); 443 QImage* qimage = new QImage(arr);
445 fseek(fin, cur, SEEK_SET); 444 fseek(fin, cur, SEEK_SET);
446 445
447 return qimage; 446 return qimage;
448} 447}
449 448
450#ifndef __STATIC 449#ifndef __STATIC
451extern "C" 450extern "C"
452{ 451{
453 CExpander* newcodec() { return new Aportis; } 452 CExpander* newcodec() { return new Aportis; }
454} 453}
455#endif 454#endif
diff --git a/noncore/apps/opie-reader/AportisCodec/AportisCodec.pro b/noncore/apps/opie-reader/AportisCodec/AportisCodec.pro
index 4b61a7a..fcab192 100644
--- a/noncore/apps/opie-reader/AportisCodec/AportisCodec.pro
+++ b/noncore/apps/opie-reader/AportisCodec/AportisCodec.pro
@@ -1,30 +1,29 @@
1DEFINES += OPIE USEQPE 1DEFINES += OPIE USEQPE
2VPATH = .. 2VPATH = ..
3 TEMPLATE= lib 3 TEMPLATE= lib
4 CONFIG = qt warn_on release dll 4 CONFIG = qt warn_on release dll
5 HEADERS = Aportis.h \ 5 HEADERS = Aportis.h \
6 CExpander.h \ 6 CExpander.h \
7 ../OREADERINC/useqpe.h \
8 config.h \ 7 config.h \
9 ustring.h \ 8 ustring.h \
10 StyleConsts.h \ 9 StyleConsts.h \
11 Markups.h \ 10 Markups.h \
12 names.h \ 11 names.h \
13 linktype.h \ 12 linktype.h \
14 pdb.h \ 13 pdb.h \
15 my_list.h \ 14 my_list.h \
16 Bkmks.h \ 15 Bkmks.h \
17 Filedata.h 16 Filedata.h
18 17
19 SOURCES = Aportis.cpp 18 SOURCES = Aportis.cpp
20 19
21 20
22 INTERFACES= 21 INTERFACES=
23 DESTDIR = $(OPIEDIR)/plugins/reader/codecs 22 DESTDIR = $(OPIEDIR)/plugins/reader/codecs
24 TARGET = Aportis 23 TARGET = Aportis
25LIBS += -lreader_pdb -lreader_codec 24LIBS += -lreader_pdb -lreader_codec
26 25
27 INCLUDEPATH+= ../OREADERINC $(OPIEDIR)/include 26 INCLUDEPATH+= $(OPIEDIR)/include
28 DEPENDPATH+= ../OREADERINC $(OPIEDIR)/include 27 DEPENDPATH+= $(OPIEDIR)/include
29 28
30include ( $(OPIEDIR)/include.pro ) \ No newline at end of file 29include ( $(OPIEDIR)/include.pro )
diff --git a/noncore/apps/opie-reader/BuffDoc.cpp b/noncore/apps/opie-reader/BuffDoc.cpp
index 22934f9..1f0a524 100644
--- a/noncore/apps/opie-reader/BuffDoc.cpp
+++ b/noncore/apps/opie-reader/BuffDoc.cpp
@@ -1,710 +1,708 @@
1#include "static.h"
2#include "names.h" 1#include "names.h"
3 2
4#define NEWLINEBREAK 3#define NEWLINEBREAK
5#define INCREMENTALWIDTH 4#define INCREMENTALWIDTH
6 5
7#include "useqpe.h"
8#include "usenef.h" 6#include "usenef.h"
9#include "BuffDoc.h" 7#include "BuffDoc.h"
10#include "config.h" 8#include "config.h"
11#include "CDrawBuffer.h" 9#include "CDrawBuffer.h"
12#include "ZText.h" 10#include "ZText.h"
13#include "ebookcodec.h" 11#include "ebookcodec.h"
14 12
15#ifdef __STATIC 13#ifdef __STATIC
16#include "Aportis.h" 14#include "Aportis.h"
17#include "CHM.h" 15#include "CHM.h"
18#include "ppm_expander.h" 16#include "ppm_expander.h"
19#include "ztxt.h" 17#include "ztxt.h"
20#include "plucker.h" 18#include "plucker.h"
21#ifdef USENEF 19#ifdef USENEF
22#include "nef.h" 20#include "nef.h"
23#include "arrierego.h" 21#include "arrierego.h"
24#endif 22#endif
25#include "iSilo.h" 23#include "iSilo.h"
26#endif 24#endif
27 25
28 26
29linkType BuffDoc::hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm) 27linkType BuffDoc::hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm)
30{ 28{
31 linkType bRet = eNone; 29 linkType bRet = eNone;
32 if (exp != NULL) 30 if (exp != NULL)
33 { 31 {
34 bRet = filt->hyperlink(n, noff, wrd, nm); 32 bRet = filt->hyperlink(n, noff, wrd, nm);
35 if ((bRet & eLink) != 0) 33 if ((bRet & eLink) != 0)
36 { 34 {
37 lastword.empty(); 35 lastword.empty();
38 lastsizes[0] = laststartline = n; 36 lastsizes[0] = laststartline = n;
39#ifdef NEWLINEBREAK 37#ifdef NEWLINEBREAK
40 lastispara = false; 38 lastispara = false;
41#else 39#else
42 lastispara = false; 40 lastispara = false;
43#endif 41#endif
44 lastsizes[0] = laststartline = exp->locate(); 42 lastsizes[0] = laststartline = exp->locate();
45 } 43 }
46 } 44 }
47 return bRet; 45 return bRet;
48} 46}
49 47
50void BuffDoc::locate(unsigned int n) 48void BuffDoc::locate(unsigned int n)
51{ 49{
52 // //qDebug("BuffDoc:locating:%u",n); 50 // //qDebug("BuffDoc:locating:%u",n);
53 lastword.empty(); 51 lastword.empty();
54 lastsizes[0] = laststartline = n; 52 lastsizes[0] = laststartline = n;
55#ifdef NEWLINEBREAK 53#ifdef NEWLINEBREAK
56 lastispara = false; 54 lastispara = false;
57#else 55#else
58 lastispara = false; 56 lastispara = false;
59#endif 57#endif
60 // tchar linebuf[1024]; 58 // tchar linebuf[1024];
61 if (exp != NULL) filt->locate(n); 59 if (exp != NULL) filt->locate(n);
62 // //qDebug("BuffDoc:Located"); 60 // //qDebug("BuffDoc:Located");
63} 61}
64 62
65static bool isletter(unsigned short c) 63static bool isletter(unsigned short c)
66{ 64{
67 if ('a' <= c && c <= 'z') return true; 65 if ('a' <= c && c <= 'z') return true;
68 if ('A' <= c && c <= 'Z') return true; 66 if ('A' <= c && c <= 'Z') return true;
69 // Cyrillic letters 67 // Cyrillic letters
70 if (0x400 <= c && c <= 0x52F) return true; 68 if (0x400 <= c && c <= 0x52F) return true;
71 return false; 69 return false;
72} 70}
73 71
74static bool isvowel(unsigned short c) // Only want lower case vowels 72static bool isvowel(unsigned short c) // Only want lower case vowels
75{ 73{
76 switch (c) 74 switch (c)
77 { 75 {
78 case 'a': 76 case 'a':
79 case 'e': 77 case 'e':
80 case 'i': 78 case 'i':
81 case 'o': 79 case 'o':
82 case 'u': 80 case 'u':
83 // Cyrillic vowels 81 // Cyrillic vowels
84 case 0x430: 82 case 0x430:
85 case 0x435: 83 case 0x435:
86 case 0x438: 84 case 0x438:
87 case 0x43E: 85 case 0x43E:
88 case 0x443: 86 case 0x443:
89 case 0x44B: 87 case 0x44B:
90 case 0x44D: 88 case 0x44D:
91 case 0x44E: 89 case 0x44E:
92 case 0x44F: 90 case 0x44F:
93 case 0x451: 91 case 0x451:
94 92
95 case 0x450: 93 case 0x450:
96 case 0x454: 94 case 0x454:
97 case 0x456: 95 case 0x456:
98 case 0x457: 96 case 0x457:
99 case 0x45D: 97 case 0x45D:
100 98
101 case 0x463: 99 case 0x463:
102 100
103 case 0x4AF: 101 case 0x4AF:
104 case 0x4B1: 102 case 0x4B1:
105 case 0x4D1: 103 case 0x4D1:
106 case 0x4D3: 104 case 0x4D3:
107 105
108 case 0x4D5: 106 case 0x4D5:
109 case 0x4D7: 107 case 0x4D7:
110 case 0x4E3: 108 case 0x4E3:
111 case 0x4E5: 109 case 0x4E5:
112 case 0x4E7: 110 case 0x4E7:
113 case 0x4E9: 111 case 0x4E9:
114 case 0x4EB: 112 case 0x4EB:
115 case 0x4ED: 113 case 0x4ED:
116 case 0x4EF: 114 case 0x4EF:
117 case 0x4F1: 115 case 0x4F1:
118 case 0x4F3: 116 case 0x4F3:
119 case 0x4F9: 117 case 0x4F9:
120 return true; 118 return true;
121 default: 119 default:
122 return ((0xe0 <= c) && (c <= 0xfc) && (c != 0xf1) && (c != 0xf7) && (c != 0xe7)); 120 return ((0xe0 <= c) && (c <= 0xfc) && (c != 0xf1) && (c != 0xf7) && (c != 0xe7));
123 } 121 }
124} 122}
125 123
126inline bool isconsonant(unsigned short c) 124inline bool isconsonant(unsigned short c)
127{ 125{
128 switch( c ) 126 switch( c )
129 { 127 {
130 // Some cyrillic letters are neither vowels, nor consonants, or otherwise 128 // Some cyrillic letters are neither vowels, nor consonants, or otherwise
131 // the letters no word can start from. 129 // the letters no word can start from.
132 case 0x439: 130 case 0x439:
133 case 0x44A: 131 case 0x44A:
134 case 0x44C: 132 case 0x44C:
135 133
136 case 0x45E: 134 case 0x45E:
137 135
138 return false; 136 return false;
139 137
140 default: 138 default:
141 return (isletter(c) && !isvowel(c)); 139 return (isletter(c) && !isvowel(c));
142 } 140 }
143 return (isletter(c) && !isvowel(c)); 141 return (isletter(c) && !isvowel(c));
144} 142}
145 143
146#ifdef NEWLINEBREAK 144#ifdef NEWLINEBREAK
147bool BuffDoc::getline(CDrawBuffer* buff, int wth, unsigned short _lborder, unsigned short _rborder, bool hyphenate, int availht) 145bool BuffDoc::getline(CDrawBuffer* buff, int wth, unsigned short _lborder, unsigned short _rborder, bool hyphenate, int availht)
148{ 146{
149 bool moreleft = true; 147 bool moreleft = true;
150 bool margindone = false; 148 bool margindone = false;
151 int isCentred = -1; 149 int isCentred = -1;
152 int w = wth-(_lborder+_rborder); 150 int w = wth-(_lborder+_rborder);
153 tchar ch = 32; 151 tchar ch = 32;
154 CStyle cs; 152 CStyle cs;
155 buff->empty(); 153 buff->empty();
156 if (exp == NULL) 154 if (exp == NULL)
157 { 155 {
158 buff->empty(); 156 buff->empty();
159 buff->setEof(); 157 buff->setEof();
160 return false; 158 return false;
161 } 159 }
162 int len = 0; 160 int len = 0;
163 if (lastword.length() > 0) 161 if (lastword.length() > 0)
164 { 162 {
165 if (isCentred < 0) 163 if (isCentred < 0)
166 { 164 {
167 isCentred = (lastword.firststyle().getJustify() == m_AlignCentre) ? 1 : 0; 165 isCentred = (lastword.firststyle().getJustify() == m_AlignCentre) ? 1 : 0;
168 } 166 }
169 *buff = lastword; 167 *buff = lastword;
170 cs = lastword.laststyle(); 168 cs = lastword.laststyle();
171 w -= buff->leftMargin() + buff->rightMargin(); 169 w -= buff->leftMargin() + buff->rightMargin();
172 margindone = true; 170 margindone = true;
173 len = lastword.length(); 171 len = lastword.length();
174 } 172 }
175 else buff->empty(); 173 else buff->empty();
176 lastword.empty(); 174 lastword.empty();
177 unsigned int slen = buff->width(availht, len); 175 unsigned int slen = buff->width(availht, len);
178 if (lastispara) buff->setstartpara(); 176 if (lastispara) buff->setstartpara();
179 int nospaces = 0; 177 int nospaces = 0;
180 while (1) 178 while (1)
181 { 179 {
182 getch(ch, cs, lastsizes[len]); 180 getch(ch, cs, lastsizes[len]);
183 if (isCentred < 0) 181 if (isCentred < 0)
184 { 182 {
185 isCentred = (cs.getJustify() == m_AlignCentre) ? 1 : 0; 183 isCentred = (cs.getJustify() == m_AlignCentre) ? 1 : 0;
186 } 184 }
187 if (ch == 10 && len == 0 && !lastispara) 185 if (ch == 10 && len == 0 && !lastispara)
188 { 186 {
189 getch(ch, cs, lastsizes[len]); 187 getch(ch, cs, lastsizes[len]);
190 buff->setstartpara(); 188 buff->setstartpara();
191 } 189 }
192 if (ch == UEOF) 190 if (ch == UEOF)
193 { 191 {
194 buff->setendpara(cs); 192 buff->setendpara(cs);
195 if (len == 0) 193 if (len == 0)
196 { 194 {
197 buff->setEof(); 195 buff->setEof();
198 moreleft = false; 196 moreleft = false;
199 } 197 }
200 laststartline = exp->locate(); 198 laststartline = exp->locate();
201 break; 199 break;
202 } 200 }
203 if (ch == 10) 201 if (ch == 10)
204 { 202 {
205 buff->setendpara(cs); 203 buff->setendpara(cs);
206 lastispara = true; 204 lastispara = true;
207 laststartline = exp->locate(); 205 laststartline = exp->locate();
208 break; 206 break;
209 } 207 }
210 if (ch == 6) 208 if (ch == 6)
211 { 209 {
212 buff->setendpara(cs); 210 buff->setendpara(cs);
213 buff->setBop(); 211 buff->setBop();
214 lastispara = true; 212 lastispara = true;
215 laststartline = exp->locate(); 213 laststartline = exp->locate();
216 break; 214 break;
217 } 215 }
218 lastispara = false; 216 lastispara = false;
219 buff->addch(ch, cs); 217 buff->addch(ch, cs);
220 if (ch == ' ') 218 if (ch == ' ')
221 { 219 {
222 nospaces++; 220 nospaces++;
223 } 221 }
224 len++; 222 len++;
225 if (!margindone) 223 if (!margindone)
226 { 224 {
227 w -= buff->leftMargin() + buff->rightMargin(); 225 w -= buff->leftMargin() + buff->rightMargin();
228 margindone = true; 226 margindone = true;
229 } 227 }
230#ifdef INCREMENTALWIDTH 228#ifdef INCREMENTALWIDTH
231 if ((slen += buff->charwidth(len-1, cs)) > w) 229 if ((slen += buff->charwidth(len-1, cs)) > w)
232#else 230#else
233 if ((slen = buff->width(availht, len)) > w) 231 if ((slen = buff->width(availht, len)) > w)
234#endif 232#endif
235 { 233 {
236 if (ch == ' ' || len == 1) 234 if (ch == ' ' || len == 1)
237 { 235 {
238 if (ch == ' ') buff->truncate(len-1); 236 if (ch == ' ') buff->truncate(len-1);
239 laststartline = exp->locate(); 237 laststartline = exp->locate();
240 break; 238 break;
241 } 239 }
242 else // should do a backward search for spaces, first. 240 else // should do a backward search for spaces, first.
243 { 241 {
244 int lastk = len-4; 242 int lastk = len-4;
245 for (int i = len-2; i > 0; i--) 243 for (int i = len-2; i > 0; i--)
246 { 244 {
247 if ( 245 if (
248 (((*buff)[i] == 0x2014) && isletter((*buff)[i+1])) 246 (((*buff)[i] == 0x2014) && isletter((*buff)[i+1]))
249 || 247 ||
250 ((*buff)[i] == '-') 248 ((*buff)[i] == '-')
251 // ((*buff)[i] == '-' && !(((*buff)[i-1] == '-') || ((*buff)[i+1] == '-'))) 249 // ((*buff)[i] == '-' && !(((*buff)[i-1] == '-') || ((*buff)[i+1] == '-')))
252) 250)
253 { 251 {
254 (*buff)[len] = 0; 252 (*buff)[len] = 0;
255 lastword.setright(*buff, i+1); 253 lastword.setright(*buff, i+1);
256 buff->truncate(i+1); 254 buff->truncate(i+1);
257 (*buff)[i+1] = '\0'; 255 (*buff)[i+1] = '\0';
258 laststartline = lastsizes[i+1]; 256 laststartline = lastsizes[i+1];
259 // buff->resize(); 257 // buff->resize();
260 for (int j = 0; j < lastword.length(); j++) 258 for (int j = 0; j < lastword.length(); j++)
261 { 259 {
262 lastsizes[j] = lastsizes[j+i+1]; 260 lastsizes[j] = lastsizes[j+i+1];
263 } 261 }
264 return true; 262 return true;
265 } 263 }
266 264
267 //if (hyphenate && (m_hyphenthreshold+1)*i < m_hyphenthreshold*len) 265 //if (hyphenate && (m_hyphenthreshold+1)*i < m_hyphenthreshold*len)
268 // We end up with i+1 characters instead of len-1 266 // We end up with i+1 characters instead of len-1
269 // Thus we are removing len - 1 - (i + 1) = len-i-2 267 // Thus we are removing len - 1 - (i + 1) = len-i-2
270 // The space characters will be stretched to cover 268 // The space characters will be stretched to cover
271 // nospaces to nospaces + len - i - 2 269 // nospaces to nospaces + len - i - 2
272 // The stretch factor is hence 270 // The stretch factor is hence
273 // (nospaces+len-i-2)/nospaces 271 // (nospaces+len-i-2)/nospaces
274 if (hyphenate && !isCentred && ( 100*(nospaces+len-i-2) > (100+m_hyphenthreshold)*nospaces )) 272 if (hyphenate && !isCentred && ( 100*(nospaces+len-i-2) > (100+m_hyphenthreshold)*nospaces ))
275 { 273 {
276 /* 274 /*
277 if (m_customhyphen) 275 if (m_customhyphen)
278 { 276 {
279 for (int k = lastk; k >= i && k >= 2; k--) 277 for (int k = lastk; k >= i && k >= 2; k--)
280 { 278 {
281 if ( 279 if (
282 isletter((*buff)[k+3]) 280 isletter((*buff)[k+3])
283 && 281 &&
284 isletter((*buff)[k+2]) 282 isletter((*buff)[k+2])
285 && 283 &&
286 isvowel((*buff)[k+1]) 284 isvowel((*buff)[k+1])
287 && 285 &&
288 isconsonant((*buff)[k]) 286 isconsonant((*buff)[k])
289 && 287 &&
290 isletter((*buff)[k-1]) 288 isletter((*buff)[k-1])
291 && 289 &&
292 isletter((*buff)[k-2]) 290 isletter((*buff)[k-2])
293 ) 291 )
294 { 292 {
295 (*buff)[len] = 0; 293 (*buff)[len] = 0;
296 lastword.setright(*buff, k+1); 294 lastword.setright(*buff, k+1);
297 buff->truncate(k+2); 295 buff->truncate(k+2);
298 (*buff)[k+1] = '-'; 296 (*buff)[k+1] = '-';
299 (*buff)[k+2] = '\0'; 297 (*buff)[k+2] = '\0';
300 laststartline = lastsizes[k+1]; 298 laststartline = lastsizes[k+1];
301 buff->resize(); 299 buff->resize();
302 for (int j = 0; j < lastword.length(); j++) 300 for (int j = 0; j < lastword.length(); j++)
303 { 301 {
304 lastsizes[j] = lastsizes[j+k+1]; 302 lastsizes[j] = lastsizes[j+k+1];
305 } 303 }
306 return true; 304 return true;
307 } 305 }
308 } 306 }
309 } 307 }
310 else 308 else
311 */ 309 */
312 { 310 {
313 for (int k = lastk; k >= i && k >= 1; k--) 311 for (int k = lastk; k >= i && k >= 1; k--)
314 { 312 {
315 if ( 313 if (
316 /* 314 /*
317 ( 315 (
318 k < len-3 316 k < len-3
319 && 317 &&
320 k >= 1 318 k >= 1
321 && 319 &&
322 isletter((*buff)[k+3]) 320 isletter((*buff)[k+3])
323 && 321 &&
324 isletter((*buff)[k+2]) 322 isletter((*buff)[k+2])
325 && 323 &&
326 isconsonant((*buff)[k+1]) 324 isconsonant((*buff)[k+1])
327 && 325 &&
328 ((*buff)[k+1] != 'y') 326 ((*buff)[k+1] != 'y')
329 && 327 &&
330 ((*buff)[k+1] != 'h') 328 ((*buff)[k+1] != 'h')
331 && 329 &&
332 isconsonant((*buff)[k]) 330 isconsonant((*buff)[k])
333 && 331 &&
334 ((*buff)[k] != 'h') 332 ((*buff)[k] != 'h')
335 && 333 &&
336 isletter((*buff)[k-1]) 334 isletter((*buff)[k-1])
337 ) 335 )
338 || 336 ||
339 */ 337 */
340 ( 338 (
341 isletter((*buff)[k+3]) 339 isletter((*buff)[k+3])
342 && 340 &&
343 isletter((*buff)[k+2]) 341 isletter((*buff)[k+2])
344 && 342 &&
345 isconsonant((*buff)[k+1]) 343 isconsonant((*buff)[k+1])
346 && 344 &&
347 ((*buff)[k+1] != 'y') 345 ((*buff)[k+1] != 'y')
348 && 346 &&
349 isletter((*buff)[k]) 347 isletter((*buff)[k])
350 && 348 &&
351 ((*buff)[k] != 'h') 349 ((*buff)[k] != 'h')
352 && 350 &&
353 isletter((*buff)[k-1]) 351 isletter((*buff)[k-1])
354 && // Do not hyphenate when the first part ends with a vowel, 352 && // Do not hyphenate when the first part ends with a vowel,
355 // and the second starts with the two consonants. 353 // and the second starts with the two consonants.
356 // Examples: "co-nsona-nts" -> "con-sonants", 354 // Examples: "co-nsona-nts" -> "con-sonants",
357 // "hy-phenation" -> "hyp-henation" etc. 355 // "hy-phenation" -> "hyp-henation" etc.
358 !( isvowel( (*buff)[k] ) && isconsonant( (*buff)[k+2] ) ) 356 !( isvowel( (*buff)[k] ) && isconsonant( (*buff)[k+2] ) )
359 ) 357 )
360 ) 358 )
361 { 359 {
362 (*buff)[len] = 0; 360 (*buff)[len] = 0;
363 lastword.setright(*buff, k+1); 361 lastword.setright(*buff, k+1);
364 buff->truncate(k+2); 362 buff->truncate(k+2);
365 (*buff)[k+1] = '-'; 363 (*buff)[k+1] = '-';
366 (*buff)[k+2] = '\0'; 364 (*buff)[k+2] = '\0';
367 laststartline = lastsizes[k+1]; 365 laststartline = lastsizes[k+1];
368 // buff->resize(); 366 // buff->resize();
369 for (int j = 0; j < lastword.length(); j++) 367 for (int j = 0; j < lastword.length(); j++)
370 { 368 {
371 lastsizes[j] = lastsizes[j+k+1]; 369 lastsizes[j] = lastsizes[j+k+1];
372 } 370 }
373 return true; 371 return true;
374 } 372 }
375 } 373 }
376 } 374 }
377 lastk = i; 375 lastk = i;
378 } 376 }
379 if ((*buff)[i] == ' ') 377 if ((*buff)[i] == ' ')
380 { 378 {
381 (*buff)[len] = 0; 379 (*buff)[len] = 0;
382 lastword.setright(*buff, i+1); 380 lastword.setright(*buff, i+1);
383 buff->truncate(i); 381 buff->truncate(i);
384 (*buff)[i] = '\0'; 382 (*buff)[i] = '\0';
385 laststartline = lastsizes[i+1]; 383 laststartline = lastsizes[i+1];
386 // buff->resize(); 384 // buff->resize();
387 for (int j = 0; j < lastword.length(); j++) 385 for (int j = 0; j < lastword.length(); j++)
388 { 386 {
389 lastsizes[j] = lastsizes[j+i+1]; 387 lastsizes[j] = lastsizes[j+i+1];
390 } 388 }
391 return true; 389 return true;
392 } 390 }
393 } 391 }
394 laststartline = lastsizes[len-1]; 392 laststartline = lastsizes[len-1];
395 (*buff)[len] = 0; 393 (*buff)[len] = 0;
396 lastword.setright(*buff, len - 1); 394 lastword.setright(*buff, len - 1);
397 buff->truncate(len-1); 395 buff->truncate(len-1);
398 buff->addch('-', cs); 396 buff->addch('-', cs);
399 for (int j = 0; j < lastword.length(); j++) 397 for (int j = 0; j < lastword.length(); j++)
400 { 398 {
401 lastsizes[j] = lastsizes[j+len]; 399 lastsizes[j] = lastsizes[j+len];
402 } 400 }
403 break; 401 break;
404 } 402 }
405 } 403 }
406 } 404 }
407 (*buff)[len] = '\0'; 405 (*buff)[len] = '\0';
408 // buff->resize(); 406 // buff->resize();
409 return moreleft; 407 return moreleft;
410} 408}
411#else 409#else
412bool BuffDoc::getline(CDrawBuffer* buff, int wth, unsigned short _lborder, unsigned short _rborder) 410bool BuffDoc::getline(CDrawBuffer* buff, int wth, unsigned short _lborder, unsigned short _rborder)
413{ 411{
414 bool margindone = false; 412 bool margindone = false;
415 int w = wth-(_lborder+_rborder); 413 int w = wth-(_lborder+_rborder);
416 tchar ch = 32; 414 tchar ch = 32;
417 CStyle cs; 415 CStyle cs;
418 buff->empty(); 416 buff->empty();
419 if (exp == NULL) 417 if (exp == NULL)
420 { 418 {
421 //(*buff)[0] = '\0'; 419 //(*buff)[0] = '\0';
422 buff->empty(); 420 buff->empty();
423 return false; 421 return false;
424 } 422 }
425 int len = 0, lastcheck = 0; 423 int len = 0, lastcheck = 0;
426 if (lastword.length() > 0) 424 if (lastword.length() > 0)
427 { 425 {
428 *buff = lastword; 426 *buff = lastword;
429 cs = lastword.laststyle(); 427 cs = lastword.laststyle();
430 w -= buff->leftMargin() + buff->rightMargin(); 428 w -= buff->leftMargin() + buff->rightMargin();
431 margindone = true; 429 margindone = true;
432 } 430 }
433 else buff->empty(); 431 else buff->empty();
434// //qDebug("Buff:%s Lastword:%s", (const char*)toQString(buff->data()), (const char*)toQString(lastword.data())); 432// //qDebug("Buff:%s Lastword:%s", (const char*)toQString(buff->data()), (const char*)toQString(lastword.data()));
435 lastcheck = len = buff->length(); 433 lastcheck = len = buff->length();
436 unsigned int slen = buff->width(availht, len); 434 unsigned int slen = buff->width(availht, len);
437 if (slen > w) 435 if (slen > w)
438 { 436 {
439 for ( ; len > 1; len--) 437 for ( ; len > 1; len--)
440 { 438 {
441 if (buff->width(availht, len) < w) break; 439 if (buff->width(availht, len) < w) break;
442 } 440 }
443// lastword = buff->data() + len - 1; 441// lastword = buff->data() + len - 1;
444 laststartline = lastsizes[len-1]; 442 laststartline = lastsizes[len-1];
445 for (int i = 0; i < buff->length(); i++) lastsizes[i] = lastsizes[i+len-1]; 443 for (int i = 0; i < buff->length(); i++) lastsizes[i] = lastsizes[i+len-1];
446// (*buff)[len-1] = '-'; 444// (*buff)[len-1] = '-';
447 if (len > 2) 445 if (len > 2)
448 { 446 {
449 lastword.setright(*buff, len - 1); 447 lastword.setright(*buff, len - 1);
450 buff->truncate(len-1); 448 buff->truncate(len-1);
451 buff->addch('-', cs); 449 buff->addch('-', cs);
452 (*buff)[len] = '\0'; 450 (*buff)[len] = '\0';
453 } 451 }
454 452
455 else 453 else
456 { 454 {
457 lastword.empty(); 455 lastword.empty();
458 (*buff)[len] = '\0'; 456 (*buff)[len] = '\0';
459 } 457 }
460 // buff->resize(); 458 // buff->resize();
461 return true; 459 return true;
462 } 460 }
463 if (lastispara) 461 if (lastispara)
464 { 462 {
465 lastispara = false; 463 lastispara = false;
466// lastword[0] = '\0'; 464// lastword[0] = '\0';
467 lastword.empty(); 465 lastword.empty();
468 len = buff->length(); 466 len = buff->length();
469 while (buff->width(availht, len) > w) len--; 467 while (buff->width(availht, len) > w) len--;
470// (*buff)[len] = '\0'; 468// (*buff)[len] = '\0';
471 buff->truncate(len); 469 buff->truncate(len);
472 laststartline = exp->locate(); 470 laststartline = exp->locate();
473 // buff->resize(); 471 // buff->resize();
474 return true; 472 return true;
475 } 473 }
476 lastispara = false; 474 lastispara = false;
477 for (int i = 0; i < len; i++) allsizes[i] = lastsizes[i]; 475 for (int i = 0; i < len; i++) allsizes[i] = lastsizes[i];
478 while (slen < w) 476 while (slen < w)
479 { 477 {
480 lastcheck = len; 478 lastcheck = len;
481 getch(ch, cs, allsizes[len]); 479 getch(ch, cs, allsizes[len]);
482 while (ch != ' ' && ch != '\012' && ch != UEOF && len < 128) 480 while (ch != ' ' && ch != '\012' && ch != UEOF && len < 128)
483 { 481 {
484 len++; 482 len++;
485 buff->addch(ch,cs); 483 buff->addch(ch,cs);
486 getch(ch, cs, allsizes[len]); 484 getch(ch, cs, allsizes[len]);
487 } 485 }
488 (*buff)[len] = 0; 486 (*buff)[len] = 0;
489 slen = buff->width(availht, len); 487 slen = buff->width(availht, len);
490 len++; 488 len++;
491 buff->addch(' ', cs); 489 buff->addch(' ', cs);
492 if (!margindone) 490 if (!margindone)
493 { 491 {
494 w -= buff->leftMargin() + buff->rightMargin(); 492 w -= buff->leftMargin() + buff->rightMargin();
495 margindone = true; 493 margindone = true;
496 } 494 }
497 allsizes[len] = exp->locate(); 495 allsizes[len] = exp->locate();
498 if (slen < w && ch != ' ') 496 if (slen < w && ch != ' ')
499 { 497 {
500 lastcheck = len; 498 lastcheck = len;
501 break; 499 break;
502 } 500 }
503 lastispara = (ch == '\012'); 501 lastispara = (ch == '\012');
504 } 502 }
505 (*buff)[len] = '\0'; 503 (*buff)[len] = '\0';
506// lastword = buff->data()+lastcheck; 504// lastword = buff->data()+lastcheck;
507#ifdef _WINDOWS 505#ifdef _WINDOWS
508 lastword.setright(*buff, (lastcheck > 0) ? lastcheck : 1); 506 lastword.setright(*buff, (lastcheck > 0) ? lastcheck : 1);
509 { 507 {
510 int i; 508 int i;
511 for (i = 0; i < lastword.length(); i++) lastsizes[i] = allsizes[i+lastcheck]; 509 for (i = 0; i < lastword.length(); i++) lastsizes[i] = allsizes[i+lastcheck];
512 } 510 }
513#else 511#else
514 lastword.setright(*buff, (lastcheck > 0) ? lastcheck : 1); 512 lastword.setright(*buff, (lastcheck > 0) ? lastcheck : 1);
515 for (int i = 0; i < lastword.length(); i++) lastsizes[i] = allsizes[i+lastcheck]; 513 for (int i = 0; i < lastword.length(); i++) lastsizes[i] = allsizes[i+lastcheck];
516#endif 514#endif
517 if (lastcheck > 0) 515 if (lastcheck > 0)
518 { 516 {
519 laststartline = allsizes[lastcheck]; 517 laststartline = allsizes[lastcheck];
520// (*buff)[lastcheck-1] = '\0'; 518// (*buff)[lastcheck-1] = '\0';
521 buff->truncate(lastcheck-1); 519 buff->truncate(lastcheck-1);
522 } 520 }
523 else 521 else
524 { 522 {
525 laststartline = (lastcheck == len) ? exp->locate() : allsizes[lastcheck+1]; 523 laststartline = (lastcheck == len) ? exp->locate() : allsizes[lastcheck+1];
526// (*buff)[lastcheck] = '\0'; 524// (*buff)[lastcheck] = '\0';
527 buff->truncate(lastcheck); 525 buff->truncate(lastcheck);
528 } 526 }
529// buff->frig(); 527// buff->frig();
530// buff->resize(); 528// buff->resize();
531 if (ch == UEOF && buff->length() == 0) 529 if (ch == UEOF && buff->length() == 0)
532 { 530 {
533 buff->setEof(); 531 buff->setEof();
534 return false; 532 return false;
535 } 533 }
536 return true; 534 return true;
537} 535}
538#endif 536#endif
539 537
540bool BuffDoc::getline(CDrawBuffer* buff, int wth, int cw, unsigned short _lborder, unsigned short _rborder, int availht) 538bool BuffDoc::getline(CDrawBuffer* buff, int wth, int cw, unsigned short _lborder, unsigned short _rborder, int availht)
541{ 539{
542 int w = wth-(_lborder+_rborder); 540 int w = wth-(_lborder+_rborder);
543 buff->empty(); 541 buff->empty();
544 if (exp == NULL) 542 if (exp == NULL)
545 { 543 {
546 return false; 544 return false;
547 } 545 }
548 tchar ch; 546 tchar ch;
549 CStyle cs; 547 CStyle cs;
550 int i = 1; 548 int i = 1;
551 int offset = buff->offset(w,0,0,availht); 549 int offset = buff->offset(w,0,0,availht);
552 while (i*cw < w-offset) 550 while (i*cw < w-offset)
553 { 551 {
554 unsigned long dummy; 552 unsigned long dummy;
555 getch(ch, cs, dummy); 553 getch(ch, cs, dummy);
556 if (ch == '\12' || ch == UEOF) break; 554 if (ch == '\12' || ch == UEOF) break;
557 buff->addch(ch,cs); 555 buff->addch(ch,cs);
558 i++; 556 i++;
559 } 557 }
560 buff->truncate(i); 558 buff->truncate(i);
561 laststartline = exp->locate(); 559 laststartline = exp->locate();
562 // buff->resize(); 560 // buff->resize();
563 return (ch != UEOF); 561 return (ch != UEOF);
564} 562}
565 563
566int BuffDoc::openfile(QWidget* _parent, const char *src) 564int BuffDoc::openfile(QWidget* _parent, const char *src)
567{ 565{
568 if (exp != NULL) delete exp; 566 if (exp != NULL) delete exp;
569 exp = NULL; 567 exp = NULL;
570 568
571#ifdef __STATIC 569#ifdef __STATIC
572 exp = new Aportis; 570 exp = new Aportis;
573 int ret = exp->openfile(src); 571 int ret = exp->openfile(src);
574 if (ret == -1) 572 if (ret == -1)
575 { 573 {
576 delete exp; 574 delete exp;
577 exp = NULL; 575 exp = NULL;
578 return ret; 576 return ret;
579 } 577 }
580 if (ret == -2) 578 if (ret == -2)
581 { 579 {
582 580
583 delete exp; 581 delete exp;
584 exp = new ztxt; 582 exp = new ztxt;
585 ret = exp->openfile(src); 583 ret = exp->openfile(src);
586 } 584 }
587 /* 585 /*
588 } 586 }
589 if (ret != 0) 587 if (ret != 0)
590 { 588 {
591 delete exp; 589 delete exp;
592 exp = new ebookcodec("Aportis"); 590 exp = new ebookcodec("Aportis");
593 ret = exp->openfile(src); 591 ret = exp->openfile(src);
594 if (ret == 0) qDebug("Aportis format"); 592 if (ret == 0) qDebug("Aportis format");
595 } 593 }
596 */ 594 */
597#ifdef USENEF 595#ifdef USENEF
598 if (ret != 0) 596 if (ret != 0)
599 { 597 {
600 598
601 delete exp; 599 delete exp;
602 exp = new CArriere; 600 exp = new CArriere;
603 ret = exp->openfile(src); 601 ret = exp->openfile(src);
604 if (ret == 0) qDebug("Arriere format"); 602 if (ret == 0) qDebug("Arriere format");
605 } 603 }
606 if (ret != 0) 604 if (ret != 0)
607 { 605 {
608 606
609 delete exp; 607 delete exp;
610 exp = new CNEF; 608 exp = new CNEF;
611 ret = exp->openfile(src); 609 ret = exp->openfile(src);
612 if (ret == 0) qDebug("NEF format"); 610 if (ret == 0) qDebug("NEF format");
613 } 611 }
614#endif 612#endif
615 if (ret != 0) 613 if (ret != 0)
616 { 614 {
617 615
618 delete exp; 616 delete exp;
619 exp = new CPlucker; 617 exp = new CPlucker;
620 ret = exp->openfile(src); 618 ret = exp->openfile(src);
621 } 619 }
622 if (ret != 0) 620 if (ret != 0)
623 { 621 {
624 622
625 delete exp; 623 delete exp;
626 exp = new CHM; 624 exp = new CHM;
627 ret = exp->openfile(src); 625 ret = exp->openfile(src);
628 } 626 }
629 if (ret != 0) 627 if (ret != 0)
630 { 628 {
631 629
632 delete exp; 630 delete exp;
633 exp = new iSilo; 631 exp = new iSilo;
634 ret = exp->openfile(src); 632 ret = exp->openfile(src);
635 } 633 }
636 if (ret != 0) 634 if (ret != 0)
637 { 635 {
638 delete exp; 636 delete exp;
639 //qDebug("Trying ppms"); 637 //qDebug("Trying ppms");
640 exp = new ppm_expander; 638 exp = new ppm_expander;
641 ret = exp->openfile(src); 639 ret = exp->openfile(src);
642 } 640 }
643 if (ret != 0) 641 if (ret != 0)
644 { 642 {
645 delete exp; 643 delete exp;
646 exp = new Text; 644 exp = new Text;
647 // //qDebug("Trying text"); 645 // //qDebug("Trying text");
648 ret = exp->openfile(src); 646 ret = exp->openfile(src);
649 if (ret == 0) qDebug("Text format"); 647 if (ret == 0) qDebug("Text format");
650 } 648 }
651 649
652 if (ret != 0) 650 if (ret != 0)
653 { 651 {
654 delete exp; 652 delete exp;
655 QMessageBox::information(_parent, PROGNAME, "Unknown file compression type","Try another file"); 653 QMessageBox::information(_parent, PROGNAME, "Unknown file compression type","Try another file");
656 return ret; 654 return ret;
657 } 655 }
658 // //qDebug("Doing final open:%x:%x",exp,filt); 656 // //qDebug("Doing final open:%x:%x",exp,filt);
659#else 657#else
660 QString codecpath(QTReaderUtil::getPluginPath()); 658 QString codecpath(QTReaderUtil::getPluginPath());
661 QDir d(codecpath, "*.so"); 659 QDir d(codecpath, "*.so");
662 660
663 if (d.exists()) 661 if (d.exists())
664 { 662 {
665 663
666 const QFileInfoList *list = d.entryInfoList(); 664 const QFileInfoList *list = d.entryInfoList();
667 QFileInfoListIterator it( *list ); // create list iterator 665 QFileInfoListIterator it( *list ); // create list iterator
668 QFileInfo *fi; // pointer for traversing 666 QFileInfo *fi; // pointer for traversing
669 667
670 int ret = -1; 668 int ret = -1;
671 while ( ret != 0 && (fi=it.current()) ) 669 while ( ret != 0 && (fi=it.current()) )
672 { // for each file... 670 { // for each file...
673 if (exp != NULL) delete exp; 671 if (exp != NULL) delete exp;
674 qDebug("Trying %s", (const char*)fi->fileName()); 672 qDebug("Trying %s", (const char*)fi->fileName());
675 exp = new ebookcodec(fi->fileName()); 673 exp = new ebookcodec(fi->fileName());
676 ret = exp->openfile(src); 674 ret = exp->openfile(src);
677 ++it; 675 ++it;
678 } 676 }
679 qDebug("Buffdoc:Finished opening"); 677 qDebug("Buffdoc:Finished opening");
680 if (ret != 0) 678 if (ret != 0)
681 { 679 {
682 if (exp != NULL) delete exp; 680 if (exp != NULL) delete exp;
683 exp = new Text; 681 exp = new Text;
684 ret = exp->openfile(src); 682 ret = exp->openfile(src);
685 } 683 }
686 } 684 }
687 else 685 else
688 { 686 {
689 if (exp != NULL) delete exp; 687 if (exp != NULL) delete exp;
690 exp = new Text; 688 exp = new Text;
691 exp->openfile(src); 689 exp->openfile(src);
692 } 690 }
693#endif 691#endif
694 lastword.empty(); 692 lastword.empty();
695 lastsizes[0] = laststartline = 0; 693 lastsizes[0] = laststartline = 0;
696#ifdef NEWLINEBREAK 694#ifdef NEWLINEBREAK
697 lastispara = false; 695 lastispara = false;
698#else 696#else
699 lastispara = false; 697 lastispara = false;
700#endif 698#endif
701 exp->locate(exp->getHome()); 699 exp->locate(exp->getHome());
702 filt->setsource(exp); 700 filt->setsource(exp);
703 qDebug("BuffDoc:file opened"); 701 qDebug("BuffDoc:file opened");
704 return 0; 702 return 0;
705} 703}
706 704
707QString BuffDoc::about() 705QString BuffDoc::about()
708{ 706{
709 return QString("Buffered Decompressor (c) Tim Wentford\nHyphenation algorithm (c) Tim Wentford\n (Cyrillic support by Konstantin Isakov\n")+filt->about(); 707 return QString("Buffered Decompressor (c) Tim Wentford\nHyphenation algorithm (c) Tim Wentford\n (Cyrillic support by Konstantin Isakov\n")+filt->about();
710} 708}
diff --git a/noncore/apps/opie-reader/BuffDoc.h b/noncore/apps/opie-reader/BuffDoc.h
index a7dd7bf..2b4fb57 100644
--- a/noncore/apps/opie-reader/BuffDoc.h
+++ b/noncore/apps/opie-reader/BuffDoc.h
@@ -1,144 +1,143 @@
1#ifndef __BuffDoc_h 1#ifndef __BuffDoc_h
2#define __BuffDoc_h 2#define __BuffDoc_h
3 3
4#include "useqpe.h"
5#include "CDrawBuffer.h" 4#include "CDrawBuffer.h"
6#include "CFilter.h" 5#include "CFilter.h"
7#include "CExpander.h" 6#include "CExpander.h"
8#include <qfontmetrics.h> 7#include <qfontmetrics.h>
9#include <qmessagebox.h> 8#include <qmessagebox.h>
10 9
11class BuffDoc 10class BuffDoc
12{ 11{
13 CDrawBuffer lastword; 12 CDrawBuffer lastword;
14 CSizeBuffer lastsizes, allsizes; 13 CSizeBuffer lastsizes, allsizes;
15 size_t laststartline; 14 size_t laststartline;
16 bool lastispara; 15 bool lastispara;
17 CExpander_Interface* exp; 16 CExpander_Interface* exp;
18 CFilterChain* filt; 17 CFilterChain* filt;
19 int m_hyphenthreshold; 18 int m_hyphenthreshold;
20 // bool m_customhyphen; 19 // bool m_customhyphen;
21 public: 20 public:
22 QString about(); 21 QString about();
23 bool findanchor(const QString& nm) 22 bool findanchor(const QString& nm)
24 { 23 {
25 return filt->findanchor(nm); 24 return filt->findanchor(nm);
26 } 25 }
27 // void setCustomHyphen(bool _v) { m_customhyphen = _v; } 26 // void setCustomHyphen(bool _v) { m_customhyphen = _v; }
28 // bool getCustomHyphen() { return m_customhyphen; } 27 // bool getCustomHyphen() { return m_customhyphen; }
29 void setHyphenThreshold(int _v) { m_hyphenthreshold = _v; } 28 void setHyphenThreshold(int _v) { m_hyphenthreshold = _v; }
30 void setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen) 29 void setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen)
31 { 30 {
32 if (exp == NULL) 31 if (exp == NULL)
33 { 32 {
34 data = NULL; 33 data = NULL;
35 len = 0; 34 len = 0;
36 } 35 }
37 else 36 else
38 { 37 {
39 exp->setSaveData(data, len, src, srclen); 38 exp->setSaveData(data, len, src, srclen);
40 } 39 }
41 } 40 }
42 void putSaveData(unsigned char*& src, unsigned short& srclen) 41 void putSaveData(unsigned char*& src, unsigned short& srclen)
43 { 42 {
44 if (exp != NULL) 43 if (exp != NULL)
45 { 44 {
46 exp->putSaveData(src, srclen); 45 exp->putSaveData(src, srclen);
47 } 46 }
48 } 47 }
49#ifdef USEQPE 48#ifdef USEQPE
50 void suspend() { if (exp != NULL) exp->suspend(); } 49 void suspend() { if (exp != NULL) exp->suspend(); }
51 void unsuspend() { if (exp != NULL) exp->unsuspend(); } 50 void unsuspend() { if (exp != NULL) exp->unsuspend(); }
52#else 51#else
53 void suspend() {} 52 void suspend() {}
54 void unsuspend() {} 53 void unsuspend() {}
55#endif 54#endif
56 ~BuffDoc() 55 ~BuffDoc()
57 { 56 {
58 delete filt; 57 delete filt;
59 delete exp; 58 delete exp;
60 } 59 }
61 BuffDoc() 60 BuffDoc()
62 { 61 {
63 exp = NULL; 62 exp = NULL;
64 filt = NULL; 63 filt = NULL;
65 lastword.empty(); 64 lastword.empty();
66 // // qDebug("Buffdoc created"); 65 // // qDebug("Buffdoc created");
67 } 66 }
68 bool empty() { return (exp == NULL); } 67 bool empty() { return (exp == NULL); }
69 void setfilter(CFilterChain* _f) 68 void setfilter(CFilterChain* _f)
70 { 69 {
71 if (filt != NULL) delete filt; 70 if (filt != NULL) delete filt;
72 filt = _f; 71 filt = _f;
73 filt->setsource(exp); 72 filt->setsource(exp);
74 } 73 }
75 CList<Bkmk>* getbkmklist() { return exp->getbkmklist(); } 74 CList<Bkmk>* getbkmklist() { return exp->getbkmklist(); }
76 bool hasrandomaccess() { return (exp == NULL) ? false : exp->hasrandomaccess(); } 75 bool hasrandomaccess() { return (exp == NULL) ? false : exp->hasrandomaccess(); }
77 bool iseol() { return (lastword[0] == '\0'); } 76 bool iseol() { return (lastword[0] == '\0'); }
78 int openfile(QWidget* _parent, const char *src); 77 int openfile(QWidget* _parent, const char *src);
79 tchar getch() 78 tchar getch()
80 { 79 {
81 tchar ch = UEOF; 80 tchar ch = UEOF;
82 CStyle sty; 81 CStyle sty;
83 if (exp != NULL) 82 if (exp != NULL)
84 { 83 {
85 unsigned long dummy; 84 unsigned long dummy;
86 filt->getch(ch, sty, dummy); 85 filt->getch(ch, sty, dummy);
87 } 86 }
88 return ch; 87 return ch;
89 } 88 }
90 void getch(tchar& ch, CStyle& sty, unsigned long& pos) 89 void getch(tchar& ch, CStyle& sty, unsigned long& pos)
91 { 90 {
92 if (exp != NULL) 91 if (exp != NULL)
93 { 92 {
94 filt->getch(ch, sty, pos); 93 filt->getch(ch, sty, pos);
95 } 94 }
96 else 95 else
97 ch = UEOF; 96 ch = UEOF;
98 } 97 }
99 void setwidth(int w) { if (exp != NULL) exp->setwidth(w); } 98 void setwidth(int w) { if (exp != NULL) exp->setwidth(w); }
100 QImage* getPicture(unsigned long tgt) { return (exp == NULL) ? NULL : exp->getPicture(tgt); } 99 QImage* getPicture(unsigned long tgt) { return (exp == NULL) ? NULL : exp->getPicture(tgt); }
101 unsigned int startSection() { return (exp == NULL) ? 0 : exp->startSection(); } 100 unsigned int startSection() { return (exp == NULL) ? 0 : exp->startSection(); }
102 unsigned int endSection() { return (exp == NULL) ? 0 : exp->endSection(); } 101 unsigned int endSection() { return (exp == NULL) ? 0 : exp->endSection(); }
103 unsigned int locate() { return (exp == NULL) ? 0 : laststartline; } 102 unsigned int locate() { return (exp == NULL) ? 0 : laststartline; }
104 unsigned int explocate() { return (exp == NULL) ? 0 : exp->locate(); } 103 unsigned int explocate() { return (exp == NULL) ? 0 : exp->locate(); }
105 void setContinuous(bool _b) { if (exp != NULL) exp->setContinuous(_b); } 104 void setContinuous(bool _b) { if (exp != NULL) exp->setContinuous(_b); }
106 MarkupType PreferredMarkup() { return (exp == NULL) ? cTEXT : exp->PreferredMarkup(); } 105 MarkupType PreferredMarkup() { return (exp == NULL) ? cTEXT : exp->PreferredMarkup(); }
107 linkType hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm); 106 linkType hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm);
108 size_t getHome() { return ((exp != NULL) ? exp->getHome() : 0); } 107 size_t getHome() { return ((exp != NULL) ? exp->getHome() : 0); }
109 void locate(unsigned int n); 108 void locate(unsigned int n);
110 bool getline(CDrawBuffer* buff, int w, unsigned short _lborder, unsigned short _rborder, bool hyphenate, int availht); 109 bool getline(CDrawBuffer* buff, int w, unsigned short _lborder, unsigned short _rborder, bool hyphenate, int availht);
111 bool getline(CDrawBuffer* buff, int w, int cw, unsigned short _lborder, unsigned short _rborder, int availht); 110 bool getline(CDrawBuffer* buff, int w, int cw, unsigned short _lborder, unsigned short _rborder, int availht);
112 void sizes(unsigned long& fs, unsigned long& ts) 111 void sizes(unsigned long& fs, unsigned long& ts)
113 { 112 {
114 if (exp != NULL) 113 if (exp != NULL)
115 { 114 {
116 exp->sizes(fs,ts); 115 exp->sizes(fs,ts);
117 } 116 }
118 else 117 else
119 { 118 {
120 fs = ts = 0; 119 fs = ts = 0;
121 } 120 }
122 } 121 }
123 int getpara(CBuffer& buff) 122 int getpara(CBuffer& buff)
124 { 123 {
125 tchar ch; 124 tchar ch;
126 int i = 0; 125 int i = 0;
127 while ((ch = getch()) != 10 && ch != UEOF) buff[i++] = ch; 126 while ((ch = getch()) != 10 && ch != UEOF) buff[i++] = ch;
128 buff[i] = '\0'; 127 buff[i] = '\0';
129 if (i == 0 && ch == UEOF) i = -1; 128 if (i == 0 && ch == UEOF) i = -1;
130 laststartline = exp->locate(); 129 laststartline = exp->locate();
131 return i; 130 return i;
132 } 131 }
133 void saveposn(const QString& f, size_t posn) { filt->saveposn(f, posn); } 132 void saveposn(const QString& f, size_t posn) { filt->saveposn(f, posn); }
134 void writeposn(const QString& f, size_t posn) { filt->writeposn(f, posn); } 133 void writeposn(const QString& f, size_t posn) { filt->writeposn(f, posn); }
135 linkType forward(QString& f, size_t& loc) { return filt->forward(f, loc); } 134 linkType forward(QString& f, size_t& loc) { return filt->forward(f, loc); }
136 linkType back(QString& f, size_t& loc) { return filt->back(f, loc); } 135 linkType back(QString& f, size_t& loc) { return filt->back(f, loc); }
137 bool hasnavigation() { return filt->hasnavigation(); } 136 bool hasnavigation() { return filt->hasnavigation(); }
138 bool getFile(QString href) 137 bool getFile(QString href)
139 { 138 {
140 return (exp == NULL) ? false : exp->getFile(href); 139 return (exp == NULL) ? false : exp->getFile(href);
141 } 140 }
142}; 141};
143 142
144#endif 143#endif
diff --git a/noncore/apps/opie-reader/CDrawBuffer.cpp b/noncore/apps/opie-reader/CDrawBuffer.cpp
index caccf1b..bfb3027 100644
--- a/noncore/apps/opie-reader/CDrawBuffer.cpp
+++ b/noncore/apps/opie-reader/CDrawBuffer.cpp
@@ -1,863 +1,862 @@
1#include "CDrawBuffer.h" 1#include "CDrawBuffer.h"
2#include "FontControl.h" 2#include "FontControl.h"
3#include <qfontmetrics.h> 3#include <qfontmetrics.h>
4#include <qpainter.h> 4#include <qpainter.h>
5#include <qpixmap.h> 5#include <qpixmap.h>
6#include <qimage.h> 6#include <qimage.h>
7#include "useqpe.h"
8 7
9CDrawBuffer::~CDrawBuffer() 8CDrawBuffer::~CDrawBuffer()
10{ 9{
11 while (!segs.isEmpty()) segs.erase(0); 10 while (!segs.isEmpty()) segs.erase(0);
12} 11}
13 12
14void CDrawBuffer::setright(CDrawBuffer& rhs, int f) 13void CDrawBuffer::setright(CDrawBuffer& rhs, int f)
15{ 14{
16 int i; 15 int i;
17 len = rhs.len; 16 len = rhs.len;
18 fc = rhs.fc; 17 fc = rhs.fc;
19 m_ascent = m_descent = m_lineSpacing = m_lineExtraSpacing = 0; 18 m_ascent = m_descent = m_lineSpacing = m_lineExtraSpacing = 0;
20 while (!segs.isEmpty()) 19 while (!segs.isEmpty())
21 { 20 {
22 segs.erase(0); 21 segs.erase(0);
23 } 22 }
24 for (CList<textsegment>::iterator iter = rhs.segs.begin(); iter != rhs.segs.end(); ) 23 for (CList<textsegment>::iterator iter = rhs.segs.begin(); iter != rhs.segs.end(); )
25 { 24 {
26 CList<textsegment>::iterator next = iter; 25 CList<textsegment>::iterator next = iter;
27 iter++; 26 iter++;
28 if (iter == rhs.segs.end() || iter->start > f) 27 if (iter == rhs.segs.end() || iter->start > f)
29 { 28 {
30 int st = next->start-f; 29 int st = next->start-f;
31 if (st < 0) st = 0; 30 if (st < 0) st = 0;
32 31
33 CStyle _style = next->style; 32 CStyle _style = next->style;
34 segs.push_back(textsegment(st,next->style)); 33 segs.push_back(textsegment(st,next->style));
35 } 34 }
36 } 35 }
37 for (i = f; rhs[i] != '\0'; i++) (*this)[i-f] = rhs[i]; 36 for (i = f; rhs[i] != '\0'; i++) (*this)[i-f] = rhs[i];
38 (*this)[i-f] = '\0'; 37 (*this)[i-f] = '\0';
39 len = i; 38 len = i;
40} 39}
41 40
42CDrawBuffer& CDrawBuffer::operator=(CDrawBuffer& rhs) 41CDrawBuffer& CDrawBuffer::operator=(CDrawBuffer& rhs)
43{ 42{
44 int i; 43 int i;
45// //qDebug("Trying 2"); 44// //qDebug("Trying 2");
46 len = rhs.len; 45 len = rhs.len;
47 m_ascent = rhs.m_ascent; 46 m_ascent = rhs.m_ascent;
48 m_descent = rhs.m_descent; 47 m_descent = rhs.m_descent;
49 m_lineSpacing = rhs.m_lineSpacing; 48 m_lineSpacing = rhs.m_lineSpacing;
50 m_lineExtraSpacing = rhs.m_lineExtraSpacing; 49 m_lineExtraSpacing = rhs.m_lineExtraSpacing;
51 m_showPartial = rhs.m_showPartial; 50 m_showPartial = rhs.m_showPartial;
52 while (!segs.isEmpty()) 51 while (!segs.isEmpty())
53 { 52 {
54 segs.erase(0); 53 segs.erase(0);
55 } 54 }
56 for (CList<textsegment>::iterator iter = rhs.segs.begin(); iter != rhs.segs.end(); iter++) 55 for (CList<textsegment>::iterator iter = rhs.segs.begin(); iter != rhs.segs.end(); iter++)
57 { 56 {
58 segs.push_back(*iter); 57 segs.push_back(*iter);
59 } 58 }
60 for (i = 0; rhs[i] != '\0'; i++) (*this)[i] = rhs[i]; 59 for (i = 0; rhs[i] != '\0'; i++) (*this)[i] = rhs[i];
61 (*this)[i] = '\0'; 60 (*this)[i] = '\0';
62 len = i; 61 len = i;
63// //qDebug("Tried 2"); 62// //qDebug("Tried 2");
64 return *this; 63 return *this;
65} 64}
66 65
67CDrawBuffer& CDrawBuffer::operator=(const tchar*sztmp) 66CDrawBuffer& CDrawBuffer::operator=(const tchar*sztmp)
68{ 67{
69 int i; 68 int i;
70 while (!segs.isEmpty()) 69 while (!segs.isEmpty())
71 { 70 {
72 segs.erase(0); 71 segs.erase(0);
73 } 72 }
74 segs.push_back(textsegment(0, CStyle())); 73 segs.push_back(textsegment(0, CStyle()));
75 for (i = 0; sztmp[i] != '\0'; i++) (*this)[i] = sztmp[i]; 74 for (i = 0; sztmp[i] != '\0'; i++) (*this)[i] = sztmp[i];
76 (*this)[i] = '\0'; 75 (*this)[i] = '\0';
77 len = i; 76 len = i;
78 return *this; 77 return *this;
79} 78}
80 79
81void CDrawBuffer::empty() 80void CDrawBuffer::empty()
82{ 81{
83 m_bSop = false; 82 m_bSop = false;
84 m_bEop = false; 83 m_bEop = false;
85 m_bBop = false; 84 m_bBop = false;
86 len = 0; 85 len = 0;
87 (*this)[0] = 0; 86 (*this)[0] = 0;
88 while (!segs.isEmpty()) 87 while (!segs.isEmpty())
89 { 88 {
90 segs.erase(0); 89 segs.erase(0);
91 } 90 }
92 segs.push_back(textsegment(0,CStyle())); 91 segs.push_back(textsegment(0,CStyle()));
93 m_ascent = m_descent = m_lineSpacing = m_lineExtraSpacing = 0; 92 m_ascent = m_descent = m_lineSpacing = m_lineExtraSpacing = 0;
94 m_bEof = false; 93 m_bEof = false;
95} 94}
96 95
97void CDrawBuffer::setendpara(const CStyle& _style/* = ucFontBase*/) 96void CDrawBuffer::setendpara(const CStyle& _style/* = ucFontBase*/)
98{ 97{
99 m_bEop = true; 98 m_bEop = true;
100 if (len == 0) 99 if (len == 0)
101 { 100 {
102 segs.first().start = 0; 101 segs.first().start = 0;
103 segs.first().style = _style; 102 segs.first().style = _style;
104 } 103 }
105} 104}
106 105
107void CDrawBuffer::addch(tchar ch, CStyle _style/* = ucFontBase*/) 106void CDrawBuffer::addch(tchar ch, CStyle _style/* = ucFontBase*/)
108{ 107{
109 if (len == 0) 108 if (len == 0)
110 { 109 {
111 segs.first().start = 0; 110 segs.first().start = 0;
112 segs.first().style = _style; 111 segs.first().style = _style;
113 } 112 }
114 else if (_style != segs.last().style) 113 else if (_style != segs.last().style)
115 { 114 {
116 segs.push_back(textsegment(len, _style)); 115 segs.push_back(textsegment(len, _style));
117 } 116 }
118 (*this)[len++] = ch; 117 (*this)[len++] = ch;
119} 118}
120 119
121void CDrawBuffer::truncate(int n) 120void CDrawBuffer::truncate(int n)
122{ 121{
123 len = n; 122 len = n;
124 (*this)[n] = 0; 123 (*this)[n] = 0;
125} 124}
126 125
127int CDrawBuffer::width(int availht, int numchars, bool onscreen, int scwidth, unsigned short _lborder, unsigned short _rborder) 126int CDrawBuffer::width(int availht, int numchars, bool onscreen, int scwidth, unsigned short _lborder, unsigned short _rborder)
128{ 127{
129 int gzoom = fc->gzoom(); 128 int gzoom = fc->gzoom();
130 int currentx = 0, end = 0; 129 int currentx = 0, end = 0;
131 QString text = (numchars < 0) ? toQString(data()) : toQString(data(), numchars); 130 QString text = (numchars < 0) ? toQString(data()) : toQString(data(), numchars);
132 CList<textsegment>::iterator textstart = segs.begin(); 131 CList<textsegment>::iterator textstart = segs.begin();
133 int extraspace = 0; 132 int extraspace = 0;
134 bool just = (onscreen && !m_bEop && textstart->style.getJustify() == m_AlignJustify); 133 bool just = (onscreen && !m_bEop && textstart->style.getJustify() == m_AlignJustify);
135 int spaces = 0; 134 int spaces = 0;
136 int spacesofar = 0; 135 int spacesofar = 0;
137 int spacenumber = 0; 136 int spacenumber = 0;
138 int nonspace = 0; 137 int nonspace = 0;
139 if (just) 138 if (just)
140 { 139 {
141 for (int i = 0; i < len; i++) 140 for (int i = 0; i < len; i++)
142 { 141 {
143 if ((*this)[i] != ' ') 142 if ((*this)[i] != ' ')
144 { 143 {
145 nonspace = i; 144 nonspace = i;
146 break; 145 break;
147 } 146 }
148 } 147 }
149#ifdef _WINDOWS 148#ifdef _WINDOWS
150 for (i = nonspace; i < len; i++) 149 for (i = nonspace; i < len; i++)
151#else 150#else
152 for (int i = nonspace; i < len; i++) 151 for (int i = nonspace; i < len; i++)
153#endif 152#endif
154 { 153 {
155 if ((*this)[i] == ' ') 154 if ((*this)[i] == ' ')
156 { 155 {
157 spaces++; 156 spaces++;
158 } 157 }
159 } 158 }
160 if (spaces == 0) 159 if (spaces == 0)
161 { 160 {
162 just = false; 161 just = false;
163 } 162 }
164 else 163 else
165 { 164 {
166 extraspace = (scwidth - (_lborder+_rborder) - rightMargin() - leftMargin() - width(availht)); 165 extraspace = (scwidth - (_lborder+_rborder) - rightMargin() - leftMargin() - width(availht));
167 if (extraspace == 0) just = false; 166 if (extraspace == 0) just = false;
168 } 167 }
169 } 168 }
170 CList<textsegment>::iterator textend = textstart; 169 CList<textsegment>::iterator textend = textstart;
171 do 170 do
172 { 171 {
173 textend++; 172 textend++;
174 end = (textend != segs.end()) ? textend->start : len; 173 end = (textend != segs.end()) ? textend->start : len;
175 if (numchars >= 0 && end > numchars) 174 if (numchars >= 0 && end > numchars)
176 { 175 {
177 end = numchars; 176 end = numchars;
178 } 177 }
179 CStyle currentstyle = textstart->style; 178 CStyle currentstyle = textstart->style;
180 if (currentstyle.isPicture()) 179 if (currentstyle.isPicture())
181 { 180 {
182 if (currentstyle.canScale()) 181 if (currentstyle.canScale())
183 { 182 {
184 int ht = (gzoom*currentstyle.getPicture()->height())/100; 183 int ht = (gzoom*currentstyle.getPicture()->height())/100;
185 int wt = (gzoom*currentstyle.getPicture()->width())/100; 184 int wt = (gzoom*currentstyle.getPicture()->width())/100;
186 if (ht > availht) 185 if (ht > availht)
187 { 186 {
188 wt = (wt*availht)/ht; 187 wt = (wt*availht)/ht;
189 } 188 }
190 currentx += wt; 189 currentx += wt;
191 } 190 }
192 else 191 else
193 { 192 {
194 currentx += currentstyle.getPicture()->width(); 193 currentx += currentstyle.getPicture()->width();
195 } 194 }
196 } 195 }
197 else 196 else
198 { 197 {
199 if (currentstyle.isMono() && !fc->hasCourier()) 198 if (currentstyle.isMono() && !fc->hasCourier())
200 { 199 {
201 int cw = (7*fc->getsize(currentstyle))/10; 200 int cw = (7*fc->getsize(currentstyle))/10;
202 currentx += cw*(end-textstart->start); 201 currentx += cw*(end-textstart->start);
203 } 202 }
204 else 203 else
205 { 204 {
206 QFont f(currentstyle.isMono() ? QString(fc->fixedfontname()) : fc->name(), fc->getsize(currentstyle), (currentstyle.isBold()) ? QFont::Bold : QFont::Normal, (currentstyle.isItalic()) ); 205 QFont f(currentstyle.isMono() ? QString(fc->fixedfontname()) : fc->name(), fc->getsize(currentstyle), (currentstyle.isBold()) ? QFont::Bold : QFont::Normal, (currentstyle.isItalic()) );
207 // f.setUnderline(currentstyle.isUnderline()); 206 // f.setUnderline(currentstyle.isUnderline());
208 QString str = text.mid(textstart->start, end-textstart->start); 207 QString str = text.mid(textstart->start, end-textstart->start);
209 QFontMetrics fm(f); 208 QFontMetrics fm(f);
210 if (just) 209 if (just)
211 { 210 {
212 int lastspace = -1; 211 int lastspace = -1;
213 int nsp = 0; 212 int nsp = 0;
214 int cx = currentx; 213 int cx = currentx;
215 while ((nsp = str.find(" ", lastspace+1)) >= 0) 214 while ((nsp = str.find(" ", lastspace+1)) >= 0)
216 { 215 {
217 if (nsp > nonspace) 216 if (nsp > nonspace)
218 { 217 {
219 spacenumber++; 218 spacenumber++;
220 int nexttoadd = (extraspace*spacenumber+spaces/2)/spaces - spacesofar; 219 int nexttoadd = (extraspace*spacenumber+spaces/2)/spaces - spacesofar;
221 QString nstr = str.mid(lastspace+1, nsp-lastspace); 220 QString nstr = str.mid(lastspace+1, nsp-lastspace);
222 int lw = fm.width(nstr); 221 int lw = fm.width(nstr);
223 cx += lw+nexttoadd; 222 cx += lw+nexttoadd;
224 spacesofar += nexttoadd; 223 spacesofar += nexttoadd;
225 lastspace = nsp; 224 lastspace = nsp;
226 } 225 }
227 else 226 else
228 { 227 {
229 QString nstr = str.mid(lastspace+1, nsp-lastspace); 228 QString nstr = str.mid(lastspace+1, nsp-lastspace);
230 // qDebug("str:%s: last:%d new:%d nstr:%s:", (const char*)str, lastspace, nsp, (const char*)nstr); 229 // qDebug("str:%s: last:%d new:%d nstr:%s:", (const char*)str, lastspace, nsp, (const char*)nstr);
231 int lw = fm.width(nstr); 230 int lw = fm.width(nstr);
232 cx += lw; 231 cx += lw;
233 lastspace = nsp; 232 lastspace = nsp;
234 } 233 }
235 } 234 }
236 QString nstr = str.right(str.length()-1-lastspace); 235 QString nstr = str.right(str.length()-1-lastspace);
237 cx += fm.width(nstr); 236 cx += fm.width(nstr);
238 currentx = cx; 237 currentx = cx;
239 } 238 }
240 else 239 else
241 { 240 {
242 currentx += fm.width(str); 241 currentx += fm.width(str);
243 } 242 }
244 } 243 }
245 } 244 }
246 textstart = textend; 245 textstart = textend;
247 } 246 }
248 while (textend != segs.end() && end != numchars && textstart->start < len); 247 while (textend != segs.end() && end != numchars && textstart->start < len);
249 return currentx; 248 return currentx;
250} 249}
251 250
252int CDrawBuffer::charwidth(int numchars, CStyle& currentstyle) 251int CDrawBuffer::charwidth(int numchars, CStyle& currentstyle)
253{ 252{
254 if (currentstyle.isPicture()) 253 if (currentstyle.isPicture())
255 { 254 {
256 int gzoom = fc->gzoom(); 255 int gzoom = fc->gzoom();
257 if (currentstyle.canScale()) 256 if (currentstyle.canScale())
258 { 257 {
259 return (gzoom*currentstyle.getPicture()->width())/100; 258 return (gzoom*currentstyle.getPicture()->width())/100;
260 } 259 }
261 else 260 else
262 { 261 {
263 return currentstyle.getPicture()->width(); 262 return currentstyle.getPicture()->width();
264 } 263 }
265 } 264 }
266 else 265 else
267 { 266 {
268 if (currentstyle.isMono() && !fc->hasCourier()) 267 if (currentstyle.isMono() && !fc->hasCourier())
269 { 268 {
270 return (7*fc->getsize(currentstyle))/10; 269 return (7*fc->getsize(currentstyle))/10;
271 } 270 }
272 else 271 else
273 { 272 {
274 QString text = QChar((data())[numchars]); 273 QString text = QChar((data())[numchars]);
275 QFont f(currentstyle.isMono() ? QString(fc->fixedfontname()) : fc->name(), fc->getsize(currentstyle), (currentstyle.isBold()) ? QFont::Bold : QFont::Normal, (currentstyle.isItalic()) ); 274 QFont f(currentstyle.isMono() ? QString(fc->fixedfontname()) : fc->name(), fc->getsize(currentstyle), (currentstyle.isBold()) ? QFont::Bold : QFont::Normal, (currentstyle.isItalic()) );
276 // f.setUnderline(currentstyle.isUnderline()); 275 // f.setUnderline(currentstyle.isUnderline());
277 QFontMetrics fm(f); 276 QFontMetrics fm(f);
278 return fm.width(text); 277 return fm.width(text);
279 } 278 }
280 } 279 }
281 return 0; 280 return 0;
282} 281}
283 282
284int CDrawBuffer::charwidth(int numchars) 283int CDrawBuffer::charwidth(int numchars)
285{ 284{
286 int gzoom = fc->gzoom(); 285 int gzoom = fc->gzoom();
287 int end = 0; 286 int end = 0;
288 QString text = QChar((data())[numchars]); 287 QString text = QChar((data())[numchars]);
289 CList<textsegment>::iterator textstart = segs.begin(); 288 CList<textsegment>::iterator textstart = segs.begin();
290 CList<textsegment>::iterator textend = textstart; 289 CList<textsegment>::iterator textend = textstart;
291 do 290 do
292 { 291 {
293 textend++; 292 textend++;
294 end = (textend != segs.end()) ? textend->start : len; 293 end = (textend != segs.end()) ? textend->start : len;
295 if (end <= numchars) 294 if (end <= numchars)
296 { 295 {
297 textstart = textend; 296 textstart = textend;
298 continue; 297 continue;
299 } 298 }
300 if (numchars >= 0 && end > numchars) 299 if (numchars >= 0 && end > numchars)
301 { 300 {
302 end = numchars; 301 end = numchars;
303 } 302 }
304 CStyle currentstyle = textstart->style; 303 CStyle currentstyle = textstart->style;
305 if (currentstyle.isPicture()) 304 if (currentstyle.isPicture())
306 { 305 {
307 if (currentstyle.canScale()) 306 if (currentstyle.canScale())
308 { 307 {
309 return (gzoom*currentstyle.getPicture()->width())/100; 308 return (gzoom*currentstyle.getPicture()->width())/100;
310 } 309 }
311 else 310 else
312 { 311 {
313 return currentstyle.getPicture()->width(); 312 return currentstyle.getPicture()->width();
314 } 313 }
315 } 314 }
316 else 315 else
317 { 316 {
318 if (currentstyle.isMono() && !fc->hasCourier()) 317 if (currentstyle.isMono() && !fc->hasCourier())
319 { 318 {
320 return (7*fc->getsize(currentstyle))/10; 319 return (7*fc->getsize(currentstyle))/10;
321 } 320 }
322 else 321 else
323 { 322 {
324 QFont f(currentstyle.isMono() ? QString(fc->fixedfontname()) : fc->name(), fc->getsize(currentstyle), (currentstyle.isBold()) ? QFont::Bold : QFont::Normal, (currentstyle.isItalic()) ); 323 QFont f(currentstyle.isMono() ? QString(fc->fixedfontname()) : fc->name(), fc->getsize(currentstyle), (currentstyle.isBold()) ? QFont::Bold : QFont::Normal, (currentstyle.isItalic()) );
325 // f.setUnderline(currentstyle.isUnderline()); 324 // f.setUnderline(currentstyle.isUnderline());
326 QFontMetrics fm(f); 325 QFontMetrics fm(f);
327 return fm.width(text); 326 return fm.width(text);
328 } 327 }
329 } 328 }
330 textstart = textend; 329 textstart = textend;
331 } 330 }
332 while (textend != segs.end() /* && end != numchars*/ && textstart->start < len); 331 while (textend != segs.end() /* && end != numchars*/ && textstart->start < len);
333 return 0; 332 return 0;
334} 333}
335 334
336 335
337 336
338int CDrawBuffer::leftMargin() 337int CDrawBuffer::leftMargin()
339{ 338{
340 return (segs.begin()->style.getLeftMargin()*fc->getsize(segs.begin()->style)+3)/6; 339 return (segs.begin()->style.getLeftMargin()*fc->getsize(segs.begin()->style)+3)/6;
341} 340}
342 341
343int CDrawBuffer::rightMargin() 342int CDrawBuffer::rightMargin()
344{ 343{
345 return (segs.begin()->style.getRightMargin()*fc->getsize(segs.begin()->style)+3)/6; 344 return (segs.begin()->style.getRightMargin()*fc->getsize(segs.begin()->style)+3)/6;
346} 345}
347 346
348int CDrawBuffer::offset(int scwidth, unsigned short _lborder, unsigned short _rborder, int availht) 347int CDrawBuffer::offset(int scwidth, unsigned short _lborder, unsigned short _rborder, int availht)
349{ 348{
350 int currentx = _lborder; 349 int currentx = _lborder;
351 switch(segs.begin()->style.getJustify()) 350 switch(segs.begin()->style.getJustify())
352 { 351 {
353 case m_AlignRight: 352 case m_AlignRight:
354 { 353 {
355 currentx = scwidth - _rborder - rightMargin() - width(availht); 354 currentx = scwidth - _rborder - rightMargin() - width(availht);
356 } 355 }
357 break; 356 break;
358 case m_AlignCentre: 357 case m_AlignCentre:
359 { 358 {
360 currentx = ( 359 currentx = (
361 scwidth - _lborder -_rborder + 360 scwidth - _lborder -_rborder +
362 leftMargin() - rightMargin() 361 leftMargin() - rightMargin()
363 - width(availht))/2 + _lborder; 362 - width(availht))/2 + _lborder;
364 } 363 }
365 break; 364 break;
366 case m_AlignJustify: 365 case m_AlignJustify:
367 case m_AlignLeft: 366 case m_AlignLeft:
368 currentx = _lborder + leftMargin(); 367 currentx = _lborder + leftMargin();
369 break; 368 break;
370 } 369 }
371 return currentx; 370 return currentx;
372} 371}
373 372
374void CDrawBuffer::render(QPainter* _p, int _y, bool _bMono, int _charWidth, int scwidth, unsigned short _lborder, unsigned short _rborder, const QColor& _bg, int availht) 373void CDrawBuffer::render(QPainter* _p, int _y, bool _bMono, int _charWidth, int scwidth, unsigned short _lborder, unsigned short _rborder, const QColor& _bg, int availht)
375{ 374{
376 CList<textsegment>::iterator textstart = segs.begin(); 375 CList<textsegment>::iterator textstart = segs.begin();
377 QColor paperColour = QColor(qRgb(textstart->style.pRed(), 376 QColor paperColour = QColor(qRgb(textstart->style.pRed(),
378 textstart->style.pGreen(), 377 textstart->style.pGreen(),
379 textstart->style.pBlue())); 378 textstart->style.pBlue()));
380 379
381 Highlight(_p, !(paperColour == _bg), _lborder, _y, scwidth-(_lborder+_rborder), paperColour); 380 Highlight(_p, !(paperColour == _bg), _lborder, _y, scwidth-(_lborder+_rborder), paperColour);
382 // Highlight(_p, true, _lborder, _y, scwidth-(_lborder+_rborder), paperColour); 381 // Highlight(_p, true, _lborder, _y, scwidth-(_lborder+_rborder), paperColour);
383 int gzoom = fc->gzoom(); 382 int gzoom = fc->gzoom();
384 int currentx = offset(scwidth, _lborder, _rborder, availht); 383 int currentx = offset(scwidth, _lborder, _rborder, availht);
385 if (!m_hastext) 384 if (!m_hastext)
386 { 385 {
387 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end(); iter++) 386 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end(); iter++)
388 { 387 {
389 CStyle currentstyle = iter->style; 388 CStyle currentstyle = iter->style;
390 if (currentstyle.isPicture()) 389 if (currentstyle.isPicture())
391 { 390 {
392 CStyle currentstyle = segs.begin()->style; 391 CStyle currentstyle = segs.begin()->style;
393 int ht = (gzoom*currentstyle.getPicture()->height())/100; 392 int ht = (gzoom*currentstyle.getPicture()->height())/100;
394 int wt = (gzoom*currentstyle.getPicture()->width())/100; 393 int wt = (gzoom*currentstyle.getPicture()->width())/100;
395 bool willscale = false; 394 bool willscale = false;
396 if (ht > availht) 395 if (ht > availht)
397 { 396 {
398 wt = (wt*availht)/ht; 397 wt = (wt*availht)/ht;
399 ht = availht; 398 ht = availht;
400 willscale = true; 399 willscale = true;
401 } 400 }
402 401
403 QPixmap pc; 402 QPixmap pc;
404 if ((willscale || gzoom != 100) && currentstyle.canScale()) 403 if ((willscale || gzoom != 100) && currentstyle.canScale())
405 { 404 {
406 QImage im = currentstyle.getPicture()->smoothScale(wt,ht); 405 QImage im = currentstyle.getPicture()->smoothScale(wt,ht);
407 pc.convertFromImage(im); 406 pc.convertFromImage(im);
408 } 407 }
409 else 408 else
410 { 409 {
411 pc.convertFromImage(*currentstyle.getPicture()); 410 pc.convertFromImage(*currentstyle.getPicture());
412 } 411 }
413 int yoffset = pc.height()/2; 412 int yoffset = pc.height()/2;
414 _p->drawPixmap( currentx, _y-yoffset, pc ); 413 _p->drawPixmap( currentx, _y-yoffset, pc );
415 currentx += pc.width(); 414 currentx += pc.width();
416 } 415 }
417 } 416 }
418 return; 417 return;
419 } 418 }
420 QString text = toQString(data()); 419 QString text = toQString(data());
421 int extraspace = 0; 420 int extraspace = 0;
422 bool just = (!m_bEop && textstart->style.getJustify() == m_AlignJustify); 421 bool just = (!m_bEop && textstart->style.getJustify() == m_AlignJustify);
423 int spaces = 0; 422 int spaces = 0;
424 int spacesofar = 0; 423 int spacesofar = 0;
425 int spacenumber = 0; 424 int spacenumber = 0;
426 int nonspace = 0; 425 int nonspace = 0;
427 if (just) 426 if (just)
428 { 427 {
429 for (int i = 0; i < len; i++) 428 for (int i = 0; i < len; i++)
430 { 429 {
431 if ((*this)[i] != ' ') 430 if ((*this)[i] != ' ')
432 { 431 {
433 nonspace = i; 432 nonspace = i;
434 break; 433 break;
435 } 434 }
436 } 435 }
437#ifdef _WINDOWS 436#ifdef _WINDOWS
438 for (i = nonspace; i < len; i++) 437 for (i = nonspace; i < len; i++)
439#else 438#else
440 for (int i = nonspace; i < len; i++) 439 for (int i = nonspace; i < len; i++)
441#endif 440#endif
442 { 441 {
443 if ((*this)[i] == ' ') 442 if ((*this)[i] == ' ')
444 { 443 {
445 spaces++; 444 spaces++;
446 } 445 }
447 } 446 }
448 if (spaces == 0) 447 if (spaces == 0)
449 { 448 {
450 just = false; 449 just = false;
451 } 450 }
452 else 451 else
453 { 452 {
454 extraspace = (scwidth - (_lborder+_rborder) - rightMargin() - leftMargin() - width(availht)); 453 extraspace = (scwidth - (_lborder+_rborder) - rightMargin() - leftMargin() - width(availht));
455 if (extraspace == 0) just = false; 454 if (extraspace == 0) just = false;
456 } 455 }
457 } 456 }
458 CList<textsegment>::iterator textend = textstart; 457 CList<textsegment>::iterator textend = textstart;
459 458
460 bool drawBackground = false; 459 bool drawBackground = false;
461 do 460 do
462 { 461 {
463 textend++; 462 textend++;
464 int end = (textend != segs.end()) ? textend->start : len; 463 int end = (textend != segs.end()) ? textend->start : len;
465 CStyle currentstyle = textstart->style; 464 CStyle currentstyle = textstart->style;
466 /* 465 /*
467 bool drawBackground = ( 466 bool drawBackground = (
468 currentstyle.bRed() != 255 467 currentstyle.bRed() != 255
469 || 468 ||
470 currentstyle.bGreen() != 255 469 currentstyle.bGreen() != 255
471 || 470 ||
472 currentstyle.bBlue() != 255 471 currentstyle.bBlue() != 255
473 ); 472 );
474 */ 473 */
475 QColor bgColour = QColor(qRgb(currentstyle.bRed(), 474 QColor bgColour = QColor(qRgb(currentstyle.bRed(),
476 currentstyle.bGreen(), 475 currentstyle.bGreen(),
477 currentstyle.bBlue())); 476 currentstyle.bBlue()));
478 drawBackground = !(bgColour == _bg); 477 drawBackground = !(bgColour == _bg);
479 478
480// if (drawBackground) qDebug("Drawing background"); 479// if (drawBackground) qDebug("Drawing background");
481 480
482 QFont f((currentstyle.isMono() && fc->hasCourier()) ? fc->fixedfontname() : fc->name(), fc->getsize(currentstyle), (currentstyle.isBold()) ? QFont::Bold : QFont::Normal, (currentstyle.isItalic()) ); 481 QFont f((currentstyle.isMono() && fc->hasCourier()) ? fc->fixedfontname() : fc->name(), fc->getsize(currentstyle), (currentstyle.isBold()) ? QFont::Bold : QFont::Normal, (currentstyle.isItalic()) );
483 //f.setUnderline(currentstyle.isUnderline()); 482 //f.setUnderline(currentstyle.isUnderline());
484 //if (currentstyle.isUnderline()) qDebug("UNDERLINE"); 483 //if (currentstyle.isUnderline()) qDebug("UNDERLINE");
485 _p->setFont(f); 484 _p->setFont(f);
486 QString str = text.mid(textstart->start, end-textstart->start); 485 QString str = text.mid(textstart->start, end-textstart->start);
487#if defined(OPIE) || !defined(USEQPE) 486#if defined(OPIE) || !defined(USEQPE)
488 _p->setPen(QPen(QColor(currentstyle.Red(), currentstyle.Green(), currentstyle.Blue()), fc->getsize(currentstyle)/100)); 487 _p->setPen(QPen(QColor(currentstyle.Red(), currentstyle.Green(), currentstyle.Blue()), fc->getsize(currentstyle)/100));
489#else 488#else
490 _p->setPen(QPen(QColor(currentstyle.Red(), currentstyle.Green(), currentstyle.Blue()), fc->getsize(currentstyle)/10)); 489 _p->setPen(QPen(QColor(currentstyle.Red(), currentstyle.Green(), currentstyle.Blue()), fc->getsize(currentstyle)/10));
491#endif 490#endif
492 int voffset = currentstyle.getVOffset()*fc->getsize(currentstyle)/2; 491 int voffset = currentstyle.getVOffset()*fc->getsize(currentstyle)/2;
493 492
494 if (_bMono) 493 if (_bMono)
495 { 494 {
496 495
497 Highlight(_p, drawBackground, currentx, _y, str.length()*_charWidth, bgColour); 496 Highlight(_p, drawBackground, currentx, _y, str.length()*_charWidth, bgColour);
498 if (currentstyle.isUnderline()) 497 if (currentstyle.isUnderline())
499 { 498 {
500 _p->drawLine( currentx, _y+voffset, currentx + str.length()*_charWidth, _y+voffset); 499 _p->drawLine( currentx, _y+voffset, currentx + str.length()*_charWidth, _y+voffset);
501 } 500 }
502 if (currentstyle.isStrikethru()) 501 if (currentstyle.isStrikethru())
503 { 502 {
504 int ascent = fc->ascent(currentstyle)/3; 503 int ascent = fc->ascent(currentstyle)/3;
505 _p->drawLine( currentx, _y-ascent+voffset, currentx + str.length()*_charWidth, _y-ascent+voffset); 504 _p->drawLine( currentx, _y-ascent+voffset, currentx + str.length()*_charWidth, _y-ascent+voffset);
506 } 505 }
507 for (int i = 0; i < str.length(); i++) 506 for (int i = 0; i < str.length(); i++)
508 { 507 {
509 _p->drawText( currentx + i*_charWidth, _y+voffset, QString(str[i])); 508 _p->drawText( currentx + i*_charWidth, _y+voffset, QString(str[i]));
510 } 509 }
511 currentx += str.length()*_charWidth; 510 currentx += str.length()*_charWidth;
512 } 511 }
513 else 512 else
514 { 513 {
515 if (currentstyle.isPicture()) 514 if (currentstyle.isPicture())
516 { 515 {
517 int ht = (gzoom*currentstyle.getPicture()->height())/100; 516 int ht = (gzoom*currentstyle.getPicture()->height())/100;
518 int wt = (gzoom*currentstyle.getPicture()->width())/100; 517 int wt = (gzoom*currentstyle.getPicture()->width())/100;
519 bool willscale = false; 518 bool willscale = false;
520 if (ht > availht) 519 if (ht > availht)
521 { 520 {
522 wt = (wt*availht)/ht; 521 wt = (wt*availht)/ht;
523 ht = availht; 522 ht = availht;
524 willscale = true; 523 willscale = true;
525 } 524 }
526 int ascent = fc->ascent(currentstyle)/2; 525 int ascent = fc->ascent(currentstyle)/2;
527 int yoffset = ht/2 + ascent; 526 int yoffset = ht/2 + ascent;
528 527
529 QPixmap pc; 528 QPixmap pc;
530 if ((willscale || gzoom != 100) && currentstyle.canScale()) 529 if ((willscale || gzoom != 100) && currentstyle.canScale())
531 { 530 {
532 QImage im = currentstyle.getPicture()->smoothScale(wt,ht); 531 QImage im = currentstyle.getPicture()->smoothScale(wt,ht);
533 pc.convertFromImage(im); 532 pc.convertFromImage(im);
534 } 533 }
535 else 534 else
536 { 535 {
537 pc.convertFromImage(*currentstyle.getPicture()); 536 pc.convertFromImage(*currentstyle.getPicture());
538 } 537 }
539 _p->drawPixmap( currentx, _y-yoffset, pc ); 538 _p->drawPixmap( currentx, _y-yoffset, pc );
540 currentx += wt; 539 currentx += wt;
541 } 540 }
542 else 541 else
543 { 542 {
544 if (currentstyle.isMono() && !fc->hasCourier()) 543 if (currentstyle.isMono() && !fc->hasCourier())
545 { 544 {
546 int cw = (7*fc->getsize(currentstyle))/10; 545 int cw = (7*fc->getsize(currentstyle))/10;
547 int w = cw*(end-textstart->start); 546 int w = cw*(end-textstart->start);
548 Highlight(_p, drawBackground, currentx, _y, w, bgColour); 547 Highlight(_p, drawBackground, currentx, _y, w, bgColour);
549 if (currentstyle.isUnderline()) 548 if (currentstyle.isUnderline())
550 { 549 {
551 _p->drawLine( currentx, _y+voffset, currentx + w, _y+voffset); 550 _p->drawLine( currentx, _y+voffset, currentx + w, _y+voffset);
552 } 551 }
553 if (currentstyle.isStrikethru()) 552 if (currentstyle.isStrikethru())
554 { 553 {
555 int ascent = fc->ascent(currentstyle)/3; 554 int ascent = fc->ascent(currentstyle)/3;
556 _p->drawLine( currentx, _y-ascent+voffset, currentx + w, _y-ascent+voffset); 555 _p->drawLine( currentx, _y-ascent+voffset, currentx + w, _y-ascent+voffset);
557 } 556 }
558 QString str = text.mid(textstart->start, end-textstart->start); 557 QString str = text.mid(textstart->start, end-textstart->start);
559 558
560 for (unsigned int i = 0; i < str.length(); i++) 559 for (unsigned int i = 0; i < str.length(); i++)
561 { 560 {
562#ifdef _WINDOWS 561#ifdef _WINDOWS
563 _p->drawText( currentx, _y+voffset, QString(str.at(i))); 562 _p->drawText( currentx, _y+voffset, QString(str.at(i)));
564#else 563#else
565 _p->drawText( currentx, _y+voffset, QString(str[i])); 564 _p->drawText( currentx, _y+voffset, QString(str[i]));
566#endif 565#endif
567 currentx += cw; 566 currentx += cw;
568 } 567 }
569 } 568 }
570 else 569 else
571 { 570 {
572 QFontMetrics fm(f); 571 QFontMetrics fm(f);
573 int w; 572 int w;
574 if (just) 573 if (just)
575 { 574 {
576 int lastspace = -1; 575 int lastspace = -1;
577 int nsp = 0; 576 int nsp = 0;
578 int cx = currentx; 577 int cx = currentx;
579 while ((nsp = str.find(" ", lastspace+1)) >= 0) 578 while ((nsp = str.find(" ", lastspace+1)) >= 0)
580 { 579 {
581 if (nsp+textstart->start >= nonspace) 580 if (nsp+textstart->start >= nonspace)
582 { 581 {
583 spacenumber++; 582 spacenumber++;
584 int nexttoadd = (extraspace*spacenumber+spaces/2)/spaces - spacesofar; 583 int nexttoadd = (extraspace*spacenumber+spaces/2)/spaces - spacesofar;
585 QString nstr = str.mid(lastspace+1, nsp-lastspace); 584 QString nstr = str.mid(lastspace+1, nsp-lastspace);
586 // qDebug("str:%s: last:%d new:%d nstr:%s:", (const char*)str, lastspace, nsp, (const char*)nstr); 585 // qDebug("str:%s: last:%d new:%d nstr:%s:", (const char*)str, lastspace, nsp, (const char*)nstr);
587 int lw = fm.width(nstr); 586 int lw = fm.width(nstr);
588 Highlight(_p, drawBackground, cx, _y, lw, bgColour); 587 Highlight(_p, drawBackground, cx, _y, lw, bgColour);
589 _p->drawText( cx, _y+voffset, nstr); 588 _p->drawText( cx, _y+voffset, nstr);
590 Highlight(_p, drawBackground, cx+lw, _y, nexttoadd, bgColour); 589 Highlight(_p, drawBackground, cx+lw, _y, nexttoadd, bgColour);
591 cx += lw+nexttoadd; 590 cx += lw+nexttoadd;
592 spacesofar += nexttoadd; 591 spacesofar += nexttoadd;
593 lastspace = nsp; 592 lastspace = nsp;
594 } 593 }
595 else 594 else
596 { 595 {
597 QString nstr = str.mid(lastspace+1, nsp-lastspace); 596 QString nstr = str.mid(lastspace+1, nsp-lastspace);
598 // qDebug("str:%s: last:%d new:%d nstr:%s:", (const char*)str, lastspace, nsp, (const char*)nstr); 597 // qDebug("str:%s: last:%d new:%d nstr:%s:", (const char*)str, lastspace, nsp, (const char*)nstr);
599 int lw = fm.width(nstr); 598 int lw = fm.width(nstr);
600 Highlight(_p, drawBackground, cx, _y, lw, bgColour); 599 Highlight(_p, drawBackground, cx, _y, lw, bgColour);
601 _p->drawText( cx, _y+voffset, nstr); 600 _p->drawText( cx, _y+voffset, nstr);
602 cx += lw; 601 cx += lw;
603 lastspace = nsp; 602 lastspace = nsp;
604 } 603 }
605 } 604 }
606 QString nstr = str.right(str.length()-1-lastspace); 605 QString nstr = str.right(str.length()-1-lastspace);
607 int lw = fm.width(nstr); 606 int lw = fm.width(nstr);
608 Highlight(_p, drawBackground, cx, _y, lw, bgColour); 607 Highlight(_p, drawBackground, cx, _y, lw, bgColour);
609 _p->drawText( cx, _y+voffset, nstr); 608 _p->drawText( cx, _y+voffset, nstr);
610 cx += lw; 609 cx += lw;
611 w = cx - currentx; 610 w = cx - currentx;
612 } 611 }
613 else 612 else
614 { 613 {
615 int lw = fm.width(str); 614 int lw = fm.width(str);
616 Highlight(_p, drawBackground, currentx, _y, lw, bgColour); 615 Highlight(_p, drawBackground, currentx, _y, lw, bgColour);
617 _p->drawText( currentx, _y+voffset, str); 616 _p->drawText( currentx, _y+voffset, str);
618 w = lw; 617 w = lw;
619 } 618 }
620 if (currentstyle.isUnderline()) 619 if (currentstyle.isUnderline())
621 { 620 {
622 _p->drawLine( currentx, _y+voffset, currentx + w, _y+voffset); 621 _p->drawLine( currentx, _y+voffset, currentx + w, _y+voffset);
623 } 622 }
624 if (currentstyle.isStrikethru()) 623 if (currentstyle.isStrikethru())
625 { 624 {
626 int ascent = fc->ascent(currentstyle)/3; 625 int ascent = fc->ascent(currentstyle)/3;
627 _p->drawLine( currentx, _y-ascent+voffset, currentx + w, _y-ascent+voffset); 626 _p->drawLine( currentx, _y-ascent+voffset, currentx + w, _y-ascent+voffset);
628 } 627 }
629 currentx += w; 628 currentx += w;
630 } 629 }
631 } 630 }
632 } 631 }
633 textstart = textend; 632 textstart = textend;
634 } 633 }
635 while (textend != segs.end() && textstart->start < len); 634 while (textend != segs.end() && textstart->start < len);
636/* 635/*
637 if (firstColour == bgColour) 636 if (firstColour == bgColour)
638 { 637 {
639 Highlight(_p, drawBackground, currentx, _y, scwidth - (currentx + _lborder + _rborder), bgColour); 638 Highlight(_p, drawBackground, currentx, _y, scwidth - (currentx + _lborder + _rborder), bgColour);
640 } 639 }
641 */ 640 */
642} 641}
643 642
644void CDrawBuffer::Highlight(QPainter* _p, bool drawBackground, int _x, int _y, int w, QColor bgColour) 643void CDrawBuffer::Highlight(QPainter* _p, bool drawBackground, int _x, int _y, int w, QColor bgColour)
645{ 644{
646 if (drawBackground) 645 if (drawBackground)
647 { 646 {
648 _p->fillRect(_x, _y-m_ascent, w, m_lineSpacing, bgColour); 647 _p->fillRect(_x, _y-m_ascent, w, m_lineSpacing, bgColour);
649 } 648 }
650} 649}
651 650
652CStyle CDrawBuffer::laststyle() 651CStyle CDrawBuffer::laststyle()
653{ 652{
654 return segs.last().style; 653 return segs.last().style;
655} 654}
656 655
657CStyle CDrawBuffer::firststyle() 656CStyle CDrawBuffer::firststyle()
658{ 657{
659 return segs.first().style; 658 return segs.first().style;
660} 659}
661 660
662linkType CDrawBuffer::getLinkType(int numchars, size_t& tgt, size_t& offset, size_t& pictgt, QImage*& img) 661linkType CDrawBuffer::getLinkType(int numchars, size_t& tgt, size_t& offset, size_t& pictgt, QImage*& img)
663{ 662{
664 linkType ret = eNone; 663 linkType ret = eNone;
665 int end = 0; 664 int end = 0;
666 CStyle currentstyle; 665 CStyle currentstyle;
667 CList<textsegment>::iterator textstart = segs.begin(); 666 CList<textsegment>::iterator textstart = segs.begin();
668 CList<textsegment>::iterator textend = textstart; 667 CList<textsegment>::iterator textend = textstart;
669 do 668 do
670 { 669 {
671 textend++; 670 textend++;
672 end = (textend != segs.end()) ? textend->start : len; 671 end = (textend != segs.end()) ? textend->start : len;
673 currentstyle = textstart->style; 672 currentstyle = textstart->style;
674/* 673/*
675 if (currentstyle.isPicture()) qDebug("Passed thru picture"); 674 if (currentstyle.isPicture()) qDebug("Passed thru picture");
676 if (currentstyle.getLink()) qDebug("Passed thru link"); 675 if (currentstyle.getLink()) qDebug("Passed thru link");
677 //qDebug("islink:%d - %d", numchars, end); 676 //qDebug("islink:%d - %d", numchars, end);
678*/ 677*/
679 textstart = textend; 678 textstart = textend;
680 } 679 }
681 while (textend != segs.end() && end <= numchars); 680 while (textend != segs.end() && end <= numchars);
682 img = currentstyle.getPicture(); 681 img = currentstyle.getPicture();
683 if (currentstyle.getPictureLink()) 682 if (currentstyle.getPictureLink())
684 { 683 {
685 pictgt = currentstyle.getPictureLinkData(); 684 pictgt = currentstyle.getPictureLinkData();
686 ret |= ePicture; 685 ret |= ePicture;
687 } 686 }
688 if (currentstyle.getLink()) 687 if (currentstyle.getLink())
689 { 688 {
690 tgt = currentstyle.getData(); 689 tgt = currentstyle.getData();
691 offset = currentstyle.getOffset(); 690 offset = currentstyle.getOffset();
692 ret |= eLink; 691 ret |= eLink;
693 } 692 }
694 return ret; 693 return ret;
695} 694}
696 695
697void CDrawBuffer::resize(int availht) 696void CDrawBuffer::resize(int availht)
698{ 697{
699 int gzoom = fc->gzoom(); 698 int gzoom = fc->gzoom();
700 m_ascent = m_descent = m_lineSpacing = m_lineExtraSpacing = 0; 699 m_ascent = m_descent = m_lineSpacing = m_lineExtraSpacing = 0;
701 /* 700 /*
702 int t_ascent = 0; 701 int t_ascent = 0;
703 int t_descent = 0; 702 int t_descent = 0;
704 int t_lineExtraSpacing = 0; 703 int t_lineExtraSpacing = 0;
705 */ 704 */
706 int t_lineSpacing = 0; 705 int t_lineSpacing = 0;
707 m_hastext = false; 706 m_hastext = false;
708 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end() && iter->start <= len; ) 707 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end() && iter->start <= len; )
709 { 708 {
710 CStyle _style = iter->style; 709 CStyle _style = iter->style;
711 if (!_style.isPicture()) 710 if (!_style.isPicture())
712 { 711 {
713 m_hastext = true; 712 m_hastext = true;
714 break; 713 break;
715 } 714 }
716 iter++; 715 iter++;
717 } 716 }
718 if (m_hastext) 717 if (m_hastext)
719 { 718 {
720 719
721 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end() && iter->start <= len; ) 720 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end() && iter->start <= len; )
722 { 721 {
723 CList<textsegment>::iterator next = iter; 722 CList<textsegment>::iterator next = iter;
724 iter++; 723 iter++;
725 int st = next->start; 724 int st = next->start;
726 if (st < 0) st = 0; 725 if (st < 0) st = 0;
727 726
728 CStyle _style = next->style; 727 CStyle _style = next->style;
729 728
730 int linespacing, ascent, descent, extra; 729 int linespacing, ascent, descent, extra;
731 730
732 ascent = fc->ascent(_style); 731 ascent = fc->ascent(_style);
733 descent = fc->descent(_style); 732 descent = fc->descent(_style);
734 linespacing = fc->lineSpacing(_style); 733 linespacing = fc->lineSpacing(_style);
735 extra = linespacing - ascent - descent; 734 extra = linespacing - ascent - descent;
736 /* 735 /*
737 if (ascent > t_ascent) t_ascent = ascent; 736 if (ascent > t_ascent) t_ascent = ascent;
738 if (descent > t_descent) t_descent = descent; 737 if (descent > t_descent) t_descent = descent;
739 if (extra > t_lineExtraSpacing) t_lineExtraSpacing = extra; 738 if (extra > t_lineExtraSpacing) t_lineExtraSpacing = extra;
740 t_lineSpacing = t_ascent+t_descent+t_lineExtraSpacing; 739 t_lineSpacing = t_ascent+t_descent+t_lineExtraSpacing;
741 */ 740 */
742 if (linespacing > t_lineSpacing) t_lineSpacing = linespacing; 741 if (linespacing > t_lineSpacing) t_lineSpacing = linespacing;
743 if (_style.isPicture()) 742 if (_style.isPicture())
744 { 743 {
745 int ht = (gzoom*_style.getPicture()->height())/100; 744 int ht = (gzoom*_style.getPicture()->height())/100;
746 int wt = (gzoom*_style.getPicture()->width())/100; 745 int wt = (gzoom*_style.getPicture()->width())/100;
747 746
748 bool willscale = false; 747 bool willscale = false;
749 if (ht > availht) 748 if (ht > availht)
750 { 749 {
751 wt = (wt*availht)/ht; 750 wt = (wt*availht)/ht;
752 ht = availht; 751 ht = availht;
753 willscale = true; 752 willscale = true;
754 } 753 }
755 if (willscale || _style.canScale()) 754 if (willscale || _style.canScale())
756 { 755 {
757 descent = ((gzoom*_style.getPicture()->height())/100-ascent)/2; 756 descent = ((gzoom*_style.getPicture()->height())/100-ascent)/2;
758 ascent = ((gzoom*_style.getPicture()->height())/100+ascent)/2; 757 ascent = ((gzoom*_style.getPicture()->height())/100+ascent)/2;
759 } 758 }
760 } 759 }
761 760
762 /* 761 /*
763 else if (fc != NULL) 762 else if (fc != NULL)
764 { 763 {
765 ascent = fc->ascent(_style); 764 ascent = fc->ascent(_style);
766 descent = fc->descent(_style); 765 descent = fc->descent(_style);
767 linespacing = fc->lineSpacing(_style); 766 linespacing = fc->lineSpacing(_style);
768 extra = linespacing - ascent - descent; 767 extra = linespacing - ascent - descent;
769 } 768 }
770 */ 769 */
771 if (ascent > m_ascent) m_ascent = ascent; 770 if (ascent > m_ascent) m_ascent = ascent;
772 if (descent > m_descent) m_descent = descent; 771 if (descent > m_descent) m_descent = descent;
773 if (extra > m_lineExtraSpacing) m_lineExtraSpacing = extra; 772 if (extra > m_lineExtraSpacing) m_lineExtraSpacing = extra;
774 m_lineSpacing = m_ascent+m_descent+m_lineExtraSpacing; 773 m_lineSpacing = m_ascent+m_descent+m_lineExtraSpacing;
775 } 774 }
776 m_showPartial = (m_lineSpacing > t_lineSpacing); 775 m_showPartial = (m_lineSpacing > t_lineSpacing);
777 int lead = fc->getlead(); 776 int lead = fc->getlead();
778 if (lead != 0) 777 if (lead != 0)
779 { 778 {
780 int xt = (lead*t_lineSpacing+5)/10; 779 int xt = (lead*t_lineSpacing+5)/10;
781 m_lineExtraSpacing += xt; 780 m_lineExtraSpacing += xt;
782 m_lineSpacing += xt; 781 m_lineSpacing += xt;
783 } 782 }
784 if (m_bSop) 783 if (m_bSop)
785 { 784 {
786 int xt = ((segs.begin()->style.getExtraSpace()+fc->getextraspace())*fc->getsize(segs.begin()->style)+5)/10; 785 int xt = ((segs.begin()->style.getExtraSpace()+fc->getextraspace())*fc->getsize(segs.begin()->style)+5)/10;
787 //qDebug("ExtraSpace:%d", xt); 786 //qDebug("ExtraSpace:%d", xt);
788 m_ascent += xt; 787 m_ascent += xt;
789 m_lineSpacing += xt; 788 m_lineSpacing += xt;
790 } 789 }
791 } 790 }
792 else 791 else
793 { 792 {
794 m_showPartial = true; 793 m_showPartial = true;
795 int maxheight = 0; 794 int maxheight = 0;
796 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end(); iter++) 795 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end(); iter++)
797 { 796 {
798 CStyle _style = iter->style; 797 CStyle _style = iter->style;
799 if (_style.isPicture()) 798 if (_style.isPicture())
800 { 799 {
801 int ht = 0; 800 int ht = 0;
802 if (_style.canScale()) 801 if (_style.canScale())
803 { 802 {
804 ht = ((gzoom*_style.getPicture()->height())/100); 803 ht = ((gzoom*_style.getPicture()->height())/100);
805 } 804 }
806 else 805 else
807 { 806 {
808 ht = _style.getPicture()->height(); 807 ht = _style.getPicture()->height();
809 } 808 }
810 if (ht > availht) 809 if (ht > availht)
811 { 810 {
812 ht = availht; 811 ht = availht;
813 } 812 }
814 if (ht > maxheight) maxheight = ht; 813 if (ht > maxheight) maxheight = ht;
815 } 814 }
816 } 815 }
817 m_ascent = maxheight/2; 816 m_ascent = maxheight/2;
818 m_descent = maxheight-m_ascent; 817 m_descent = maxheight-m_ascent;
819 m_lineExtraSpacing = 0; 818 m_lineExtraSpacing = 0;
820 m_lineSpacing = m_ascent+m_descent; 819 m_lineSpacing = m_ascent+m_descent;
821 } 820 }
822} 821}
823 822
824CStyle* CDrawBuffer::getNextLink(int& offset) 823CStyle* CDrawBuffer::getNextLink(int& offset)
825{ 824{
826 CStyle* ret = NULL; 825 CStyle* ret = NULL;
827 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end(); ++iter) 826 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end(); ++iter)
828 { 827 {
829 if (offset < iter->start && iter->style.getLink()) 828 if (offset < iter->start && iter->style.getLink())
830 { 829 {
831 ret = &(iter->style); 830 ret = &(iter->style);
832 offset = iter->start; 831 offset = iter->start;
833 qDebug("Found a link at offset %d!", offset); 832 qDebug("Found a link at offset %d!", offset);
834 break; 833 break;
835 } 834 }
836 } 835 }
837 return ret; 836 return ret;
838} 837}
839 838
840int CDrawBuffer::invertLink(int offset) 839int CDrawBuffer::invertLink(int offset)
841{ 840{
842 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end(); ++iter) 841 for (CList<textsegment>::iterator iter = segs.begin(); iter != segs.end(); ++iter)
843 { 842 {
844 if (offset <= iter->start && iter->style.getLink()) 843 if (offset <= iter->start && iter->style.getLink())
845 { 844 {
846 iter->style.invert(); 845 iter->style.invert();
847 unsigned long currentvalue = iter->style.getData(); 846 unsigned long currentvalue = iter->style.getData();
848 qDebug("Link data %u", currentvalue); 847 qDebug("Link data %u", currentvalue);
849 CList<textsegment>::iterator next = iter; 848 CList<textsegment>::iterator next = iter;
850 ++next; 849 ++next;
851 while (next != segs.end() && (currentvalue == next->style.getData()) && next->style.getLink()) 850 while (next != segs.end() && (currentvalue == next->style.getData()) && next->style.getLink())
852 { 851 {
853 next->style.invert(); 852 next->style.invert();
854 offset = next->start; 853 offset = next->start;
855 iter++; 854 iter++;
856 next++; 855 next++;
857 } 856 }
858 return offset; 857 return offset;
859 } 858 }
860 } 859 }
861 qDebug("Failed to invert"); 860 qDebug("Failed to invert");
862 return offset; 861 return offset;
863} 862}
diff --git a/noncore/apps/opie-reader/CExpander.h b/noncore/apps/opie-reader/CExpander.h
index e9aaf79..7fa84f9 100644
--- a/noncore/apps/opie-reader/CExpander.h
+++ b/noncore/apps/opie-reader/CExpander.h
@@ -1,149 +1,148 @@
1#ifndef __CExpander_h 1#ifndef __CExpander_h
2#define __CExpander_h 2#define __CExpander_h
3 3
4#ifndef _WINDOWS 4#ifndef _WINDOWS
5#include <unistd.h> 5#include <unistd.h>
6#endif 6#endif
7#include <stdio.h> 7#include <stdio.h>
8#include <time.h> 8#include <time.h>
9#include <sys/stat.h> 9#include <sys/stat.h>
10#include <qmessagebox.h> 10#include <qmessagebox.h>
11#include "useqpe.h"
12#include "config.h" 11#include "config.h"
13#include "StyleConsts.h" 12#include "StyleConsts.h"
14#include "Markups.h" 13#include "Markups.h"
15#include "names.h" 14#include "names.h"
16#include "linktype.h" 15#include "linktype.h"
17 16
18class QImage; 17class QImage;
19class Bkmk; 18class Bkmk;
20class QString; 19class QString;
21 20
22template<class T> 21template<class T>
23class CList; 22class CList;
24 23
25class CCharacterSource 24class CCharacterSource
26{ 25{
27 public: 26 public:
28 virtual void getch(tchar&, CStyle&, unsigned long&) = 0; 27 virtual void getch(tchar&, CStyle&, unsigned long&) = 0;
29 virtual linkType hyperlink(unsigned int n, unsigned int noff, QString&, QString& nm) = 0; 28 virtual linkType hyperlink(unsigned int n, unsigned int noff, QString&, QString& nm) = 0;
30 virtual void locate(unsigned int n) = 0; 29 virtual void locate(unsigned int n) = 0;
31 virtual bool findanchor(const QString& nm) = 0; 30 virtual bool findanchor(const QString& nm) = 0;
32 virtual void saveposn(const QString& f, size_t posn) = 0; 31 virtual void saveposn(const QString& f, size_t posn) = 0;
33 virtual void writeposn(const QString& f, size_t posn) = 0; 32 virtual void writeposn(const QString& f, size_t posn) = 0;
34 virtual linkType forward(QString& f, size_t& loc) = 0; 33 virtual linkType forward(QString& f, size_t& loc) = 0;
35 virtual linkType back(QString& f, size_t& loc) = 0; 34 virtual linkType back(QString& f, size_t& loc) = 0;
36 virtual bool hasnavigation() = 0; 35 virtual bool hasnavigation() = 0;
37 virtual int getwidth() = 0; 36 virtual int getwidth() = 0;
38 virtual QImage* getPicture(unsigned long) = 0; 37 virtual QImage* getPicture(unsigned long) = 0;
39 virtual QImage* getPicture(const QString& href) = 0; 38 virtual QImage* getPicture(const QString& href) = 0;
40 virtual bool getFile(const QString& href) = 0; 39 virtual bool getFile(const QString& href) = 0;
41 virtual QString about() = 0; 40 virtual QString about() = 0;
42}; 41};
43 42
44class CExpander_Interface 43class CExpander_Interface
45{ 44{
46 public: 45 public:
47#ifdef USEQPE 46#ifdef USEQPE
48 virtual void suspend() = 0; 47 virtual void suspend() = 0;
49 virtual void unsuspend() = 0; 48 virtual void unsuspend() = 0;
50#endif 49#endif
51 virtual QString about() = 0; 50 virtual QString about() = 0;
52 virtual size_t getHome() = 0; 51 virtual size_t getHome() = 0;
53 //CExpander_Interface(); 52 //CExpander_Interface();
54 //virtual ~CExpander_Interface(); 53 //virtual ~CExpander_Interface();
55 virtual int openfile(const char *src) = 0; 54 virtual int openfile(const char *src) = 0;
56 //virtual int OpenFile(const char *src) = 0; 55 //virtual int OpenFile(const char *src) = 0;
57 virtual unsigned int locate() = 0; 56 virtual unsigned int locate() = 0;
58 virtual void locate(unsigned int n) = 0; 57 virtual void locate(unsigned int n) = 0;
59 virtual bool hasrandomaccess() = 0; 58 virtual bool hasrandomaccess() = 0;
60 virtual void sizes(unsigned long& file, unsigned long& text) = 0; 59 virtual void sizes(unsigned long& file, unsigned long& text) = 0;
61 virtual CList<Bkmk>* getbkmklist() { return NULL; } 60 virtual CList<Bkmk>* getbkmklist() { return NULL; }
62 virtual void getch(tchar& ch, CStyle& sty, unsigned long& pos) = 0; 61 virtual void getch(tchar& ch, CStyle& sty, unsigned long& pos) = 0;
63 virtual int getch() = 0; 62 virtual int getch() = 0;
64 virtual linkType hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm) = 0; 63 virtual linkType hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm) = 0;
65 virtual MarkupType PreferredMarkup() = 0; 64 virtual MarkupType PreferredMarkup() = 0;
66 virtual void saveposn(size_t posn) {} 65 virtual void saveposn(size_t posn) {}
67 virtual void writeposn(size_t posn) {} 66 virtual void writeposn(size_t posn) {}
68 virtual linkType forward(size_t& loc) { return eNone; } 67 virtual linkType forward(size_t& loc) { return eNone; }
69 virtual linkType back(size_t& loc) { return eNone; } 68 virtual linkType back(size_t& loc) { return eNone; }
70 virtual bool hasnavigation() { return false; } 69 virtual bool hasnavigation() { return false; }
71 virtual unsigned long startSection() = 0; 70 virtual unsigned long startSection() = 0;
72 virtual unsigned long endSection() = 0; 71 virtual unsigned long endSection() = 0;
73 virtual void start2endSection() = 0; 72 virtual void start2endSection() = 0;
74 virtual QImage* getPicture(unsigned long tgt) { return NULL; } 73 virtual QImage* getPicture(unsigned long tgt) { return NULL; }
75 virtual void setContinuous(bool _b) = 0; 74 virtual void setContinuous(bool _b) = 0;
76#ifdef USEQPE 75#ifdef USEQPE
77 virtual void suspend(FILE*& fin) = 0; 76 virtual void suspend(FILE*& fin) = 0;
78 virtual void unsuspend(FILE*& fin) = 0; 77 virtual void unsuspend(FILE*& fin) = 0;
79#endif 78#endif
80 virtual void setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen) = 0; 79 virtual void setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen) = 0;
81 virtual void putSaveData(unsigned char*& src, unsigned short& srclen) = 0; 80 virtual void putSaveData(unsigned char*& src, unsigned short& srclen) = 0;
82 virtual void setwidth(int w) = 0; 81 virtual void setwidth(int w) = 0;
83 // bool findstring(const QString& info); 82 // bool findstring(const QString& info);
84 // int getpara(CBuffer& buff); 83 // int getpara(CBuffer& buff);
85 virtual int getwidth() = 0; 84 virtual int getwidth() = 0;
86 virtual QImage* getPicture(const QString& href) = 0; 85 virtual QImage* getPicture(const QString& href) = 0;
87 virtual bool getFile(const QString& href) = 0; 86 virtual bool getFile(const QString& href) = 0;
88}; 87};
89 88
90class CExpander : public CExpander_Interface 89class CExpander : public CExpander_Interface
91{ 90{
92 protected: 91 protected:
93 size_t m_homepos; 92 size_t m_homepos;
94 bool m_continuous; 93 bool m_continuous;
95 char* fname; 94 char* fname;
96 bool bSuspended; 95 bool bSuspended;
97 size_t suspos; 96 size_t suspos;
98 time_t sustime; 97 time_t sustime;
99 int m_scrWidth; 98 int m_scrWidth;
100 unsigned long m_currentstart, m_currentend; 99 unsigned long m_currentstart, m_currentend;
101 public: 100 public:
102#ifdef USEQPE 101#ifdef USEQPE
103 virtual void suspend() = 0; 102 virtual void suspend() = 0;
104 virtual void unsuspend() = 0; 103 virtual void unsuspend() = 0;
105#endif 104#endif
106 size_t getHome(); 105 size_t getHome();
107 CExpander(); 106 CExpander();
108 virtual ~CExpander(); 107 virtual ~CExpander();
109 int openfile(const char *src); 108 int openfile(const char *src);
110 virtual int OpenFile(const char *src) = 0; 109 virtual int OpenFile(const char *src) = 0;
111 virtual unsigned int locate() = 0; 110 virtual unsigned int locate() = 0;
112 virtual void locate(unsigned int n) = 0; 111 virtual void locate(unsigned int n) = 0;
113 virtual bool hasrandomaccess() = 0; 112 virtual bool hasrandomaccess() = 0;
114 virtual void sizes(unsigned long& file, unsigned long& text) = 0; 113 virtual void sizes(unsigned long& file, unsigned long& text) = 0;
115 virtual CList<Bkmk>* getbkmklist() { return NULL; } 114 virtual CList<Bkmk>* getbkmklist() { return NULL; }
116 virtual void getch(tchar& ch, CStyle& sty, unsigned long& pos); 115 virtual void getch(tchar& ch, CStyle& sty, unsigned long& pos);
117 virtual int getch() = 0; 116 virtual int getch() = 0;
118 virtual linkType hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm); 117 virtual linkType hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm);
119 virtual MarkupType PreferredMarkup() = 0; 118 virtual MarkupType PreferredMarkup() = 0;
120 virtual void saveposn(size_t posn) {} 119 virtual void saveposn(size_t posn) {}
121 virtual void writeposn(size_t posn) {} 120 virtual void writeposn(size_t posn) {}
122 virtual linkType forward(size_t& loc) { return eNone; } 121 virtual linkType forward(size_t& loc) { return eNone; }
123 virtual linkType back(size_t& loc) { return eNone; } 122 virtual linkType back(size_t& loc) { return eNone; }
124 virtual bool hasnavigation() { return false; } 123 virtual bool hasnavigation() { return false; }
125 unsigned long startSection(); 124 unsigned long startSection();
126 unsigned long endSection(); 125 unsigned long endSection();
127 virtual void start2endSection(); 126 virtual void start2endSection();
128 virtual QImage* getPicture(unsigned long tgt) { return NULL; } 127 virtual QImage* getPicture(unsigned long tgt) { return NULL; }
129 void setContinuous(bool _b) { m_continuous = _b; } 128 void setContinuous(bool _b) { m_continuous = _b; }
130#ifdef USEQPE 129#ifdef USEQPE
131 virtual void suspend(FILE*& fin); 130 virtual void suspend(FILE*& fin);
132 virtual void unsuspend(FILE*& fin); 131 virtual void unsuspend(FILE*& fin);
133#endif 132#endif
134 virtual void setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen); 133 virtual void setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen);
135 virtual void putSaveData(unsigned char*& src, unsigned short& srclen); 134 virtual void putSaveData(unsigned char*& src, unsigned short& srclen);
136 void setwidth(int w) 135 void setwidth(int w)
137 { 136 {
138 m_scrWidth = w; 137 m_scrWidth = w;
139 } 138 }
140 int getwidth() 139 int getwidth()
141 { 140 {
142 return m_scrWidth; 141 return m_scrWidth;
143 } 142 }
144 // bool findstring(const QString& info); 143 // bool findstring(const QString& info);
145 // int getpara(CBuffer& buff); 144 // int getpara(CBuffer& buff);
146 virtual QImage* getPicture(const QString& href) { return NULL; } 145 virtual QImage* getPicture(const QString& href) { return NULL; }
147 virtual bool getFile(const QString& href) { return false; } 146 virtual bool getFile(const QString& href) { return false; }
148}; 147};
149#endif 148#endif
diff --git a/noncore/apps/opie-reader/CFilter.cpp b/noncore/apps/opie-reader/CFilter.cpp
index 6f76e9a..6d94d70 100644
--- a/noncore/apps/opie-reader/CFilter.cpp
+++ b/noncore/apps/opie-reader/CFilter.cpp
@@ -1,815 +1,814 @@
1#include <qmap.h> 1#include <qmap.h>
2#include <qfileinfo.h> 2#include <qfileinfo.h>
3#include <qtextstream.h> 3#include <qtextstream.h>
4#include <qdir.h> 4#include <qdir.h>
5#include "useqpe.h"
6#ifdef USEQPE 5#ifdef USEQPE
7#include <qpe/global.h> 6#include <qpe/global.h>
8#endif 7#endif
9#include "CDrawBuffer.h" 8#include "CDrawBuffer.h"
10#include "CFilter.h" 9#include "CFilter.h"
11#include "hrule.h" 10#include "hrule.h"
12#include "util.h" 11#include "util.h"
13 12
14#include <qregexp.h> 13#include <qregexp.h>
15#include <qimage.h> 14#include <qimage.h>
16#include <qpixmap.h> 15#include <qpixmap.h>
17//#include <qprogressdialog.h> 16//#include <qprogressdialog.h>
18//#include <qapplication.h> 17//#include <qapplication.h>
19 18
20void textfmt::mygetch(tchar& ch, CStyle& sty, unsigned long& pos) 19void textfmt::mygetch(tchar& ch, CStyle& sty, unsigned long& pos)
21{ 20{
22 if (uselast) 21 if (uselast)
23 { 22 {
24 ch = lastchar; 23 ch = lastchar;
25 uselast = false; 24 uselast = false;
26 } 25 }
27 else 26 else
28 { 27 {
29 parent->getch(ch, sty, pos); 28 parent->getch(ch, sty, pos);
30 } 29 }
31} 30}
32 31
33void textfmt::getch(tchar& ch, CStyle& sty, unsigned long& pos) 32void textfmt::getch(tchar& ch, CStyle& sty, unsigned long& pos)
34{ 33{
35 mygetch(ch, sty, pos); 34 mygetch(ch, sty, pos);
36 do 35 do
37 { 36 {
38 sty = currentstyle; 37 sty = currentstyle;
39 switch (ch) 38 switch (ch)
40 { 39 {
41 case 10: 40 case 10:
42 currentstyle.unset(); 41 currentstyle.unset();
43 sty = currentstyle; 42 sty = currentstyle;
44 break; 43 break;
45// Use this if you want to replace -- by em-dash 44// Use this if you want to replace -- by em-dash
46 case '-': 45 case '-':
47 // parent->getch(ch, sty); 46 // parent->getch(ch, sty);
48 mygetch(ch, sty, pos); 47 mygetch(ch, sty, pos);
49 if (ch == '-') 48 if (ch == '-')
50 { 49 {
51 ch = 0x2014; 50 ch = 0x2014;
52 } 51 }
53 else 52 else
54 { 53 {
55 lastchar = ch; 54 lastchar = ch;
56 uselast = true; 55 uselast = true;
57 ch = '-'; 56 ch = '-';
58 } 57 }
59 break; 58 break;
60 case '*': 59 case '*':
61 if (currentstyle.isBold()) 60 if (currentstyle.isBold())
62 { 61 {
63// Already bold - time to turn it off? 62// Already bold - time to turn it off?
64// The next two lines ensure that * follows a character but it works better without 63// The next two lines ensure that * follows a character but it works better without
65 // QChar c(lastchar); 64 // QChar c(lastchar);
66 // if ((lastchar != '*') && (c.isPunct() || c.isLetterOrNumber())) 65 // if ((lastchar != '*') && (c.isPunct() || c.isLetterOrNumber()))
67 if (lastchar != '*') 66 if (lastchar != '*')
68 { 67 {
69 currentstyle.unsetBold(); 68 currentstyle.unsetBold();
70 CStyle dummy; 69 CStyle dummy;
71 // parent->getch(ch, dummy); 70 // parent->getch(ch, dummy);
72 mygetch(ch, dummy, pos); 71 mygetch(ch, dummy, pos);
73 } 72 }
74 } 73 }
75 else 74 else
76 { 75 {
77// not bold - time to turn it on? 76// not bold - time to turn it on?
78 CStyle dummy; 77 CStyle dummy;
79 // parent->getch(ch, dummy); 78 // parent->getch(ch, dummy);
80 mygetch(ch, dummy, pos); 79 mygetch(ch, dummy, pos);
81 QChar c(ch); 80 QChar c(ch);
82 if ((ch != '*') && (c.isPunct() || c.isLetterOrNumber())) 81 if ((ch != '*') && (c.isPunct() || c.isLetterOrNumber()))
83 { 82 {
84 currentstyle.setBold(); 83 currentstyle.setBold();
85 } 84 }
86 else 85 else
87 { 86 {
88 lastchar = ch; 87 lastchar = ch;
89 uselast = true; 88 uselast = true;
90 ch = '*'; 89 ch = '*';
91 } 90 }
92 91
93 } 92 }
94 break; 93 break;
95 case '_': 94 case '_':
96 if (currentstyle.isItalic()) 95 if (currentstyle.isItalic())
97 { 96 {
98// Already bold - time to turn it off? 97// Already bold - time to turn it off?
99// The next two lines ensure that * follows a character but it works better without 98// The next two lines ensure that * follows a character but it works better without
100 // QChar c(lastchar); 99 // QChar c(lastchar);
101 // if ((lastchar != '_') && (c.isPunct() || c.isLetterOrNumber())) 100 // if ((lastchar != '_') && (c.isPunct() || c.isLetterOrNumber()))
102 if (lastchar != '_') 101 if (lastchar != '_')
103 { 102 {
104 currentstyle.unsetItalic(); 103 currentstyle.unsetItalic();
105 CStyle dummy; 104 CStyle dummy;
106 // parent->getch(ch, dummy); 105 // parent->getch(ch, dummy);
107 mygetch(ch, dummy, pos); 106 mygetch(ch, dummy, pos);
108 } 107 }
109 } 108 }
110 else 109 else
111 { 110 {
112// not bold - time to turn it on? 111// not bold - time to turn it on?
113 CStyle dummy; 112 CStyle dummy;
114 // parent->getch(ch, dummy); 113 // parent->getch(ch, dummy);
115 mygetch(ch, dummy, pos); 114 mygetch(ch, dummy, pos);
116 QChar c(ch); 115 QChar c(ch);
117 if ((ch != '_') && (c.isPunct() || c.isLetterOrNumber())) 116 if ((ch != '_') && (c.isPunct() || c.isLetterOrNumber()))
118 { 117 {
119 currentstyle.setItalic(); 118 currentstyle.setItalic();
120 } 119 }
121 else 120 else
122 { 121 {
123 lastchar = ch; 122 lastchar = ch;
124 uselast = true; 123 uselast = true;
125 ch = '_'; 124 ch = '_';
126 } 125 }
127 126
128 } 127 }
129 break; 128 break;
130 } 129 }
131 } 130 }
132 while (sty != currentstyle); 131 while (sty != currentstyle);
133 if (!uselast) lastchar = ch; 132 if (!uselast) lastchar = ch;
134 return; 133 return;
135} 134}
136 135
137void remap::getch(tchar& ch, CStyle& sty, unsigned long& pos) 136void remap::getch(tchar& ch, CStyle& sty, unsigned long& pos)
138{ 137{
139 if (q[offset] != 0) 138 if (q[offset] != 0)
140 { 139 {
141 q[offset++]; 140 q[offset++];
142 sty = currentstyle; 141 sty = currentstyle;
143 return; 142 return;
144 } 143 }
145 parent->getch(ch, sty, pos); 144 parent->getch(ch, sty, pos);
146 switch (ch) 145 switch (ch)
147 { 146 {
148 case 0x201a: 147 case 0x201a:
149 ch = '\''; 148 ch = '\'';
150 break; 149 break;
151 case 0x0192: 150 case 0x0192:
152 ch = 'f'; 151 ch = 'f';
153 break; 152 break;
154 case 0x201e: 153 case 0x201e:
155 ch = '"'; 154 ch = '"';
156 break; 155 break;
157 case 0x2026: 156 case 0x2026:
158 offset = 0; 157 offset = 0;
159 q[0] = '.'; 158 q[0] = '.';
160 q[1] = '.'; 159 q[1] = '.';
161 q[2] = 0; 160 q[2] = 0;
162 ch = '.'; // should be ... 161 ch = '.'; // should be ...
163 break; 162 break;
164 case 0x0160: 163 case 0x0160:
165 ch = 'S'; 164 ch = 'S';
166 break; 165 break;
167 case 0x2039: 166 case 0x2039:
168 ch = '<'; 167 ch = '<';
169 break; 168 break;
170 case 0x0152: 169 case 0x0152:
171 offset = 0; 170 offset = 0;
172 q[0] = 'E'; 171 q[0] = 'E';
173 q[1] = 0; 172 q[1] = 0;
174 ch = 'O'; 173 ch = 'O';
175 break; 174 break;
176 case 0x017d: 175 case 0x017d:
177 ch = 'Z'; 176 ch = 'Z';
178 break; 177 break;
179 case 0x2018: 178 case 0x2018:
180 ch = '\''; 179 ch = '\'';
181 break; 180 break;
182 case 0x2019: 181 case 0x2019:
183 ch = '\''; 182 ch = '\'';
184 break; 183 break;
185 case 0x201c: 184 case 0x201c:
186 ch = '"'; 185 ch = '"';
187 break; 186 break;
188 case 0x201d: 187 case 0x201d:
189 ch = '"'; 188 ch = '"';
190 break; 189 break;
191 case 0x2022: 190 case 0x2022:
192 ch = '>'; 191 ch = '>';
193 break; 192 break;
194 case 0x2013: 193 case 0x2013:
195 ch = '-'; 194 ch = '-';
196 break; 195 break;
197 case 0x2014: 196 case 0x2014:
198 offset = 0; 197 offset = 0;
199 q[0] = '-'; 198 q[0] = '-';
200 q[1] = 0; 199 q[1] = 0;
201 ch = '-'; // should be -- 200 ch = '-'; // should be --
202 break; 201 break;
203 case 0x02dc: 202 case 0x02dc:
204 ch = '~'; 203 ch = '~';
205 break; 204 break;
206 case 0x0161: 205 case 0x0161:
207 ch = 's'; 206 ch = 's';
208 break; 207 break;
209 case 0x203a: 208 case 0x203a:
210 ch = '>'; 209 ch = '>';
211 break; 210 break;
212 case 0x0153: 211 case 0x0153:
213 offset = 0; 212 offset = 0;
214 q[0] = 'e'; 213 q[0] = 'e';
215 q[1] = 0; 214 q[1] = 0;
216 ch = 'o';// should be oe 215 ch = 'o';// should be oe
217 break; 216 break;
218 /* 217 /*
219 case 0x0009: // tab 218 case 0x0009: // tab
220 offset = 0; 219 offset = 0;
221 q[0] = ' '; 220 q[0] = ' ';
222 q[1] = 0; 221 q[1] = 0;
223 ch = ' '; 222 ch = ' ';
224 break; 223 break;
225 */ 224 */
226 case 0x017e: 225 case 0x017e:
227 ch = 'z'; 226 ch = 'z';
228 break; 227 break;
229 case 0x0178: 228 case 0x0178:
230 ch = 'Y'; 229 ch = 'Y';
231 break; 230 break;
232 } 231 }
233 currentstyle = sty; 232 currentstyle = sty;
234} 233}
235 234
236void PeanutFormatter::getch(tchar& ch, CStyle& sty, unsigned long& pos) 235void PeanutFormatter::getch(tchar& ch, CStyle& sty, unsigned long& pos)
237{ 236{
238 CStyle dummy; 237 CStyle dummy;
239 currentstyle.setColour(0,0,0); 238 currentstyle.setColour(0,0,0);
240 parent->getch(ch, dummy, pos); 239 parent->getch(ch, dummy, pos);
241 while (ch == '\\') 240 while (ch == '\\')
242 { 241 {
243 parent->getch(ch, dummy, pos); 242 parent->getch(ch, dummy, pos);
244 if (ch == '\\') break; 243 if (ch == '\\') break;
245 switch(ch) 244 switch(ch)
246 { 245 {
247 case 'a': 246 case 'a':
248 { 247 {
249 int code = 0; 248 int code = 0;
250 for (int i = 0; i < 3; i++) 249 for (int i = 0; i < 3; i++)
251 { 250 {
252 parent->getch(ch, dummy, pos); 251 parent->getch(ch, dummy, pos);
253 code = 10*code + ch - '0'; 252 code = 10*code + ch - '0';
254 } 253 }
255 ch = code; 254 ch = code;
256 } 255 }
257 break; 256 break;
258 case 'v': 257 case 'v':
259 { 258 {
260 while (1) 259 while (1)
261 { 260 {
262 parent->getch(ch, dummy, pos); 261 parent->getch(ch, dummy, pos);
263 if (ch == '\\') 262 if (ch == '\\')
264 { 263 {
265 parent->getch(ch, dummy, pos); 264 parent->getch(ch, dummy, pos);
266 if (ch == 'v') 265 if (ch == 'v')
267 { 266 {
268 parent->getch(ch, dummy, pos); 267 parent->getch(ch, dummy, pos);
269 break; 268 break;
270 } 269 }
271 } 270 }
272 } 271 }
273 } 272 }
274 break; 273 break;
275 case 's': 274 case 's':
276 case 'n': 275 case 'n':
277 currentstyle.setFontSize(0); 276 currentstyle.setFontSize(0);
278 parent->getch(ch,dummy, pos); 277 parent->getch(ch,dummy, pos);
279 break; 278 break;
280 case 'p': 279 case 'p':
281 currentstyle.unset(); 280 currentstyle.unset();
282 // parent->getch(ch,dummy); 281 // parent->getch(ch,dummy);
283 ch = 10; 282 ch = 10;
284 break; 283 break;
285 case 'l': 284 case 'l':
286 if (currentstyle.getFontSize() == 1) 285 if (currentstyle.getFontSize() == 1)
287 { 286 {
288 currentstyle.setFontSize(0); 287 currentstyle.setFontSize(0);
289 } 288 }
290 else 289 else
291 { 290 {
292 currentstyle.setFontSize(1); 291 currentstyle.setFontSize(1);
293 } 292 }
294 parent->getch(ch, dummy, pos); 293 parent->getch(ch, dummy, pos);
295 break; 294 break;
296 case 'x': 295 case 'x':
297 if (currentstyle.getFontSize() == 0) 296 if (currentstyle.getFontSize() == 0)
298 { 297 {
299 // currentstyle.unset(); 298 // currentstyle.unset();
300 // currentstyle.setBold(); 299 // currentstyle.setBold();
301 currentstyle.setFontSize(1); 300 currentstyle.setFontSize(1);
302 } 301 }
303 else 302 else
304 { 303 {
305 currentstyle.unset(); 304 currentstyle.unset();
306 } 305 }
307 // parent->getch(ch, dummy); 306 // parent->getch(ch, dummy);
308 ch = 10; 307 ch = 10;
309 break; 308 break;
310 case 'i': 309 case 'i':
311 if (currentstyle.isItalic()) 310 if (currentstyle.isItalic())
312 { 311 {
313 currentstyle.unsetItalic(); 312 currentstyle.unsetItalic();
314 } 313 }
315 else 314 else
316 { 315 {
317 currentstyle.setItalic(); 316 currentstyle.setItalic();
318 } 317 }
319 parent->getch(ch, dummy, pos); 318 parent->getch(ch, dummy, pos);
320 break; 319 break;
321 case 'b': 320 case 'b':
322 case 'B': 321 case 'B':
323 if (currentstyle.isBold()) 322 if (currentstyle.isBold())
324 { 323 {
325 currentstyle.unsetBold(); 324 currentstyle.unsetBold();
326 } 325 }
327 else 326 else
328 { 327 {
329 currentstyle.setBold(); 328 currentstyle.setBold();
330 } 329 }
331 parent->getch(ch, dummy, pos); 330 parent->getch(ch, dummy, pos);
332 break; 331 break;
333 case 'c': 332 case 'c':
334 if (currentstyle.getJustify() == m_AlignCentre) 333 if (currentstyle.getJustify() == m_AlignCentre)
335 { 334 {
336 currentstyle.setLeftJustify(); 335 currentstyle.setLeftJustify();
337 } 336 }
338 else 337 else
339 { 338 {
340 currentstyle.setCentreJustify(); 339 currentstyle.setCentreJustify();
341 } 340 }
342 parent->getch(ch, dummy, pos); 341 parent->getch(ch, dummy, pos);
343 break; 342 break;
344 case 'r': 343 case 'r':
345 if (currentstyle.getJustify() == m_AlignRight) 344 if (currentstyle.getJustify() == m_AlignRight)
346 { 345 {
347 currentstyle.setLeftJustify(); 346 currentstyle.setLeftJustify();
348 } 347 }
349 else 348 else
350 { 349 {
351 currentstyle.setRightJustify(); 350 currentstyle.setRightJustify();
352 } 351 }
353 parent->getch(ch, dummy, pos); 352 parent->getch(ch, dummy, pos);
354 break; 353 break;
355 default: 354 default:
356 currentstyle.setColour(255,0,0); 355 currentstyle.setColour(255,0,0);
357 } 356 }
358 } 357 }
359 sty = currentstyle; 358 sty = currentstyle;
360} 359}
361 360
362void OnePara::getch(tchar& ch, CStyle& sty, unsigned long& pos) 361void OnePara::getch(tchar& ch, CStyle& sty, unsigned long& pos)
363{ 362{
364 parent->getch(ch, sty, pos); 363 parent->getch(ch, sty, pos);
365 if (m_lastchar == 10) 364 if (m_lastchar == 10)
366 { 365 {
367 while (ch == 10) parent->getch(ch, sty, pos); 366 while (ch == 10) parent->getch(ch, sty, pos);
368 } 367 }
369 m_lastchar = ch; 368 m_lastchar = ch;
370} 369}
371 370
372void repalm::getch(tchar& ch, CStyle& sty, unsigned long& pos) 371void repalm::getch(tchar& ch, CStyle& sty, unsigned long& pos)
373{ 372{
374 parent->getch(ch, sty, pos); 373 parent->getch(ch, sty, pos);
375 switch (ch) 374 switch (ch)
376 { 375 {
377 case 0x80: 376 case 0x80:
378 ch = 0x20ac; 377 ch = 0x20ac;
379 break; 378 break;
380 case 0x82: 379 case 0x82:
381 ch = 0x201a; 380 ch = 0x201a;
382 break; 381 break;
383 case 0x83: 382 case 0x83:
384 ch = 0x0192; 383 ch = 0x0192;
385 break; 384 break;
386 case 0x84: 385 case 0x84:
387 ch = 0x201e; 386 ch = 0x201e;
388 break; 387 break;
389 case 0x85: 388 case 0x85:
390 ch = 0x2026; 389 ch = 0x2026;
391 break; 390 break;
392 case 0x86: 391 case 0x86:
393 ch = 0x2020; 392 ch = 0x2020;
394 break; 393 break;
395 case 0x87: 394 case 0x87:
396 ch = 0x2021; 395 ch = 0x2021;
397 break; 396 break;
398 case 0x88: 397 case 0x88:
399 ch = 0x02c6; 398 ch = 0x02c6;
400 break; 399 break;
401 case 0x89: 400 case 0x89:
402 ch = 0x2030; 401 ch = 0x2030;
403 break; 402 break;
404 case 0x8a: 403 case 0x8a:
405 ch = 0x0160; 404 ch = 0x0160;
406 break; 405 break;
407 case 0x8b: 406 case 0x8b:
408 ch = 0x2039; 407 ch = 0x2039;
409 break; 408 break;
410 case 0x8c: 409 case 0x8c:
411 ch = 0x0152; 410 ch = 0x0152;
412 break; 411 break;
413/* 412/*
414 case 0x8e: 413 case 0x8e:
415 ch = 0x017d; 414 ch = 0x017d;
416 break; 415 break;
417*/ 416*/
418 case 0x91: 417 case 0x91:
419 ch = 0x2018; 418 ch = 0x2018;
420 break; 419 break;
421 case 0x92: 420 case 0x92:
422 ch = 0x2019; 421 ch = 0x2019;
423 break; 422 break;
424 case 0x93: 423 case 0x93:
425 ch = 0x201c; 424 ch = 0x201c;
426 break; 425 break;
427 case 0x94: 426 case 0x94:
428 ch = 0x201d; 427 ch = 0x201d;
429 break; 428 break;
430 case 0x95: 429 case 0x95:
431 ch = 0x2022; 430 ch = 0x2022;
432 break; 431 break;
433 case 0x96: 432 case 0x96:
434 ch = 0x2013; 433 ch = 0x2013;
435 break; 434 break;
436 case 0x97: 435 case 0x97:
437 ch = 0x2014; 436 ch = 0x2014;
438 break; 437 break;
439 case 0x98: 438 case 0x98:
440 ch = 0x02dc; 439 ch = 0x02dc;
441 break; 440 break;
442 case 0x99: 441 case 0x99:
443 ch = 0x2122; 442 ch = 0x2122;
444 break; 443 break;
445 case 0x9a: 444 case 0x9a:
446 ch = 0x0161; 445 ch = 0x0161;
447 break; 446 break;
448 case 0x9b: 447 case 0x9b:
449 ch = 0x203a; 448 ch = 0x203a;
450 break; 449 break;
451 case 0x9c: 450 case 0x9c:
452 ch = 0x0153; 451 ch = 0x0153;
453 break; 452 break;
454 case 0x9e: 453 case 0x9e:
455 ch = 0x017e; 454 ch = 0x017e;
456 break; 455 break;
457 case 0x9f: 456 case 0x9f:
458 ch = 0x0178; 457 ch = 0x0178;
459 break; 458 break;
460 case 0x18: 459 case 0x18:
461 ch = 0x2026; 460 ch = 0x2026;
462 break; 461 break;
463 case 0x19: 462 case 0x19:
464 ch = 0x2007; 463 ch = 0x2007;
465 break; 464 break;
466 case 0x8d: 465 case 0x8d:
467 ch = 0x2662; 466 ch = 0x2662;
468 break; 467 break;
469 case 0x8e: 468 case 0x8e:
470 ch = 0x2663; 469 ch = 0x2663;
471 break; 470 break;
472 case 0x8f: 471 case 0x8f:
473 ch = 0x2661; 472 ch = 0x2661;
474 break; 473 break;
475 case 0x90: 474 case 0x90:
476 ch = 0x2660; 475 ch = 0x2660;
477 break; 476 break;
478 default: 477 default:
479 break; 478 break;
480 } 479 }
481} 480}
482 481
483//static tchar nextpart[] = { 'C','l','i','c','k',' ','h','e','r','e',' ','f','o','r',' ','t','h','e',' ','n','e','x','t',' ','p','a','r','t',0 }; 482//static tchar nextpart[] = { 'C','l','i','c','k',' ','h','e','r','e',' ','f','o','r',' ','t','h','e',' ','n','e','x','t',' ','p','a','r','t',0 };
484//static tchar prevpart[] = { 'C','l','i','c','k',' ','h','e','r','e',' ','f','o','r',' ','t','h','e',' ','p','r','e','v','i','o','u','s',' ','p','a','r','t',0 }; 483//static tchar prevpart[] = { 'C','l','i','c','k',' ','h','e','r','e',' ','f','o','r',' ','t','h','e',' ','p','r','e','v','i','o','u','s',' ','p','a','r','t',0 };
485 484
486void DePluck::getch(tchar& ch, CStyle& sty, unsigned long& pos) 485void DePluck::getch(tchar& ch, CStyle& sty, unsigned long& pos)
487{ 486{
488 if (m_buffed > 0) 487 if (m_buffed > 0)
489 { 488 {
490 sty = m_laststyle; 489 sty = m_laststyle;
491 ch = nextpart[m_current++]; 490 ch = nextpart[m_current++];
492 if (m_current == m_buffed) 491 if (m_current == m_buffed)
493 { 492 {
494 m_current = m_buffed = 0; 493 m_current = m_buffed = 0;
495 } 494 }
496 } 495 }
497 else 496 else
498 { 497 {
499 if (m_buffer != 0) 498 if (m_buffer != 0)
500 { 499 {
501 ch = m_buffer; 500 ch = m_buffer;
502 m_buffer = 0; 501 m_buffer = 0;
503 return; 502 return;
504 } 503 }
505 unsigned long lnk, lnkoff; 504 unsigned long lnk, lnkoff;
506 do 505 do
507 { 506 {
508 if (nextpart[m_buffed] == 0) break; 507 if (nextpart[m_buffed] == 0) break;
509 parent->getch(ch, sty, pos); 508 parent->getch(ch, sty, pos);
510 m_laststyle = sty; 509 m_laststyle = sty;
511 if (sty.getLink()) 510 if (sty.getLink())
512 { 511 {
513 lnk = sty.getData(); 512 lnk = sty.getData();
514 lnkoff = sty.getOffset(); 513 lnkoff = sty.getOffset();
515 } 514 }
516 } while (ch == nextpart[m_buffed] && sty.getLink() && ++m_buffed); 515 } while (ch == nextpart[m_buffed] && sty.getLink() && ++m_buffed);
517 m_current = 0; 516 m_current = 0;
518 if (nextpart[m_buffed] == 0) 517 if (nextpart[m_buffed] == 0)
519 { 518 {
520 m_buffed = 0; 519 m_buffed = 0;
521 QString dmy, dmy2; 520 QString dmy, dmy2;
522 parent->hyperlink(lnk, lnkoff, dmy, dmy2); 521 parent->hyperlink(lnk, lnkoff, dmy, dmy2);
523 do 522 do
524 { 523 {
525 parent->getch(ch, sty, pos); 524 parent->getch(ch, sty, pos);
526 } 525 }
527 while (ch != 10); 526 while (ch != 10);
528 parent->getch(ch, sty, pos); 527 parent->getch(ch, sty, pos);
529 } 528 }
530 else if (m_buffed > 0) 529 else if (m_buffed > 0)
531 { 530 {
532 m_buffer = ch; 531 m_buffer = ch;
533 ch = nextpart[0]; 532 ch = nextpart[0];
534 if (m_buffed == 1) 533 if (m_buffed == 1)
535 { 534 {
536 m_buffed = 0; 535 m_buffed = 0;
537 } 536 }
538 else m_current = 1; 537 else m_current = 1;
539 } 538 }
540 } 539 }
541 540
542 return; 541 return;
543} 542}
544 543
545HighlightFilter::HighlightFilter(QTReader* _p) : pReader(_p), lastpos(0), nextpos(0), red(255), green(255), blue(255) 544HighlightFilter::HighlightFilter(QTReader* _p) : pReader(_p), lastpos(0), nextpos(0), red(255), green(255), blue(255)
546{ 545{
547} 546}
548 547
549#include "Bkmks.h" 548#include "Bkmks.h"
550#include "QTReader.h" 549#include "QTReader.h"
551 550
552void HighlightFilter::refresh(unsigned long pos) 551void HighlightFilter::refresh(unsigned long pos)
553{ 552{
554 bkmks = pReader->Bkmklist(); 553 bkmks = pReader->Bkmklist();
555 554
556 red = green = blue = 255; 555 red = green = blue = 255;
557 556
558 if (bkmks == NULL) 557 if (bkmks == NULL)
559 { 558 {
560 lastpos = 0; 559 lastpos = 0;
561 nextpos = 0xffffffff; 560 nextpos = 0xffffffff;
562 } 561 }
563 else 562 else
564 { 563 {
565 lastpos = 0; 564 lastpos = 0;
566 nextpos = 0xffffffff; 565 nextpos = 0xffffffff;
567 for (CList<Bkmk>::iterator i = bkmks->begin(); i != bkmks->end(); i++) 566 for (CList<Bkmk>::iterator i = bkmks->begin(); i != bkmks->end(); i++)
568 { 567 {
569 if ((*i).value() <= pos && pos < (*i).value2()) 568 if ((*i).value() <= pos && pos < (*i).value2())
570 { 569 {
571 red = i->red(); 570 red = i->red();
572 green = i->green(); 571 green = i->green();
573 blue = i->blue(); 572 blue = i->blue();
574 lastpos = (*i).value(); 573 lastpos = (*i).value();
575 nextpos = (*i).value2(); 574 nextpos = (*i).value2();
576 break; 575 break;
577 } 576 }
578 if ((*i).value() > pos) 577 if ((*i).value() > pos)
579 { 578 {
580 nextpos = (*i).value(); 579 nextpos = (*i).value();
581 break; 580 break;
582 } 581 }
583 lastpos = (*i).value(); 582 lastpos = (*i).value();
584 } 583 }
585 } 584 }
586} 585}
587 586
588void HighlightFilter::getch(tchar& ch, CStyle& sty, unsigned long& pos) 587void HighlightFilter::getch(tchar& ch, CStyle& sty, unsigned long& pos)
589{ 588{
590 parent->getch(ch, sty, pos); 589 parent->getch(ch, sty, pos);
591 if (bkmks != pReader->Bkmklist() || pos <= lastpos || pos >= nextpos) 590 if (bkmks != pReader->Bkmklist() || pos <= lastpos || pos >= nextpos)
592 { 591 {
593 // qDebug("Recalc <%lu, %lu, %lu>", lastpos, pos, nextpos); 592 // qDebug("Recalc <%lu, %lu, %lu>", lastpos, pos, nextpos);
594 refresh(pos); 593 refresh(pos);
595 // qDebug("Recalc(2) <%lu, %lu, %lu>", lastpos, pos, nextpos); 594 // qDebug("Recalc(2) <%lu, %lu, %lu>", lastpos, pos, nextpos);
596 } 595 }
597 int r = sty.bRed(), g = sty.bGreen(), b = sty.bBlue(); 596 int r = sty.bRed(), g = sty.bGreen(), b = sty.bBlue();
598 if (r == 255 && g == 255 && b == 255) 597 if (r == 255 && g == 255 && b == 255)
599 { 598 {
600 sty.setBackground(red, green, blue); 599 sty.setBackground(red, green, blue);
601 } 600 }
602} 601}
603 602
604void kern::getch(tchar& ch, CStyle& sty, unsigned long& pos) 603void kern::getch(tchar& ch, CStyle& sty, unsigned long& pos)
605{ 604{
606 if (uselast) 605 if (uselast)
607 { 606 {
608 ch = lastchar; 607 ch = lastchar;
609 sty = laststy; 608 sty = laststy;
610 uselast = false; 609 uselast = false;
611 return; 610 return;
612 } 611 }
613 else 612 else
614 { 613 {
615 parent->getch(ch, sty, pos); 614 parent->getch(ch, sty, pos);
616 } 615 }
617 switch (ch) 616 switch (ch)
618 { 617 {
619 case 'f': 618 case 'f':
620 { 619 {
621 tchar savedchar = 'f'; 620 tchar savedchar = 'f';
622 parent->getch(ch, sty, pos); 621 parent->getch(ch, sty, pos);
623 switch (ch) 622 switch (ch)
624 { 623 {
625 case 'i': 624 case 'i':
626 ch = (251 << 8) + 1; 625 ch = (251 << 8) + 1;
627 break; 626 break;
628 case 'l': 627 case 'l':
629 ch = (251 << 8) + 2; 628 ch = (251 << 8) + 2;
630 break; 629 break;
631 default: 630 default:
632 lastchar = ch; 631 lastchar = ch;
633 uselast = true; 632 uselast = true;
634 laststy = sty; 633 laststy = sty;
635 ch = savedchar; 634 ch = savedchar;
636 } 635 }
637 } 636 }
638 break; 637 break;
639 default: 638 default:
640 break; 639 break;
641 } 640 }
642} 641}
643 642
644class ErrorFilter : public CFilter 643class ErrorFilter : public CFilter
645{ 644{
646 QString error; 645 QString error;
647 int currentpos; 646 int currentpos;
648 public: 647 public:
649 ErrorFilter(const QString& _s) : error(_s), currentpos(0) {} 648 ErrorFilter(const QString& _s) : error(_s), currentpos(0) {}
650 ~ErrorFilter() {} 649 ~ErrorFilter() {}
651 void getch(tchar& ch, CStyle& sty, unsigned long& pos) 650 void getch(tchar& ch, CStyle& sty, unsigned long& pos)
652 { 651 {
653 if (currentpos == error.length()) 652 if (currentpos == error.length())
654 { 653 {
655 ch = UEOF; 654 ch = UEOF;
656 currentpos = 0; 655 currentpos = 0;
657 } 656 }
658 else 657 else
659 { 658 {
660 ch = error[currentpos++].unicode(); 659 ch = error[currentpos++].unicode();
661 } 660 }
662 } 661 }
663 QString about() { return parent->about(); } 662 QString about() { return parent->about(); }
664}; 663};
665 664
666#ifndef __STATIC 665#ifndef __STATIC
667ExternFilter::ExternFilter(const QString& nm, const QString& optional) : filt(NULL), handle(NULL) 666ExternFilter::ExternFilter(const QString& nm, const QString& optional) : filt(NULL), handle(NULL)
668{ 667{
669 QString filterpath(QTReaderUtil::getPluginPath("filters/lib")); 668 QString filterpath(QTReaderUtil::getPluginPath("filters/lib"));
670 filterpath += nm; 669 filterpath += nm;
671 filterpath += ".so"; 670 filterpath += ".so";
672 if (QFile::exists(filterpath)) 671 if (QFile::exists(filterpath))
673 { 672 {
674 qDebug("Filter:%s", (const char*)filterpath); 673 qDebug("Filter:%s", (const char*)filterpath);
675 handle = dlopen(filterpath, RTLD_LAZY); 674 handle = dlopen(filterpath, RTLD_LAZY);
676 if (handle == 0) 675 if (handle == 0)
677 { 676 {
678 qDebug("Can't find filter:%s", dlerror()); 677 qDebug("Can't find filter:%s", dlerror());
679 // status = -10; 678 // status = -10;
680 filt = new ErrorFilter(QString("Can't find plugin:")+nm); 679 filt = new ErrorFilter(QString("Can't find plugin:")+nm);
681 return; 680 return;
682 } 681 }
683 CFilter* (*newfilter)(const QString&); 682 CFilter* (*newfilter)(const QString&);
684 newfilter = (CFilter* (*)(const QString&))dlsym(handle, "newfilter"); 683 newfilter = (CFilter* (*)(const QString&))dlsym(handle, "newfilter");
685 if (newfilter == NULL) 684 if (newfilter == NULL)
686 { 685 {
687 qDebug("Can't find newfilter"); 686 qDebug("Can't find newfilter");
688 filt = new ErrorFilter(QString("Can't find entry point in plugin:")+nm); 687 filt = new ErrorFilter(QString("Can't find entry point in plugin:")+nm);
689 return; 688 return;
690 } 689 }
691 filt = (*newfilter)(optional); 690 filt = (*newfilter)(optional);
692 } 691 }
693 else 692 else
694 { 693 {
695 qDebug("No filter path"); 694 qDebug("No filter path");
696 filt = new ErrorFilter(QString("No filter plugins installed:")+nm); 695 filt = new ErrorFilter(QString("No filter plugins installed:")+nm);
697 } 696 }
698 if (filt == NULL) 697 if (filt == NULL)
699 { 698 {
700 qDebug("Can't do newfilter"); 699 qDebug("Can't do newfilter");
701 filt = new ErrorFilter(QString("Filter creation failed:")+nm); 700 filt = new ErrorFilter(QString("Filter creation failed:")+nm);
702 return; 701 return;
703 } 702 }
704} 703}
705#endif 704#endif
706 705
707void makeInverse::getch(tchar& ch, CStyle& sty, unsigned long& pos) 706void makeInverse::getch(tchar& ch, CStyle& sty, unsigned long& pos)
708{ 707{
709 parent->getch(ch, sty, pos); 708 parent->getch(ch, sty, pos);
710 int r,g,b; 709 int r,g,b;
711 r = 255 - sty.Red(), g = 255 - sty.Green(), b = 255 - sty.Blue(); 710 r = 255 - sty.Red(), g = 255 - sty.Green(), b = 255 - sty.Blue();
712 sty.setColour(r,g,b); 711 sty.setColour(r,g,b);
713 r = 255 - sty.bRed(), g = 255 - sty.bGreen(), b = 255 - sty.bBlue(); 712 r = 255 - sty.bRed(), g = 255 - sty.bGreen(), b = 255 - sty.bBlue();
714 sty.setBackground(r,g,b); 713 sty.setBackground(r,g,b);
715 r = 255 - sty.pRed(), g = 255 - sty.pGreen(), b = 255 - sty.pBlue(); 714 r = 255 - sty.pRed(), g = 255 - sty.pGreen(), b = 255 - sty.pBlue();
716 sty.setPaper(r,g,b); 715 sty.setPaper(r,g,b);
717} 716}
718/* 717/*
719void makeNegative::getch(tchar& ch, CStyle& sty, unsigned long& pos) 718void makeNegative::getch(tchar& ch, CStyle& sty, unsigned long& pos)
720{ 719{
721 parent->getch(ch, sty, pos); 720 parent->getch(ch, sty, pos);
722 QColor fg(sty.Red(), sty.Green(), sty.Blue()); 721 QColor fg(sty.Red(), sty.Green(), sty.Blue());
723 int h,s,v; 722 int h,s,v;
724 fg.hsv(&h,&s,&v); 723 fg.hsv(&h,&s,&v);
725 fg.setHsv(h,s,255-v); 724 fg.setHsv(h,s,255-v);
726 int r,g,b; 725 int r,g,b;
727 fg.rgb(&r,&g,&b); 726 fg.rgb(&r,&g,&b);
728 sty.setColour(r,g,b); 727 sty.setColour(r,g,b);
729 728
730 fg = QColor(sty.bRed(), sty.bGreen(), sty.bBlue()); 729 fg = QColor(sty.bRed(), sty.bGreen(), sty.bBlue());
731 fg.hsv(&h,&s,&v); 730 fg.hsv(&h,&s,&v);
732 fg.setHsv(h,s,255-v); 731 fg.setHsv(h,s,255-v);
733 fg.rgb(&r,&g,&b); 732 fg.rgb(&r,&g,&b);
734 sty.setBackground(r,g,b); 733 sty.setBackground(r,g,b);
735} 734}
736*/ 735*/
737void setbg::getch(tchar& ch, CStyle& sty, unsigned long& pos) 736void setbg::getch(tchar& ch, CStyle& sty, unsigned long& pos)
738{ 737{
739 parent->getch(ch, sty, pos); 738 parent->getch(ch, sty, pos);
740 int r = sty.pRed(), g = sty.pGreen(), b = sty.pBlue(); 739 int r = sty.pRed(), g = sty.pGreen(), b = sty.pBlue();
741 if (r == 255 && g == 255 && b == 255) 740 if (r == 255 && g == 255 && b == 255)
742 { 741 {
743 sty.setPaper(m_r,m_g,m_b); 742 sty.setPaper(m_r,m_g,m_b);
744 } 743 }
745 else 744 else
746 { 745 {
747 qDebug("We have background [%x%x%x]", r, g, b); 746 qDebug("We have background [%x%x%x]", r, g, b);
748 } 747 }
749 r = sty.bRed(), g = sty.bGreen(), b = sty.bBlue(); 748 r = sty.bRed(), g = sty.bGreen(), b = sty.bBlue();
750 if (r == 255 && g == 255 && b == 255) 749 if (r == 255 && g == 255 && b == 255)
751 { 750 {
752 sty.setBackground(m_r,m_g,m_b); 751 sty.setBackground(m_r,m_g,m_b);
753 } 752 }
754 else 753 else
755 { 754 {
756 qDebug("We have background [%x%x%x]", r, g, b); 755 qDebug("We have background [%x%x%x]", r, g, b);
757 } 756 }
758} 757}
759 758
760void setfg::getch(tchar& ch, CStyle& sty, unsigned long& pos) 759void setfg::getch(tchar& ch, CStyle& sty, unsigned long& pos)
761{ 760{
762 parent->getch(ch, sty, pos); 761 parent->getch(ch, sty, pos);
763 int r = sty.Red(), g = sty.Green(), b = sty.Blue(); 762 int r = sty.Red(), g = sty.Green(), b = sty.Blue();
764 if (r == 0 && g == 0 && b == 0) 763 if (r == 0 && g == 0 && b == 0)
765 { 764 {
766 sty.setColour(m_r,m_g,m_b); 765 sty.setColour(m_r,m_g,m_b);
767 } 766 }
768} 767}
769 768
770#include "CRegExp.h" 769#include "CRegExp.h"
771 770
772repara::repara(const QString& pat) : tch(0) 771repara::repara(const QString& pat) : tch(0)
773{ 772{
774 // QString pat("{\\n[A-Z\"]}"); 773 // QString pat("{\\n[A-Z\"]}");
775 flt = new CRegExpFilt(pat, false); 774 flt = new CRegExpFilt(pat, false);
776 qDebug("Construction done"); 775 qDebug("Construction done");
777} 776}
778 777
779repara::~repara() 778repara::~repara()
780{ 779{
781 delete flt; 780 delete flt;
782} 781}
783 782
784void repara::getch(tchar& ch, CStyle& sty, unsigned long& pos) 783void repara::getch(tchar& ch, CStyle& sty, unsigned long& pos)
785{ 784{
786 if (flt->empty()) 785 if (flt->empty())
787 { 786 {
788 while (flt->empty()) 787 while (flt->empty())
789 { 788 {
790 parent->getch(ch, sty, pos); 789 parent->getch(ch, sty, pos);
791 flt->addch(ch); 790 flt->addch(ch);
792 } 791 }
793 } 792 }
794 ch = flt->pop(); 793 ch = flt->pop();
795 /* 794 /*
796 parent->getch(ch, sty, pos); 795 parent->getch(ch, sty, pos);
797 if (ch == 10 || ch == ' ') 796 if (ch == 10 || ch == ' ')
798 { 797 {
799 if (tch == 10) 798 if (tch == 10)
800 { 799 {
801 tch = ch; 800 tch = ch;
802 ch = 10; 801 ch = 10;
803 return; 802 return;
804 } 803 }
805 else 804 else
806 { 805 {
807 tch = ch; 806 tch = ch;
808 ch = ' '; 807 ch = ' ';
809 return; 808 return;
810 } 809 }
811 } 810 }
812 tch = ch; 811 tch = ch;
813 */ 812 */
814 return; 813 return;
815} 814}
diff --git a/noncore/apps/opie-reader/CFilter.h b/noncore/apps/opie-reader/CFilter.h
index cec9618..174e6b4 100644
--- a/noncore/apps/opie-reader/CFilter.h
+++ b/noncore/apps/opie-reader/CFilter.h
@@ -1,475 +1,474 @@
1#ifndef __CFILTER_H 1#ifndef __CFILTER_H
2#define __CFILTER_H 2#define __CFILTER_H
3 3
4#include "CExpander.h" 4#include "CExpander.h"
5#include "CEncoding.h" 5#include "CEncoding.h"
6 6
7class CFilter_IFace : public CCharacterSource 7class CFilter_IFace : public CCharacterSource
8{ 8{
9 public: 9 public:
10 virtual linkType hyperlink(unsigned int n, unsigned int noff, QString& w, QString& nm) = 0; 10 virtual linkType hyperlink(unsigned int n, unsigned int noff, QString& w, QString& nm) = 0;
11 virtual void setparent(CCharacterSource* p) = 0; 11 virtual void setparent(CCharacterSource* p) = 0;
12 virtual ~CFilter_IFace() {}; 12 virtual ~CFilter_IFace() {};
13 virtual void locate(unsigned int n) = 0; 13 virtual void locate(unsigned int n) = 0;
14 virtual bool findanchor(const QString& nm) = 0; 14 virtual bool findanchor(const QString& nm) = 0;
15 virtual void saveposn(const QString& f, size_t posn) = 0; 15 virtual void saveposn(const QString& f, size_t posn) = 0;
16 virtual void writeposn(const QString& f, size_t posn) = 0; 16 virtual void writeposn(const QString& f, size_t posn) = 0;
17 virtual linkType forward(QString& f, size_t& loc) = 0; 17 virtual linkType forward(QString& f, size_t& loc) = 0;
18 virtual linkType back(QString& f, size_t& loc) = 0; 18 virtual linkType back(QString& f, size_t& loc) = 0;
19 virtual bool hasnavigation() = 0; 19 virtual bool hasnavigation() = 0;
20 virtual int getwidth() = 0; 20 virtual int getwidth() = 0;
21 virtual CCharacterSource* getparent() = 0; 21 virtual CCharacterSource* getparent() = 0;
22}; 22};
23 23
24class CFilter : public CFilter_IFace 24class CFilter : public CFilter_IFace
25{ 25{
26 protected: 26 protected:
27 CCharacterSource* parent; 27 CCharacterSource* parent;
28 public: 28 public:
29 virtual linkType hyperlink(unsigned int n, unsigned int noff, QString& w, QString& nm) 29 virtual linkType hyperlink(unsigned int n, unsigned int noff, QString& w, QString& nm)
30 { 30 {
31 return parent->hyperlink(n,noff,w,nm); 31 return parent->hyperlink(n,noff,w,nm);
32 } 32 }
33 CFilter() : parent(NULL) {} 33 CFilter() : parent(NULL) {}
34 void setparent(CCharacterSource* p) { parent = p; } 34 void setparent(CCharacterSource* p) { parent = p; }
35 CCharacterSource* getparent() { return parent; } 35 CCharacterSource* getparent() { return parent; }
36 virtual ~CFilter() {}; 36 virtual ~CFilter() {};
37 virtual void locate(unsigned int n) 37 virtual void locate(unsigned int n)
38 { 38 {
39 parent->locate(n); 39 parent->locate(n);
40 } 40 }
41 virtual bool findanchor(const QString& nm) 41 virtual bool findanchor(const QString& nm)
42 { 42 {
43 return parent->findanchor(nm); 43 return parent->findanchor(nm);
44 } 44 }
45 virtual void saveposn(const QString& f, size_t posn) { parent->saveposn(f, posn); } 45 virtual void saveposn(const QString& f, size_t posn) { parent->saveposn(f, posn); }
46 virtual void writeposn(const QString& f, size_t posn) { parent->writeposn(f, posn); } 46 virtual void writeposn(const QString& f, size_t posn) { parent->writeposn(f, posn); }
47 virtual linkType forward(QString& f, size_t& loc) { return parent->forward(f, loc); } 47 virtual linkType forward(QString& f, size_t& loc) { return parent->forward(f, loc); }
48 virtual linkType back(QString& f, size_t& loc) { return parent->back(f, loc); } 48 virtual linkType back(QString& f, size_t& loc) { return parent->back(f, loc); }
49 virtual bool hasnavigation() { return parent->hasnavigation(); } 49 virtual bool hasnavigation() { return parent->hasnavigation(); }
50 virtual int getwidth() { return parent->getwidth(); } 50 virtual int getwidth() { return parent->getwidth(); }
51 QImage* getPicture(unsigned long tgt) { return parent->getPicture(tgt); } 51 QImage* getPicture(unsigned long tgt) { return parent->getPicture(tgt); }
52 QImage* getPicture(const QString& href) { return parent->getPicture(href); } 52 QImage* getPicture(const QString& href) { return parent->getPicture(href); }
53 bool getFile(const QString& href) { return parent->getFile(href); } 53 bool getFile(const QString& href) { return parent->getFile(href); }
54}; 54};
55 55
56class CFilterChain 56class CFilterChain
57{ 57{
58 CExpander_Interface* expander; 58 CExpander_Interface* expander;
59 CEncoding* encoder; 59 CEncoding* encoder;
60 CFilter_IFace* first; 60 CFilter_IFace* first;
61 CCharacterSource* front; 61 CCharacterSource* front;
62 public: 62 public:
63 CFilterChain(CEncoding* _e) : encoder(_e), first(NULL), front(_e) {}; 63 CFilterChain(CEncoding* _e) : encoder(_e), first(NULL), front(_e) {};
64 ~CFilterChain() 64 ~CFilterChain()
65 { 65 {
66 CCharacterSource* p = front; 66 CCharacterSource* p = front;
67 while (p != encoder) 67 while (p != encoder)
68 { 68 {
69 CFilter_IFace* pnext = (CFilter_IFace*)p; 69 CFilter_IFace* pnext = (CFilter_IFace*)p;
70 p = ((CFilter_IFace*)p)->getparent(); 70 p = ((CFilter_IFace*)p)->getparent();
71 delete pnext; 71 delete pnext;
72 } 72 }
73 delete encoder; 73 delete encoder;
74 } 74 }
75 linkType hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm) 75 linkType hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm)
76 { 76 {
77 return front->hyperlink(n, noff, wrd, nm); 77 return front->hyperlink(n, noff, wrd, nm);
78 } 78 }
79 void locate(unsigned int n) 79 void locate(unsigned int n)
80 { 80 {
81 front->locate(n); 81 front->locate(n);
82 } 82 }
83 void getch(tchar& ch, CStyle& sty, unsigned long& pos) 83 void getch(tchar& ch, CStyle& sty, unsigned long& pos)
84 { 84 {
85 front->getch(ch, sty, pos); 85 front->getch(ch, sty, pos);
86 } 86 }
87 void addfilter(CFilter_IFace* p) 87 void addfilter(CFilter_IFace* p)
88 { 88 {
89 if (first == NULL) 89 if (first == NULL)
90 { 90 {
91 front = first = p; 91 front = first = p;
92 p->setparent(encoder); 92 p->setparent(encoder);
93 } 93 }
94 else 94 else
95 { 95 {
96 p->setparent(front); 96 p->setparent(front);
97 front = p; 97 front = p;
98 } 98 }
99 } 99 }
100 void setsource(CExpander_Interface* p) 100 void setsource(CExpander_Interface* p)
101 { 101 {
102 expander = p; 102 expander = p;
103 encoder->setparent(p); 103 encoder->setparent(p);
104 } 104 }
105 void setencoder(CEncoding* p) 105 void setencoder(CEncoding* p)
106 { 106 {
107 delete encoder; 107 delete encoder;
108 encoder = p; 108 encoder = p;
109 first->setparent(p); 109 first->setparent(p);
110 encoder->setparent(expander); 110 encoder->setparent(expander);
111 } 111 }
112 bool findanchor(const QString& nm) 112 bool findanchor(const QString& nm)
113 { 113 {
114 return front->findanchor(nm); 114 return front->findanchor(nm);
115 } 115 }
116 void saveposn(const QString& f, size_t posn) { front->saveposn(f, posn); } 116 void saveposn(const QString& f, size_t posn) { front->saveposn(f, posn); }
117 void writeposn(const QString& f, size_t posn) { front->writeposn(f, posn); } 117 void writeposn(const QString& f, size_t posn) { front->writeposn(f, posn); }
118 linkType forward(QString& f, size_t& loc) { return front->forward(f, loc); } 118 linkType forward(QString& f, size_t& loc) { return front->forward(f, loc); }
119 linkType back(QString& f, size_t& loc) { return front->back(f, loc); } 119 linkType back(QString& f, size_t& loc) { return front->back(f, loc); }
120 bool hasnavigation() { return front->hasnavigation(); } 120 bool hasnavigation() { return front->hasnavigation(); }
121 QString about() { return QString("Filter chain (c) Tim Wentford\n")+front->about(); } 121 QString about() { return QString("Filter chain (c) Tim Wentford\n")+front->about(); }
122}; 122};
123 123
124class stripcr : public CFilter 124class stripcr : public CFilter
125{ 125{
126 public: 126 public:
127 stripcr() {} 127 stripcr() {}
128 ~stripcr() {} 128 ~stripcr() {}
129 void getch(tchar& ch, CStyle& sty, unsigned long& pos) 129 void getch(tchar& ch, CStyle& sty, unsigned long& pos)
130 { 130 {
131 do 131 do
132 { 132 {
133 parent->getch(ch, sty, pos); 133 parent->getch(ch, sty, pos);
134 } 134 }
135 while (ch == 13); 135 while (ch == 13);
136 } 136 }
137 QString about() { return QString("StripCR filter (c) Tim Wentford\n")+parent->about(); } 137 QString about() { return QString("StripCR filter (c) Tim Wentford\n")+parent->about(); }
138}; 138};
139 139
140class dehyphen : public CFilter 140class dehyphen : public CFilter
141{ 141{
142 bool m_bCharWaiting; 142 bool m_bCharWaiting;
143 tchar m_nextChar; 143 tchar m_nextChar;
144 CStyle m_nextSty; 144 CStyle m_nextSty;
145 public: 145 public:
146 dehyphen() : m_bCharWaiting(false) {} 146 dehyphen() : m_bCharWaiting(false) {}
147 ~dehyphen() {} 147 ~dehyphen() {}
148 void getch(tchar& ch, CStyle& sty, unsigned long& pos) 148 void getch(tchar& ch, CStyle& sty, unsigned long& pos)
149 { 149 {
150 if (m_bCharWaiting) 150 if (m_bCharWaiting)
151 { 151 {
152 m_bCharWaiting = false; 152 m_bCharWaiting = false;
153 ch = m_nextChar; 153 ch = m_nextChar;
154 sty = m_nextSty; 154 sty = m_nextSty;
155 return; 155 return;
156 } 156 }
157 parent->getch(ch, sty, pos); 157 parent->getch(ch, sty, pos);
158 if (ch != '-') return; 158 if (ch != '-') return;
159 parent->getch(m_nextChar, m_nextSty, pos); 159 parent->getch(m_nextChar, m_nextSty, pos);
160 if (m_nextChar != 10) 160 if (m_nextChar != 10)
161 { 161 {
162 m_bCharWaiting = true; 162 m_bCharWaiting = true;
163 ch = '-'; 163 ch = '-';
164 return; 164 return;
165 } 165 }
166 parent->getch(ch, sty, pos); 166 parent->getch(ch, sty, pos);
167 } 167 }
168 QString about() { return QString("Hyphenation filter (c) Tim Wentford\n")+parent->about(); } 168 QString about() { return QString("Hyphenation filter (c) Tim Wentford\n")+parent->about(); }
169}; 169};
170 170
171template<class A, class B>class QMap; 171template<class A, class B>class QMap;
172 172
173const int m_cmaxdepth = 8; 173const int m_cmaxdepth = 8;
174 174
175class htmlmark 175class htmlmark
176{ 176{
177 QString file; 177 QString file;
178 size_t pos; 178 size_t pos;
179 public: 179 public:
180 htmlmark() : file(), pos(0) {} 180 htmlmark() : file(), pos(0) {}
181 htmlmark(const QString& _f, size_t _p) : file(_f), pos(_p) {} 181 htmlmark(const QString& _f, size_t _p) : file(_f), pos(_p) {}
182 QString filename() { return file; } 182 QString filename() { return file; }
183 size_t posn() { return pos; } 183 size_t posn() { return pos; }
184}; 184};
185 185
186class unindent : public CFilter 186class unindent : public CFilter
187{ 187{
188 tchar lc; 188 tchar lc;
189 public: 189 public:
190 unindent() : lc(0) {} 190 unindent() : lc(0) {}
191 ~unindent() {} 191 ~unindent() {}
192 void getch(tchar& ch, CStyle& sty, unsigned long& pos) 192 void getch(tchar& ch, CStyle& sty, unsigned long& pos)
193 { 193 {
194 if (lc == 10) 194 if (lc == 10)
195 { 195 {
196 do 196 do
197 { 197 {
198 parent->getch(ch, sty, pos); 198 parent->getch(ch, sty, pos);
199 } 199 }
200 while (ch == ' '); 200 while (ch == ' ');
201 } 201 }
202 else parent->getch(ch, sty, pos); 202 else parent->getch(ch, sty, pos);
203 lc = ch; 203 lc = ch;
204 return; 204 return;
205 } 205 }
206 QString about() { return QString("Unindent filter (c) Tim Wentford\n")+parent->about(); } 206 QString about() { return QString("Unindent filter (c) Tim Wentford\n")+parent->about(); }
207}; 207};
208 208
209class CRegExpFilt; 209class CRegExpFilt;
210class repara : public CFilter 210class repara : public CFilter
211{ 211{
212 tchar tch; 212 tchar tch;
213 CRegExpFilt* flt; 213 CRegExpFilt* flt;
214 public: 214 public:
215 repara(const QString&); 215 repara(const QString&);
216 ~repara(); 216 ~repara();
217 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 217 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
218 QString about() { return QString("Reparagraph filter (c) Tim Wentford\n")+parent->about(); } 218 QString about() { return QString("Reparagraph filter (c) Tim Wentford\n")+parent->about(); }
219}; 219};
220 220
221class indenter : public CFilter 221class indenter : public CFilter
222{ 222{
223 int amnt; 223 int amnt;
224 int indent; 224 int indent;
225 CStyle lsty; 225 CStyle lsty;
226 public: 226 public:
227 indenter(int _a=5) : amnt(_a), indent(0) {} 227 indenter(int _a=5) : amnt(_a), indent(0) {}
228 ~indenter() {} 228 ~indenter() {}
229 void getch(tchar& ch, CStyle& sty, unsigned long& pos) 229 void getch(tchar& ch, CStyle& sty, unsigned long& pos)
230 { 230 {
231 if (indent > 0) 231 if (indent > 0)
232 { 232 {
233 indent--; 233 indent--;
234 ch = ' '; 234 ch = ' ';
235 sty = lsty; 235 sty = lsty;
236 return; 236 return;
237 } 237 }
238 parent->getch(ch, sty, pos); 238 parent->getch(ch, sty, pos);
239 if (ch == 10) 239 if (ch == 10)
240 { 240 {
241 indent = amnt; 241 indent = amnt;
242 lsty = sty; 242 lsty = sty;
243 } 243 }
244 return; 244 return;
245 } 245 }
246 QString about() { return QString("Indentation filter (c) Tim Wentford\n")+parent->about(); } 246 QString about() { return QString("Indentation filter (c) Tim Wentford\n")+parent->about(); }
247}; 247};
248 248
249class dblspce : public CFilter 249class dblspce : public CFilter
250{ 250{
251 bool lastlf; 251 bool lastlf;
252 CStyle lsty; 252 CStyle lsty;
253 public: 253 public:
254 dblspce() : lastlf(false) {} 254 dblspce() : lastlf(false) {}
255 ~dblspce() {} 255 ~dblspce() {}
256 void getch(tchar& ch, CStyle& sty, unsigned long& pos) 256 void getch(tchar& ch, CStyle& sty, unsigned long& pos)
257 { 257 {
258 if (lastlf) 258 if (lastlf)
259 { 259 {
260 lastlf = false; 260 lastlf = false;
261 ch = 10; 261 ch = 10;
262 sty = lsty; 262 sty = lsty;
263 return; 263 return;
264 } 264 }
265 parent->getch(ch, sty, pos); 265 parent->getch(ch, sty, pos);
266 if (lastlf = (ch == 10)) 266 if (lastlf = (ch == 10))
267 { 267 {
268 lsty = sty; 268 lsty = sty;
269 } 269 }
270 return; 270 return;
271 } 271 }
272 QString about() { return QString("Double space (c) Tim Wentford\n")+parent->about(); } 272 QString about() { return QString("Double space (c) Tim Wentford\n")+parent->about(); }
273}; 273};
274 274
275class textfmt : public CFilter 275class textfmt : public CFilter
276{ 276{
277 CStyle currentstyle; 277 CStyle currentstyle;
278 tchar lastchar; 278 tchar lastchar;
279 bool uselast; 279 bool uselast;
280 void mygetch(tchar&, CStyle&, unsigned long& pos); 280 void mygetch(tchar&, CStyle&, unsigned long& pos);
281 public: 281 public:
282 textfmt() : lastchar(0), uselast(false) {} 282 textfmt() : lastchar(0), uselast(false) {}
283 ~textfmt() {} 283 ~textfmt() {}
284 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 284 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
285 QString about() { return QString("Text formatting filter (c) Tim Wentford\n")+parent->about(); } 285 QString about() { return QString("Text formatting filter (c) Tim Wentford\n")+parent->about(); }
286}; 286};
287 287
288class embolden : public CFilter 288class embolden : public CFilter
289{ 289{
290 public: 290 public:
291 embolden() {} 291 embolden() {}
292 ~embolden() {} 292 ~embolden() {}
293 void getch(tchar& ch, CStyle& sty, unsigned long& pos) 293 void getch(tchar& ch, CStyle& sty, unsigned long& pos)
294 { 294 {
295 parent->getch(ch, sty, pos); 295 parent->getch(ch, sty, pos);
296 sty.setBold(); 296 sty.setBold();
297 } 297 }
298 QString about() { return QString("Emboldening filter (c) Tim Wentford\n")+parent->about(); } 298 QString about() { return QString("Emboldening filter (c) Tim Wentford\n")+parent->about(); }
299}; 299};
300 300
301class remap : public CFilter 301class remap : public CFilter
302{ 302{
303 tchar q[3]; 303 tchar q[3];
304 int offset; 304 int offset;
305 CStyle currentstyle; 305 CStyle currentstyle;
306 public: 306 public:
307 remap() : offset(0) { q[0] = 0; } 307 remap() : offset(0) { q[0] = 0; }
308 ~remap() {} 308 ~remap() {}
309 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 309 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
310 QString about() { return QString("Character remapping filter (c) Tim Wentford\n")+parent->about(); } 310 QString about() { return QString("Character remapping filter (c) Tim Wentford\n")+parent->about(); }
311}; 311};
312 312
313class PeanutFormatter : public CFilter 313class PeanutFormatter : public CFilter
314{ 314{
315 CStyle currentstyle; 315 CStyle currentstyle;
316 public: 316 public:
317 ~PeanutFormatter() {} 317 ~PeanutFormatter() {}
318 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 318 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
319 QString about() { return QString("PML filter (c) Tim Wentford\n")+parent->about(); } 319 QString about() { return QString("PML filter (c) Tim Wentford\n")+parent->about(); }
320}; 320};
321 321
322class OnePara : public CFilter 322class OnePara : public CFilter
323{ 323{
324 tchar m_lastchar; 324 tchar m_lastchar;
325 public: 325 public:
326 OnePara() : m_lastchar(0) {} 326 OnePara() : m_lastchar(0) {}
327 ~OnePara() {} 327 ~OnePara() {}
328 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 328 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
329 QString about() { return QString("Single space filter (c) Tim Wentford\n")+parent->about(); } 329 QString about() { return QString("Single space filter (c) Tim Wentford\n")+parent->about(); }
330}; 330};
331 331
332class DePluck : public CFilter 332class DePluck : public CFilter
333{ 333{
334 tchar* nextpart; 334 tchar* nextpart;
335 tchar m_buffer; 335 tchar m_buffer;
336 int m_buffed; 336 int m_buffed;
337 int m_current; 337 int m_current;
338 bool m_debuff; 338 bool m_debuff;
339 CStyle m_laststyle; 339 CStyle m_laststyle;
340 public: 340 public:
341 DePluck(tchar* t) : nextpart(t), m_buffer(0), m_buffed(0), m_current(0), m_debuff(false) {} 341 DePluck(tchar* t) : nextpart(t), m_buffer(0), m_buffed(0), m_current(0), m_debuff(false) {}
342 ~DePluck() {} 342 ~DePluck() {}
343 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 343 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
344 QString about() { return QString("Depluck filter (c) Tim Wentford\n")+parent->about(); } 344 QString about() { return QString("Depluck filter (c) Tim Wentford\n")+parent->about(); }
345}; 345};
346 346
347class repalm : public CFilter 347class repalm : public CFilter
348{ 348{
349 public: 349 public:
350 ~repalm() {} 350 ~repalm() {}
351 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 351 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
352 QString about() { return QString("Repalm filter (c) Tim Wentford\n")+parent->about(); } 352 QString about() { return QString("Repalm filter (c) Tim Wentford\n")+parent->about(); }
353}; 353};
354 354
355class FullJust : public CFilter 355class FullJust : public CFilter
356{ 356{
357 public: 357 public:
358 void getch(tchar& ch, CStyle& sty, unsigned long& pos) 358 void getch(tchar& ch, CStyle& sty, unsigned long& pos)
359 { 359 {
360 parent->getch(ch, sty, pos); 360 parent->getch(ch, sty, pos);
361 if (sty.getJustify() == m_AlignLeft) sty.setFullJustify(); 361 if (sty.getJustify() == m_AlignLeft) sty.setFullJustify();
362 } 362 }
363 QString about() { return QString("Full justification filter (c) Tim Wentford\n")+parent->about(); } 363 QString about() { return QString("Full justification filter (c) Tim Wentford\n")+parent->about(); }
364}; 364};
365/* 365/*
366class AddSpace : public CFilter 366class AddSpace : public CFilter
367{ 367{
368 unsigned char m_espc; 368 unsigned char m_espc;
369 public: 369 public:
370 AddSpace(unsigned char s) : m_espc(s) {} 370 AddSpace(unsigned char s) : m_espc(s) {}
371 void getch(tchar& ch, CStyle& sty, unsigned long& pos) 371 void getch(tchar& ch, CStyle& sty, unsigned long& pos)
372 { 372 {
373 parent->getch(ch, sty, pos); 373 parent->getch(ch, sty, pos);
374 sty.setExtraSpace(m_espc); 374 sty.setExtraSpace(m_espc);
375 } 375 }
376}; 376};
377*/ 377*/
378 378
379class QTReader; 379class QTReader;
380 380
381class HighlightFilter : public CFilter 381class HighlightFilter : public CFilter
382{ 382{
383 QTReader* pReader; 383 QTReader* pReader;
384 unsigned long lastpos, nextpos; 384 unsigned long lastpos, nextpos;
385 unsigned char red, green, blue; 385 unsigned char red, green, blue;
386 CList<Bkmk>* bkmks; 386 CList<Bkmk>* bkmks;
387 public: 387 public:
388 HighlightFilter(QTReader*); 388 HighlightFilter(QTReader*);
389 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 389 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
390 void refresh(unsigned long); 390 void refresh(unsigned long);
391 QString about() { return QString("High-lighting filter (c) Tim Wentford\n")+parent->about(); } 391 QString about() { return QString("High-lighting filter (c) Tim Wentford\n")+parent->about(); }
392}; 392};
393 393
394#include "static.h"
395#ifndef __STATIC 394#ifndef __STATIC
396#include <dlfcn.h> 395#include <dlfcn.h>
397 396
398class ExternFilter : public CFilter_IFace 397class ExternFilter : public CFilter_IFace
399{ 398{
400 CFilter* filt; 399 CFilter* filt;
401 void *handle; 400 void *handle;
402 public: 401 public:
403 linkType hyperlink(unsigned int n, unsigned int noff, QString& w, QString& nm) 402 linkType hyperlink(unsigned int n, unsigned int noff, QString& w, QString& nm)
404 { 403 {
405 return filt->hyperlink(n, noff, w, nm); 404 return filt->hyperlink(n, noff, w, nm);
406 } 405 }
407 void setparent(CCharacterSource* p) { filt->setparent(p); } 406 void setparent(CCharacterSource* p) { filt->setparent(p); }
408 ExternFilter(const QString& nm, const QString& optional); 407 ExternFilter(const QString& nm, const QString& optional);
409 ~ExternFilter() 408 ~ExternFilter()
410 { 409 {
411 if (filt != NULL) delete filt; 410 if (filt != NULL) delete filt;
412 if (handle != NULL) dlclose(handle); 411 if (handle != NULL) dlclose(handle);
413 } 412 }
414 void locate(unsigned int n) { filt->locate(n); } 413 void locate(unsigned int n) { filt->locate(n); }
415 bool findanchor(const QString& nm) { return filt->findanchor(nm); } 414 bool findanchor(const QString& nm) { return filt->findanchor(nm); }
416 void saveposn(const QString& f, size_t posn) { filt->saveposn(f, posn); } 415 void saveposn(const QString& f, size_t posn) { filt->saveposn(f, posn); }
417 void writeposn(const QString& f, size_t posn) { filt->writeposn(f, posn); } 416 void writeposn(const QString& f, size_t posn) { filt->writeposn(f, posn); }
418 linkType forward(QString& f, size_t& loc) { return filt->forward(f, loc); } 417 linkType forward(QString& f, size_t& loc) { return filt->forward(f, loc); }
419 linkType back(QString& f, size_t& loc) { return filt->back(f, loc); } 418 linkType back(QString& f, size_t& loc) { return filt->back(f, loc); }
420 bool hasnavigation() { return filt->hasnavigation(); } 419 bool hasnavigation() { return filt->hasnavigation(); }
421 int getwidth() { return filt->getwidth(); } 420 int getwidth() { return filt->getwidth(); }
422 CCharacterSource* getparent() { return filt->getparent(); } 421 CCharacterSource* getparent() { return filt->getparent(); }
423 void getch(tchar& c, CStyle& s, unsigned long& l) { filt->getch(c, s, l); } 422 void getch(tchar& c, CStyle& s, unsigned long& l) { filt->getch(c, s, l); }
424 QImage* getPicture(unsigned long tgt) { return filt->getPicture(tgt); } 423 QImage* getPicture(unsigned long tgt) { return filt->getPicture(tgt); }
425 CFilter* filter() { return filt; } 424 CFilter* filter() { return filt; }
426 QImage* getPicture(const QString& href) { return filt->getPicture(href); } 425 QImage* getPicture(const QString& href) { return filt->getPicture(href); }
427 bool getFile(const QString& href) { return filt->getFile(href); } 426 bool getFile(const QString& href) { return filt->getFile(href); }
428 QString about() { return QString("Filter plug-in (c) Tim Wentford\n")+filt->about(); } 427 QString about() { return QString("Filter plug-in (c) Tim Wentford\n")+filt->about(); }
429}; 428};
430#endif 429#endif
431 430
432class kern : public CFilter 431class kern : public CFilter
433{ 432{
434 tchar lastchar; 433 tchar lastchar;
435 bool uselast; 434 bool uselast;
436 CStyle laststy; 435 CStyle laststy;
437 public: 436 public:
438 kern() : lastchar(0), uselast(false) {} 437 kern() : lastchar(0), uselast(false) {}
439 ~kern() {} 438 ~kern() {}
440 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 439 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
441 QString about() { return QString("Kerning filter (c) Tim Wentford\n")+parent->about(); } 440 QString about() { return QString("Kerning filter (c) Tim Wentford\n")+parent->about(); }
442}; 441};
443 442
444class makeInverse : public CFilter 443class makeInverse : public CFilter
445{ 444{
446 public: 445 public:
447 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 446 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
448 QString about() { return QString("Colourmap inversion filter (c) Tim Wentford\n")+parent->about(); } 447 QString about() { return QString("Colourmap inversion filter (c) Tim Wentford\n")+parent->about(); }
449}; 448};
450/* 449/*
451class makeNegative : public CFilter 450class makeNegative : public CFilter
452{ 451{
453 public: 452 public:
454 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 453 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
455}; 454};
456*/ 455*/
457class setbg : public CFilter 456class setbg : public CFilter
458{ 457{
459 int m_r, m_g, m_b; 458 int m_r, m_g, m_b;
460 public: 459 public:
461 setbg(int _r, int _g, int _b) : m_r(_r), m_g(_g), m_b(_b) {} 460 setbg(int _r, int _g, int _b) : m_r(_r), m_g(_g), m_b(_b) {}
462 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 461 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
463 QString about() { return QString("Background colour filter (c) Tim Wentford\n")+parent->about(); } 462 QString about() { return QString("Background colour filter (c) Tim Wentford\n")+parent->about(); }
464}; 463};
465 464
466class setfg : public CFilter 465class setfg : public CFilter
467{ 466{
468 int m_r, m_g, m_b; 467 int m_r, m_g, m_b;
469 public: 468 public:
470 setfg(int _r, int _g, int _b) : m_r(_r), m_g(_g), m_b(_b) {} 469 setfg(int _r, int _g, int _b) : m_r(_r), m_g(_g), m_b(_b) {}
471 void getch(tchar& ch, CStyle& sty, unsigned long& pos); 470 void getch(tchar& ch, CStyle& sty, unsigned long& pos);
472 QString about() { return QString("Foreground colour filter (c) Tim Wentford\n")+parent->about(); } 471 QString about() { return QString("Foreground colour filter (c) Tim Wentford\n")+parent->about(); }
473}; 472};
474 473
475#endif 474#endif
diff --git a/noncore/apps/opie-reader/CHM.cpp b/noncore/apps/opie-reader/CHM.cpp
index 9d1eb87..88d53bf 100644
--- a/noncore/apps/opie-reader/CHM.cpp
+++ b/noncore/apps/opie-reader/CHM.cpp
@@ -1,380 +1,379 @@
1#include "CHM.h" 1#include "CHM.h"
2#include "chm_lib.h" 2#include "chm_lib.h"
3#include "static.h"
4#include <qstring.h> 3#include <qstring.h>
5#include <qstringlist.h> 4#include <qstringlist.h>
6#include <stdio.h> 5#include <stdio.h>
7#include <qimage.h> 6#include <qimage.h>
8#include <qpixmap.h> 7#include <qpixmap.h>
9 8
10#ifndef __STATIC 9#ifndef __STATIC
11extern "C" 10extern "C"
12{ 11{
13 CExpander* newcodec() { return new CHM; } 12 CExpander* newcodec() { return new CHM; }
14} 13}
15#endif 14#endif
16 15
17static int _print_ui_index(struct chmFile *h, struct chmUnitInfo *ui, 16static int _print_ui_index(struct chmFile *h, struct chmUnitInfo *ui,
18 void *context) 17 void *context)
19{ 18{
20 CHM *chm = (CHM *)context; 19 CHM *chm = (CHM *)context;
21 QString temp = "<tr>"; 20 QString temp = "<tr>";
22 char buff[1024]; 21 char buff[1024];
23 sprintf( buff,"<td align=right>%8d\n</td><td><a href=\"%s\">%s</a></td></tr>",(int)ui->length, ui->path, ui->path); 22 sprintf( buff,"<td align=right>%8d\n</td><td><a href=\"%s\">%s</a></td></tr>",(int)ui->length, ui->path, ui->path);
24 temp += buff; 23 temp += buff;
25 chm->addContent(temp); 24 chm->addContent(temp);
26 return CHM_ENUMERATOR_CONTINUE; 25 return CHM_ENUMERATOR_CONTINUE;
27} 26}
28 27
29static int _get_hhc (struct chmFile *h, struct chmUnitInfo *ui, 28static int _get_hhc (struct chmFile *h, struct chmUnitInfo *ui,
30 void *context) 29 void *context)
31{ 30{
32 CHM *chm = (CHM *)context; 31 CHM *chm = (CHM *)context;
33 QString PathName = ui->path; 32 QString PathName = ui->path;
34 if (PathName.find(".hhc") > -1) { 33 if (PathName.find(".hhc") > -1) {
35 chm->setPath(PathName); 34 chm->setPath(PathName);
36 } 35 }
37 return CHM_ENUMERATOR_CONTINUE; 36 return CHM_ENUMERATOR_CONTINUE;
38} 37}
39 38
40CHM::CHM() { 39CHM::CHM() {
41 chmFile = NULL; 40 chmFile = NULL;
42 chmPath = ""; 41 chmPath = "";
43 chmHHCPath = ""; 42 chmHHCPath = "";
44 chmBuffer = ""; 43 chmBuffer = "";
45 bufpos = 0; 44 bufpos = 0;
46} 45}
47 46
48CHM::~CHM() { 47CHM::~CHM() {
49 if (chmFile != NULL) 48 if (chmFile != NULL)
50 chm_close(chmFile); 49 chm_close(chmFile);
51} 50}
52 51
53void CHM::suspend() { 52void CHM::suspend() {
54#ifdef USEQPE 53#ifdef USEQPE
55 bSuspended = true; 54 bSuspended = true;
56 //suspos = gztell(file); 55 //suspos = gztell(file);
57 chm_close(chmFile); 56 chm_close(chmFile);
58 chmFile = NULL; 57 chmFile = NULL;
59 sustime = time(NULL); 58 sustime = time(NULL);
60#endif 59#endif
61} 60}
62 61
63void CHM::unsuspend() { 62void CHM::unsuspend() {
64#ifdef USEQPE 63#ifdef USEQPE
65 if (bSuspended) 64 if (bSuspended)
66 { 65 {
67 bSuspended = false; 66 bSuspended = false;
68 int delay = time(NULL) - sustime; 67 int delay = time(NULL) - sustime;
69 if (delay < 10) 68 if (delay < 10)
70 sleep(10-delay); 69 sleep(10-delay);
71 chmFile = chm_open(fname); 70 chmFile = chm_open(fname);
72 for (int i = 0; chmFile == NULL && i < 5; i++) { 71 for (int i = 0; chmFile == NULL && i < 5; i++) {
73 sleep(5); 72 sleep(5);
74 chmFile = chm_open(fname); 73 chmFile = chm_open(fname);
75 } 74 }
76 if (chmFile == NULL) { 75 if (chmFile == NULL) {
77 QMessageBox::warning(NULL, PROGNAME, "Couldn't reopen file"); 76 QMessageBox::warning(NULL, PROGNAME, "Couldn't reopen file");
78 exit(0); 77 exit(0);
79 } 78 }
80 //suspos = gzseek(file, suspos, SEEK_SET); 79 //suspos = gzseek(file, suspos, SEEK_SET);
81 } 80 }
82#endif 81#endif
83} 82}
84 83
85void CHM::addContent(QString content) { 84void CHM::addContent(QString content) {
86 chmBuffer += content; 85 chmBuffer += content;
87} 86}
88 87
89void CHM::FillHomeContent() { 88void CHM::FillHomeContent() {
90 if (chmHHCPath != "") { 89 if (chmHHCPath != "") {
91 const char *ext; 90 const char *ext;
92 char buffer[65536]; 91 char buffer[65536];
93 unsigned int swath, offset; 92 unsigned int swath, offset;
94 QString tmp=""; 93 QString tmp="";
95 QString HTML=""; 94 QString HTML="";
96 /* try to find the file */ 95 /* try to find the file */
97 const char *filename = (const char *)chmHHCPath; 96 const char *filename = (const char *)chmHHCPath;
98 if (chm_resolve_object(chmFile, filename, &m_ui) != CHM_RESOLVE_SUCCESS) 97 if (chm_resolve_object(chmFile, filename, &m_ui) != CHM_RESOLVE_SUCCESS)
99 { 98 {
100 chmBuffer = "HELP"; 99 chmBuffer = "HELP";
101 fsize = chmBuffer.length(); 100 fsize = chmBuffer.length();
102 return; 101 return;
103 } 102 }
104 m_homestart = m_ui.start; 103 m_homestart = m_ui.start;
105 m_homeend = m_homestart + m_ui.length; 104 m_homeend = m_homestart + m_ui.length;
106 swath = 65536; 105 swath = 65536;
107 offset = 0; 106 offset = 0;
108 fsize = m_ui.length; 107 fsize = m_ui.length;
109 while (offset < m_ui.length) 108 while (offset < m_ui.length)
110 { 109 {
111 if ((m_ui.length - offset) < 65536) 110 if ((m_ui.length - offset) < 65536)
112 swath = m_ui.length - offset; 111 swath = m_ui.length - offset;
113 else 112 else
114 swath = 65536; 113 swath = 65536;
115 swath = (int)chm_retrieve_object(chmFile, &m_ui, (unsigned char *) buffer, offset, swath); 114 swath = (int)chm_retrieve_object(chmFile, &m_ui, (unsigned char *) buffer, offset, swath);
116 tmp += buffer; 115 tmp += buffer;
117 offset += swath; 116 offset += swath;
118 } 117 }
119 HTML +="<!DOCTYPE HTML PUBLIC \"-//IETF//DTD HTML//EN>\r\n"; 118 HTML +="<!DOCTYPE HTML PUBLIC \"-//IETF//DTD HTML//EN>\r\n";
120 HTML +="<HTML>\r\n"; 119 HTML +="<HTML>\r\n";
121 HTML +="<BODY>\r\n"; 120 HTML +="<BODY>\r\n";
122 HTML +="<h2>Home Page</h2>\r\n"; 121 HTML +="<h2>Home Page</h2>\r\n";
123 HTML +="<h3>\r\n"; 122 HTML +="<h3>\r\n";
124 QStringList qsl = QStringList::split("\r\n",tmp); 123 QStringList qsl = QStringList::split("\r\n",tmp);
125 QString NameFind ="<param name=\"Name\" value=\""; 124 QString NameFind ="<param name=\"Name\" value=\"";
126 QString LocalFind = "<param name=\"Local\" value=\""; 125 QString LocalFind = "<param name=\"Local\" value=\"";
127 QString ULOpenFind = "<UL>"; 126 QString ULOpenFind = "<UL>";
128 QString LIOpenFind = "<LI>"; 127 QString LIOpenFind = "<LI>";
129 QString ULCloseFind = "</UL>"; 128 QString ULCloseFind = "</UL>";
130 QString Name = ""; 129 QString Name = "";
131 QString Local = ""; 130 QString Local = "";
132 for ( QStringList::Iterator it = qsl.begin(); it != qsl.end(); ++it ) { 131 for ( QStringList::Iterator it = qsl.begin(); it != qsl.end(); ++it ) {
133 QString Line = (*it); 132 QString Line = (*it);
134 int NamePos = Line.find( NameFind); 133 int NamePos = Line.find( NameFind);
135 int LocalPos = Line.find( LocalFind); 134 int LocalPos = Line.find( LocalFind);
136 if (NamePos > -1) { 135 if (NamePos > -1) {
137 Name = Line.mid(NamePos+NameFind.length(),Line.length()); 136 Name = Line.mid(NamePos+NameFind.length(),Line.length());
138 Name = Name.left(Name.length() - 2); 137 Name = Name.left(Name.length() - 2);
139 } 138 }
140 if (LocalPos > -1) { 139 if (LocalPos > -1) {
141 Local = Line.mid(LocalPos+LocalFind.length(),Line.length()); 140 Local = Line.mid(LocalPos+LocalFind.length(),Line.length());
142 Local = Local.left(Local.length() - 2); 141 Local = Local.left(Local.length() - 2);
143 if (Name != "") { 142 if (Name != "") {
144 HTML += "<br>\r\n<a href="; 143 HTML += "<br>\r\n<a href=";
145 HTML += Local; 144 HTML += Local;
146 HTML += ">"; 145 HTML += ">";
147 HTML += Name; 146 HTML += Name;
148 HTML += "</a>\r\n"; 147 HTML += "</a>\r\n";
149 Name = ""; 148 Name = "";
150 } 149 }
151 } 150 }
152 } 151 }
153 HTML +="</h3>"; 152 HTML +="</h3>";
154 HTML +="</BODY>\r\n"; 153 HTML +="</BODY>\r\n";
155 HTML +="</HTML>\r\n"; 154 HTML +="</HTML>\r\n";
156 chmHomeBuffer = HTML; 155 chmHomeBuffer = HTML;
157 chmBuffer = HTML; 156 chmBuffer = HTML;
158 fsize = chmBuffer.length(); 157 fsize = chmBuffer.length();
159 m_currentstart = m_ui.start; 158 m_currentstart = m_ui.start;
160 m_currentend = m_currentstart+chmBuffer.length(); 159 m_currentend = m_currentstart+chmBuffer.length();
161 } 160 }
162} 161}
163 162
164bool CHM::FillBuffer() 163bool CHM::FillBuffer()
165{ 164{
166 bool bRetVal = false; 165 bool bRetVal = false;
167 char buffer[65536]; 166 char buffer[65536];
168 int swath, offset; 167 int swath, offset;
169 chmBuffer = ""; 168 chmBuffer = "";
170 swath = 65536; 169 swath = 65536;
171 offset = 0; 170 offset = 0;
172 fsize = m_ui.length; 171 fsize = m_ui.length;
173 while (offset < m_ui.length) 172 while (offset < m_ui.length)
174 { 173 {
175 if ((m_ui.length - offset) < 65536) 174 if ((m_ui.length - offset) < 65536)
176 swath = m_ui.length - offset; 175 swath = m_ui.length - offset;
177 else 176 else
178 swath = 65536; 177 swath = 65536;
179 swath = (int)chm_retrieve_object(chmFile, &m_ui, (unsigned char *) buffer, offset, swath); 178 swath = (int)chm_retrieve_object(chmFile, &m_ui, (unsigned char *) buffer, offset, swath);
180 chmBuffer += buffer; 179 chmBuffer += buffer;
181 offset += swath; 180 offset += swath;
182 } 181 }
183 //There seems to be a ton of gobbledygook at the end that is reminiscent of the hhc file - remove it 182 //There seems to be a ton of gobbledygook at the end that is reminiscent of the hhc file - remove it
184 QString temp = chmBuffer.lower(); 183 QString temp = chmBuffer.lower();
185 int lpos = temp.find("</html"); 184 int lpos = temp.find("</html");
186 if (lpos > -1) { 185 if (lpos > -1) {
187 chmBuffer.truncate(lpos); 186 chmBuffer.truncate(lpos);
188 chmBuffer = chmBuffer+"</HTML>"; 187 chmBuffer = chmBuffer+"</HTML>";
189 } 188 }
190 fsize = chmBuffer.length(); 189 fsize = chmBuffer.length();
191 190
192 bufpos = 0; 191 bufpos = 0;
193 bRetVal = true; 192 bRetVal = true;
194 m_currentstart = m_ui.start; 193 m_currentstart = m_ui.start;
195 m_currentend = m_currentstart+chmBuffer.length(); 194 m_currentend = m_currentstart+chmBuffer.length();
196 return bRetVal; 195 return bRetVal;
197} 196}
198 197
199bool CHM::FillContent() { 198bool CHM::FillContent() {
200 bool bRetVal = false; 199 bool bRetVal = false;
201 if (chmPath != "") { 200 if (chmPath != "") {
202 /* try to find the file */ 201 /* try to find the file */
203 const char *filename = (const char *)chmPath; 202 const char *filename = (const char *)chmPath;
204 if (chm_resolve_object(chmFile, filename, &m_ui) != CHM_RESOLVE_SUCCESS) 203 if (chm_resolve_object(chmFile, filename, &m_ui) != CHM_RESOLVE_SUCCESS)
205 { 204 {
206 fsize = chmBuffer.length(); 205 fsize = chmBuffer.length();
207 return bRetVal; 206 return bRetVal;
208 } 207 }
209 208
210 char buffer[65536]; 209 char buffer[65536];
211 int swath, offset; 210 int swath, offset;
212 chmBuffer = ""; 211 chmBuffer = "";
213 swath = 65536; 212 swath = 65536;
214 offset = 0; 213 offset = 0;
215 fsize = m_ui.length; 214 fsize = m_ui.length;
216 while (offset < m_ui.length) 215 while (offset < m_ui.length)
217 { 216 {
218 if ((m_ui.length - offset) < 65536) 217 if ((m_ui.length - offset) < 65536)
219 swath = m_ui.length - offset; 218 swath = m_ui.length - offset;
220 else 219 else
221 swath = 65536; 220 swath = 65536;
222 swath = (int)chm_retrieve_object(chmFile, &m_ui, (unsigned char *) buffer, offset, swath); 221 swath = (int)chm_retrieve_object(chmFile, &m_ui, (unsigned char *) buffer, offset, swath);
223 chmBuffer += buffer; 222 chmBuffer += buffer;
224 offset += swath; 223 offset += swath;
225 } 224 }
226 //There seems to be a ton of gobbledygook at the end that is reminiscent of the hhc file - remove it 225 //There seems to be a ton of gobbledygook at the end that is reminiscent of the hhc file - remove it
227 QString temp = chmBuffer.lower(); 226 QString temp = chmBuffer.lower();
228 int lpos = temp.find("</html"); 227 int lpos = temp.find("</html");
229 if (lpos > -1) { 228 if (lpos > -1) {
230 chmBuffer.truncate(lpos); 229 chmBuffer.truncate(lpos);
231 chmBuffer = chmBuffer+"</HTML>"; 230 chmBuffer = chmBuffer+"</HTML>";
232 } 231 }
233 fsize = chmBuffer.length(); 232 fsize = chmBuffer.length();
234 233
235 bufpos = 0; 234 bufpos = 0;
236 m_currentstart = m_ui.start; 235 m_currentstart = m_ui.start;
237 m_currentend = m_currentstart+chmBuffer.length(); 236 m_currentend = m_currentstart+chmBuffer.length();
238 bRetVal = true; 237 bRetVal = true;
239 } 238 }
240 return bRetVal; 239 return bRetVal;
241} 240}
242 241
243bool CHM::getFile(const QString& href) { 242bool CHM::getFile(const QString& href) {
244 qDebug("Got:%s", (const char*)href); 243 qDebug("Got:%s", (const char*)href);
245 bool bRetVal = false; 244 bool bRetVal = false;
246 QString temp = chmPath; 245 QString temp = chmPath;
247 chmPath = href; 246 chmPath = href;
248 if (FillContent()) { 247 if (FillContent()) {
249 qDebug("Got it"); 248 qDebug("Got it");
250 bRetVal = true; 249 bRetVal = true;
251 } else { 250 } else {
252 qDebug("Missed"); 251 qDebug("Missed");
253 chmPath = temp; 252 chmPath = temp;
254 FillContent(); 253 FillContent();
255 } 254 }
256 return bRetVal; 255 return bRetVal;
257} 256}
258 257
259QImage *CHM::getPicture(const QString& href) { 258QImage *CHM::getPicture(const QString& href) {
260 QImage *img = NULL; 259 QImage *img = NULL;
261 QString PicRef = "/"+href; 260 QString PicRef = "/"+href;
262 struct chmUnitInfo ui; 261 struct chmUnitInfo ui;
263 const char *ext; 262 const char *ext;
264 /* try to find the file */ 263 /* try to find the file */
265 const char *filename = (const char *)PicRef; 264 const char *filename = (const char *)PicRef;
266 if (chm_resolve_object(chmFile, filename, &ui) != CHM_RESOLVE_SUCCESS) 265 if (chm_resolve_object(chmFile, filename, &ui) != CHM_RESOLVE_SUCCESS)
267 { 266 {
268 qDebug ("Could not resolve image"); 267 qDebug ("Could not resolve image");
269 return img; 268 return img;
270 } 269 }
271 if (ui.length > 0) { 270 if (ui.length > 0) {
272 char *temp = new char[ui.length]; 271 char *temp = new char[ui.length];
273 char buffer[65536]; 272 char buffer[65536];
274 int swath, offset; 273 int swath, offset;
275 swath = 65536; 274 swath = 65536;
276 offset = 0; 275 offset = 0;
277 276
278 while (offset < ui.length) 277 while (offset < ui.length)
279 { 278 {
280 if ((ui.length - offset) < 65536) 279 if ((ui.length - offset) < 65536)
281 swath = ui.length - offset; 280 swath = ui.length - offset;
282 else 281 else
283 swath = 65536; 282 swath = 65536;
284 swath = (int)chm_retrieve_object(chmFile, &ui, (unsigned char *) buffer, offset, swath); 283 swath = (int)chm_retrieve_object(chmFile, &ui, (unsigned char *) buffer, offset, swath);
285 memcpy( (void *) (temp + offset), (void *)&buffer, swath ); 284 memcpy( (void *) (temp + offset), (void *)&buffer, swath );
286 offset += swath; 285 offset += swath;
287 } 286 }
288 QByteArray qba; 287 QByteArray qba;
289 qba.setRawData( (const char *)temp, ui.length); 288 qba.setRawData( (const char *)temp, ui.length);
290 QPixmap qpm(qba); 289 QPixmap qpm(qba);
291 img = new QImage(qpm.convertToImage()); 290 img = new QImage(qpm.convertToImage());
292 qba.resetRawData((const char *)temp, ui.length); 291 qba.resetRawData((const char *)temp, ui.length);
293 delete[] temp; 292 delete[] temp;
294 } 293 }
295 294
296 return img; 295 return img;
297} 296}
298 297
299int CHM::OpenFile(const char *src) { 298int CHM::OpenFile(const char *src) {
300 if (chmFile != NULL) chm_close(chmFile); 299 if (chmFile != NULL) chm_close(chmFile);
301 struct stat _stat; 300 struct stat _stat;
302 stat(src,&_stat); 301 stat(src,&_stat);
303 fsize = _stat.st_size; 302 fsize = _stat.st_size;
304 chmFile = chm_open(src); 303 chmFile = chm_open(src);
305 if (chmFile != NULL) { 304 if (chmFile != NULL) {
306 chm_enumerate(chmFile, 305 chm_enumerate(chmFile,
307 CHM_ENUMERATE_ALL, 306 CHM_ENUMERATE_ALL,
308 _get_hhc, 307 _get_hhc,
309 (void *)this); 308 (void *)this);
310 if ( chmPath != "") { 309 if ( chmPath != "") {
311 setHomePath(chmPath); 310 setHomePath(chmPath);
312 FillHomeContent(); 311 FillHomeContent();
313 } 312 }
314 } 313 }
315 m_homepos = locate(); 314 m_homepos = locate();
316 qDebug("Home:%u", m_homepos); 315 qDebug("Home:%u", m_homepos);
317 return (chmFile==NULL); 316 return (chmFile==NULL);
318} 317}
319 318
320int CHM::getch() { 319int CHM::getch() {
321 if ( (bufpos+1) >= chmBuffer.length() ) 320 if ( (bufpos+1) >= chmBuffer.length() )
322 return EOF; 321 return EOF;
323#ifdef _WINDOWS 322#ifdef _WINDOWS
324 QChar letter = chmBuffer.at(bufpos++); 323 QChar letter = chmBuffer.at(bufpos++);
325#else 324#else
326 QChar letter = chmBuffer[bufpos++]; 325 QChar letter = chmBuffer[bufpos++];
327#endif 326#endif
328 return (int)(char)letter; 327 return (int)(char)letter;
329} 328}
330 329
331void CHM::getch(tchar& ch, CStyle& sty) 330void CHM::getch(tchar& ch, CStyle& sty)
332{ 331{
333 int ich = getch(); 332 int ich = getch();
334 ch = (ich == EOF) ? UEOF : ich; 333 ch = (ich == EOF) ? UEOF : ich;
335} 334}
336 335
337void CHM::start2endSection() 336void CHM::start2endSection()
338{ 337{
339 m_currentstart = m_ui.start; 338 m_currentstart = m_ui.start;
340 m_currentend = m_currentstart+chmBuffer.length(); 339 m_currentend = m_currentstart+chmBuffer.length();
341} 340}
342 341
343unsigned int CHM::locate() { 342unsigned int CHM::locate() {
344 return m_currentstart+bufpos; 343 return m_currentstart+bufpos;
345} 344}
346 345
347void CHM::locate(unsigned int n) { 346void CHM::locate(unsigned int n) {
348 if (n == 0) n = m_homepos; 347 if (n == 0) n = m_homepos;
349 if (n >= m_homestart && n < m_homeend) 348 if (n >= m_homestart && n < m_homeend)
350 { 349 {
351 FillHomeContent(); 350 FillHomeContent();
352 bufpos = n - m_homestart; 351 bufpos = n - m_homestart;
353 start2endSection(); 352 start2endSection();
354 qDebug("Home:%u:<%u, %u, %u>", m_ui.start, m_currentstart, n, m_currentend); 353 qDebug("Home:%u:<%u, %u, %u>", m_ui.start, m_currentstart, n, m_currentend);
355 } 354 }
356 else if (n >= m_currentstart && n < m_currentend) 355 else if (n >= m_currentstart && n < m_currentend)
357 { 356 {
358 bufpos = n - m_currentstart; 357 bufpos = n - m_currentstart;
359 } 358 }
360 else if (CHM_RESOLVE_FAILURE == chm_resolve_location(chmFile, n/4, &m_ui)) 359 else if (CHM_RESOLVE_FAILURE == chm_resolve_location(chmFile, n/4, &m_ui))
361 { 360 {
362 qDebug("Resolve failure"); 361 qDebug("Resolve failure");
363 FillHomeContent(); 362 FillHomeContent();
364 bufpos = 0; 363 bufpos = 0;
365 start2endSection(); 364 start2endSection();
366 qDebug("Home:%u:<%u, %u, %u>", m_ui.start, m_currentstart, n, m_currentend); 365 qDebug("Home:%u:<%u, %u, %u>", m_ui.start, m_currentstart, n, m_currentend);
367 } 366 }
368 else 367 else
369 { 368 {
370 qDebug("Resolve success"); 369 qDebug("Resolve success");
371 FillBuffer(); 370 FillBuffer();
372 start2endSection(); 371 start2endSection();
373 bufpos=n-m_currentstart; 372 bufpos=n-m_currentstart;
374 qDebug("Not Home:%u:<%u, %u, %u>", m_ui.start, m_currentstart, n, m_currentend); 373 qDebug("Not Home:%u:<%u, %u, %u>", m_ui.start, m_currentstart, n, m_currentend);
375 } 374 }
376} 375}
377 376
378void CHM::sizes(unsigned long& _file, unsigned long& _text) { 377void CHM::sizes(unsigned long& _file, unsigned long& _text) {
379 _text = _file = fsize; 378 _text = _file = fsize;
380} 379}
diff --git a/noncore/apps/opie-reader/CHM.h b/noncore/apps/opie-reader/CHM.h
index 7dac46f..001f7fc 100644
--- a/noncore/apps/opie-reader/CHM.h
+++ b/noncore/apps/opie-reader/CHM.h
@@ -1,68 +1,67 @@
1#ifndef __CHM_h 1#ifndef __CHM_h
2#define __CHM_h 2#define __CHM_h
3#include <stdio.h> 3#include <stdio.h>
4#include <sys/stat.h> 4#include <sys/stat.h>
5#include "useqpe.h"
6#include "CExpander.h" 5#include "CExpander.h"
7#include "chm_lib.h" 6#include "chm_lib.h"
8#include "my_list.h" 7#include "my_list.h"
9#include "CExpander.h" 8#include "CExpander.h"
10 9
11struct Ref { 10struct Ref {
12 QString RefName; 11 QString RefName;
13 QString RefLoc; 12 QString RefLoc;
14 int beginpos; 13 int beginpos;
15 int endpos; 14 int endpos;
16}; 15};
17 16
18struct Pic { 17struct Pic {
19 QString RefName; 18 QString RefName;
20 QString RefLoc; 19 QString RefLoc;
21 int beginpos; 20 int beginpos;
22 int endpos; 21 int endpos;
23}; 22};
24 23
25class CHM : public CExpander 24class CHM : public CExpander
26{ 25{
27 void start2endSection(); 26 void start2endSection();
28 struct chmUnitInfo m_ui; 27 struct chmUnitInfo m_ui;
29 struct chmFile *chmFile; 28 struct chmFile *chmFile;
30 chmUnitInfo chmui; 29 chmUnitInfo chmui;
31 //alloc a meg to buffer 30 //alloc a meg to buffer
32 QString chmHomeBuffer; 31 QString chmHomeBuffer;
33 QString chmBuffer; 32 QString chmBuffer;
34 QString chmPath; 33 QString chmPath;
35 QString chmHHCPath; 34 QString chmHHCPath;
36 unsigned int bufpos; 35 unsigned int bufpos;
37 unsigned long fsize; 36 unsigned long fsize;
38 unsigned long m_homestart, m_homeend; 37 unsigned long m_homestart, m_homeend;
39public: 38public:
40 void suspend(); 39 void suspend();
41 void unsuspend(); 40 void unsuspend();
42 bool hasnavigation() { return true; } 41 bool hasnavigation() { return true; }
43 42
44 CHM(); 43 CHM();
45 virtual ~CHM(); 44 virtual ~CHM();
46 int OpenFile(const char *src); 45 int OpenFile(const char *src);
47 int getch(); 46 int getch();
48 unsigned int locate(); 47 unsigned int locate();
49 void locate(unsigned int n); 48 void locate(unsigned int n);
50 bool hasrandomaccess() { return true; } 49 bool hasrandomaccess() { return true; }
51 void sizes(unsigned long& _file, unsigned long& _text); 50 void sizes(unsigned long& _file, unsigned long& _text);
52 void addContent(QString content); 51 void addContent(QString content);
53 void getch(tchar& ch, CStyle& sty); 52 void getch(tchar& ch, CStyle& sty);
54 void setPath(QString PathName) {chmPath = PathName;}; 53 void setPath(QString PathName) {chmPath = PathName;};
55 void setHomePath(QString PathName) {chmHHCPath = PathName;}; 54 void setHomePath(QString PathName) {chmHHCPath = PathName;};
56 55
57 MarkupType PreferredMarkup() { 56 MarkupType PreferredMarkup() {
58 return cCHM; 57 return cCHM;
59 } 58 }
60 bool getFile(const QString& href); 59 bool getFile(const QString& href);
61 QImage *getPicture(const QString& href); 60 QImage *getPicture(const QString& href);
62 QString about() { return QString("CHM codec (c) Bob Griffin\nchm_lib (c) Jed Wing\nLZX code (c) Stuart Cale"); } 61 QString about() { return QString("CHM codec (c) Bob Griffin\nchm_lib (c) Jed Wing\nLZX code (c) Stuart Cale"); }
63private : 62private :
64 bool FillBuffer(); 63 bool FillBuffer();
65 bool FillContent(); 64 bool FillContent();
66 void FillHomeContent(); 65 void FillHomeContent();
67}; 66};
68#endif 67#endif
diff --git a/noncore/apps/opie-reader/CHM/CHM.pro b/noncore/apps/opie-reader/CHM/CHM.pro
index 6ed86f6..d3a2a28 100644
--- a/noncore/apps/opie-reader/CHM/CHM.pro
+++ b/noncore/apps/opie-reader/CHM/CHM.pro
@@ -1,18 +1,18 @@
1DEFINES += OPIE USEQPE 1DEFINES += OPIE USEQPE
2VPATH = .. 2VPATH = ..
3 TEMPLATE= lib 3 TEMPLATE= lib
4 CONFIG = qt warn_on release dll 4 CONFIG = qt warn_on release dll
5 HEADERS = CHM.h chm_lib.h lzx.h 5 HEADERS = CHM.h chm_lib.h lzx.h
6 6
7 SOURCES = CHM.cpp chm_lib.c lzx.c 7 SOURCES = CHM.cpp chm_lib.c lzx.c
8 8
9 9
10 INTERFACES= 10 INTERFACES=
11 DESTDIR = $(OPIEDIR)/plugins/reader/codecs 11 DESTDIR = $(OPIEDIR)/plugins/reader/codecs
12 TARGET = CHM 12 TARGET = CHM
13LIBS += -lreader_codec 13LIBS += -lreader_codec
14 14
15 INCLUDEPATH+= ../OREADERINC $(OPIEDIR)/include 15 INCLUDEPATH+= $(OPIEDIR)/include
16 DEPENDPATH+= ../OREADERINC $(OPIEDIR)/include 16 DEPENDPATH+= $(OPIEDIR)/include
17 17
18include ( $(OPIEDIR)/include.pro ) \ No newline at end of file 18include ( $(OPIEDIR)/include.pro ) \ No newline at end of file
diff --git a/noncore/apps/opie-reader/CloseDialog.h b/noncore/apps/opie-reader/CloseDialog.h
index 62e6423..54aaf1c 100644
--- a/noncore/apps/opie-reader/CloseDialog.h
+++ b/noncore/apps/opie-reader/CloseDialog.h
@@ -1,62 +1,61 @@
1/**************************************************************************** 1/****************************************************************************
2** Form interface generated from reading ui file 'Prefs.ui' 2** Form interface generated from reading ui file 'Prefs.ui'
3** 3**
4** Created: Tue Feb 11 23:53:32 2003 4** Created: Tue Feb 11 23:53:32 2003
5** by: The User Interface Compiler (uic) 5** by: The User Interface Compiler (uic)
6** 6**
7** WARNING! All changes made in this file will be lost! 7** WARNING! All changes made in this file will be lost!
8****************************************************************************/ 8****************************************************************************/
9#ifndef __CLOSEDIALOG_H 9#ifndef __CLOSEDIALOG_H
10#define __CLOSEDIALOG_H 10#define __CLOSEDIALOG_H
11 11
12#include "useqpe.h"
13#include <qvariant.h> 12#include <qvariant.h>
14#include <qwidget.h> 13#include <qwidget.h>
15#include <qtabdialog.h> 14#include <qtabdialog.h>
16#include <qtabwidget.h> 15#include <qtabwidget.h>
17#include <qspinbox.h> 16#include <qspinbox.h>
18#include <qcheckbox.h> 17#include <qcheckbox.h>
19#include <qcombobox.h> 18#include <qcombobox.h>
20#include <qlineedit.h> 19#include <qlineedit.h>
21//#include <qpe/menubutton.h> 20//#include <qpe/menubutton.h>
22#include <qvbuttongroup.h> 21#include <qvbuttongroup.h>
23 22
24class QVBoxLayout; 23class QVBoxLayout;
25class QHBoxLayout; 24class QHBoxLayout;
26class QGridLayout; 25class QGridLayout;
27//class QCheckBox; 26//class QCheckBox;
28class QLabel; 27class QLabel;
29//class QSpinBox; 28//class QSpinBox;
30 29
31class CCloseDialog : public QDialog 30class CCloseDialog : public QDialog
32{ 31{
33Q_OBJECT 32Q_OBJECT
34 QCheckBox *file, *marks, *config; 33 QCheckBox *file, *marks, *config;
35#ifndef USEQPE 34#ifndef USEQPE
36 void keyPressEvent(QKeyEvent* e) 35 void keyPressEvent(QKeyEvent* e)
37 { 36 {
38 switch (e->key()) 37 switch (e->key())
39 { 38 {
40 case Key_Escape: 39 case Key_Escape:
41 e->accept(); 40 e->accept();
42 reject(); 41 reject();
43 break; 42 break;
44 case Key_Space: 43 case Key_Space:
45 case Key_Return: 44 case Key_Return:
46 e->accept(); 45 e->accept();
47 accept(); 46 accept();
48 break; 47 break;
49 default: 48 default:
50 QWidget::keyPressEvent(e); 49 QWidget::keyPressEvent(e);
51 } 50 }
52 } 51 }
53#endif 52#endif
54 public: 53 public:
55 CCloseDialog(const QString&, bool fs = true, QWidget* parent = 0, const char* name = 0); 54 CCloseDialog(const QString&, bool fs = true, QWidget* parent = 0, const char* name = 0);
56 ~CCloseDialog() {} 55 ~CCloseDialog() {}
57 bool delFile() { return file->isChecked(); } 56 bool delFile() { return file->isChecked(); }
58 bool delMarks() { return marks->isChecked(); } 57 bool delMarks() { return marks->isChecked(); }
59 bool delConfig() { return config->isChecked(); } 58 bool delConfig() { return config->isChecked(); }
60 59
61}; 60};
62#endif // CPREFS_H 61#endif // CPREFS_H
diff --git a/noncore/apps/opie-reader/FontControl.cpp b/noncore/apps/opie-reader/FontControl.cpp
index bbd9fe0..9bb3bc0 100644
--- a/noncore/apps/opie-reader/FontControl.cpp
+++ b/noncore/apps/opie-reader/FontControl.cpp
@@ -1,67 +1,66 @@
1#include <qfontdatabase.h> 1#include <qfontdatabase.h>
2#include "useqpe.h"
3#include "FontControl.h" 2#include "FontControl.h"
4 3
5int FontControl::gzoom() 4int FontControl::gzoom()
6{ 5{
7 if (m_fixgraphics) 6 if (m_fixgraphics)
8 { 7 {
9 return 100; 8 return 100;
10 } 9 }
11 else 10 else
12 { 11 {
13 int ret; 12 int ret;
14 if (m_size == g_size) 13 if (m_size == g_size)
15 { 14 {
16 ret = m_fontsizes[m_size]*m_basesize; 15 ret = m_fontsizes[m_size]*m_basesize;
17 } 16 }
18 else if (g_size < 0) 17 else if (g_size < 0)
19 { 18 {
20 int f = -g_size; 19 int f = -g_size;
21 ret = (m_fontsizes[0]*m_basesize) >> (f/2); 20 ret = (m_fontsizes[0]*m_basesize) >> (f/2);
22 if (f%2) ret = (2*ret/3); 21 if (f%2) ret = (2*ret/3);
23 } 22 }
24 else 23 else
25 { 24 {
26 int f = g_size - m_maxsize + 1; 25 int f = g_size - m_maxsize + 1;
27 ret = (m_fontsizes[m_maxsize-1]*m_basesize) << (f/2); 26 ret = (m_fontsizes[m_maxsize-1]*m_basesize) << (f/2);
28 if (f%2) ret = (3*ret/2); 27 if (f%2) ret = (3*ret/2);
29 } 28 }
30 return ret; 29 return ret;
31 } 30 }
32} 31}
33 32
34bool FontControl::ChangeFont(QString& n, int tgt) 33bool FontControl::ChangeFont(QString& n, int tgt)
35{ 34{
36 QValueList<int>::Iterator it; 35 QValueList<int>::Iterator it;
37 QFontDatabase fdb; 36 QFontDatabase fdb;
38 QValueList<int> sizes = fdb.pointSizes(n); 37 QValueList<int> sizes = fdb.pointSizes(n);
39 if (sizes.count() == 0) 38 if (sizes.count() == 0)
40 { 39 {
41 return false; 40 return false;
42 } 41 }
43 else 42 else
44 { 43 {
45 m_fontname = n; 44 m_fontname = n;
46 m_maxsize = sizes.count(); 45 m_maxsize = sizes.count();
47 if (m_fontsizes != NULL) delete [] m_fontsizes; 46 if (m_fontsizes != NULL) delete [] m_fontsizes;
48 m_fontsizes = new int[m_maxsize]; 47 m_fontsizes = new int[m_maxsize];
49 uint i = 0; 48 uint i = 0;
50 uint best = 0; 49 uint best = 0;
51 for (it = sizes.begin(); it != sizes.end(); it++) 50 for (it = sizes.begin(); it != sizes.end(); it++)
52 { 51 {
53#if defined(OPIE) || !defined(USEQPE) 52#if defined(OPIE) || !defined(USEQPE)
54 m_fontsizes[i] = (*it); 53 m_fontsizes[i] = (*it);
55#else 54#else
56 m_fontsizes[i] = (*it)/10; 55 m_fontsizes[i] = (*it)/10;
57#endif 56#endif
58 if (abs(tgt-m_fontsizes[i]) < abs(tgt-m_fontsizes[best])) 57 if (abs(tgt-m_fontsizes[i]) < abs(tgt-m_fontsizes[best]))
59 { 58 {
60 best = i; 59 best = i;
61 } 60 }
62 i++; 61 i++;
63 } 62 }
64 g_size = m_size = best; 63 g_size = m_size = best;
65 } 64 }
66 return true; 65 return true;
67} 66}
diff --git a/noncore/apps/opie-reader/HTMLFilter/HTMLFilter.pro b/noncore/apps/opie-reader/HTMLFilter/HTMLFilter.pro
index cc049a9..8eb6f17 100644
--- a/noncore/apps/opie-reader/HTMLFilter/HTMLFilter.pro
+++ b/noncore/apps/opie-reader/HTMLFilter/HTMLFilter.pro
@@ -1,20 +1,20 @@
1DEFINES += OPIE USEQPE 1DEFINES += OPIE USEQPE
2VPATH = .. 2VPATH = ..
3 TEMPLATE= lib 3 TEMPLATE= lib
4 CONFIG = qt warn_on release dll 4 CONFIG = qt warn_on release dll
5 HEADERS = CFilter.h \ 5 HEADERS = CFilter.h \
6 util.h 6 util.h
7 7
8 SOURCES = striphtml.cpp 8 SOURCES = striphtml.cpp
9 9
10# copy data file to install directory 10# copy data file to install directory
11QMAKE_PRE_LINK = mkdir -p $(OPIEDIR)/plugins/reader/data && cp ../HTMLentities $(OPIEDIR)/plugins/reader/data/HTMLentities 11QMAKE_PRE_LINK = mkdir -p $(OPIEDIR)/plugins/reader/data && cp ../HTMLentities $(OPIEDIR)/plugins/reader/data/HTMLentities
12 12
13 INTERFACES= 13 INTERFACES=
14 DESTDIR = $(OPIEDIR)/plugins/reader/filters 14 DESTDIR = $(OPIEDIR)/plugins/reader/filters
15 TARGET = HTMLfilter 15 TARGET = HTMLfilter
16 16
17 INCLUDEPATH+= ../OREADERINC $(OPIEDIR)/include 17 INCLUDEPATH+= $(OPIEDIR)/include
18 DEPENDPATH+= ../OREADERINC $(OPIEDIR)/include 18 DEPENDPATH+= $(OPIEDIR)/include
19 19
20include ( $(OPIEDIR)/include.pro ) 20include ( $(OPIEDIR)/include.pro )
diff --git a/noncore/apps/opie-reader/Palm2QImage.cpp b/noncore/apps/opie-reader/Palm2QImage.cpp
index c1b7b7a..c6907eb 100644
--- a/noncore/apps/opie-reader/Palm2QImage.cpp
+++ b/noncore/apps/opie-reader/Palm2QImage.cpp
@@ -1,299 +1,298 @@
1/* -*- mode: c; indent-tabs-mode: nil; -*- */ 1/* -*- mode: c; indent-tabs-mode: nil; -*- */
2#include "useqpe.h"
3#include <stdio.h> 2#include <stdio.h>
4#include <stdlib.h> 3#include <stdlib.h>
5#include <string.h> 4#include <string.h>
6#ifndef _WINDOWS 5#ifndef _WINDOWS
7#include <unistd.h> /* for link */ 6#include <unistd.h> /* for link */
8#endif 7#endif
9#include <sys/types.h> 8#include <sys/types.h>
10#include <sys/stat.h> 9#include <sys/stat.h>
11#include <stdarg.h> 10#include <stdarg.h>
12 11
13#include <qimage.h> 12#include <qimage.h>
14 13
15/***********************************************************************/ 14/***********************************************************************/
16/***********************************************************************/ 15/***********************************************************************/
17/***** *****/ 16/***** *****/
18/***** Code to decode the Palm image format to JPEG *****/ 17/***** Code to decode the Palm image format to JPEG *****/
19/***** *****/ 18/***** *****/
20/***********************************************************************/ 19/***********************************************************************/
21/***********************************************************************/ 20/***********************************************************************/
22 21
23#define READ_BIGENDIAN_SHORT(p) (((p)[0] << 8)|((p)[1])) 22#define READ_BIGENDIAN_SHORT(p) (((p)[0] << 8)|((p)[1]))
24#define READ_BIGENDIAN_LONG(p) (((p)[0] << 24)|((p)[1] << 16)|((p)[2] << 8)|((p)[3])) 23#define READ_BIGENDIAN_LONG(p) (((p)[0] << 24)|((p)[1] << 16)|((p)[2] << 8)|((p)[3]))
25 24
26#define PALM_IS_COMPRESSED_FLAG 0x8000 25#define PALM_IS_COMPRESSED_FLAG 0x8000
27#define PALM_HAS_COLORMAP_FLAG 0x4000 26#define PALM_HAS_COLORMAP_FLAG 0x4000
28#define PALM_HAS_TRANSPARENCY_FLAG 0x2000 27#define PALM_HAS_TRANSPARENCY_FLAG 0x2000
29#define PALM_DIRECT_COLOR_FLAG 0x0400 28#define PALM_DIRECT_COLOR_FLAG 0x0400
30#define PALM_4_BYTE_FIELD_FLAG 0x0200 29#define PALM_4_BYTE_FIELD_FLAG 0x0200
31 30
32#define PALM_COMPRESSION_SCANLINE 0x00 31#define PALM_COMPRESSION_SCANLINE 0x00
33#define PALM_COMPRESSION_RLE 0x01 32#define PALM_COMPRESSION_RLE 0x01
34#define PALM_COMPRESSION_PACKBITS 0x02 33#define PALM_COMPRESSION_PACKBITS 0x02
35#define PALM_COMPRESSION_NONE 0xFF 34#define PALM_COMPRESSION_NONE 0xFF
36 35
37#define PALM_COLORMAP_SIZE 232 36#define PALM_COLORMAP_SIZE 232
38 37
39typedef struct { 38typedef struct {
40 unsigned char red; 39 unsigned char red;
41 unsigned char green; 40 unsigned char green;
42 unsigned char blue; 41 unsigned char blue;
43} ColorMapEntry; 42} ColorMapEntry;
44 43
45static ColorMapEntry Palm8BitColormap[] = { 44static ColorMapEntry Palm8BitColormap[] = {
46 { 255, 255, 255 }, { 255, 204, 255 }, { 255, 153, 255 }, { 255, 102, 255 }, 45 { 255, 255, 255 }, { 255, 204, 255 }, { 255, 153, 255 }, { 255, 102, 255 },
47 { 255, 51, 255 }, { 255, 0, 255 }, { 255, 255, 204 }, { 255, 204, 204 }, 46 { 255, 51, 255 }, { 255, 0, 255 }, { 255, 255, 204 }, { 255, 204, 204 },
48 { 255, 153, 204 }, { 255, 102, 204 }, { 255, 51, 204 }, { 255, 0, 204 }, 47 { 255, 153, 204 }, { 255, 102, 204 }, { 255, 51, 204 }, { 255, 0, 204 },
49 { 255, 255, 153 }, { 255, 204, 153 }, { 255, 153, 153 }, { 255, 102, 153 }, 48 { 255, 255, 153 }, { 255, 204, 153 }, { 255, 153, 153 }, { 255, 102, 153 },
50 { 255, 51, 153 }, { 255, 0, 153 }, { 204, 255, 255 }, { 204, 204, 255 }, 49 { 255, 51, 153 }, { 255, 0, 153 }, { 204, 255, 255 }, { 204, 204, 255 },
51 { 204, 153, 255 }, { 204, 102, 255 }, { 204, 51, 255 }, { 204, 0, 255 }, 50 { 204, 153, 255 }, { 204, 102, 255 }, { 204, 51, 255 }, { 204, 0, 255 },
52 { 204, 255, 204 }, { 204, 204, 204 }, { 204, 153, 204 }, { 204, 102, 204 }, 51 { 204, 255, 204 }, { 204, 204, 204 }, { 204, 153, 204 }, { 204, 102, 204 },
53 { 204, 51, 204 }, { 204, 0, 204 }, { 204, 255, 153 }, { 204, 204, 153 }, 52 { 204, 51, 204 }, { 204, 0, 204 }, { 204, 255, 153 }, { 204, 204, 153 },
54 { 204, 153, 153 }, { 204, 102, 153 }, { 204, 51, 153 }, { 204, 0, 153 }, 53 { 204, 153, 153 }, { 204, 102, 153 }, { 204, 51, 153 }, { 204, 0, 153 },
55 { 153, 255, 255 }, { 153, 204, 255 }, { 153, 153, 255 }, { 153, 102, 255 }, 54 { 153, 255, 255 }, { 153, 204, 255 }, { 153, 153, 255 }, { 153, 102, 255 },
56 { 153, 51, 255 }, { 153, 0, 255 }, { 153, 255, 204 }, { 153, 204, 204 }, 55 { 153, 51, 255 }, { 153, 0, 255 }, { 153, 255, 204 }, { 153, 204, 204 },
57 { 153, 153, 204 }, { 153, 102, 204 }, { 153, 51, 204 }, { 153, 0, 204 }, 56 { 153, 153, 204 }, { 153, 102, 204 }, { 153, 51, 204 }, { 153, 0, 204 },
58 { 153, 255, 153 }, { 153, 204, 153 }, { 153, 153, 153 }, { 153, 102, 153 }, 57 { 153, 255, 153 }, { 153, 204, 153 }, { 153, 153, 153 }, { 153, 102, 153 },
59 { 153, 51, 153 }, { 153, 0, 153 }, { 102, 255, 255 }, { 102, 204, 255 }, 58 { 153, 51, 153 }, { 153, 0, 153 }, { 102, 255, 255 }, { 102, 204, 255 },
60 { 102, 153, 255 }, { 102, 102, 255 }, { 102, 51, 255 }, { 102, 0, 255 }, 59 { 102, 153, 255 }, { 102, 102, 255 }, { 102, 51, 255 }, { 102, 0, 255 },
61 { 102, 255, 204 }, { 102, 204, 204 }, { 102, 153, 204 }, { 102, 102, 204 }, 60 { 102, 255, 204 }, { 102, 204, 204 }, { 102, 153, 204 }, { 102, 102, 204 },
62 { 102, 51, 204 }, { 102, 0, 204 }, { 102, 255, 153 }, { 102, 204, 153 }, 61 { 102, 51, 204 }, { 102, 0, 204 }, { 102, 255, 153 }, { 102, 204, 153 },
63 { 102, 153, 153 }, { 102, 102, 153 }, { 102, 51, 153 }, { 102, 0, 153 }, 62 { 102, 153, 153 }, { 102, 102, 153 }, { 102, 51, 153 }, { 102, 0, 153 },
64 { 51, 255, 255 }, { 51, 204, 255 }, { 51, 153, 255 }, { 51, 102, 255 }, 63 { 51, 255, 255 }, { 51, 204, 255 }, { 51, 153, 255 }, { 51, 102, 255 },
65 { 51, 51, 255 }, { 51, 0, 255 }, { 51, 255, 204 }, { 51, 204, 204 }, 64 { 51, 51, 255 }, { 51, 0, 255 }, { 51, 255, 204 }, { 51, 204, 204 },
66 { 51, 153, 204 }, { 51, 102, 204 }, { 51, 51, 204 }, { 51, 0, 204 }, 65 { 51, 153, 204 }, { 51, 102, 204 }, { 51, 51, 204 }, { 51, 0, 204 },
67 { 51, 255, 153 }, { 51, 204, 153 }, { 51, 153, 153 }, { 51, 102, 153 }, 66 { 51, 255, 153 }, { 51, 204, 153 }, { 51, 153, 153 }, { 51, 102, 153 },
68 { 51, 51, 153 }, { 51, 0, 153 }, { 0, 255, 255 }, { 0, 204, 255 }, 67 { 51, 51, 153 }, { 51, 0, 153 }, { 0, 255, 255 }, { 0, 204, 255 },
69 { 0, 153, 255 }, { 0, 102, 255 }, { 0, 51, 255 }, { 0, 0, 255 }, 68 { 0, 153, 255 }, { 0, 102, 255 }, { 0, 51, 255 }, { 0, 0, 255 },
70 { 0, 255, 204 }, { 0, 204, 204 }, { 0, 153, 204 }, { 0, 102, 204 }, 69 { 0, 255, 204 }, { 0, 204, 204 }, { 0, 153, 204 }, { 0, 102, 204 },
71 { 0, 51, 204 }, { 0, 0, 204 }, { 0, 255, 153 }, { 0, 204, 153 }, 70 { 0, 51, 204 }, { 0, 0, 204 }, { 0, 255, 153 }, { 0, 204, 153 },
72 { 0, 153, 153 }, { 0, 102, 153 }, { 0, 51, 153 }, { 0, 0, 153 }, 71 { 0, 153, 153 }, { 0, 102, 153 }, { 0, 51, 153 }, { 0, 0, 153 },
73 { 255, 255, 102 }, { 255, 204, 102 }, { 255, 153, 102 }, { 255, 102, 102 }, 72 { 255, 255, 102 }, { 255, 204, 102 }, { 255, 153, 102 }, { 255, 102, 102 },
74 { 255, 51, 102 }, { 255, 0, 102 }, { 255, 255, 51 }, { 255, 204, 51 }, 73 { 255, 51, 102 }, { 255, 0, 102 }, { 255, 255, 51 }, { 255, 204, 51 },
75 { 255, 153, 51 }, { 255, 102, 51 }, { 255, 51, 51 }, { 255, 0, 51 }, 74 { 255, 153, 51 }, { 255, 102, 51 }, { 255, 51, 51 }, { 255, 0, 51 },
76 { 255, 255, 0 }, { 255, 204, 0 }, { 255, 153, 0 }, { 255, 102, 0 }, 75 { 255, 255, 0 }, { 255, 204, 0 }, { 255, 153, 0 }, { 255, 102, 0 },
77 { 255, 51, 0 }, { 255, 0, 0 }, { 204, 255, 102 }, { 204, 204, 102 }, 76 { 255, 51, 0 }, { 255, 0, 0 }, { 204, 255, 102 }, { 204, 204, 102 },
78 { 204, 153, 102 }, { 204, 102, 102 }, { 204, 51, 102 }, { 204, 0, 102 }, 77 { 204, 153, 102 }, { 204, 102, 102 }, { 204, 51, 102 }, { 204, 0, 102 },
79 { 204, 255, 51 }, { 204, 204, 51 }, { 204, 153, 51 }, { 204, 102, 51 }, 78 { 204, 255, 51 }, { 204, 204, 51 }, { 204, 153, 51 }, { 204, 102, 51 },
80 { 204, 51, 51 }, { 204, 0, 51 }, { 204, 255, 0 }, { 204, 204, 0 }, 79 { 204, 51, 51 }, { 204, 0, 51 }, { 204, 255, 0 }, { 204, 204, 0 },
81 { 204, 153, 0 }, { 204, 102, 0 }, { 204, 51, 0 }, { 204, 0, 0 }, 80 { 204, 153, 0 }, { 204, 102, 0 }, { 204, 51, 0 }, { 204, 0, 0 },
82 { 153, 255, 102 }, { 153, 204, 102 }, { 153, 153, 102 }, { 153, 102, 102 }, 81 { 153, 255, 102 }, { 153, 204, 102 }, { 153, 153, 102 }, { 153, 102, 102 },
83 { 153, 51, 102 }, { 153, 0, 102 }, { 153, 255, 51 }, { 153, 204, 51 }, 82 { 153, 51, 102 }, { 153, 0, 102 }, { 153, 255, 51 }, { 153, 204, 51 },
84 { 153, 153, 51 }, { 153, 102, 51 }, { 153, 51, 51 }, { 153, 0, 51 }, 83 { 153, 153, 51 }, { 153, 102, 51 }, { 153, 51, 51 }, { 153, 0, 51 },
85 { 153, 255, 0 }, { 153, 204, 0 }, { 153, 153, 0 }, { 153, 102, 0 }, 84 { 153, 255, 0 }, { 153, 204, 0 }, { 153, 153, 0 }, { 153, 102, 0 },
86 { 153, 51, 0 }, { 153, 0, 0 }, { 102, 255, 102 }, { 102, 204, 102 }, 85 { 153, 51, 0 }, { 153, 0, 0 }, { 102, 255, 102 }, { 102, 204, 102 },
87 { 102, 153, 102 }, { 102, 102, 102 }, { 102, 51, 102 }, { 102, 0, 102 }, 86 { 102, 153, 102 }, { 102, 102, 102 }, { 102, 51, 102 }, { 102, 0, 102 },
88 { 102, 255, 51 }, { 102, 204, 51 }, { 102, 153, 51 }, { 102, 102, 51 }, 87 { 102, 255, 51 }, { 102, 204, 51 }, { 102, 153, 51 }, { 102, 102, 51 },
89 { 102, 51, 51 }, { 102, 0, 51 }, { 102, 255, 0 }, { 102, 204, 0 }, 88 { 102, 51, 51 }, { 102, 0, 51 }, { 102, 255, 0 }, { 102, 204, 0 },
90 { 102, 153, 0 }, { 102, 102, 0 }, { 102, 51, 0 }, { 102, 0, 0 }, 89 { 102, 153, 0 }, { 102, 102, 0 }, { 102, 51, 0 }, { 102, 0, 0 },
91 { 51, 255, 102 }, { 51, 204, 102 }, { 51, 153, 102 }, { 51, 102, 102 }, 90 { 51, 255, 102 }, { 51, 204, 102 }, { 51, 153, 102 }, { 51, 102, 102 },
92 { 51, 51, 102 }, { 51, 0, 102 }, { 51, 255, 51 }, { 51, 204, 51 }, 91 { 51, 51, 102 }, { 51, 0, 102 }, { 51, 255, 51 }, { 51, 204, 51 },
93 { 51, 153, 51 }, { 51, 102, 51 }, { 51, 51, 51 }, { 51, 0, 51 }, 92 { 51, 153, 51 }, { 51, 102, 51 }, { 51, 51, 51 }, { 51, 0, 51 },
94 { 51, 255, 0 }, { 51, 204, 0 }, { 51, 153, 0 }, { 51, 102, 0 }, 93 { 51, 255, 0 }, { 51, 204, 0 }, { 51, 153, 0 }, { 51, 102, 0 },
95 { 51, 51, 0 }, { 51, 0, 0 }, { 0, 255, 102 }, { 0, 204, 102 }, 94 { 51, 51, 0 }, { 51, 0, 0 }, { 0, 255, 102 }, { 0, 204, 102 },
96 { 0, 153, 102 }, { 0, 102, 102 }, { 0, 51, 102 }, { 0, 0, 102 }, 95 { 0, 153, 102 }, { 0, 102, 102 }, { 0, 51, 102 }, { 0, 0, 102 },
97 { 0, 255, 51 }, { 0, 204, 51 }, { 0, 153, 51 }, { 0, 102, 51 }, 96 { 0, 255, 51 }, { 0, 204, 51 }, { 0, 153, 51 }, { 0, 102, 51 },
98 { 0, 51, 51 }, { 0, 0, 51 }, { 0, 255, 0 }, { 0, 204, 0 }, 97 { 0, 51, 51 }, { 0, 0, 51 }, { 0, 255, 0 }, { 0, 204, 0 },
99 { 0, 153, 0 }, { 0, 102, 0 }, { 0, 51, 0 }, { 17, 17, 17 }, 98 { 0, 153, 0 }, { 0, 102, 0 }, { 0, 51, 0 }, { 17, 17, 17 },
100 { 34, 34, 34 }, { 68, 68, 68 }, { 85, 85, 85 }, { 119, 119, 119 }, 99 { 34, 34, 34 }, { 68, 68, 68 }, { 85, 85, 85 }, { 119, 119, 119 },
101 { 136, 136, 136 }, { 170, 170, 170 }, { 187, 187, 187 }, { 221, 221, 221 }, 100 { 136, 136, 136 }, { 170, 170, 170 }, { 187, 187, 187 }, { 221, 221, 221 },
102 { 238, 238, 238 }, { 192, 192, 192 }, { 128, 0, 0 }, { 128, 0, 128 }, 101 { 238, 238, 238 }, { 192, 192, 192 }, { 128, 0, 0 }, { 128, 0, 128 },
103 { 0, 128, 0 }, { 0, 128, 128 }, { 0, 0, 0 }, { 0, 0, 0 }, 102 { 0, 128, 0 }, { 0, 128, 128 }, { 0, 0, 0 }, { 0, 0, 0 },
104 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, 103 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 },
105 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, 104 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 },
106 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, 105 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 },
107 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, 106 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 },
108 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, 107 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 },
109 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }}; 108 { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }};
110 109
111static ColorMapEntry Palm1BitColormap[] = {{ 255, 255, 255 }, { 0, 0, 0 }}; 110static ColorMapEntry Palm1BitColormap[] = {{ 255, 255, 255 }, { 0, 0, 0 }};
112 111
113static ColorMapEntry Palm2BitColormap[] = { 112static ColorMapEntry Palm2BitColormap[] = {
114 { 255, 255, 255 }, { 192, 192, 192 }, { 128, 128, 128 }, { 0, 0, 0 }}; 113 { 255, 255, 255 }, { 192, 192, 192 }, { 128, 128, 128 }, { 0, 0, 0 }};
115 114
116static ColorMapEntry Palm4BitColormap[] = { 115static ColorMapEntry Palm4BitColormap[] = {
117 { 255, 255, 255 }, { 238, 238, 238 }, { 221, 221, 221 }, { 204, 204, 204 }, 116 { 255, 255, 255 }, { 238, 238, 238 }, { 221, 221, 221 }, { 204, 204, 204 },
118 { 187, 187, 187 }, { 170, 170, 170 }, { 153, 153, 153 }, { 136, 136, 136 }, 117 { 187, 187, 187 }, { 170, 170, 170 }, { 153, 153, 153 }, { 136, 136, 136 },
119 { 119, 119, 119 }, { 102, 102, 102 }, { 85, 85, 85 }, { 68, 68, 68 }, 118 { 119, 119, 119 }, { 102, 102, 102 }, { 85, 85, 85 }, { 68, 68, 68 },
120 { 51, 51, 51 }, { 34, 34, 34 }, { 17, 17, 17 }, { 0, 0, 0 }}; 119 { 51, 51, 51 }, { 34, 34, 34 }, { 17, 17, 17 }, { 0, 0, 0 }};
121 120
122QImage* Palm2QImage 121QImage* Palm2QImage
123 (unsigned char *image_bytes_in, int byte_count_in) 122 (unsigned char *image_bytes_in, int byte_count_in)
124{ 123{
125 unsigned int width, height, bytes_per_row, flags, next_depth_offset; 124 unsigned int width, height, bytes_per_row, flags, next_depth_offset;
126 unsigned int bits_per_pixel, version, transparent_index, compression_type, i, j, inval, inbit, mask, incount; 125 unsigned int bits_per_pixel, version, transparent_index, compression_type, i, j, inval, inbit, mask, incount;
127 unsigned int palm_red_bits, palm_green_bits, palm_blue_bits; 126 unsigned int palm_red_bits, palm_green_bits, palm_blue_bits;
128 unsigned char *palm_ptr, *x_ptr, *imagedata, *inbyte, *rowbuf, *lastrow, 127 unsigned char *palm_ptr, *x_ptr, *imagedata, *inbyte, *rowbuf, *lastrow,
129 *imagedatastart, *palmimage; 128 *imagedatastart, *palmimage;
130 ColorMapEntry *colormap; 129 ColorMapEntry *colormap;
131 130
132 palmimage = image_bytes_in; 131 palmimage = image_bytes_in;
133 width = READ_BIGENDIAN_SHORT(palmimage + 0); 132 width = READ_BIGENDIAN_SHORT(palmimage + 0);
134 height = READ_BIGENDIAN_SHORT(palmimage + 2); 133 height = READ_BIGENDIAN_SHORT(palmimage + 2);
135 bytes_per_row = READ_BIGENDIAN_SHORT(palmimage + 4); 134 bytes_per_row = READ_BIGENDIAN_SHORT(palmimage + 4);
136 flags = READ_BIGENDIAN_SHORT(palmimage + 6); 135 flags = READ_BIGENDIAN_SHORT(palmimage + 6);
137 bits_per_pixel = palmimage[8]; 136 bits_per_pixel = palmimage[8];
138 version = palmimage[9]; 137 version = palmimage[9];
139 next_depth_offset = READ_BIGENDIAN_SHORT(palmimage + 10); 138 next_depth_offset = READ_BIGENDIAN_SHORT(palmimage + 10);
140 transparent_index = palmimage[12]; 139 transparent_index = palmimage[12];
141 compression_type = palmimage[13]; 140 compression_type = palmimage[13];
142 /* bytes 14 and 15 are reserved by Palm and always 0 */ 141 /* bytes 14 and 15 are reserved by Palm and always 0 */
143 142
144#if 0 143#if 0
145// qDebug ("Palm image is %dx%d, %d bpp, version %d, flags 0x%x, compression %d", width, height, bits_per_pixel, version, flags, compression_type); 144// qDebug ("Palm image is %dx%d, %d bpp, version %d, flags 0x%x, compression %d", width, height, bits_per_pixel, version, flags, compression_type);
146#endif 145#endif
147 146
148 if (compression_type == PALM_COMPRESSION_PACKBITS) { 147 if (compression_type == PALM_COMPRESSION_PACKBITS) {
149// qDebug ("Image uses packbits compression; not yet supported"); 148// qDebug ("Image uses packbits compression; not yet supported");
150 return NULL; 149 return NULL;
151 } else if ((compression_type != PALM_COMPRESSION_NONE) && 150 } else if ((compression_type != PALM_COMPRESSION_NONE) &&
152 (compression_type != PALM_COMPRESSION_RLE) && 151 (compression_type != PALM_COMPRESSION_RLE) &&
153 (compression_type != PALM_COMPRESSION_SCANLINE)) { 152 (compression_type != PALM_COMPRESSION_SCANLINE)) {
154// qDebug ("Image uses unknown compression, code 0x%x", compression_type); 153// qDebug ("Image uses unknown compression, code 0x%x", compression_type);
155 return NULL; 154 return NULL;
156 } 155 }
157 156
158 /* as of PalmOS 4.0, there are 6 different kinds of Palm pixmaps: 157 /* as of PalmOS 4.0, there are 6 different kinds of Palm pixmaps:
159 158
160 1, 2, or 4 bit grayscale 159 1, 2, or 4 bit grayscale
161 8-bit StaticColor using the Palm standard colormap 160 8-bit StaticColor using the Palm standard colormap
162 8-bit PseudoColor using a user-specified colormap 161 8-bit PseudoColor using a user-specified colormap
163 16-bit DirectColor using 5 bits for red, 6 for green, and 5 for blue 162 16-bit DirectColor using 5 bits for red, 6 for green, and 5 for blue
164 163
165 Each of these can be compressed with one of four compression schemes, 164 Each of these can be compressed with one of four compression schemes,
166 "RLE", "Scanline", "PackBits", or none. 165 "RLE", "Scanline", "PackBits", or none.
167 166
168 We begin by constructing the colormap. 167 We begin by constructing the colormap.
169 */ 168 */
170 169
171 if (flags & PALM_HAS_COLORMAP_FLAG) { 170 if (flags & PALM_HAS_COLORMAP_FLAG) {
172// qDebug("Palm images with custom colormaps are not currently supported.\n"); 171// qDebug("Palm images with custom colormaps are not currently supported.\n");
173 return NULL; 172 return NULL;
174 } else if (bits_per_pixel == 1) { 173 } else if (bits_per_pixel == 1) {
175 colormap = Palm1BitColormap; 174 colormap = Palm1BitColormap;
176 imagedatastart = palmimage + 16; 175 imagedatastart = palmimage + 16;
177 } else if (bits_per_pixel == 2) { 176 } else if (bits_per_pixel == 2) {
178 colormap = Palm2BitColormap; 177 colormap = Palm2BitColormap;
179 imagedatastart = palmimage + 16; 178 imagedatastart = palmimage + 16;
180 } else if (bits_per_pixel == 4) { 179 } else if (bits_per_pixel == 4) {
181 colormap = Palm4BitColormap; 180 colormap = Palm4BitColormap;
182 imagedatastart = palmimage + 16; 181 imagedatastart = palmimage + 16;
183 } else if (bits_per_pixel == 8) { 182 } else if (bits_per_pixel == 8) {
184 colormap = Palm8BitColormap; 183 colormap = Palm8BitColormap;
185 imagedatastart = palmimage + 16; 184 imagedatastart = palmimage + 16;
186 } else if (bits_per_pixel == 16 && (flags & PALM_DIRECT_COLOR_FLAG)) { 185 } else if (bits_per_pixel == 16 && (flags & PALM_DIRECT_COLOR_FLAG)) {
187 colormap = NULL; 186 colormap = NULL;
188 palm_red_bits = palmimage[16]; 187 palm_red_bits = palmimage[16];
189 palm_green_bits = palmimage[17]; 188 palm_green_bits = palmimage[17];
190 palm_blue_bits = palmimage[18]; 189 palm_blue_bits = palmimage[18];
191// qDebug("Bits:%d, %d, %d", palm_red_bits, palm_green_bits, palm_blue_bits); 190// qDebug("Bits:%d, %d, %d", palm_red_bits, palm_green_bits, palm_blue_bits);
192 if (palm_blue_bits > 8 || palm_green_bits > 8 || palm_red_bits > 8) { 191 if (palm_blue_bits > 8 || palm_green_bits > 8 || palm_red_bits > 8) {
193// qDebug("Can't handle this format DirectColor image -- too wide in some color (%d:%d:%d)\n", palm_red_bits, palm_green_bits, palm_blue_bits); 192// qDebug("Can't handle this format DirectColor image -- too wide in some color (%d:%d:%d)\n", palm_red_bits, palm_green_bits, palm_blue_bits);
194 return NULL; 193 return NULL;
195 } 194 }
196 if (bits_per_pixel > (8 * sizeof(unsigned long))) { 195 if (bits_per_pixel > (8 * sizeof(unsigned long))) {
197// qDebug ("Can't handle this format DirectColor image -- too many bits per pixel (%d)\n", bits_per_pixel); 196// qDebug ("Can't handle this format DirectColor image -- too many bits per pixel (%d)\n", bits_per_pixel);
198 return NULL; 197 return NULL;
199 } 198 }
200 imagedatastart = palmimage + 24; 199 imagedatastart = palmimage + 24;
201 } else { 200 } else {
202// qDebug("Unknown bits-per-pixel of %d encountered.\n", bits_per_pixel); 201// qDebug("Unknown bits-per-pixel of %d encountered.\n", bits_per_pixel);
203 return NULL; 202 return NULL;
204 } 203 }
205 204
206#ifndef USEQPE 205#ifndef USEQPE
207 QImage* qimage = new QImage(width, height, 32); 206 QImage* qimage = new QImage(width, height, 32);
208#else 207#else
209 QImage* qimage = new QImage(width, height, 16); 208 QImage* qimage = new QImage(width, height, 16);
210#endif 209#endif
211 210
212 /* row by row, uncompress the Palm image and copy it to the JPEG buffer */ 211 /* row by row, uncompress the Palm image and copy it to the JPEG buffer */
213 rowbuf = new unsigned char[bytes_per_row * width]; 212 rowbuf = new unsigned char[bytes_per_row * width];
214 lastrow = new unsigned char[bytes_per_row * width]; 213 lastrow = new unsigned char[bytes_per_row * width];
215 214
216 for (i=0, palm_ptr = imagedatastart , x_ptr = imagedata; i < height; ++i) { 215 for (i=0, palm_ptr = imagedatastart , x_ptr = imagedata; i < height; ++i) {
217// qDebug("inval:%x palm_ptr:%x x_ptr:%x bpr:%x", inval, palm_ptr, x_ptr, bytes_per_row); 216// qDebug("inval:%x palm_ptr:%x x_ptr:%x bpr:%x", inval, palm_ptr, x_ptr, bytes_per_row);
218 217
219 /* first, uncompress the Palm image */ 218 /* first, uncompress the Palm image */
220 if ((flags & PALM_IS_COMPRESSED_FLAG) && (compression_type == PALM_COMPRESSION_RLE)) { 219 if ((flags & PALM_IS_COMPRESSED_FLAG) && (compression_type == PALM_COMPRESSION_RLE)) {
221 for (j = 0; j < bytes_per_row; ) { 220 for (j = 0; j < bytes_per_row; ) {
222 incount = *palm_ptr++; 221 incount = *palm_ptr++;
223 inval = *palm_ptr++; 222 inval = *palm_ptr++;
224 memset(rowbuf + j, inval, incount); 223 memset(rowbuf + j, inval, incount);
225 j += incount; 224 j += incount;
226 } 225 }
227 } else if ((flags & PALM_IS_COMPRESSED_FLAG) && (compression_type == PALM_COMPRESSION_SCANLINE)) { 226 } else if ((flags & PALM_IS_COMPRESSED_FLAG) && (compression_type == PALM_COMPRESSION_SCANLINE)) {
228 for (j = 0; j < bytes_per_row; j += 8) { 227 for (j = 0; j < bytes_per_row; j += 8) {
229 incount = *palm_ptr++; 228 incount = *palm_ptr++;
230 inval = ((bytes_per_row - j) < 8) ? (bytes_per_row - j) : 8; 229 inval = ((bytes_per_row - j) < 8) ? (bytes_per_row - j) : 8;
231 for (inbit = 0; inbit < inval; inbit += 1) { 230 for (inbit = 0; inbit < inval; inbit += 1) {
232 if (incount & (1 << (7 - inbit))) 231 if (incount & (1 << (7 - inbit)))
233 rowbuf[j + inbit] = *palm_ptr++; 232 rowbuf[j + inbit] = *palm_ptr++;
234 else 233 else
235 rowbuf[j + inbit] = lastrow[j + inbit]; 234 rowbuf[j + inbit] = lastrow[j + inbit];
236 } 235 }
237 } 236 }
238 memcpy (lastrow, rowbuf, bytes_per_row); 237 memcpy (lastrow, rowbuf, bytes_per_row);
239 } else if (((flags & PALM_IS_COMPRESSED_FLAG) && 238 } else if (((flags & PALM_IS_COMPRESSED_FLAG) &&
240 (compression_type == PALM_COMPRESSION_NONE)) || 239 (compression_type == PALM_COMPRESSION_NONE)) ||
241 ((flags & PALM_IS_COMPRESSED_FLAG) == 0)) 240 ((flags & PALM_IS_COMPRESSED_FLAG) == 0))
242 { 241 {
243 memcpy (rowbuf, palm_ptr, bytes_per_row); 242 memcpy (rowbuf, palm_ptr, bytes_per_row);
244 palm_ptr += bytes_per_row; 243 palm_ptr += bytes_per_row;
245 } 244 }
246 else { 245 else {
247 qDebug("Case 4"); 246 qDebug("Case 4");
248 qDebug("Is compressed:%s", ((flags & PALM_IS_COMPRESSED_FLAG) == 0) ? "false" : "true"); 247 qDebug("Is compressed:%s", ((flags & PALM_IS_COMPRESSED_FLAG) == 0) ? "false" : "true");
249 qDebug("Has colourmap:%s", ((flags & PALM_HAS_COLORMAP_FLAG) == 0) ? "false" : "true"); 248 qDebug("Has colourmap:%s", ((flags & PALM_HAS_COLORMAP_FLAG) == 0) ? "false" : "true");
250 qDebug("Has transparency:%s", ((flags & PALM_HAS_TRANSPARENCY_FLAG) == 0) ? "false" : "true"); 249 qDebug("Has transparency:%s", ((flags & PALM_HAS_TRANSPARENCY_FLAG) == 0) ? "false" : "true");
251 qDebug("Direct colour:%s", ((flags & PALM_DIRECT_COLOR_FLAG) == 0) ? "false" : "true"); 250 qDebug("Direct colour:%s", ((flags & PALM_DIRECT_COLOR_FLAG) == 0) ? "false" : "true");
252 qDebug("four byte field:%s", ((flags & PALM_4_BYTE_FIELD_FLAG) == 0) ? "false" : "true"); 251 qDebug("four byte field:%s", ((flags & PALM_4_BYTE_FIELD_FLAG) == 0) ? "false" : "true");
253 memcpy (rowbuf, palm_ptr, bytes_per_row); 252 memcpy (rowbuf, palm_ptr, bytes_per_row);
254 palm_ptr += bytes_per_row; 253 palm_ptr += bytes_per_row;
255 } 254 }
256 /* next, write it to the GDK bitmap */ 255 /* next, write it to the GDK bitmap */
257 if (colormap) { 256 if (colormap) {
258 mask = (1 << bits_per_pixel) - 1; 257 mask = (1 << bits_per_pixel) - 1;
259 for (inbit = 8 - bits_per_pixel, inbyte = rowbuf, j = 0; j < width; ++j) { 258 for (inbit = 8 - bits_per_pixel, inbyte = rowbuf, j = 0; j < width; ++j) {
260 inval = ((*inbyte) & (mask << inbit)) >> inbit; 259 inval = ((*inbyte) & (mask << inbit)) >> inbit;
261 /* correct for oddity of the 8-bit color Palm pixmap... */ 260 /* correct for oddity of the 8-bit color Palm pixmap... */
262 if ((bits_per_pixel == 8) && (inval == 0xFF)) inval = 231; 261 if ((bits_per_pixel == 8) && (inval == 0xFF)) inval = 231;
263 /* now lookup the correct color and set the pixel in the GTK bitmap */ 262 /* now lookup the correct color and set the pixel in the GTK bitmap */
264 QRgb colour = qRgb(colormap[inval].red, colormap[inval].green, colormap[inval].blue); 263 QRgb colour = qRgb(colormap[inval].red, colormap[inval].green, colormap[inval].blue);
265 qimage->setPixel(j, i, colour); 264 qimage->setPixel(j, i, colour);
266 if (!inbit) { 265 if (!inbit) {
267 ++inbyte; 266 ++inbyte;
268 inbit = 8 - bits_per_pixel; 267 inbit = 8 - bits_per_pixel;
269 } else { 268 } else {
270 inbit -= bits_per_pixel; 269 inbit -= bits_per_pixel;
271 } 270 }
272 } 271 }
273 } else if (!colormap && 272 } else if (!colormap &&
274 bits_per_pixel == 16) { 273 bits_per_pixel == 16) {
275 for (inbyte = rowbuf, j = 0; j < width; ++j) { 274 for (inbyte = rowbuf, j = 0; j < width; ++j) {
276 inval = ((unsigned short)inbyte[0] << (unsigned short)8) | inbyte[1]; 275 inval = ((unsigned short)inbyte[0] << (unsigned short)8) | inbyte[1];
277 276
278/* 277/*
279 qDebug ("pixel is %d,%d (%d:%d:%d)", 278 qDebug ("pixel is %d,%d (%d:%d:%d)",
280 j, i, 279 j, i,
281 ((inval >> (bits_per_pixel - palm_red_bits)) & ((1 << palm_red_bits) - 1)) << (8-palm_red_bits), 280 ((inval >> (bits_per_pixel - palm_red_bits)) & ((1 << palm_red_bits) - 1)) << (8-palm_red_bits),
282 ((inval >> palm_blue_bits) & ((1 << palm_green_bits) - 1)) << (8-palm_green_bits), 281 ((inval >> palm_blue_bits) & ((1 << palm_green_bits) - 1)) << (8-palm_green_bits),
283 ((inval >> 0) & ((1 << palm_blue_bits) - 1)) << (8-palm_blue_bits)); 282 ((inval >> 0) & ((1 << palm_blue_bits) - 1)) << (8-palm_blue_bits));
284*/ 283*/
285 QRgb colour = qRgb( 284 QRgb colour = qRgb(
286 ((inval >> (bits_per_pixel - palm_red_bits)) & ((1 << palm_red_bits) - 1)) << (8-palm_red_bits), 285 ((inval >> (bits_per_pixel - palm_red_bits)) & ((1 << palm_red_bits) - 1)) << (8-palm_red_bits),
287 ((inval >> palm_blue_bits) & ((1 << palm_green_bits) - 1)) << (8-palm_green_bits), 286 ((inval >> palm_blue_bits) & ((1 << palm_green_bits) - 1)) << (8-palm_green_bits),
288 ((inval >> 0) & ((1 << palm_blue_bits) - 1)) << (8-palm_blue_bits)); 287 ((inval >> 0) & ((1 << palm_blue_bits) - 1)) << (8-palm_blue_bits));
289 qimage->setPixel(j, i, colour); 288 qimage->setPixel(j, i, colour);
290 inbyte += 2; 289 inbyte += 2;
291 } 290 }
292 } 291 }
293 } 292 }
294 293
295 delete [] rowbuf; 294 delete [] rowbuf;
296 delete [] lastrow; 295 delete [] lastrow;
297 296
298 return qimage; 297 return qimage;
299} 298}
diff --git a/noncore/apps/opie-reader/PluckerCodec/PluckerCodec.pro b/noncore/apps/opie-reader/PluckerCodec/PluckerCodec.pro
index 6ed4032..7042542 100644
--- a/noncore/apps/opie-reader/PluckerCodec/PluckerCodec.pro
+++ b/noncore/apps/opie-reader/PluckerCodec/PluckerCodec.pro
@@ -1,18 +1,18 @@
1DEFINES += OPIE USEQPE 1DEFINES += OPIE USEQPE
2VPATH = .. 2VPATH = ..
3 TEMPLATE= lib 3 TEMPLATE= lib
4 CONFIG = qt warn_on release dll 4 CONFIG = qt warn_on release dll
5 HEADERS = plucker.h 5 HEADERS = plucker.h
6 6
7 SOURCES = plucker.cpp \ 7 SOURCES = plucker.cpp \
8 Palm2QImage.cpp 8 Palm2QImage.cpp
9 9
10 INTERFACES= 10 INTERFACES=
11 DESTDIR = $(OPIEDIR)/plugins/reader/codecs 11 DESTDIR = $(OPIEDIR)/plugins/reader/codecs
12 TARGET = Plucker 12 TARGET = Plucker
13LIBS += -lreader_pdb -lreader_pluckerbase -lreader_codec 13LIBS += -lreader_pdb -lreader_pluckerbase -lreader_codec
14 14
15 INCLUDEPATH+= ../OREADERINC $(OPIEDIR)/include 15 INCLUDEPATH+= $(OPIEDIR)/include
16 DEPENDPATH+= ../OREADERINC $(OPIEDIR)/include 16 DEPENDPATH+= $(OPIEDIR)/include
17 17
18include ( $(OPIEDIR)/include.pro ) 18include ( $(OPIEDIR)/include.pro )
diff --git a/noncore/apps/opie-reader/QTReader.cpp b/noncore/apps/opie-reader/QTReader.cpp
index dfdba28..33884a0 100644
--- a/noncore/apps/opie-reader/QTReader.cpp
+++ b/noncore/apps/opie-reader/QTReader.cpp
@@ -1,2986 +1,2985 @@
1/**************************************************************************** 1/****************************************************************************
2** $Id$ 2** $Id$
3** 3**
4** Copyright (C) 1992-2000 Trolltech AS. All rights reserved. 4** Copyright (C) 1992-2000 Trolltech AS. All rights reserved.
5** 5**
6** This file is part of an example program for Qt. This example 6** This file is part of an example program for Qt. This example
7** program may be used, distributed and modified without limitation. 7** program may be used, distributed and modified without limitation.
8** 8**
9*****************************************************************************/ 9*****************************************************************************/
10 10
11const int _SBARHEIGHT = 3; 11const int _SBARHEIGHT = 3;
12 12
13#include "useqpe.h"
14#include <qpainter.h> 13#include <qpainter.h>
15//#include <qdirectpainter_qws.h> 14//#include <qdirectpainter_qws.h>
16#include <qimage.h> 15#include <qimage.h>
17#include <qtimer.h> 16#include <qtimer.h>
18#include "config.h" 17#include "config.h"
19#include "QTReader.h" 18#include "QTReader.h"
20//#include "QTReaderApp.h" 19//#include "QTReaderApp.h"
21#include "CDrawBuffer.h" 20#include "CDrawBuffer.h"
22#ifdef USEQPE 21#ifdef USEQPE
23#include <qpe/qpeapplication.h> 22#include <qpe/qpeapplication.h>
24#endif 23#endif
25#include <math.h> 24#include <math.h>
26#include <ctype.h> 25#include <ctype.h>
27#include <stdio.h> //for sprintf 26#include <stdio.h> //for sprintf
28#ifdef USEQPE 27#ifdef USEQPE
29#include <qpe/config.h> 28#include <qpe/config.h>
30#include <qpe/applnk.h> 29#include <qpe/applnk.h>
31#include <qpe/global.h> 30#include <qpe/global.h>
32#include <qpe/qcopenvelope_qws.h> 31#include <qpe/qcopenvelope_qws.h>
33#endif 32#endif
34#include <qfileinfo.h> 33#include <qfileinfo.h>
35#include <qdir.h> 34#include <qdir.h>
36 35
37#ifdef _UNICODE 36#ifdef _UNICODE
38const char *QTReader::fonts[] = { "unifont", "Courier", "Times", 0 }; 37const char *QTReader::fonts[] = { "unifont", "Courier", "Times", 0 };
39#else 38#else
40const char *QTReader::fonts[] = { "Helvetica", "Courier", "Times", 0 }; 39const char *QTReader::fonts[] = { "Helvetica", "Courier", "Times", 0 };
41#endif 40#endif
42//const int QTReader::fontsizes[] = { 8, 10, 12, 14, 18, 24, 30, 40, 50, 60, 70, 80, 90, 100, 0 }; 41//const int QTReader::fontsizes[] = { 8, 10, 12, 14, 18, 24, 30, 40, 50, 60, 70, 80, 90, 100, 0 };
43 42
44//const tchar *QTReader::fonts[] = { "unifont", "fixed", "micro", "smoothtimes", "Courier", "Times", 0 }; 43//const tchar *QTReader::fonts[] = { "unifont", "fixed", "micro", "smoothtimes", "Courier", "Times", 0 };
45//const int QTReader::fontsizes[] = {10,16,17,22,0}; 44//const int QTReader::fontsizes[] = {10,16,17,22,0};
46//const tchar *QTReader::fonts[] = { "verdana", "Courier", "Times", 0 }; 45//const tchar *QTReader::fonts[] = { "verdana", "Courier", "Times", 0 };
47//const int QTReader::fontsizes[] = {1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,0}; 46//const int QTReader::fontsizes[] = {1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,0};
48 47
49tchar QTReader::pluckernextpart[] = { 'C','l','i','c','k',' ','h','e','r','e',' ','f','o','r',' ','t','h','e',' ','n','e','x','t',' ','p','a','r','t',0 }; 48tchar QTReader::pluckernextpart[] = { 'C','l','i','c','k',' ','h','e','r','e',' ','f','o','r',' ','t','h','e',' ','n','e','x','t',' ','p','a','r','t',0 };
50tchar QTReader::jplucknextpart[] = { 'N','e','x','t',' ','P','a','r','t',' ','>','>',0 }; 49tchar QTReader::jplucknextpart[] = { 'N','e','x','t',' ','P','a','r','t',' ','>','>',0 };
51//tchar QTReader::jplucknextpart[] = { 10,'#',10,'N','e','x','t',' ','P','a','r','t',' ','>','>',0 }; 50//tchar QTReader::jplucknextpart[] = { 10,'#',10,'N','e','x','t',' ','P','a','r','t',' ','>','>',0 };
52 51
53 52
54QTReader::QTReader( QWidget *parent, const char *name, WFlags f) : 53QTReader::QTReader( QWidget *parent, const char *name, WFlags f) :
55 QWidget(parent, name, f), 54 QWidget(parent, name, f),
56 m_default_fg(0,0,0), 55 m_default_fg(0,0,0),
57 m_default_bg(255,255,255), 56 m_default_bg(255,255,255),
58 m_bg(255,255,255), 57 m_bg(255,255,255),
59 m_delay(100), 58 m_delay(100),
60 m_scrolldy1(0), 59 m_scrolldy1(0),
61 m_scrolldy2(0), 60 m_scrolldy2(0),
62 m_totalscroll(0), 61 m_totalscroll(0),
63 m_autoScroll(false), 62 m_autoScroll(false),
64 //textarray(NULL), 63 //textarray(NULL),
65 //locnarray(NULL), 64 //locnarray(NULL),
66 numlines(0), 65 numlines(0),
67 m_fontname("unifont"), 66 m_fontname("unifont"),
68 m_fm(NULL), 67 m_fm(NULL),
69 mouseUpOn(true), 68 mouseUpOn(true),
70 m_twotouch(true), 69 m_twotouch(true),
71 m_touchone(true), 70 m_touchone(true),
72 bDoUpdates(false), 71 bDoUpdates(false),
73#ifdef _SCROLLPIPE 72#ifdef _SCROLLPIPE
74 m_pipeout(NULL), 73 m_pipeout(NULL),
75#endif 74#endif
76 m_left_border(2), 75 m_left_border(2),
77 m_right_border(2), 76 m_right_border(2),
78 m_rotated(true), 77 m_rotated(true),
79 pBkmklist(NULL), 78 pBkmklist(NULL),
80 m_scrollpos(0), 79 m_scrollpos(0),
81 // bNegative(false), 80 // bNegative(false),
82 bInverse(false), 81 bInverse(false),
83 m_highlightfilter(NULL), 82 m_highlightfilter(NULL),
84 m_bgIsScaled(false), 83 m_bgIsScaled(false),
85 m_scrollstep(2), 84 m_scrollstep(2),
86 m_topmargin(5), 85 m_topmargin(5),
87 m_bottommargin(5), 86 m_bottommargin(5),
88 m_reparastring("{\\n[\\n ]}"), 87 m_reparastring("{\\n[\\n ]}"),
89 m_currentlinkstyle(NULL), 88 m_currentlinkstyle(NULL),
90 m_currentlinkoffset(-1), 89 m_currentlinkoffset(-1),
91 m_currentlink(-1) 90 m_currentlink(-1)
92{ 91{
93 m_overlap = 1; 92 m_overlap = 1;
94 setKeyCompression ( true ); 93 setKeyCompression ( true );
95#ifdef DOUBLEBUFFER 94#ifdef DOUBLEBUFFER
96 dbuff = new QPixmap(); 95 dbuff = new QPixmap();
97 dbp = new QPainter(); 96 dbp = new QPainter();
98 // if (painter->isActive()) painter->end(); 97 // if (painter->isActive()) painter->end();
99 // painter->begin(frame); 98 // painter->begin(frame);
100#endif 99#endif
101// init(); 100// init();
102 101
103} 102}
104 103
105/* 104/*
106QTReader::QTReader( const QString& filename, QWidget *parent=0, const tchar *name=0, WFlags f = 0) : 105QTReader::QTReader( const QString& filename, QWidget *parent=0, const tchar *name=0, WFlags f = 0) :
107 QWidget(parent, name, f), 106 QWidget(parent, name, f),
108 m_textfont(0), 107 m_textfont(0),
109 m_textsize(1), 108 m_textsize(1),
110 textarray(NULL), 109 textarray(NULL),
111 numlines(0), 110 numlines(0),
112 bstripcr(true), 111 bstripcr(true),
113 bunindent(false), 112 bunindent(false),
114 brepara(false), 113 brepara(false),
115 bdblspce(false), 114 bdblspce(false),
116 btight(false), 115 btight(false),
117 bindenter(0), 116 bindenter(0),
118 m_fm(NULL) 117 m_fm(NULL)
119{ 118{
120 init(); 119 init();
121// // qDebug("Load_file(1)"); 120// // qDebug("Load_file(1)");
122 load_file((const tchar*)filename); 121 load_file((const tchar*)filename);
123} 122}
124*/ 123*/
125 124
126/* 125/*
127void QTReader::mouseMoveEvent(QMouseEvent* _e) 126void QTReader::mouseMoveEvent(QMouseEvent* _e)
128{ 127{
129 128
130 mouseUpOn = !(_e->pos().x() == -1); 129 mouseUpOn = !(_e->pos().x() == -1);
131 130
132 qDebug("MouseMove:[%d, %d]", _e->pos().x(), _e->pos().y()); 131 qDebug("MouseMove:[%d, %d]", _e->pos().x(), _e->pos().y());
133} 132}
134*/ 133*/
135long QTReader::real_delay() 134long QTReader::real_delay()
136{ 135{
137 return m_scrollstep*( 8976 + m_delay ) / ( m_linespacing * m_linespacing ); 136 return m_scrollstep*( 8976 + m_delay ) / ( m_linespacing * m_linespacing );
138} 137}
139 138
140void QTReader::mousePressEvent( QMouseEvent* _e ) 139void QTReader::mousePressEvent( QMouseEvent* _e )
141{ 140{
142 buffdoc.unsuspend(); 141 buffdoc.unsuspend();
143 int x, y, ht, wh; 142 int x, y, ht, wh;
144 if (m_rotated) 143 if (m_rotated)
145 { 144 {
146 x = _e->y(); 145 x = _e->y();
147 y = width()-_e->x(); 146 y = width()-_e->x();
148 ht = width(); 147 ht = width();
149 wh = height(); 148 wh = height();
150 } 149 }
151 else 150 else
152 { 151 {
153 x = _e->x(); 152 x = _e->x();
154 y = _e->y(); 153 y = _e->y();
155 ht = height(); 154 ht = height();
156 wh = width(); 155 wh = width();
157 } 156 }
158 if (_e->button() == RightButton) 157 if (_e->button() == RightButton)
159 { 158 {
160 //qDebug("MousePress"); 159 //qDebug("MousePress");
161 mouseUpOn = false; 160 mouseUpOn = false;
162 if (m_swapmouse) 161 if (m_swapmouse)
163 { 162 {
164 int lineno = 0; 163 int lineno = 0;
165 /* 164 /*
166 int hgt = textarray[0]->lineSpacing(); 165 int hgt = textarray[0]->lineSpacing();
167 while ((hgt < y) && (lineno < numlines)) 166 while ((hgt < y) && (lineno < numlines))
168 { 167 {
169 hgt += textarray[++lineno]->lineSpacing(); 168 hgt += textarray[++lineno]->lineSpacing();
170 } 169 }
171 */ 170 */
172 size_t startpos, startoffset, tgt, tgtoffset, pictgt; 171 size_t startpos, startoffset, tgt, tgtoffset, pictgt;
173 QImage* img; 172 QImage* img;
174 getcurrentpos(x, y, wh, ht, lineno, startpos, startoffset, tgt, tgtoffset, pictgt, img); 173 getcurrentpos(x, y, wh, ht, lineno, startpos, startoffset, tgt, tgtoffset, pictgt, img);
175 processmousewordevent(startpos, startoffset, _e, lineno); 174 processmousewordevent(startpos, startoffset, _e, lineno);
176 } 175 }
177 else 176 else
178 processmousepositionevent(_e); 177 processmousepositionevent(_e);
179 } 178 }
180} 179}
181 180
182void QTReader::processmousepositionevent( QMouseEvent* _e ) 181void QTReader::processmousepositionevent( QMouseEvent* _e )
183{ 182{
184 int x, y, ht, wh; 183 int x, y, ht, wh;
185 if (m_rotated) 184 if (m_rotated)
186 { 185 {
187 x = _e->y(); 186 x = _e->y();
188 y = width()-_e->x(); 187 y = width()-_e->x();
189 ht = width(); 188 ht = width();
190 wh = height(); 189 wh = height();
191 } 190 }
192 else 191 else
193 { 192 {
194 x = _e->x(); 193 x = _e->x();
195 y = _e->y(); 194 y = _e->y();
196 ht = height(); 195 ht = height();
197 wh = width(); 196 wh = width();
198 } 197 }
199 if (buffdoc.hasnavigation()) 198 if (buffdoc.hasnavigation())
200 { 199 {
201 if (y > (2*ht)/3) 200 if (y > (2*ht)/3)
202 { 201 {
203 goDown(); 202 goDown();
204 } 203 }
205 else if (y < ht/3) 204 else if (y < ht/3)
206 { 205 {
207 goUp(); 206 goUp();
208 } 207 }
209 else 208 else
210 { 209 {
211 if (x < wh/3) 210 if (x < wh/3)
212 { 211 {
213 goBack(); 212 goBack();
214 } 213 }
215 else if (x > (2*wh)/3) 214 else if (x > (2*wh)/3)
216 { 215 {
217 goForward(); 216 goForward();
218 } 217 }
219 else 218 else
220 { 219 {
221 goHome(); 220 goHome();
222 } 221 }
223 } 222 }
224 } 223 }
225 else 224 else
226 { 225 {
227 if (y > ht/2) 226 if (y > ht/2)
228 { 227 {
229 goDown(); 228 goDown();
230 } 229 }
231 else 230 else
232 { 231 {
233 goUp(); 232 goUp();
234 } 233 }
235 } 234 }
236} 235}
237 236
238void QTReader::goHome() 237void QTReader::goHome()
239{ 238{
240 if (buffdoc.hasnavigation()) 239 if (buffdoc.hasnavigation())
241 { 240 {
242 size_t current=pagelocate(); 241 size_t current=pagelocate();
243 size_t home=buffdoc.getHome(); 242 size_t home=buffdoc.getHome();
244 if (current!=home) 243 if (current!=home)
245 { 244 {
246 buffdoc.saveposn(m_lastfile, current); 245 buffdoc.saveposn(m_lastfile, current);
247 locate(home); 246 locate(home);
248 } 247 }
249 } 248 }
250 else 249 else
251 locate(0); 250 locate(0);
252} 251}
253 252
254void QTReader::goBack() 253void QTReader::goBack()
255{ 254{
256 if (buffdoc.hasnavigation()) 255 if (buffdoc.hasnavigation())
257 { 256 {
258 size_t target = pagelocate(); 257 size_t target = pagelocate();
259 QString nxt = m_lastfile; 258 QString nxt = m_lastfile;
260 buffdoc.writeposn(m_lastfile, target); 259 buffdoc.writeposn(m_lastfile, target);
261 linkType lt = buffdoc.back(nxt, target); 260 linkType lt = buffdoc.back(nxt, target);
262 if ((lt & eFile) != 0) 261 if ((lt & eFile) != 0)
263 { 262 {
264 if (nxt != m_lastfile) 263 if (nxt != m_lastfile)
265 { 264 {
266 emit NewFileRequest(nxt); 265 emit NewFileRequest(nxt);
267 } 266 }
268 locate(target); 267 locate(target);
269 } 268 }
270 else if ((lt & eLink) != 0) 269 else if ((lt & eLink) != 0)
271 { 270 {
272 locate(target); 271 locate(target);
273 } 272 }
274 } 273 }
275} 274}
276 275
277void QTReader::goForward() 276void QTReader::goForward()
278{ 277{
279 if (buffdoc.hasnavigation()) 278 if (buffdoc.hasnavigation())
280 { 279 {
281 size_t target = pagelocate(); 280 size_t target = pagelocate();
282 QString nxt = m_lastfile; 281 QString nxt = m_lastfile;
283 linkType lt = buffdoc.forward(nxt, target); 282 linkType lt = buffdoc.forward(nxt, target);
284 if ((lt & eFile) != 0) 283 if ((lt & eFile) != 0)
285 { 284 {
286 if (nxt != m_lastfile) 285 if (nxt != m_lastfile)
287 { 286 {
288 emit NewFileRequest(nxt); 287 emit NewFileRequest(nxt);
289 } 288 }
290 locate(target); 289 locate(target);
291 } 290 }
292 else if ((lt & eLink) != 0) 291 else if ((lt & eLink) != 0)
293 { 292 {
294 locate(target); 293 locate(target);
295 } 294 }
296 } 295 }
297} 296}
298 297
299linkType QTReader::getcurrentpos(int x, int y, int w, int h, int& lineno, size_t& start, size_t& offset, size_t& tgt, size_t& tgtoffset, size_t& pictgt, QImage*& img) 298linkType QTReader::getcurrentpos(int x, int y, int w, int h, int& lineno, size_t& start, size_t& offset, size_t& tgt, size_t& tgtoffset, size_t& pictgt, QImage*& img)
300{ 299{
301 int ht; 300 int ht;
302 if (m_scrolldy == m_topmargin) 301 if (m_scrolldy == m_topmargin)
303 { 302 {
304 lineno = 0; 303 lineno = 0;
305 ht = textarray[0]->lineSpacing()-m_scrolldy1 + m_topmargin; 304 ht = textarray[0]->lineSpacing()-m_scrolldy1 + m_topmargin;
306 } 305 }
307 else 306 else
308 { 307 {
309 if (y >= m_scrolldy) 308 if (y >= m_scrolldy)
310 { 309 {
311 lineno = 0; 310 lineno = 0;
312 ht = textarray[0]->lineSpacing()-m_scrolldy1+m_scrolldy + m_topmargin; 311 ht = textarray[0]->lineSpacing()-m_scrolldy1+m_scrolldy + m_topmargin;
313 } 312 }
314 else 313 else
315 { 314 {
316 lineno = 0; 315 lineno = 0;
317 ht = textarray[0]->lineSpacing()-m_scrolldy1+m_scrolldy+m_topmargin; 316 ht = textarray[0]->lineSpacing()-m_scrolldy1+m_scrolldy+m_topmargin;
318 while ((ht < h) && (lineno < numlines-1)) 317 while ((ht < h) && (lineno < numlines-1))
319 { 318 {
320 ht += textarray[++lineno]->lineSpacing(); 319 ht += textarray[++lineno]->lineSpacing();
321 } 320 }
322 ht = textarray[lineno]->lineSpacing(); 321 ht = textarray[lineno]->lineSpacing();
323 } 322 }
324 } 323 }
325 while ((ht < y) && (lineno < numlines-1)) 324 while ((ht < y) && (lineno < numlines-1))
326 { 325 {
327 ht += textarray[++lineno]->lineSpacing(); 326 ht += textarray[++lineno]->lineSpacing();
328 } 327 }
329 if (ht < y && textarray[numlines]->showPartial()) lineno = numlines; 328 if (ht < y && textarray[numlines]->showPartial()) lineno = numlines;
330 start = locnarray[lineno]; 329 start = locnarray[lineno];
331 int availht = ((m_rotated) ? width() : height()) - m_topmargin - m_bottommargin; 330 int availht = ((m_rotated) ? width() : height()) - m_topmargin - m_bottommargin;
332 if (m_bMonoSpaced) 331 if (m_bMonoSpaced)
333 { 332 {
334 offset = (x - textarray[lineno]->offset(w, m_left_border, m_right_border, availht))/m_charWidth; 333 offset = (x - textarray[lineno]->offset(w, m_left_border, m_right_border, availht))/m_charWidth;
335 } 334 }
336 else 335 else
337 { 336 {
338 int i; 337 int i;
339 CDrawBuffer* t = textarray[lineno]; 338 CDrawBuffer* t = textarray[lineno];
340 x = x - t->offset(width(), m_left_border, m_right_border, availht); 339 x = x - t->offset(width(), m_left_border, m_right_border, availht);
341 for (i = t->length(); i > 0 && t->width(availht, i, true, w, m_left_border, m_right_border) > x; i--); 340 for (i = t->length(); i > 0 && t->width(availht, i, true, w, m_left_border, m_right_border) > x; i--);
342 offset = i; 341 offset = i;
343 } 342 }
344 return textarray[lineno]->getLinkType(offset, tgt, tgtoffset, pictgt, img); 343 return textarray[lineno]->getLinkType(offset, tgt, tgtoffset, pictgt, img);
345} 344}
346 345
347void QTReader::suspend() 346void QTReader::suspend()
348{ 347{
349 buffdoc.suspend(); 348 buffdoc.suspend();
350 /*#ifdef OPIE 349 /*#ifdef OPIE
351 if (memcmp("/mnt/", m_lastfile.latin1(), 5) == 0) buffdoc.suspend(); 350 if (memcmp("/mnt/", m_lastfile.latin1(), 5) == 0) buffdoc.suspend();
352#else 351#else
353 if (memcmp("/usr/mnt.rom/", m_lastfile.latin1(), 13) == 0) buffdoc.suspend(); 352 if (memcmp("/usr/mnt.rom/", m_lastfile.latin1(), 13) == 0) buffdoc.suspend();
354#endif 353#endif
355 */ 354 */
356} 355}
357 356
358void QTReader::setTwoTouch(bool _b) 357void QTReader::setTwoTouch(bool _b)
359{ 358{
360 setBackgroundColor( m_bg ); 359 setBackgroundColor( m_bg );
361 m_twotouch = m_touchone = _b; 360 m_twotouch = m_touchone = _b;
362} 361}
363 362
364void QTReader::setContinuous(bool _b) 363void QTReader::setContinuous(bool _b)
365{ 364{
366 buffdoc.unsuspend(); 365 buffdoc.unsuspend();
367 buffdoc.setContinuous(m_continuousDocument = _b); 366 buffdoc.setContinuous(m_continuousDocument = _b);
368} 367}
369 368
370void QTReader::processmousewordevent(size_t startpos, size_t startoffset, QMouseEvent* _e, int lineno) 369void QTReader::processmousewordevent(size_t startpos, size_t startoffset, QMouseEvent* _e, int lineno)
371{ 370{
372 unsigned long wrdstart, wrdend; 371 unsigned long wrdstart, wrdend;
373 QString wrd; 372 QString wrd;
374 int availht = ((m_rotated) ? width() : height()) - m_topmargin - m_bottommargin; 373 int availht = ((m_rotated) ? width() : height()) - m_topmargin - m_bottommargin;
375 if (m_twotouch) 374 if (m_twotouch)
376 { 375 {
377 if (m_touchone) 376 if (m_touchone)
378 { 377 {
379 m_touchone = false; 378 m_touchone = false;
380 m_startpos = startpos; 379 m_startpos = startpos;
381 m_startoffset = startoffset; 380 m_startoffset = startoffset;
382 setBackgroundColor( lightGray ); 381 setBackgroundColor( lightGray );
383 } 382 }
384 else 383 else
385 { 384 {
386 m_touchone = true; 385 m_touchone = true;
387 setBackgroundColor( m_bg ); 386 setBackgroundColor( m_bg );
388 size_t endpos, endoffset; 387 size_t endpos, endoffset;
389 endpos = startpos; 388 endpos = startpos;
390 endoffset = startoffset; 389 endoffset = startoffset;
391 size_t currentpos = locate(); 390 size_t currentpos = locate();
392 if (endpos >= m_startpos) 391 if (endpos >= m_startpos)
393 { 392 {
394 jumpto(m_startpos); 393 jumpto(m_startpos);
395 for (int i = 0; i < m_startoffset; i++) 394 for (int i = 0; i < m_startoffset; i++)
396 { 395 {
397 getch(); 396 getch();
398 } 397 }
399 wrdstart = buffdoc.explocate(); 398 wrdstart = buffdoc.explocate();
400 if (m_startpos == endpos) 399 if (m_startpos == endpos)
401 { 400 {
402 for (int i = m_startoffset; i <= endoffset; i++) 401 for (int i = m_startoffset; i <= endoffset; i++)
403 { 402 {
404 wrd += QChar(getch()); 403 wrd += QChar(getch());
405 } 404 }
406 } 405 }
407 else 406 else
408 { 407 {
409 while (buffdoc.explocate() <= endpos) 408 while (buffdoc.explocate() <= endpos)
410 { 409 {
411 wrd += QChar(getch()); 410 wrd += QChar(getch());
412 } 411 }
413 for (int i = 0; i < endoffset; i++) 412 for (int i = 0; i < endoffset; i++)
414 { 413 {
415 wrd += QChar(getch()); 414 wrd += QChar(getch());
416 } 415 }
417 } 416 }
418 wrdend = buffdoc.explocate(); 417 wrdend = buffdoc.explocate();
419 jumpto(currentpos); 418 jumpto(currentpos);
420 } 419 }
421 } 420 }
422 } 421 }
423 else if (m_bMonoSpaced) 422 else if (m_bMonoSpaced)
424 { 423 {
425 int chno = (m_rotated) ? 424 int chno = (m_rotated) ?
426 (_e->y()-textarray[lineno]->offset(height(), m_left_border, m_right_border, availht))/m_charWidth 425 (_e->y()-textarray[lineno]->offset(height(), m_left_border, m_right_border, availht))/m_charWidth
427 : 426 :
428 (_e->x()-textarray[lineno]->offset(width(), m_left_border, m_right_border, availht))/m_charWidth; 427 (_e->x()-textarray[lineno]->offset(width(), m_left_border, m_right_border, availht))/m_charWidth;
429 if (chno < ustrlen(textarray[lineno]->data())) 428 if (chno < ustrlen(textarray[lineno]->data()))
430 { 429 {
431 wrd[0] = textarray[lineno]->data()[chno]; 430 wrd[0] = textarray[lineno]->data()[chno];
432 } 431 }
433 } 432 }
434 else 433 else
435 { 434 {
436 CDrawBuffer* t = textarray[lineno]; 435 CDrawBuffer* t = textarray[lineno];
437 int first = 0; 436 int first = 0;
438 int tgt = (m_rotated) ? 437 int tgt = (m_rotated) ?
439 _e->y() - t->offset(height(), m_left_border, m_right_border, availht) : 438 _e->y() - t->offset(height(), m_left_border, m_right_border, availht) :
440 _e->x() - t->offset(width(), m_left_border, m_right_border, availht); 439 _e->x() - t->offset(width(), m_left_border, m_right_border, availht);
441 while (1) 440 while (1)
442 { 441 {
443 int i = first+1; 442 int i = first+1;
444 int availht = ((m_rotated) ? width() : height()) - m_topmargin - m_bottommargin; 443 int availht = ((m_rotated) ? width() : height()) - m_topmargin - m_bottommargin;
445 while (QChar((*t)[i]).isLetter() && (*t)[i] != 0) i++; 444 while (QChar((*t)[i]).isLetter() && (*t)[i] != 0) i++;
446 if (t->width(availht, i, true, (m_rotated) ? height() : width(), m_left_border, m_right_border) > tgt) 445 if (t->width(availht, i, true, (m_rotated) ? height() : width(), m_left_border, m_right_border) > tgt)
447 { 446 {
448 wrd = toQString(t->data()+first, i - first); 447 wrd = toQString(t->data()+first, i - first);
449 // qDebug("Got %s", (const char *)wrd); 448 // qDebug("Got %s", (const char *)wrd);
450 break; 449 break;
451 } 450 }
452 while (!QChar((*t)[i]).isLetter() && (*t)[i] != 0) i++; 451 while (!QChar((*t)[i]).isLetter() && (*t)[i] != 0) i++;
453 if ((*t)[i] == 0) break; 452 if ((*t)[i] == 0) break;
454 first = i; 453 first = i;
455 } 454 }
456 } 455 }
457 if (!wrd.isEmpty()) 456 if (!wrd.isEmpty())
458 { 457 {
459 qDebug("Selecteed:%s", (const char*)wrd); 458 qDebug("Selecteed:%s", (const char*)wrd);
460 if (m_twotouch) 459 if (m_twotouch)
461 { 460 {
462 emit OnWordSelected(wrd, wrdstart, wrdend, wrd); 461 emit OnWordSelected(wrd, wrdstart, wrdend, wrd);
463 } 462 }
464 else 463 else
465 { 464 {
466 QString line = toQString(textarray[lineno]->data()); 465 QString line = toQString(textarray[lineno]->data());
467 emit OnWordSelected(wrd, locnarray[lineno], locnarray[lineno]+line.length(), line); 466 emit OnWordSelected(wrd, locnarray[lineno], locnarray[lineno]+line.length(), line);
468 } 467 }
469 } 468 }
470} 469}
471 470
472void QTReader::mouseReleaseEvent( QMouseEvent* _e ) 471void QTReader::mouseReleaseEvent( QMouseEvent* _e )
473{ 472{
474 buffdoc.unsuspend(); 473 buffdoc.unsuspend();
475 int x, y, ht, wh; 474 int x, y, ht, wh;
476 if (m_rotated) 475 if (m_rotated)
477 { 476 {
478 x = _e->y(); 477 x = _e->y();
479 y = width()-_e->x(); 478 y = width()-_e->x();
480 ht = width(); 479 ht = width();
481 wh = height(); 480 wh = height();
482 } 481 }
483 else 482 else
484 { 483 {
485 x = _e->x(); 484 x = _e->x();
486 y = _e->y(); 485 y = _e->y();
487 ht = height(); 486 ht = height();
488 wh = width(); 487 wh = width();
489 } 488 }
490 if (_e->button() == LeftButton) 489 if (_e->button() == LeftButton)
491 { 490 {
492 if (mouseUpOn) 491 if (mouseUpOn)
493 { 492 {
494 // qDebug("MouseRelease"); 493 // qDebug("MouseRelease");
495 switch(m_scrollpos) 494 switch(m_scrollpos)
496 { 495 {
497 case 1: // Bottom 496 case 1: // Bottom
498 if (y > ht - 5) 497 if (y > ht - 5)
499 { 498 {
500 locate(buffdoc.startSection()+((buffdoc.endSection()-buffdoc.startSection())*x+wh/2)/wh); 499 locate(buffdoc.startSection()+((buffdoc.endSection()-buffdoc.startSection())*x+wh/2)/wh);
501 return; 500 return;
502 } 501 }
503 break; 502 break;
504 case 2: // right 503 case 2: // right
505 if (x > wh - m_right_border) 504 if (x > wh - m_right_border)
506 { 505 {
507 locate(buffdoc.startSection()+((buffdoc.endSection()-buffdoc.startSection())*y+ht/2)/ht); 506 locate(buffdoc.startSection()+((buffdoc.endSection()-buffdoc.startSection())*y+ht/2)/ht);
508 return; 507 return;
509 } 508 }
510 break; 509 break;
511 case 3: // left 510 case 3: // left
512 if (x < m_left_border) 511 if (x < m_left_border)
513 { 512 {
514 locate(buffdoc.startSection()+((buffdoc.endSection()-buffdoc.startSection())*y+ht/2)/ht); 513 locate(buffdoc.startSection()+((buffdoc.endSection()-buffdoc.startSection())*y+ht/2)/ht);
515 return; 514 return;
516 } 515 }
517 break; 516 break;
518 case 0: 517 case 0:
519 default: 518 default:
520 break; 519 break;
521 } 520 }
522 if (textarray[0] != NULL) 521 if (textarray[0] != NULL)
523 { 522 {
524 QString line; 523 QString line;
525 // int lineno = _e->y()/m_linespacing; 524 // int lineno = _e->y()/m_linespacing;
526 int lineno = 0; 525 int lineno = 0;
527 /* 526 /*
528 int ht = textarray[0]->lineSpacing(); 527 int ht = textarray[0]->lineSpacing();
529 while ((ht < y) && (lineno < numlines)) 528 while ((ht < y) && (lineno < numlines))
530 { 529 {
531 ht += textarray[++lineno]->lineSpacing(); 530 ht += textarray[++lineno]->lineSpacing();
532 } 531 }
533 */ 532 */
534 size_t startpos, startoffset, tgt, tgtoffset, pictgt; 533 size_t startpos, startoffset, tgt, tgtoffset, pictgt;
535 QImage* img; 534 QImage* img;
536 if (m_currentlinkstyle != NULL) 535 if (m_currentlinkstyle != NULL)
537 { 536 {
538 textarray[m_currentlink]->invertLink(m_currentlinkoffset); 537 textarray[m_currentlink]->invertLink(m_currentlinkoffset);
539 m_currentlinkstyle = NULL; 538 m_currentlinkstyle = NULL;
540 m_currentlink = -1; 539 m_currentlink = -1;
541 m_currentlinkoffset = -1; 540 m_currentlinkoffset = -1;
542 } 541 }
543 linkType glt = getcurrentpos(x, y, wh, ht, lineno, startpos, startoffset, tgt, tgtoffset, pictgt, img); 542 linkType glt = getcurrentpos(x, y, wh, ht, lineno, startpos, startoffset, tgt, tgtoffset, pictgt, img);
544 if ((glt & eLink) != 0) 543 if ((glt & eLink) != 0)
545 { 544 {
546 if ((glt & ePicture) != 0) 545 if ((glt & ePicture) != 0)
547 { 546 {
548 qDebug("Big Picture:%x", pictgt); 547 qDebug("Big Picture:%x", pictgt);
549 if (QMessageBox::warning(this, PROGNAME, "Show picture or goto link?", "Show", "Goto Link") == 0) 548 if (QMessageBox::warning(this, PROGNAME, "Show picture or goto link?", "Show", "Goto Link") == 0)
550 { 549 {
551 QImage* pm = buffdoc.getPicture(pictgt); 550 QImage* pm = buffdoc.getPicture(pictgt);
552 if (pm != NULL) 551 if (pm != NULL)
553 { 552 {
554 emit OnShowPicture(*pm); 553 emit OnShowPicture(*pm);
555 delete pm; 554 delete pm;
556 return; 555 return;
557 } 556 }
558 } 557 }
559 } 558 }
560 else if (img != NULL) 559 else if (img != NULL)
561 { 560 {
562 if (QMessageBox::warning(this, PROGNAME, "Show picture or goto link?", "Show", "Goto Link") == 0) 561 if (QMessageBox::warning(this, PROGNAME, "Show picture or goto link?", "Show", "Goto Link") == 0)
563 { 562 {
564 emit OnShowPicture(*img); 563 emit OnShowPicture(*img);
565 return; 564 return;
566 } 565 }
567 } 566 }
568 size_t saveposn = pagelocate(); 567 size_t saveposn = pagelocate();
569 QString href, nm; 568 QString href, nm;
570 linkType lt = buffdoc.hyperlink(tgt, tgtoffset, href, nm); 569 linkType lt = buffdoc.hyperlink(tgt, tgtoffset, href, nm);
571 qDebug("URL(1):%s", (const char*)href); 570 qDebug("URL(1):%s", (const char*)href);
572 if ((lt & eFile) != 0) 571 if ((lt & eFile) != 0)
573 { 572 {
574 buffdoc.saveposn(m_lastfile, saveposn); 573 buffdoc.saveposn(m_lastfile, saveposn);
575#ifdef USEQPE 574#ifdef USEQPE
576 { 575 {
577 QCopEnvelope e("QPE/System", "busy()"); 576 QCopEnvelope e("QPE/System", "busy()");
578 } 577 }
579#endif 578#endif
580 ResetScroll(); 579 ResetScroll();
581 if (!href.isEmpty()) 580 if (!href.isEmpty())
582 { 581 {
583 if (!buffdoc.getFile(href)) 582 if (!buffdoc.getFile(href))
584 { 583 {
585 emit NewFileRequest(href); 584 emit NewFileRequest(href);
586 } 585 }
587 else 586 else
588 { 587 {
589 ResetScroll(); 588 ResetScroll();
590 fillbuffer(); 589 fillbuffer();
591 update(); 590 update();
592 } 591 }
593 } 592 }
594 if (!nm.isEmpty()) 593 if (!nm.isEmpty())
595 { 594 {
596 qDebug("QTReader:Finding %s", (const char*)nm); 595 qDebug("QTReader:Finding %s", (const char*)nm);
597 if (buffdoc.findanchor(nm)) 596 if (buffdoc.findanchor(nm))
598 { 597 {
599 fillbuffer(); 598 fillbuffer();
600 update(); 599 update();
601 } 600 }
602 } 601 }
603 //fillbuffer(); 602 //fillbuffer();
604 //update(); 603 //update();
605#ifdef USEQPE 604#ifdef USEQPE
606 { 605 {
607 QCopEnvelope e("QPE/System", "notBusy()"); 606 QCopEnvelope e("QPE/System", "notBusy()");
608 } 607 }
609#endif 608#endif
610 } 609 }
611 else if ((lt & eLink) != 0) 610 else if ((lt & eLink) != 0)
612 { 611 {
613 buffdoc.saveposn(m_lastfile, saveposn); 612 buffdoc.saveposn(m_lastfile, saveposn);
614 ResetScroll(); 613 ResetScroll();
615 fillbuffer(); 614 fillbuffer();
616 update(); 615 update();
617 } 616 }
618 else 617 else
619 { 618 {
620 if ((lt & ePicture) != 0) 619 if ((lt & ePicture) != 0)
621 { 620 {
622 QImage* pm = buffdoc.getPicture(tgt); 621 QImage* pm = buffdoc.getPicture(tgt);
623 if (pm != NULL) 622 if (pm != NULL)
624 { 623 {
625 emit OnShowPicture(*pm); 624 emit OnShowPicture(*pm);
626 delete pm; 625 delete pm;
627 } 626 }
628 } 627 }
629 else 628 else
630 { 629 {
631 // QString anchortext = textarray[lineno]->getanchortext(startoffset); 630 // QString anchortext = textarray[lineno]->getanchortext(startoffset);
632 if (!href.isEmpty()) 631 if (!href.isEmpty())
633 { 632 {
634 emit OnURLSelected(href, tgt); 633 emit OnURLSelected(href, tgt);
635 } 634 }
636 } 635 }
637 locate(pagelocate()); 636 locate(pagelocate());
638 } 637 }
639 return; 638 return;
640 } 639 }
641 else if ((glt & ePicture) != 0) 640 else if ((glt & ePicture) != 0)
642 { 641 {
643 qDebug("Big Picture:%x", pictgt); 642 qDebug("Big Picture:%x", pictgt);
644 QImage* pm = buffdoc.getPicture(pictgt); 643 QImage* pm = buffdoc.getPicture(pictgt);
645 if (pm != NULL) 644 if (pm != NULL)
646 { 645 {
647 emit OnShowPicture(*pm); 646 emit OnShowPicture(*pm);
648 delete pm; 647 delete pm;
649 } 648 }
650 else 649 else
651 { 650 {
652 locate(pagelocate()); 651 locate(pagelocate());
653 } 652 }
654 return; 653 return;
655 } 654 }
656 else if (img != NULL) 655 else if (img != NULL)
657 { 656 {
658 emit OnShowPicture(*img); 657 emit OnShowPicture(*img);
659 return; 658 return;
660 } 659 }
661 if (m_swapmouse) 660 if (m_swapmouse)
662 processmousepositionevent(_e); 661 processmousepositionevent(_e);
663 else 662 else
664 processmousewordevent(startpos, startoffset, _e, lineno); 663 processmousewordevent(startpos, startoffset, _e, lineno);
665 } 664 }
666 } 665 }
667 else 666 else
668 { 667 {
669 mouseUpOn = true; 668 mouseUpOn = true;
670 } 669 }
671 } 670 }
672} 671}
673 672
674void QTReader::focusInEvent(QFocusEvent* e) 673void QTReader::focusInEvent(QFocusEvent* e)
675{ 674{
676 if (m_autoScroll) timer->start(real_delay(), false); 675 if (m_autoScroll) timer->start(real_delay(), false);
677 update(); 676 update();
678} 677}
679 678
680void QTReader::focusOutEvent(QFocusEvent* e) 679void QTReader::focusOutEvent(QFocusEvent* e)
681{ 680{
682 if (m_autoScroll) 681 if (m_autoScroll)
683 { 682 {
684 timer->stop(); 683 timer->stop();
685 //m_scrolldy1 = m_scrolldy2 = 0; 684 //m_scrolldy1 = m_scrolldy2 = 0;
686 } 685 }
687} 686}
688 687
689#include <qapplication.h> 688#include <qapplication.h>
690#include <qdrawutil.h> 689#include <qdrawutil.h>
691#ifndef _WINDOWS 690#ifndef _WINDOWS
692#include <unistd.h> 691#include <unistd.h>
693#endif 692#endif
694 693
695void QTReader::goDown() 694void QTReader::goDown()
696{ 695{
697 if (m_bpagemode) 696 if (m_bpagemode)
698 { 697 {
699 dopagedn(); 698 dopagedn();
700 } 699 }
701 else 700 else
702 { 701 {
703 lineDown(); 702 lineDown();
704 } 703 }
705} 704}
706 705
707void QTReader::goUp() 706void QTReader::goUp()
708{ 707{
709 if (m_bpagemode) 708 if (m_bpagemode)
710 { 709 {
711 dopageup(); 710 dopageup();
712 } 711 }
713 else 712 else
714 { 713 {
715 lineUp(); 714 lineUp();
716 } 715 }
717} 716}
718 717
719void QTReader::NavUp() 718void QTReader::NavUp()
720{ 719{
721 buffdoc.unsuspend(); 720 buffdoc.unsuspend();
722 if (buffdoc.hasnavigation()) 721 if (buffdoc.hasnavigation())
723 { 722 {
724/* 723/*
725 size_t target = pagelocate(); 724 size_t target = pagelocate();
726 if (buffdoc.back(target)) 725 if (buffdoc.back(target))
727 { 726 {
728 locate(target); 727 locate(target);
729 } 728 }
730*/ 729*/
731 locate(buffdoc.startSection()); 730 locate(buffdoc.startSection());
732 } 731 }
733 else 732 else
734 { 733 {
735 goUp(); 734 goUp();
736 } 735 }
737} 736}
738 737
739void QTReader::NavDown() 738void QTReader::NavDown()
740{ 739{
741 buffdoc.unsuspend(); 740 buffdoc.unsuspend();
742 if (buffdoc.hasnavigation()) 741 if (buffdoc.hasnavigation())
743 { 742 {
744/* 743/*
745 size_t target = pagelocate(); 744 size_t target = pagelocate();
746 if (buffdoc.forward(target)) 745 if (buffdoc.forward(target))
747 { 746 {
748 locate(target); 747 locate(target);
749 } 748 }
750*/ 749*/
751 dopageup(buffdoc.endSection()); 750 dopageup(buffdoc.endSection());
752 } 751 }
753 else 752 else
754 { 753 {
755 goDown(); 754 goDown();
756 } 755 }
757} 756}
758 757
759void QTReader::zoomin() 758void QTReader::zoomin()
760{ 759{
761 if (m_fontControl.increasesize()) 760 if (m_fontControl.increasesize())
762 { 761 {
763 bool sc = m_autoScroll; 762 bool sc = m_autoScroll;
764 setautoscroll(false); 763 setautoscroll(false);
765 setfont(); 764 setfont();
766 locate(pagelocate()); 765 locate(pagelocate());
767 repaint(); 766 repaint();
768 setautoscroll(sc); 767 setautoscroll(sc);
769 } 768 }
770} 769}
771 770
772void QTReader::zoomout() 771void QTReader::zoomout()
773{ 772{
774 if (m_fontControl.decreasesize()) 773 if (m_fontControl.decreasesize())
775 { 774 {
776 bool sc = m_autoScroll; 775 bool sc = m_autoScroll;
777 setautoscroll(false); 776 setautoscroll(false);
778 setfont(); 777 setfont();
779 locate(pagelocate()); 778 locate(pagelocate());
780 repaint(); 779 repaint();
781 setautoscroll(sc); 780 setautoscroll(sc);
782 } 781 }
783} 782}
784 783
785void QTReader::reduceScroll() 784void QTReader::reduceScroll()
786{ 785{
787 if (m_delay < 59049) 786 if (m_delay < 59049)
788 { 787 {
789 m_delay = (3*m_delay)/2; 788 m_delay = (3*m_delay)/2;
790 timer->changeInterval(real_delay()); 789 timer->changeInterval(real_delay());
791 } 790 }
792 else 791 else
793 { 792 {
794 m_delay = 59049; 793 m_delay = 59049;
795 } 794 }
796} 795}
797 796
798void QTReader::increaseScroll() 797void QTReader::increaseScroll()
799{ 798{
800 if (m_delay > 454) 799 if (m_delay > 454)
801 { 800 {
802 m_delay = (2*m_delay)/3; 801 m_delay = (2*m_delay)/3;
803 timer->changeInterval(real_delay()); 802 timer->changeInterval(real_delay());
804 } 803 }
805 else 804 else
806 { 805 {
807 m_delay = 454; 806 m_delay = 454;
808 } 807 }
809} 808}
810 809
811void QTReader::keyPressEvent(QKeyEvent* e) 810void QTReader::keyPressEvent(QKeyEvent* e)
812{ 811{
813 buffdoc.unsuspend(); 812 buffdoc.unsuspend();
814 813
815 //((QTReaderApp*)parent()->parent())->handlekey(e); 814 //((QTReaderApp*)parent()->parent())->handlekey(e);
816 emit HandleKeyRequest(e); 815 emit HandleKeyRequest(e);
817// e->ignore(); 816// e->ignore();
818 return; 817 return;
819#ifdef _SCROLLPIPE 818#ifdef _SCROLLPIPE
820 if (m_isPaused) 819 if (m_isPaused)
821 { 820 {
822 m_isPaused = false; 821 m_isPaused = false;
823 if (e->key() != Key_Space) 822 if (e->key() != Key_Space)
824 { 823 {
825 m_autoScroll = false; 824 m_autoScroll = false;
826 if (m_pipeout != NULL) 825 if (m_pipeout != NULL)
827 { 826 {
828 pclose(m_pipeout); 827 pclose(m_pipeout);
829 m_pipeout = NULL; 828 m_pipeout = NULL;
830 } 829 }
831 //((QTReaderApp*)parent()->parent())->setScrollState(m_autoScroll); 830 //((QTReaderApp*)parent()->parent())->setScrollState(m_autoScroll);
832 emit SetScrollState(m_autoScroll); 831 emit SetScrollState(m_autoScroll);
833 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; 832 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable;
834 } 833 }
835 else 834 else
836 { 835 {
837 timer->start(real_delay(), false); 836 timer->start(real_delay(), false);
838 } 837 }
839 e->accept(); 838 e->accept();
840 return; 839 return;
841 } 840 }
842#endif 841#endif
843} 842}
844 843
845void QTReader::CalculateScrollParameters() 844void QTReader::CalculateScrollParameters()
846{ 845{
847 int bmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0); 846 int bmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0);
848 if (bmargin < m_bottommargin) bmargin = m_bottommargin; 847 if (bmargin < m_bottommargin) bmargin = m_bottommargin;
849 switch (m_scrolltype) 848 switch (m_scrolltype)
850 { 849 {
851 case 0: 850 case 0:
852 { 851 {
853 if (m_scrolldy == m_topmargin) 852 if (m_scrolldy == m_topmargin)
854 { 853 {
855 m_scrolldy1 = 0; 854 m_scrolldy1 = 0;
856 m_scrolldy2 = 0; 855 m_scrolldy2 = 0;
857 m_totalscroll = 0; 856 m_totalscroll = 0;
858 return; 857 return;
859 } 858 }
860 if (m_scrolldy < textarray[0]->lineSpacing()) 859 if (m_scrolldy < textarray[0]->lineSpacing())
861 { 860 {
862 m_scrolldy2 = m_scrolldy; 861 m_scrolldy2 = m_scrolldy;
863 return; 862 return;
864 } 863 }
865 int ht = m_scrolldy - m_scrolldy1; 864 int ht = m_scrolldy - m_scrolldy1;
866 int i; 865 int i;
867 for (i = 0; (ht < ((m_rotated) ? width() : height())-bmargin) && (i < numlines); i++) 866 for (i = 0; (ht < ((m_rotated) ? width() : height())-bmargin) && (i < numlines); i++)
868 { 867 {
869 ht += textarray[i]->lineSpacing(); 868 ht += textarray[i]->lineSpacing();
870 } 869 }
871 ht = 0; 870 ht = 0;
872 int j; 871 int j;
873 i--; 872 i--;
874 for (j = i; j < numlines; j++) 873 for (j = i; j < numlines; j++)
875 { 874 {
876 ht += textarray[j]->lineSpacing(); 875 ht += textarray[j]->lineSpacing();
877 } 876 }
878 ht -= ( 877 ht -= (
879 textarray[i]->lineExtraSpacing() 878 textarray[i]->lineExtraSpacing()
880 + 879 +
881 (i != 0) ? textarray[numlines-1]->lineExtraSpacing() : 0 880 (i != 0) ? textarray[numlines-1]->lineExtraSpacing() : 0
882 )/2-2; 881 )/2-2;
883 882
884 m_scrolldy2 = m_scrolldy-ht; 883 m_scrolldy2 = m_scrolldy-ht;
885 } 884 }
886 break; 885 break;
887 case 1: 886 case 1:
888 case 2: 887 case 2:
889 case 3: 888 case 3:
890 { 889 {
891 int ypos = m_topmargin; 890 int ypos = m_topmargin;
892 for (int i = 0; i < numlines; i++) 891 for (int i = 0; i < numlines; i++)
893 { 892 {
894 ypos += textarray[i]->lineSpacing(); 893 ypos += textarray[i]->lineSpacing();
895 } 894 }
896 ypos -= ( 895 ypos -= (
897 textarray[0]->lineExtraSpacing() 896 textarray[0]->lineExtraSpacing()
898 + 897 +
899 ((numlines > 1) ? textarray[numlines-1]->lineExtraSpacing() : 0) 898 ((numlines > 1) ? textarray[numlines-1]->lineExtraSpacing() : 0)
900 )/2 + 899 )/2 +
901 m_scrolldy1 - 2; 900 m_scrolldy1 - 2;
902 m_scrolldy2 = ((m_rotated) ? width() : height()) - ypos - bmargin; 901 m_scrolldy2 = ((m_rotated) ? width() : height()) - ypos - bmargin;
903 } 902 }
904 break; 903 break;
905 } 904 }
906} 905}
907 906
908void QTReader::setautoscroll(bool _sc) 907void QTReader::setautoscroll(bool _sc)
909{ 908{
910 if (_sc == m_autoScroll) return; 909 if (_sc == m_autoScroll) return;
911 if (m_autoScroll) 910 if (m_autoScroll)
912 { 911 {
913 m_autoScroll = false; 912 m_autoScroll = false;
914#ifdef USEQPE 913#ifdef USEQPE
915 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; 914 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable;
916#endif 915#endif
917#ifdef _SCROLLPIPE 916#ifdef _SCROLLPIPE
918 if (m_pipeout != NULL) 917 if (m_pipeout != NULL)
919 { 918 {
920 pclose(m_pipeout); 919 pclose(m_pipeout);
921 m_pipeout = NULL; 920 m_pipeout = NULL;
922 } 921 }
923#endif 922#endif
924 //m_scrolldy1 = 0; 923 //m_scrolldy1 = 0;
925 //refresh(); 924 //refresh();
926 } 925 }
927 else 926 else
928 { 927 {
929 CDrawBuffer* reusebuffer = textarray[numlines]; 928 CDrawBuffer* reusebuffer = textarray[numlines];
930 if (reusebuffer == NULL || reusebuffer->eof()) return; 929 if (reusebuffer == NULL || reusebuffer->eof()) return;
931 m_autoScroll = true; 930 m_autoScroll = true;
932 CalculateScrollParameters(); 931 CalculateScrollParameters();
933 932
934#ifdef _SCROLLPIPE 933#ifdef _SCROLLPIPE
935 if (!m_pipetarget.isEmpty()) 934 if (!m_pipetarget.isEmpty())
936 { 935 {
937 // qDebug("Opening pipe to %s", (const char*)m_pipetarget); 936 // qDebug("Opening pipe to %s", (const char*)m_pipetarget);
938 m_pipeout = popen((const char*)m_pipetarget, "w"); 937 m_pipeout = popen((const char*)m_pipetarget, "w");
939 m_isPaused = false; 938 m_isPaused = false;
940 } 939 }
941#endif 940#endif
942 autoscroll(); 941 autoscroll();
943#ifdef USEQPE 942#ifdef USEQPE
944 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Disable; // light is even not dimmed 943 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Disable; // light is even not dimmed
945#endif 944#endif
946 } 945 }
947} 946}
948 947
949bool QTReader::getline(CDrawBuffer *buff) 948bool QTReader::getline(CDrawBuffer *buff)
950{ 949{
951 buffdoc.unsuspend(); 950 buffdoc.unsuspend();
952 bool bRet; 951 bool bRet;
953 int availht = ((m_rotated) ? width() : height()) - m_topmargin - m_bottommargin; 952 int availht = ((m_rotated) ? width() : height()) - m_topmargin - m_bottommargin;
954 if (m_bMonoSpaced) 953 if (m_bMonoSpaced)
955 { 954 {
956 bRet = buffdoc.getline(buff ,(m_rotated) ? height() : width(), m_charWidth, m_left_border, m_right_border, availht); 955 bRet = buffdoc.getline(buff ,(m_rotated) ? height() : width(), m_charWidth, m_left_border, m_right_border, availht);
957 } 956 }
958 else 957 else
959 { 958 {
960 bRet = buffdoc.getline(buff, (m_rotated) ? height() : width(), m_left_border, m_right_border, hyphenate, availht); 959 bRet = buffdoc.getline(buff, (m_rotated) ? height() : width(), m_left_border, m_right_border, hyphenate, availht);
961 } 960 }
962 buff->resize(availht); 961 buff->resize(availht);
963 return bRet; 962 return bRet;
964} 963}
965 964
966void QTReader::doscroll() 965void QTReader::doscroll()
967{ 966{
968 if (!m_autoScroll) 967 if (!m_autoScroll)
969 { 968 {
970 timer->stop(); 969 timer->stop();
971 return; 970 return;
972 } 971 }
973 switch (m_scrolltype) 972 switch (m_scrolltype)
974 { 973 {
975 case 0: 974 case 0:
976 doinplacescroll(); 975 doinplacescroll();
977 break; 976 break;
978 case 1: 977 case 1:
979 dorollingscroll(false); 978 dorollingscroll(false);
980 break; 979 break;
981 case 2: 980 case 2:
982 dorollingscroll(true); 981 dorollingscroll(true);
983 break; 982 break;
984 case 3: 983 case 3:
985 dostaticscroll(); 984 dostaticscroll();
986 break; 985 break;
987 } 986 }
988} 987}
989 988
990void QTReader::doinplacescroll() 989void QTReader::doinplacescroll()
991{ 990{
992 QPainter p( this ); 991 QPainter p( this );
993 // p.setBackgroundMode(OpaqueMode); 992 // p.setBackgroundMode(OpaqueMode);
994 int wh, ht; 993 int wh, ht;
995 int bmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0); 994 int bmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0);
996 if (bmargin < m_bottommargin) bmargin = m_bottommargin; 995 if (bmargin < m_bottommargin) bmargin = m_bottommargin;
997 if (m_rotated) 996 if (m_rotated)
998 { 997 {
999 ht = width()-bmargin; 998 ht = width()-bmargin;
1000 wh = height(); 999 wh = height();
1001 } 1000 }
1002 else 1001 else
1003 { 1002 {
1004 ht = height()-bmargin; 1003 ht = height()-bmargin;
1005 wh = width(); 1004 wh = width();
1006 } 1005 }
1007 int lastdy = m_scrolldy; 1006 int lastdy = m_scrolldy;
1008 m_scrolldy += m_scrollstep; 1007 m_scrolldy += m_scrollstep;
1009 if ((m_scrolldy1 = m_scrolldy1+m_scrollstep) >= textarray[0]->lineSpacing()) 1008 if ((m_scrolldy1 = m_scrolldy1+m_scrollstep) >= textarray[0]->lineSpacing())
1010 { 1009 {
1011 int ht = textarray[0]->lineSpacing(); 1010 int ht = textarray[0]->lineSpacing();
1012#ifdef _SCROLLPIPE 1011#ifdef _SCROLLPIPE
1013 if (m_pipeout != NULL) 1012 if (m_pipeout != NULL)
1014 { 1013 {
1015 QString outstr = toQString(textarray[0]->data()); 1014 QString outstr = toQString(textarray[0]->data());
1016 if (!outstr.isEmpty()) 1015 if (!outstr.isEmpty())
1017 { 1016 {
1018 fprintf(m_pipeout, "%s\n", (const char*)outstr); 1017 fprintf(m_pipeout, "%s\n", (const char*)outstr);
1019 fflush(m_pipeout); 1018 fflush(m_pipeout);
1020 } 1019 }
1021 else if (m_pauseAfterEachPara) 1020 else if (m_pauseAfterEachPara)
1022 { 1021 {
1023 m_isPaused = true; 1022 m_isPaused = true;
1024 timer->stop(); 1023 timer->stop();
1025 } 1024 }
1026 } 1025 }
1027#endif 1026#endif
1028 CDrawBuffer* buff = textarray[0]; 1027 CDrawBuffer* buff = textarray[0];
1029 for (int i = 1; i <= numlines; i++) 1028 for (int i = 1; i <= numlines; i++)
1030 { 1029 {
1031 textarray[i-1] = textarray[i]; 1030 textarray[i-1] = textarray[i];
1032 locnarray[i-1] = locnarray[i]; 1031 locnarray[i-1] = locnarray[i];
1033 } 1032 }
1034 textarray[numlines] = buff; 1033 textarray[numlines] = buff;
1035 --numlines; 1034 --numlines;
1036 m_scrolldy1 -= ht; 1035 m_scrolldy1 -= ht;
1037 } 1036 }
1038 if ((m_scrolldy2 = m_scrolldy2+m_scrollstep) >= textarray[numlines]->lineSpacing()) 1037 if ((m_scrolldy2 = m_scrolldy2+m_scrollstep) >= textarray[numlines]->lineSpacing())
1039 { 1038 {
1040 m_scrolldy2 -= textarray[numlines]->lineSpacing(); 1039 m_scrolldy2 -= textarray[numlines]->lineSpacing();
1041 numlines++; 1040 numlines++;
1042 1041
1043 if (textarray[numlines] == NULL) 1042 if (textarray[numlines] == NULL)
1044 { 1043 {
1045 textarray[numlines] = new CDrawBuffer(&m_fontControl); 1044 textarray[numlines] = new CDrawBuffer(&m_fontControl);
1046 } 1045 }
1047 locnarray[numlines] = locate(); 1046 locnarray[numlines] = locate();
1048 int ch = getline(textarray[numlines]); 1047 int ch = getline(textarray[numlines]);
1049 if (m_rotated) 1048 if (m_rotated)
1050 { 1049 {
1051 blitRot(width()-m_scrolldy, 0, height(), -1, textarray[numlines-1]); 1050 blitRot(width()-m_scrolldy, 0, height(), -1, textarray[numlines-1]);
1052 } 1051 }
1053 else 1052 else
1054 { 1053 {
1055 if (m_bgpm.isNull()) 1054 if (m_bgpm.isNull())
1056 { 1055 {
1057 p.fillRect(m_left_border,m_scrolldy-textarray[numlines-1]->lineSpacing(),width()-(m_left_border+m_right_border),textarray[numlines-1]->lineSpacing(),m_bg); 1056 p.fillRect(m_left_border,m_scrolldy-textarray[numlines-1]->lineSpacing(),width()-(m_left_border+m_right_border),textarray[numlines-1]->lineSpacing(),m_bg);
1058 } 1057 }
1059 else 1058 else
1060 { 1059 {
1061 int h_tmp = textarray[numlines-1]->lineSpacing(); 1060 int h_tmp = textarray[numlines-1]->lineSpacing();
1062 bitBlt(this, m_left_border, m_scrolldy-h_tmp, dbuff, m_left_border, m_scrolldy-h_tmp, width()-(m_left_border+m_right_border), h_tmp); 1061 bitBlt(this, m_left_border, m_scrolldy-h_tmp, dbuff, m_left_border, m_scrolldy-h_tmp, width()-(m_left_border+m_right_border), h_tmp);
1063 } 1062 }
1064 textarray[numlines-1]->render(&p, m_scrolldy -textarray[numlines-1]->lineSpacing()+ textarray[numlines-1]->ascent(), m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin); 1063 textarray[numlines-1]->render(&p, m_scrolldy -textarray[numlines-1]->lineSpacing()+ textarray[numlines-1]->ascent(), m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin);
1065 } 1064 }
1066 mylastpos = locate(); 1065 mylastpos = locate();
1067 if (!ch) 1066 if (!ch)
1068 { 1067 {
1069 /* 1068 /*
1070 if (m_rotated) 1069 if (m_rotated)
1071 { 1070 {
1072 blitRot2(0,0,height(),width()-m_scrolldy,NULL); 1071 blitRot2(0,0,height(),width()-m_scrolldy,NULL);
1073 // blitRot2(0,0,0,height(),width()-m_scrolldy,NULL); 1072 // blitRot2(0,0,0,height(),width()-m_scrolldy,NULL);
1074 } 1073 }
1075 else 1074 else
1076 { 1075 {
1077 if (m_bgpm.isNull()) 1076 if (m_bgpm.isNull())
1078 { 1077 {
1079 p.fillRect(0,m_scrolldy,width(),height()-m_scrolldy,m_bg); 1078 p.fillRect(0,m_scrolldy,width(),height()-m_scrolldy,m_bg);
1080 } 1079 }
1081 else 1080 else
1082 { 1081 {
1083 bitBlt(this, 0, m_scrolldy, dbuff, 0, m_scrolldy, width(), height()-m_scrolldy); 1082 bitBlt(this, 0, m_scrolldy, dbuff, 0, m_scrolldy, width(), height()-m_scrolldy);
1084 } 1083 }
1085 } 1084 }
1086 */ 1085 */
1087 m_scrolldy = m_topmargin; 1086 m_scrolldy = m_topmargin;
1088 m_autoScroll = false; 1087 m_autoScroll = false;
1089#ifdef _SCROLLPIPE 1088#ifdef _SCROLLPIPE
1090 for (int i = 0; i < numlines; i++) 1089 for (int i = 0; i < numlines; i++)
1091 { 1090 {
1092 if (m_pipeout != NULL) 1091 if (m_pipeout != NULL)
1093 { 1092 {
1094 QString outstr = toQString(textarray[i]->data()); 1093 QString outstr = toQString(textarray[i]->data());
1095 if (!outstr.isEmpty()) 1094 if (!outstr.isEmpty())
1096 { 1095 {
1097 fprintf(m_pipeout, "%s\n", (const char*)outstr); 1096 fprintf(m_pipeout, "%s\n", (const char*)outstr);
1098 fflush(m_pipeout); 1097 fflush(m_pipeout);
1099 } 1098 }
1100 } 1099 }
1101 } 1100 }
1102#endif 1101#endif
1103 //((QTReaderApp*)parent()->parent())->setScrollState(m_autoScroll); 1102 //((QTReaderApp*)parent()->parent())->setScrollState(m_autoScroll);
1104 emit SetScrollState(m_autoScroll); 1103 emit SetScrollState(m_autoScroll);
1105#ifdef USEQPE 1104#ifdef USEQPE
1106 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; 1105 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable;
1107#endif 1106#endif
1108 } 1107 }
1109 if (m_scrolldy > ht-textarray[numlines]->lineSpacing()) 1108 if (m_scrolldy > ht-textarray[numlines]->lineSpacing())
1110 { 1109 {
1111 if (m_rotated) 1110 if (m_rotated)
1112 { 1111 {
1113 if (m_bgpm.isNull()) 1112 if (m_bgpm.isNull())
1114 { 1113 {
1115 p.fillRect(bmargin, m_left_border, ht-m_scrolldy, wh-(m_left_border+m_right_border), m_bg); 1114 p.fillRect(bmargin, m_left_border, ht-m_scrolldy, wh-(m_left_border+m_right_border), m_bg);
1116 } 1115 }
1117 else 1116 else
1118 { 1117 {
1119 blitRot(bmargin, 0,height(), ht-m_scrolldy, NULL); 1118 blitRot(bmargin, 0,height(), ht-m_scrolldy, NULL);
1120 } 1119 }
1121 } 1120 }
1122 else 1121 else
1123 if (m_bgpm.isNull()) 1122 if (m_bgpm.isNull())
1124 { 1123 {
1125 p.fillRect(m_left_border,m_scrolldy,width()-(m_left_border+m_right_border),height()-m_scrolldy,m_bg); 1124 p.fillRect(m_left_border,m_scrolldy,width()-(m_left_border+m_right_border),height()-m_scrolldy,m_bg);
1126 } 1125 }
1127 else 1126 else
1128 { 1127 {
1129 bitBlt(this,m_left_border,m_scrolldy,dbuff,m_left_border,m_scrolldy,width()-(m_left_border+m_right_border), height()-m_scrolldy); 1128 bitBlt(this,m_left_border,m_scrolldy,dbuff,m_left_border,m_scrolldy,width()-(m_left_border+m_right_border), height()-m_scrolldy);
1130 } 1129 }
1131 m_scrolldy = m_topmargin; 1130 m_scrolldy = m_topmargin;
1132 m_scrolldy2 = 0; 1131 m_scrolldy2 = 0;
1133 } 1132 }
1134 redrawScroll(&p); 1133 redrawScroll(&p);
1135 emitRedraw(); 1134 emitRedraw();
1136 lastdy = -1; 1135 lastdy = -1;
1137 } 1136 }
1138 // else 1137 // else
1139 { 1138 {
1140 if (m_rotated) 1139 if (m_rotated)
1141 { 1140 {
1142 if (lastdy >= 0) 1141 if (lastdy >= 0)
1143 { 1142 {
1144 if (m_bgpm.isNull()) 1143 if (m_bgpm.isNull())
1145 { 1144 {
1146 p.fillRect(width()-lastdy, m_left_border, m_scrollstep, wh-(m_left_border+m_right_border),m_bg); 1145 p.fillRect(width()-lastdy, m_left_border, m_scrollstep, wh-(m_left_border+m_right_border),m_bg);
1147 } 1146 }
1148 else 1147 else
1149 { 1148 {
1150 blitRot(width()-lastdy,m_left_border,wh-(m_left_border+m_right_border), m_scrollstep, NULL); 1149 blitRot(width()-lastdy,m_left_border,wh-(m_left_border+m_right_border), m_scrollstep, NULL);
1151 } 1150 }
1152 } 1151 }
1153 p.fillRect(width()-m_scrolldy, m_left_border, 1,wh-(m_left_border+m_right_border),m_scrollcolor); 1152 p.fillRect(width()-m_scrolldy, m_left_border, 1,wh-(m_left_border+m_right_border),m_scrollcolor);
1154 } 1153 }
1155 else 1154 else
1156 { 1155 {
1157 if (lastdy >= 0) 1156 if (lastdy >= 0)
1158 { 1157 {
1159 if (m_bgpm.isNull()) 1158 if (m_bgpm.isNull())
1160 { 1159 {
1161 p.fillRect(m_left_border,lastdy,width()-(m_left_border+m_right_border),m_scrollstep,m_bg); 1160 p.fillRect(m_left_border,lastdy,width()-(m_left_border+m_right_border),m_scrollstep,m_bg);
1162 } 1161 }
1163 else 1162 else
1164 { 1163 {
1165 bitBlt(this, m_left_border, lastdy, dbuff, m_left_border, lastdy, width()-(m_left_border+m_right_border), m_scrollstep); 1164 bitBlt(this, m_left_border, lastdy, dbuff, m_left_border, lastdy, width()-(m_left_border+m_right_border), m_scrollstep);
1166 } 1165 }
1167 } 1166 }
1168 p.fillRect(m_left_border,m_scrolldy,width()-(m_left_border+m_right_border),1,m_scrollcolor); 1167 p.fillRect(m_left_border,m_scrolldy,width()-(m_left_border+m_right_border),1,m_scrollcolor);
1169 } 1168 }
1170 } 1169 }
1171} 1170}
1172 1171
1173void QTReader::dorollingscroll(bool _statbord) 1172void QTReader::dorollingscroll(bool _statbord)
1174{ 1173{
1175 bool bredrawscroll = false; 1174 bool bredrawscroll = false;
1176 QPainter p( this ); 1175 QPainter p( this );
1177 // 2 = right, 3 = left 1176 // 2 = right, 3 = left
1178 int tmargin = (_statbord) ? m_topmargin : 0; 1177 int tmargin = (_statbord) ? m_topmargin : 0;
1179 int lmargin = (m_scrollpos == 3 || _statbord) ? m_left_border : 0; 1178 int lmargin = (m_scrollpos == 3 || _statbord) ? m_left_border : 0;
1180 int rmargin = (m_scrollpos == 2 || _statbord) ? m_right_border : 0; 1179 int rmargin = (m_scrollpos == 2 || _statbord) ? m_right_border : 0;
1181 int hmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0); 1180 int hmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0);
1182 if (hmargin < m_bottommargin) hmargin = m_bottommargin; 1181 if (hmargin < m_bottommargin) hmargin = m_bottommargin;
1183 if (m_rotated) 1182 if (m_rotated)
1184 { 1183 {
1185 m_totalscroll = (m_totalscroll+m_scrollstep) % width(); 1184 m_totalscroll = (m_totalscroll+m_scrollstep) % width();
1186 bitBlt(this, m_scrollstep+hmargin, lmargin, this, hmargin, lmargin, width()-tmargin-hmargin, height()-(lmargin+rmargin)); 1185 bitBlt(this, m_scrollstep+hmargin, lmargin, this, hmargin, lmargin, width()-tmargin-hmargin, height()-(lmargin+rmargin));
1187 if (!m_bgpm.isNull()) 1186 if (!m_bgpm.isNull())
1188 { 1187 {
1189 blitRot(hmargin, tmargin, height(), m_scrollstep, NULL); 1188 blitRot(hmargin, tmargin, height(), m_scrollstep, NULL);
1190 } 1189 }
1191 else 1190 else
1192 { 1191 {
1193 p.fillRect(hmargin, rmargin, m_scrollstep, height()-lmargin-rmargin, m_bg); 1192 p.fillRect(hmargin, rmargin, m_scrollstep, height()-lmargin-rmargin, m_bg);
1194 } 1193 }
1195 } 1194 }
1196 else 1195 else
1197 { 1196 {
1198 m_totalscroll = (m_totalscroll+m_scrollstep) % height(); 1197 m_totalscroll = (m_totalscroll+m_scrollstep) % height();
1199 bitBlt(this,lmargin,tmargin,this,lmargin,tmargin+m_scrollstep,width()-(lmargin+rmargin),height() - tmargin - hmargin - m_scrollstep); 1198 bitBlt(this,lmargin,tmargin,this,lmargin,tmargin+m_scrollstep,width()-(lmargin+rmargin),height() - tmargin - hmargin - m_scrollstep);
1200 if (m_bgpm.isNull()) 1199 if (m_bgpm.isNull())
1201 { 1200 {
1202 p.fillRect(0, height() - (m_scrollstep+1) - hmargin, width(), (m_scrollstep+1), m_bg); 1201 p.fillRect(0, height() - (m_scrollstep+1) - hmargin, width(), (m_scrollstep+1), m_bg);
1203 } 1202 }
1204 else 1203 else
1205 { 1204 {
1206 int loff = (_statbord) ? 0 : m_totalscroll; 1205 int loff = (_statbord) ? 0 : m_totalscroll;
1207 bitBlt(this,0,height() - (m_scrollstep+1) - hmargin, dbuff, 0, (loff+height() - (m_scrollstep+1) - hmargin) % height(), width(), (m_scrollstep+1)); 1206 bitBlt(this,0,height() - (m_scrollstep+1) - hmargin, dbuff, 0, (loff+height() - (m_scrollstep+1) - hmargin) % height(), width(), (m_scrollstep+1));
1208 } 1207 }
1209 } 1208 }
1210 1209
1211 if ((m_scrolldy1 = m_scrolldy1+m_scrollstep) >= textarray[0]->lineSpacing()) 1210 if ((m_scrolldy1 = m_scrolldy1+m_scrollstep) >= textarray[0]->lineSpacing())
1212 { 1211 {
1213 int ht = textarray[0]->lineSpacing(); 1212 int ht = textarray[0]->lineSpacing();
1214 bredrawscroll = true; 1213 bredrawscroll = true;
1215#ifdef _SCROLLPIPE 1214#ifdef _SCROLLPIPE
1216 if (m_pipeout != NULL) 1215 if (m_pipeout != NULL)
1217 { 1216 {
1218 QString outstr = toQString(textarray[0]->data()); 1217 QString outstr = toQString(textarray[0]->data());
1219 if (!outstr.isEmpty()) 1218 if (!outstr.isEmpty())
1220 { 1219 {
1221 fprintf(m_pipeout, "%s\n", (const char*)outstr); 1220 fprintf(m_pipeout, "%s\n", (const char*)outstr);
1222 fflush(m_pipeout); 1221 fflush(m_pipeout);
1223 } 1222 }
1224 else if (m_pauseAfterEachPara) 1223 else if (m_pauseAfterEachPara)
1225 { 1224 {
1226 m_isPaused = true; 1225 m_isPaused = true;
1227 timer->stop(); 1226 timer->stop();
1228 } 1227 }
1229 } 1228 }
1230#endif 1229#endif
1231 CDrawBuffer* buff = textarray[0]; 1230 CDrawBuffer* buff = textarray[0];
1232 for (int i = 1; i <= numlines; i++) 1231 for (int i = 1; i <= numlines; i++)
1233 { 1232 {
1234 textarray[i-1] = textarray[i]; 1233 textarray[i-1] = textarray[i];
1235 locnarray[i-1] = locnarray[i]; 1234 locnarray[i-1] = locnarray[i];
1236 } 1235 }
1237 textarray[numlines] = buff; 1236 textarray[numlines] = buff;
1238 --numlines; 1237 --numlines;
1239 m_scrolldy1 -= ht; 1238 m_scrolldy1 -= ht;
1240 } 1239 }
1241 if ((m_scrolldy2 = m_scrolldy2+m_scrollstep) >= textarray[numlines]->lineSpacing()) 1240 if ((m_scrolldy2 = m_scrolldy2+m_scrollstep) >= textarray[numlines]->lineSpacing())
1242 { 1241 {
1243 bredrawscroll = true; 1242 bredrawscroll = true;
1244 m_scrolldy2 -= textarray[numlines]->lineSpacing(); 1243 m_scrolldy2 -= textarray[numlines]->lineSpacing();
1245 numlines++; 1244 numlines++;
1246 1245
1247 if (textarray[numlines] == NULL) 1246 if (textarray[numlines] == NULL)
1248 { 1247 {
1249 textarray[numlines] = new CDrawBuffer(&m_fontControl); 1248 textarray[numlines] = new CDrawBuffer(&m_fontControl);
1250 } 1249 }
1251 locnarray[numlines] = locate(); 1250 locnarray[numlines] = locate();
1252 int ch = getline(textarray[numlines]); 1251 int ch = getline(textarray[numlines]);
1253 if (m_rotated) 1252 if (m_rotated)
1254 { 1253 {
1255 blitRot(hmargin, 0, height(), -1, textarray[numlines-1]); 1254 blitRot(hmargin, 0, height(), -1, textarray[numlines-1]);
1256 } 1255 }
1257 else 1256 else
1258 { 1257 {
1259 // textarray[numlines-1]->render(&p, height() - textarray[numlines-1]->descent() - 2 - hmargin, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg); 1258 // textarray[numlines-1]->render(&p, height() - textarray[numlines-1]->descent() - 2 - hmargin, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg);
1260 textarray[numlines-1]->render(&p, height() - textarray[numlines-1]->descent() - textarray[numlines-1]->lineExtraSpacing() - 1 - hmargin, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin); 1259 textarray[numlines-1]->render(&p, height() - textarray[numlines-1]->descent() - textarray[numlines-1]->lineExtraSpacing() - 1 - hmargin, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin);
1261 1260
1262 } 1261 }
1263 mylastpos = locate(); 1262 mylastpos = locate();
1264 if (!ch) 1263 if (!ch)
1265 { 1264 {
1266 redrawScroll(&p); 1265 redrawScroll(&p);
1267 emitRedraw(); 1266 emitRedraw();
1268 m_autoScroll = false; 1267 m_autoScroll = false;
1269#ifdef _SCROLLPIPE 1268#ifdef _SCROLLPIPE
1270 for (int i = 0; i < numlines; i++) 1269 for (int i = 0; i < numlines; i++)
1271 { 1270 {
1272 if (m_pipeout != NULL) 1271 if (m_pipeout != NULL)
1273 { 1272 {
1274 QString outstr = toQString(textarray[i]->data()); 1273 QString outstr = toQString(textarray[i]->data());
1275 if (!outstr.isEmpty()) 1274 if (!outstr.isEmpty())
1276 { 1275 {
1277 fprintf(m_pipeout, "%s\n", (const char*)outstr); 1276 fprintf(m_pipeout, "%s\n", (const char*)outstr);
1278 fflush(m_pipeout); 1277 fflush(m_pipeout);
1279 } 1278 }
1280 } 1279 }
1281 } 1280 }
1282#endif 1281#endif
1283 emit SetScrollState(m_autoScroll); 1282 emit SetScrollState(m_autoScroll);
1284#ifdef USEQPE 1283#ifdef USEQPE
1285 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; 1284 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable;
1286#endif 1285#endif
1287 return; 1286 return;
1288 } 1287 }
1289 } 1288 }
1290 if (!bredrawscroll && ((m_scrolldy2/m_scrollstep) % 10 == 5) && textarray[numlines]->showPartial()) 1289 if (!bredrawscroll && ((m_scrolldy2/m_scrollstep) % 10 == 5) && textarray[numlines]->showPartial())
1291 { 1290 {
1292 if (m_rotated) 1291 if (m_rotated)
1293 { 1292 {
1294 blitRot(hmargin + m_scrolldy2 - textarray[numlines]->lineSpacing(), 0, height(), -1, textarray[numlines]); 1293 blitRot(hmargin + m_scrolldy2 - textarray[numlines]->lineSpacing(), 0, height(), -1, textarray[numlines]);
1295 } 1294 }
1296 else 1295 else
1297 { 1296 {
1298 textarray[numlines]->render( &p, height() + textarray[numlines]->lineSpacing() - textarray[numlines]->descent() - 2 - hmargin-m_scrolldy2, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin); 1297 textarray[numlines]->render( &p, height() + textarray[numlines]->lineSpacing() - textarray[numlines]->descent() - 2 - hmargin-m_scrolldy2, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin);
1299 } 1298 }
1300 } 1299 }
1301 if (m_scrollpos != 0) 1300 if (m_scrollpos != 0)
1302 { 1301 {
1303 redrawScroll(&p); 1302 redrawScroll(&p);
1304 } 1303 }
1305 if (bredrawscroll) emitRedraw(); 1304 if (bredrawscroll) emitRedraw();
1306} 1305}
1307 1306
1308void QTReader::dostaticscroll() 1307void QTReader::dostaticscroll()
1309{ 1308{
1310 redrawall(); 1309 redrawall();
1311 bool bredraw = false; 1310 bool bredraw = false;
1312 if ((m_scrolldy1 = m_scrolldy1+m_scrollstep) >= textarray[0]->lineSpacing()) 1311 if ((m_scrolldy1 = m_scrolldy1+m_scrollstep) >= textarray[0]->lineSpacing())
1313 { 1312 {
1314 int ht = textarray[0]->lineSpacing(); 1313 int ht = textarray[0]->lineSpacing();
1315 bredraw = true; 1314 bredraw = true;
1316#ifdef _SCROLLPIPE 1315#ifdef _SCROLLPIPE
1317 if (m_pipeout != NULL) 1316 if (m_pipeout != NULL)
1318 { 1317 {
1319 QString outstr = toQString(textarray[0]->data()); 1318 QString outstr = toQString(textarray[0]->data());
1320 if (!outstr.isEmpty()) 1319 if (!outstr.isEmpty())
1321 { 1320 {
1322 fprintf(m_pipeout, "%s\n", (const char*)outstr); 1321 fprintf(m_pipeout, "%s\n", (const char*)outstr);
1323 fflush(m_pipeout); 1322 fflush(m_pipeout);
1324 } 1323 }
1325 else if (m_pauseAfterEachPara) 1324 else if (m_pauseAfterEachPara)
1326 { 1325 {
1327 m_isPaused = true; 1326 m_isPaused = true;
1328 timer->stop(); 1327 timer->stop();
1329 } 1328 }
1330 } 1329 }
1331#endif 1330#endif
1332 CDrawBuffer* buff = textarray[0]; 1331 CDrawBuffer* buff = textarray[0];
1333 for (int i = 1; i <= numlines; i++) 1332 for (int i = 1; i <= numlines; i++)
1334 { 1333 {
1335 textarray[i-1] = textarray[i]; 1334 textarray[i-1] = textarray[i];
1336 locnarray[i-1] = locnarray[i]; 1335 locnarray[i-1] = locnarray[i];
1337 } 1336 }
1338 textarray[numlines] = buff; 1337 textarray[numlines] = buff;
1339 --numlines; 1338 --numlines;
1340 m_scrolldy1 -= ht; 1339 m_scrolldy1 -= ht;
1341 } 1340 }
1342 if ((m_scrolldy2 = m_scrolldy2 + m_scrollstep) >= textarray[numlines]->lineSpacing()) 1341 if ((m_scrolldy2 = m_scrolldy2 + m_scrollstep) >= textarray[numlines]->lineSpacing())
1343 { 1342 {
1344 bredraw = true; 1343 bredraw = true;
1345 m_scrolldy2 -= textarray[numlines]->lineSpacing(); 1344 m_scrolldy2 -= textarray[numlines]->lineSpacing();
1346 numlines++; 1345 numlines++;
1347 1346
1348 if (textarray[numlines] == NULL) 1347 if (textarray[numlines] == NULL)
1349 { 1348 {
1350 textarray[numlines] = new CDrawBuffer(&m_fontControl); 1349 textarray[numlines] = new CDrawBuffer(&m_fontControl);
1351 } 1350 }
1352 locnarray[numlines] = locate(); 1351 locnarray[numlines] = locate();
1353 int ch = getline(textarray[numlines]); 1352 int ch = getline(textarray[numlines]);
1354 mylastpos = locate(); 1353 mylastpos = locate();
1355 if (!ch) 1354 if (!ch)
1356 { 1355 {
1357 redrawall(); 1356 redrawall();
1358 emitRedraw(); 1357 emitRedraw();
1359 m_autoScroll = false; 1358 m_autoScroll = false;
1360#ifdef _SCROLLPIPE 1359#ifdef _SCROLLPIPE
1361 for (int i = 0; i < numlines; i++) 1360 for (int i = 0; i < numlines; i++)
1362 { 1361 {
1363 if (m_pipeout != NULL) 1362 if (m_pipeout != NULL)
1364 { 1363 {
1365 QString outstr = toQString(textarray[i]->data()); 1364 QString outstr = toQString(textarray[i]->data());
1366 if (!outstr.isEmpty()) 1365 if (!outstr.isEmpty())
1367 { 1366 {
1368 fprintf(m_pipeout, "%s\n", (const char*)outstr); 1367 fprintf(m_pipeout, "%s\n", (const char*)outstr);
1369 fflush(m_pipeout); 1368 fflush(m_pipeout);
1370 } 1369 }
1371 } 1370 }
1372 } 1371 }
1373#endif 1372#endif
1374 emit SetScrollState(m_autoScroll); 1373 emit SetScrollState(m_autoScroll);
1375#ifdef USEQPE 1374#ifdef USEQPE
1376 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; 1375 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable;
1377#endif 1376#endif
1378 return; 1377 return;
1379 } 1378 }
1380 } 1379 }
1381 if (bredraw) emitRedraw(); 1380 if (bredraw) emitRedraw();
1382} 1381}
1383 1382
1384void QTReader::redrawScroll(QPainter* p) 1383void QTReader::redrawScroll(QPainter* p)
1385{ 1384{
1386 int offset = (m_scrolltype == 1) ? m_totalscroll : 0; 1385 int offset = (m_scrolltype == 1) ? m_totalscroll : 0;
1387 switch (m_scrollpos) 1386 switch (m_scrollpos)
1388 { 1387 {
1389 case 1: 1388 case 1:
1390 { 1389 {
1391 int hmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0); 1390 int hmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0);
1392 if (hmargin < m_bottommargin) hmargin = m_bottommargin; 1391 if (hmargin < m_bottommargin) hmargin = m_bottommargin;
1393 if (m_rotated) 1392 if (m_rotated)
1394 { 1393 {
1395 if (m_bgpm.isNull()) 1394 if (m_bgpm.isNull())
1396 { 1395 {
1397 p->fillRect(0,0,hmargin,height(),m_bg); 1396 p->fillRect(0,0,hmargin,height(),m_bg);
1398 } 1397 }
1399 else 1398 else
1400 { 1399 {
1401 blitRot(0,0, height(), hmargin, NULL); 1400 blitRot(0,0, height(), hmargin, NULL);
1402 } 1401 }
1403 } 1402 }
1404 else 1403 else
1405 { 1404 {
1406 if (m_bgpm.isNull()) 1405 if (m_bgpm.isNull())
1407 { 1406 {
1408 p->fillRect(0,height() - hmargin,width(),hmargin,m_bg); 1407 p->fillRect(0,height() - hmargin,width(),hmargin,m_bg);
1409 } 1408 }
1410 else 1409 else
1411 { 1410 {
1412 int toffset = (offset+height()-hmargin) % height(); 1411 int toffset = (offset+height()-hmargin) % height();
1413 if (toffset+hmargin > height()) 1412 if (toffset+hmargin > height())
1414 { 1413 {
1415 int fp = height()-toffset; 1414 int fp = height()-toffset;
1416 bitBlt(this, 1415 bitBlt(this,
1417 0,height() - hmargin, 1416 0,height() - hmargin,
1418 dbuff, 1417 dbuff,
1419 0, toffset, width(), fp); 1418 0, toffset, width(), fp);
1420 bitBlt(this, 1419 bitBlt(this,
1421 0,height()-hmargin+fp, 1420 0,height()-hmargin+fp,
1422 dbuff, 1421 dbuff,
1423 0, 0, width(), hmargin-fp); 1422 0, 0, width(), hmargin-fp);
1424 } 1423 }
1425 else 1424 else
1426 { 1425 {
1427 bitBlt(this, 1426 bitBlt(this,
1428 0,height() - hmargin, 1427 0,height() - hmargin,
1429 dbuff, 1428 dbuff,
1430 0, toffset, width(), hmargin); 1429 0, toffset, width(), hmargin);
1431 } 1430 }
1432 } 1431 }
1433 } 1432 }
1434 } 1433 }
1435 break; 1434 break;
1436 case 2: //right 1435 case 2: //right
1437 if (m_rotated) 1436 if (m_rotated)
1438 { 1437 {
1439 if (m_bgpm.isNull()) 1438 if (m_bgpm.isNull())
1440 { 1439 {
1441 p->fillRect(0,height()-m_right_border,width(),m_right_border,m_bg); 1440 p->fillRect(0,height()-m_right_border,width(),m_right_border,m_bg);
1442 } 1441 }
1443 else 1442 else
1444 { 1443 {
1445 blitRot(0,height()-m_right_border, m_right_border, width(), NULL); 1444 blitRot(0,height()-m_right_border, m_right_border, width(), NULL);
1446 } 1445 }
1447 } 1446 }
1448 else 1447 else
1449 { 1448 {
1450 if (m_bgpm.isNull()) 1449 if (m_bgpm.isNull())
1451 { 1450 {
1452 p->fillRect(width()-m_right_border,0,m_right_border,height(),m_bg); 1451 p->fillRect(width()-m_right_border,0,m_right_border,height(),m_bg);
1453 } 1452 }
1454 else 1453 else
1455 { 1454 {
1456 int x = width() - m_right_border; 1455 int x = width() - m_right_border;
1457 int fp = height()-offset; 1456 int fp = height()-offset;
1458 bitBlt(this, x, 0, dbuff, x, offset, m_right_border, fp); 1457 bitBlt(this, x, 0, dbuff, x, offset, m_right_border, fp);
1459 bitBlt(this, x, fp, dbuff, x, 0, m_right_border, height()-fp); 1458 bitBlt(this, x, fp, dbuff, x, 0, m_right_border, height()-fp);
1460 } 1459 }
1461 } 1460 }
1462 break; 1461 break;
1463 case 3: //left 1462 case 3: //left
1464 if (m_rotated) 1463 if (m_rotated)
1465 { 1464 {
1466 if (m_bgpm.isNull()) 1465 if (m_bgpm.isNull())
1467 { 1466 {
1468 p->fillRect(0,0,width(),m_left_border,m_bg); 1467 p->fillRect(0,0,width(),m_left_border,m_bg);
1469 } 1468 }
1470 else 1469 else
1471 { 1470 {
1472 blitRot(0,0, m_left_border, width(), NULL); 1471 blitRot(0,0, m_left_border, width(), NULL);
1473 } 1472 }
1474 } 1473 }
1475 else 1474 else
1476 { 1475 {
1477 if (m_bgpm.isNull()) 1476 if (m_bgpm.isNull())
1478 { 1477 {
1479 p->fillRect(0,0,m_left_border,height(),m_bg); 1478 p->fillRect(0,0,m_left_border,height(),m_bg);
1480 } 1479 }
1481 else 1480 else
1482 { 1481 {
1483 int fp = height()-offset; 1482 int fp = height()-offset;
1484 bitBlt(this, 0, 0, dbuff, 0, offset, m_left_border, fp); 1483 bitBlt(this, 0, 0, dbuff, 0, offset, m_left_border, fp);
1485 bitBlt(this, 0, fp, dbuff, 0, 0, m_left_border, height()-fp); 1484 bitBlt(this, 0, fp, dbuff, 0, 0, m_left_border, height()-fp);
1486 } 1485 }
1487 } 1486 }
1488 break; 1487 break;
1489 case 0: 1488 case 0:
1490 default: 1489 default:
1491 break; 1490 break;
1492 } 1491 }
1493 if (m_scrollpos != 0) DrawScroll(p, width(), height()); 1492 if (m_scrollpos != 0) DrawScroll(p, width(), height());
1494} 1493}
1495 1494
1496void QTReader::autoscroll() 1495void QTReader::autoscroll()
1497{ 1496{
1498 drawBackground(); 1497 drawBackground();
1499 dbp->end(); 1498 dbp->end();
1500 timer->start(real_delay(), false); 1499 timer->start(real_delay(), false);
1501} 1500}
1502 1501
1503void QTReader::setfont() 1502void QTReader::setfont()
1504{ 1503{
1505// m_fontControl.Change 1504// m_fontControl.Change
1506 m_charWidth = (m_charpc*m_fontControl.currentsize())/100; 1505 m_charWidth = (m_charpc*m_fontControl.currentsize())/100;
1507 if (m_charWidth <= 0) m_charWidth = 1; 1506 if (m_charWidth <= 0) m_charWidth = 1;
1508 m_ascent = m_fontControl.ascent(); 1507 m_ascent = m_fontControl.ascent();
1509 m_descent = m_fontControl.descent(); 1508 m_descent = m_fontControl.descent();
1510 m_linespacing = m_fontControl.lineSpacing(); 1509 m_linespacing = m_fontControl.lineSpacing();
1511} 1510}
1512 1511
1513void QTReader::DrawStraight(QPainter* p, int w, int h) 1512void QTReader::DrawStraight(QPainter* p, int w, int h)
1514{ 1513{
1515 if (m_scrolldy == m_topmargin) 1514 if (m_scrolldy == m_topmargin)
1516 { 1515 {
1517 int ypos = textarray[0]->ascent()-m_scrolldy1+m_topmargin; 1516 int ypos = textarray[0]->ascent()-m_scrolldy1+m_topmargin;
1518 textarray[0]->render( p, ypos, m_bMonoSpaced, m_charWidth, w, m_left_border, m_right_border, m_bg, h-m_topmargin-m_bottommargin); 1517 textarray[0]->render( p, ypos, m_bMonoSpaced, m_charWidth, w, m_left_border, m_right_border, m_bg, h-m_topmargin-m_bottommargin);
1519 int i; 1518 int i;
1520 for (i = 1; i < numlines; i++) 1519 for (i = 1; i < numlines; i++)
1521 { 1520 {
1522 ypos += (textarray[i-1]->descent() + textarray[i]->ascent())+ 1521 ypos += (textarray[i-1]->descent() + textarray[i]->ascent())+
1523 (textarray[i-1]->lineExtraSpacing() + textarray[i]->lineExtraSpacing())/2; 1522 (textarray[i-1]->lineExtraSpacing() + textarray[i]->lineExtraSpacing())/2;
1524 textarray[i]->render( p, ypos, m_bMonoSpaced, m_charWidth, w, m_left_border, m_right_border, m_bg, h-m_topmargin-m_bottommargin); 1523 textarray[i]->render( p, ypos, m_bMonoSpaced, m_charWidth, w, m_left_border, m_right_border, m_bg, h-m_topmargin-m_bottommargin);
1525 } 1524 }
1526 if (textarray[i]->showPartial()) 1525 if (textarray[i]->showPartial())
1527 { 1526 {
1528 ypos += (textarray[i-1]->descent() + textarray[i]->ascent())+ 1527 ypos += (textarray[i-1]->descent() + textarray[i]->ascent())+
1529 (textarray[i-1]->lineExtraSpacing() + textarray[i]->lineExtraSpacing())/2; 1528 (textarray[i-1]->lineExtraSpacing() + textarray[i]->lineExtraSpacing())/2;
1530 textarray[i]->render( p, ypos, m_bMonoSpaced, m_charWidth, w, m_left_border, m_right_border, m_bg, h-m_topmargin-m_bottommargin); 1529 textarray[i]->render( p, ypos, m_bMonoSpaced, m_charWidth, w, m_left_border, m_right_border, m_bg, h-m_topmargin-m_bottommargin);
1531 } 1530 }
1532 } 1531 }
1533 else 1532 else
1534 { 1533 {
1535 int ypos = textarray[0]->ascent()-m_scrolldy1+m_scrolldy+m_topmargin; 1534 int ypos = textarray[0]->ascent()-m_scrolldy1+m_scrolldy+m_topmargin;
1536 textarray[0]->render( p, ypos, m_bMonoSpaced, m_charWidth, w, m_left_border, m_right_border, m_bg, h-m_topmargin-m_bottommargin); 1535 textarray[0]->render( p, ypos, m_bMonoSpaced, m_charWidth, w, m_left_border, m_right_border, m_bg, h-m_topmargin-m_bottommargin);
1537 // p->fillRect(m_border, 0, w-2*m_border, m_scrolldy, m_bg); 1536 // p->fillRect(m_border, 0, w-2*m_border, m_scrolldy, m_bg);
1538 for (int i = 1; i < numlines; i++) 1537 for (int i = 1; i < numlines; i++)
1539 { 1538 {
1540 ypos += (textarray[i-1]->descent() + textarray[i]->ascent())+ 1539 ypos += (textarray[i-1]->descent() + textarray[i]->ascent())+
1541 (textarray[i-1]->lineExtraSpacing() + textarray[i]->lineExtraSpacing())/2; 1540 (textarray[i-1]->lineExtraSpacing() + textarray[i]->lineExtraSpacing())/2;
1542 if (ypos+textarray[i]->descent() > h) 1541 if (ypos+textarray[i]->descent() > h)
1543 { 1542 {
1544 ypos = textarray[i]->ascent(); 1543 ypos = textarray[i]->ascent();
1545 } 1544 }
1546 textarray[i]->render( p, ypos, m_bMonoSpaced, m_charWidth, w, m_left_border, m_right_border, m_bg, h-m_topmargin-m_bottommargin); 1545 textarray[i]->render( p, ypos, m_bMonoSpaced, m_charWidth, w, m_left_border, m_right_border, m_bg, h-m_topmargin-m_bottommargin);
1547 } 1546 }
1548 p->fillRect(m_left_border,m_scrolldy,w-(m_left_border+m_right_border),1,m_scrollcolor); 1547 p->fillRect(m_left_border,m_scrolldy,w-(m_left_border+m_right_border),1,m_scrollcolor);
1549 } 1548 }
1550 bool wasrotated = m_rotated; 1549 bool wasrotated = m_rotated;
1551 m_rotated = false; 1550 m_rotated = false;
1552 DrawScroll(p, w, h); 1551 DrawScroll(p, w, h);
1553 m_rotated = wasrotated; 1552 m_rotated = wasrotated;
1554 1553
1555} 1554}
1556 1555
1557void QTReader::redrawall() 1556void QTReader::redrawall()
1558{ 1557{
1559 if (m_rotated) 1558 if (m_rotated)
1560 { 1559 {
1561#ifdef DOUBLEBUFFER 1560#ifdef DOUBLEBUFFER
1562 drawBackground(); 1561 drawBackground();
1563 DrawStraight(dbp, height(), width()); 1562 DrawStraight(dbp, height(), width());
1564 dbp->end(); 1563 dbp->end();
1565 1564
1566 QWMatrix m; 1565 QWMatrix m;
1567 m.rotate(90); 1566 m.rotate(90);
1568 QPixmap rp = dbuff->xForm(m); 1567 QPixmap rp = dbuff->xForm(m);
1569 bitBlt(this, 0,0,&rp,0,0,-1,-1); 1568 bitBlt(this, 0,0,&rp,0,0,-1,-1);
1570#else 1569#else
1571 QPixmap dbuff(height(), width()); 1570 QPixmap dbuff(height(), width());
1572 QPainter dbp(&dbuff); 1571 QPainter dbp(&dbuff);
1573 // dbp.setBackgroundMode(OpaqueMode); 1572 // dbp.setBackgroundMode(OpaqueMode);
1574 dbp.fillRect(dbuff.rect(), m_bg); 1573 dbp.fillRect(dbuff.rect(), m_bg);
1575 1574
1576 DrawStraight(&dbp, height(), width()); 1575 DrawStraight(&dbp, height(), width());
1577 1576
1578 QWMatrix m; 1577 QWMatrix m;
1579 m.rotate(90); 1578 m.rotate(90);
1580 QPixmap rp = dbuff.xForm(m); 1579 QPixmap rp = dbuff.xForm(m);
1581 bitBlt(this, 0,0,&rp,0,0,-1,-1); 1580 bitBlt(this, 0,0,&rp,0,0,-1,-1);
1582#endif 1581#endif
1583 } 1582 }
1584 else 1583 else
1585 { 1584 {
1586#ifdef DOUBLEBUFFER 1585#ifdef DOUBLEBUFFER
1587 drawBackground(); 1586 drawBackground();
1588 DrawStraight(dbp, width(), height()); 1587 DrawStraight(dbp, width(), height());
1589 dbp->end(); 1588 dbp->end();
1590 bitBlt(this, 0,0,dbuff,0,0,-1,-1); 1589 bitBlt(this, 0,0,dbuff,0,0,-1,-1);
1591#else 1590#else
1592 DrawStraight(p, width(), height()); 1591 DrawStraight(p, width(), height());
1593#endif 1592#endif
1594 } 1593 }
1595} 1594}
1596 1595
1597void QTReader::drawFonts() 1596void QTReader::drawFonts()
1598{ 1597{
1599 if (bDoUpdates) 1598 if (bDoUpdates)
1600 { 1599 {
1601 int hmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0); 1600 int hmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0);
1602 if (hmargin < m_bottommargin) hmargin = m_bottommargin; 1601 if (hmargin < m_bottommargin) hmargin = m_bottommargin;
1603 //qDebug("How refreshing..."); 1602 //qDebug("How refreshing...");
1604 if (buffdoc.empty()) return; 1603 if (buffdoc.empty()) return;
1605 setfont(); 1604 setfont();
1606 //if (!m_autoScroll) m_scrolldy1 = 0; 1605 //if (!m_autoScroll) m_scrolldy1 = 0;
1607#ifdef ROTATION_ENABLED 1606#ifdef ROTATION_ENABLED
1608 if (m_lastwidth != ((m_rotated) ? height() : width())) 1607 if (m_lastwidth != ((m_rotated) ? height() : width()))
1609 { 1608 {
1610 m_scrolldy = m_topmargin; 1609 m_scrolldy = m_topmargin;
1611 // qDebug("Not Optimised %d", m_lastwidth); 1610 // qDebug("Not Optimised %d", m_lastwidth);
1612 m_lastwidth = ((m_rotated) ? height() : width()); 1611 m_lastwidth = ((m_rotated) ? height() : width());
1613 m_lastheight = ((m_rotated) ? width() : height()); 1612 m_lastheight = ((m_rotated) ? width() : height());
1614 buffdoc.setwidth(m_lastwidth-(m_left_border+m_right_border)); 1613 buffdoc.setwidth(m_lastwidth-(m_left_border+m_right_border));
1615 locate(pagelocate()); 1614 locate(pagelocate());
1616 // qDebug("Not Optimised %d", m_lastwidth); 1615 // qDebug("Not Optimised %d", m_lastwidth);
1617 } 1616 }
1618 else 1617 else
1619 { 1618 {
1620 int newht = ((m_rotated) ? width() : height()); 1619 int newht = ((m_rotated) ? width() : height());
1621 if (m_lastheight > newht) 1620 if (m_lastheight > newht)
1622 { 1621 {
1623 // qDebug("Optimised < %d %d %d", numlines, m_lastheight, newht); 1622 // qDebug("Optimised < %d %d %d", numlines, m_lastheight, newht);
1624 m_scrolldy = m_topmargin; 1623 m_scrolldy = m_topmargin;
1625 int ypos = m_scrolldy1+m_topmargin; 1624 int ypos = m_scrolldy1+m_topmargin;
1626 for (int i = 0; i < numlines; i++) 1625 for (int i = 0; i < numlines; i++)
1627 { 1626 {
1628 if ((ypos += textarray[i]->lineSpacing()) > newht - hmargin) 1627 if ((ypos += textarray[i]->lineSpacing()) > newht - hmargin)
1629 { 1628 {
1630 numlines = i; 1629 numlines = i;
1631 jumpto(mylastpos = locnarray[i+1]); 1630 jumpto(mylastpos = locnarray[i+1]);
1632 break; 1631 break;
1633 } 1632 }
1634 } 1633 }
1635 // qDebug("Optimised < %d", numlines); 1634 // qDebug("Optimised < %d", numlines);
1636 m_lastheight = newht; 1635 m_lastheight = newht;
1637 } 1636 }
1638 else if (m_lastheight < newht) 1637 else if (m_lastheight < newht)
1639 { 1638 {
1640 m_scrolldy = m_topmargin; 1639 m_scrolldy = m_topmargin;
1641 // qDebug("Optimised > %d", numlines); 1640 // qDebug("Optimised > %d", numlines);
1642 int ypos = m_scrolldy1+m_topmargin; 1641 int ypos = m_scrolldy1+m_topmargin;
1643 for (int i = 0; i <= numlines; i++) 1642 for (int i = 0; i <= numlines; i++)
1644 { 1643 {
1645 ypos += textarray[i]->lineSpacing(); 1644 ypos += textarray[i]->lineSpacing();
1646 } 1645 }
1647 fillbuffer(numlines+1, ypos, newht); 1646 fillbuffer(numlines+1, ypos, newht);
1648 // qDebug("Optimised > %d", numlines); 1647 // qDebug("Optimised > %d", numlines);
1649 } 1648 }
1650 if (numlines > 0) 1649 if (numlines > 0)
1651 { 1650 {
1652 redrawall(); 1651 redrawall();
1653 } 1652 }
1654 } 1653 }
1655#else 1654#else
1656 if (m_lastwidth != width()) 1655 if (m_lastwidth != width())
1657 { 1656 {
1658 // qDebug("Not Optimised %d", m_lastwidth); 1657 // qDebug("Not Optimised %d", m_lastwidth);
1659 m_lastwidth = width(); 1658 m_lastwidth = width();
1660 m_lastheight = height(); 1659 m_lastheight = height();
1661 buffdoc.setwidth(m_lastwidth-(m_left_border+m_right_border)); 1660 buffdoc.setwidth(m_lastwidth-(m_left_border+m_right_border));
1662 locate(pagelocate()); 1661 locate(pagelocate());
1663 // qDebug("Not Optimised %d", m_lastwidth); 1662 // qDebug("Not Optimised %d", m_lastwidth);
1664 } 1663 }
1665 else 1664 else
1666 { 1665 {
1667 int newht = height(); 1666 int newht = height();
1668 if (m_lastheight > newht) 1667 if (m_lastheight > newht)
1669 { 1668 {
1670 // qDebug("Optimised < %d %d %d", numlines, m_lastheight, newht); 1669 // qDebug("Optimised < %d %d %d", numlines, m_lastheight, newht);
1671 int ypos = m_topmargin; 1670 int ypos = m_topmargin;
1672 for (int i = 0; i < numlines; i++) 1671 for (int i = 0; i < numlines; i++)
1673 { 1672 {
1674 if ((ypos += textarray[i]->lineSpacing()) > newht - hmargin) 1673 if ((ypos += textarray[i]->lineSpacing()) > newht - hmargin)
1675 { 1674 {
1676 numlines = i; 1675 numlines = i;
1677 jumpto(mylastpos = locnarray[i+1]); 1676 jumpto(mylastpos = locnarray[i+1]);
1678 break; 1677 break;
1679 } 1678 }
1680 } 1679 }
1681 // qDebug("Optimised < %d", numlines); 1680 // qDebug("Optimised < %d", numlines);
1682 m_lastheight = newht; 1681 m_lastheight = newht;
1683 } 1682 }
1684 else if (m_lastheight < newht) 1683 else if (m_lastheight < newht)
1685 { 1684 {
1686 // qDebug("Optimised > %d", numlines); 1685 // qDebug("Optimised > %d", numlines);
1687 int ypos = m_topmargin; 1686 int ypos = m_topmargin;
1688 for (int i = 0; i <= numlines; i++) 1687 for (int i = 0; i <= numlines; i++)
1689 { 1688 {
1690 ypos += textarray[i]->lineSpacing(); 1689 ypos += textarray[i]->lineSpacing();
1691 } 1690 }
1692 fillbuffer(numlines+1, ypos, newht); 1691 fillbuffer(numlines+1, ypos, newht);
1693 // qDebug("Optimised > %d", numlines); 1692 // qDebug("Optimised > %d", numlines);
1694 } 1693 }
1695 if (numlines > 0) 1694 if (numlines > 0)
1696 { 1695 {
1697 int ypos = textarray[0]->ascent()+m_topmargin; 1696 int ypos = textarray[0]->ascent()+m_topmargin;
1698 textarray[0]->render( p, ypos, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin); 1697 textarray[0]->render( p, ypos, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin);
1699 // int last = (m_showlast) ? numlines : numlines-1; 1698 // int last = (m_showlast) ? numlines : numlines-1;
1700 // for (int i = 1; i <= last; i++) 1699 // for (int i = 1; i <= last; i++)
1701 for (int i = 1; i < numlines; i++) 1700 for (int i = 1; i < numlines; i++)
1702 { 1701 {
1703 // ypos += (textarray[i-1]->lineSpacing() + textarray[i]->lineSpacing())/2; 1702 // ypos += (textarray[i-1]->lineSpacing() + textarray[i]->lineSpacing())/2;
1704 ypos += (textarray[i-1]->descent() + textarray[i]->ascent())+ 1703 ypos += (textarray[i-1]->descent() + textarray[i]->ascent())+
1705 (textarray[i-1]->lineExtraSpacing() + textarray[i]->lineExtraSpacing())/2; 1704 (textarray[i-1]->lineExtraSpacing() + textarray[i]->lineExtraSpacing())/2;
1706 textarray[i]->render( p, ypos, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin); 1705 textarray[i]->render( p, ypos, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin);
1707 } 1706 }
1708// mylastpos = locate(); 1707// mylastpos = locate();
1709 } 1708 }
1710 } 1709 }
1711#endif 1710#endif
1712 emitRedraw(); 1711 emitRedraw();
1713 } 1712 }
1714/* 1713/*
1715 else 1714 else
1716 { 1715 {
1717 qDebug("Not so refreshing..."); 1716 qDebug("Not so refreshing...");
1718 } 1717 }
1719*/ 1718*/
1720} 1719}
1721 1720
1722void QTReader::DrawScroll( QPainter *p, int _w, int _h ) 1721void QTReader::DrawScroll( QPainter *p, int _w, int _h )
1723{ 1722{
1724 if (!buffdoc.empty()) 1723 if (!buffdoc.empty())
1725 { 1724 {
1726 QBrush checkered = QBrush( Dense4Pattern ); 1725 QBrush checkered = QBrush( Dense4Pattern );
1727 checkered.setColor(m_scrollbarcolor); 1726 checkered.setColor(m_scrollbarcolor);
1728 switch (m_scrollpos) 1727 switch (m_scrollpos)
1729 { 1728 {
1730 case 1: 1729 case 1:
1731 if (m_rotated) 1730 if (m_rotated)
1732 { 1731 {
1733 p->fillRect(0, 0, 2, _h, checkered); 1732 p->fillRect(0, 0, 2, _h, checkered);
1734 } 1733 }
1735 else 1734 else
1736 { 1735 {
1737 p->fillRect(0, _h-2, _w, 2, checkered); 1736 p->fillRect(0, _h-2, _w, 2, checkered);
1738 } 1737 }
1739 break; 1738 break;
1740 case 2: 1739 case 2:
1741 if (m_rotated) 1740 if (m_rotated)
1742 { 1741 {
1743 p->fillRect(0, _h-2, _w, 2, checkered); 1742 p->fillRect(0, _h-2, _w, 2, checkered);
1744 } 1743 }
1745 else 1744 else
1746 { 1745 {
1747 p->fillRect(_w-2, 0, 2, _h, checkered); 1746 p->fillRect(_w-2, 0, 2, _h, checkered);
1748 } 1747 }
1749 break; 1748 break;
1750 case 3: 1749 case 3:
1751 if (m_rotated) 1750 if (m_rotated)
1752 { 1751 {
1753 p->fillRect(0, 0, _w, 2, checkered); 1752 p->fillRect(0, 0, _w, 2, checkered);
1754 } 1753 }
1755 else 1754 else
1756 { 1755 {
1757 p->fillRect(0, 0, 2, _h, checkered); 1756 p->fillRect(0, 0, 2, _h, checkered);
1758 } 1757 }
1759 break; 1758 break;
1760 case 0: 1759 case 0:
1761 default: 1760 default:
1762 break; 1761 break;
1763 } 1762 }
1764 switch (m_scrollpos) 1763 switch (m_scrollpos)
1765 { 1764 {
1766 case 1: 1765 case 1:
1767 { 1766 {
1768 int ht; 1767 int ht;
1769 if (m_rotated) 1768 if (m_rotated)
1770 { 1769 {
1771 ht = _h; 1770 ht = _h;
1772 } 1771 }
1773 else 1772 else
1774 { 1773 {
1775 ht = _w; 1774 ht = _w;
1776 } 1775 }
1777 int sectionsize = (buffdoc.endSection()-buffdoc.startSection()); 1776 int sectionsize = (buffdoc.endSection()-buffdoc.startSection());
1778 int mid = (ht*(locnarray[numlines]+locnarray[0]-2*buffdoc.startSection())+sectionsize)/(2*sectionsize); 1777 int mid = (ht*(locnarray[numlines]+locnarray[0]-2*buffdoc.startSection())+sectionsize)/(2*sectionsize);
1779 int sliderheight = ((locnarray[numlines]-locnarray[0])*ht+sectionsize/2)/sectionsize; 1778 int sliderheight = ((locnarray[numlines]-locnarray[0])*ht+sectionsize/2)/sectionsize;
1780 int sliderpos; 1779 int sliderpos;
1781 if (sliderheight < 10) 1780 if (sliderheight < 10)
1782 { 1781 {
1783 sliderheight = 10; 1782 sliderheight = 10;
1784 sliderpos = mid-5; 1783 sliderpos = mid-5;
1785 } 1784 }
1786 else 1785 else
1787 { 1786 {
1788 sliderpos = (ht*(locnarray[0]-buffdoc.startSection())+sectionsize/2)/sectionsize; 1787 sliderpos = (ht*(locnarray[0]-buffdoc.startSection())+sectionsize/2)/sectionsize;
1789 } 1788 }
1790 if (m_rotated) 1789 if (m_rotated)
1791 { 1790 {
1792 p->fillRect(0, sliderpos, 3, sliderheight, m_scrollbarcolor); 1791 p->fillRect(0, sliderpos, 3, sliderheight, m_scrollbarcolor);
1793 } 1792 }
1794 else 1793 else
1795 { 1794 {
1796 p->fillRect(sliderpos, _h-3, sliderheight, 3, m_scrollbarcolor); 1795 p->fillRect(sliderpos, _h-3, sliderheight, 3, m_scrollbarcolor);
1797 } 1796 }
1798 } 1797 }
1799 break; 1798 break;
1800 case 2: 1799 case 2:
1801 case 3: 1800 case 3:
1802 { 1801 {
1803 int ht; 1802 int ht;
1804 if (m_rotated) 1803 if (m_rotated)
1805 { 1804 {
1806 ht = _w; 1805 ht = _w;
1807 } 1806 }
1808 else 1807 else
1809 { 1808 {
1810 ht = _h; 1809 ht = _h;
1811 } 1810 }
1812 int sectionsize = (buffdoc.endSection()-buffdoc.startSection()); 1811 int sectionsize = (buffdoc.endSection()-buffdoc.startSection());
1813 int mid = (ht*(locnarray[numlines]+locnarray[0]-2*buffdoc.startSection())+sectionsize)/(2*sectionsize); 1812 int mid = (ht*(locnarray[numlines]+locnarray[0]-2*buffdoc.startSection())+sectionsize)/(2*sectionsize);
1814 int sliderheight = ((locnarray[numlines]-locnarray[0])*ht+sectionsize/2)/sectionsize; 1813 int sliderheight = ((locnarray[numlines]-locnarray[0])*ht+sectionsize/2)/sectionsize;
1815 int sliderpos; 1814 int sliderpos;
1816 if (sliderheight < 10) 1815 if (sliderheight < 10)
1817 { 1816 {
1818 sliderheight = 10; 1817 sliderheight = 10;
1819 sliderpos = mid-5; 1818 sliderpos = mid-5;
1820 } 1819 }
1821 else 1820 else
1822 { 1821 {
1823 sliderpos = (ht*(locnarray[0]-buffdoc.startSection())+sectionsize/2)/sectionsize; 1822 sliderpos = (ht*(locnarray[0]-buffdoc.startSection())+sectionsize/2)/sectionsize;
1824 } 1823 }
1825 if (m_rotated) 1824 if (m_rotated)
1826 { 1825 {
1827 int hoff; 1826 int hoff;
1828 if (m_scrollpos == 2) //right 1827 if (m_scrollpos == 2) //right
1829 { 1828 {
1830 hoff = _h-3; 1829 hoff = _h-3;
1831 } 1830 }
1832 else 1831 else
1833 { 1832 {
1834 hoff = 0; 1833 hoff = 0;
1835 } 1834 }
1836 p->fillRect(ht-sliderpos-sliderheight, hoff, sliderheight, 3, m_scrollbarcolor); 1835 p->fillRect(ht-sliderpos-sliderheight, hoff, sliderheight, 3, m_scrollbarcolor);
1837 } 1836 }
1838 else 1837 else
1839 { 1838 {
1840 int hoff; 1839 int hoff;
1841 if (m_scrollpos == 2) //right 1840 if (m_scrollpos == 2) //right
1842 { 1841 {
1843 hoff = _w-3; 1842 hoff = _w-3;
1844 } 1843 }
1845 else 1844 else
1846 { 1845 {
1847 hoff = 0; 1846 hoff = 0;
1848 } 1847 }
1849 p->fillRect(hoff, sliderpos, 3, sliderheight, m_scrollbarcolor); 1848 p->fillRect(hoff, sliderpos, 3, sliderheight, m_scrollbarcolor);
1850 } 1849 }
1851 } 1850 }
1852 break; 1851 break;
1853 case 0: 1852 case 0:
1854 default: 1853 default:
1855 break; 1854 break;
1856 } 1855 }
1857 } 1856 }
1858} 1857}
1859 1858
1860/* 1859/*
1861void QTReader::DrawScroll( QPainter *p ) 1860void QTReader::DrawScroll( QPainter *p )
1862{ 1861{
1863 if (m_border > 5 && !buffdoc.empty()) 1862 if (m_border > 5 && !buffdoc.empty())
1864 { 1863 {
1865 int ht, wh; 1864 int ht, wh;
1866 if (m_rotated) 1865 if (m_rotated)
1867 { 1866 {
1868 ht = width(); 1867 ht = width();
1869 wh = height()g; 1868 wh = height()g;
1870 p->fillRect(0, wh-2, ht, 2, cyan); 1869 p->fillRect(0, wh-2, ht, 2, cyan);
1871 } 1870 }
1872 else 1871 else
1873 { 1872 {
1874 ht = height(); 1873 ht = height();
1875 wh = width(); 1874 wh = width();
1876 p->fillRect(wh-2, 0, 2, ht, cyan); 1875 p->fillRect(wh-2, 0, 2, ht, cyan);
1877 } 1876 }
1878 int sectionsize = (buffdoc.endSection()-buffdoc.startSection()); 1877 int sectionsize = (buffdoc.endSection()-buffdoc.startSection());
1879 int mid = (ht*(locnarray[numlines]+locnarray[0]-2*buffdoc.startSection())+sectionsize)/(2*sectionsize); 1878 int mid = (ht*(locnarray[numlines]+locnarray[0]-2*buffdoc.startSection())+sectionsize)/(2*sectionsize);
1880 if (m_rotated) 1879 if (m_rotated)
1881 { 1880 {
1882 p->fillRect(ht-mid-5, wh-2, 10, 2, yellow); 1881 p->fillRect(ht-mid-5, wh-2, 10, 2, yellow);
1883 p->fillRect(ht-(ht*(locnarray[numlines]-buffdoc.startSection())+sectionsize/2)/sectionsize, wh-2, ((locnarray[numlines]-locnarray[0])*ht+sectionsize/2)/sectionsize, 2, magenta); 1882 p->fillRect(ht-(ht*(locnarray[numlines]-buffdoc.startSection())+sectionsize/2)/sectionsize, wh-2, ((locnarray[numlines]-locnarray[0])*ht+sectionsize/2)/sectionsize, 2, magenta);
1884 } 1883 }
1885 else 1884 else
1886 { 1885 {
1887 p->fillRect(wh-2, mid-5, 2, 10, yellow); 1886 p->fillRect(wh-2, mid-5, 2, 10, yellow);
1888 p->fillRect(wh-2, (ht*(locnarray[0]-buffdoc.startSection())+sectionsize/2)/sectionsize, 2, ((locnarray[numlines]-locnarray[0])*ht+sectionsize/2)/sectionsize, magenta); 1887 p->fillRect(wh-2, (ht*(locnarray[0]-buffdoc.startSection())+sectionsize/2)/sectionsize, 2, ((locnarray[numlines]-locnarray[0])*ht+sectionsize/2)/sectionsize, magenta);
1889 } 1888 }
1890 } 1889 }
1891} 1890}
1892*/ 1891*/
1893QString QTReader::firstword() 1892QString QTReader::firstword()
1894{ 1893{
1895 if (m_bMonoSpaced) 1894 if (m_bMonoSpaced)
1896 { 1895 {
1897 return toQString(textarray[0]->data()); 1896 return toQString(textarray[0]->data());
1898 } 1897 }
1899 else 1898 else
1900 { 1899 {
1901 int start, end, len, j; 1900 int start, end, len, j;
1902 for (j = 0; j < numlines; j++) 1901 for (j = 0; j < numlines; j++)
1903 { 1902 {
1904 len = textarray[j]->length(); 1903 len = textarray[j]->length();
1905 for (start = 0; start < len && !isalpha((*textarray[j])[start]); start++); 1904 for (start = 0; start < len && !isalpha((*textarray[j])[start]); start++);
1906 if (start < len) break; 1905 if (start < len) break;
1907 } 1906 }
1908 if (j < numlines) 1907 if (j < numlines)
1909 { 1908 {
1910 QString ret = ""; 1909 QString ret = "";
1911 for (end = start; end < len && isalpha((*textarray[j])[end]); end++) 1910 for (end = start; end < len && isalpha((*textarray[j])[end]); end++)
1912 ret += (*textarray[j])[end]; 1911 ret += (*textarray[j])[end];
1913 if (ret.isEmpty()) ret = "Current position"; 1912 if (ret.isEmpty()) ret = "Current position";
1914 return ret; 1913 return ret;
1915 } 1914 }
1916 else 1915 else
1917 return "Current position"; 1916 return "Current position";
1918 } 1917 }
1919} 1918}
1920 1919
1921// 1920//
1922// Construct the QTReader with buttons. 1921// Construct the QTReader with buttons.
1923// 1922//
1924 1923
1925bool QTReader::ChangeFont(int tgt) 1924bool QTReader::ChangeFont(int tgt)
1926{ 1925{
1927 return m_fontControl.ChangeFont(m_fontname, tgt); 1926 return m_fontControl.ChangeFont(m_fontname, tgt);
1928} 1927}
1929 1928
1930void QTReader::init() 1929void QTReader::init()
1931{ 1930{
1932 buffdoc.unsuspend(); 1931 buffdoc.unsuspend();
1933 setBackgroundColor( m_bg ); 1932 setBackgroundColor( m_bg );
1934 buffdoc.setfilter(getfilter()); 1933 buffdoc.setfilter(getfilter());
1935 ChangeFont(m_textsize); 1934 ChangeFont(m_textsize);
1936 setFocusPolicy(QWidget::StrongFocus); 1935 setFocusPolicy(QWidget::StrongFocus);
1937 timer = new QTimer(this); 1936 timer = new QTimer(this);
1938 connect(timer, SIGNAL(timeout()), this, SLOT(doscroll())); 1937 connect(timer, SIGNAL(timeout()), this, SLOT(doscroll()));
1939 // QMessageBox::information(this, "init", m_lastfile, 1); 1938 // QMessageBox::information(this, "init", m_lastfile, 1);
1940 setfont(); 1939 setfont();
1941} 1940}
1942 1941
1943// 1942//
1944// Clean up 1943// Clean up
1945// 1944//
1946QTReader::~QTReader() 1945QTReader::~QTReader()
1947{ 1946{
1948#ifdef DOUBLEBUFFER 1947#ifdef DOUBLEBUFFER
1949 delete dbuff; 1948 delete dbuff;
1950 delete dbp; 1949 delete dbp;
1951#endif 1950#endif
1952#ifdef USEQPE 1951#ifdef USEQPE
1953 if (m_autoScroll) 1952 if (m_autoScroll)
1954 { 1953 {
1955 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; 1954 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable;
1956 } 1955 }
1957#endif 1956#endif
1958#ifdef _SCROLLPIPE 1957#ifdef _SCROLLPIPE
1959 if (m_pipeout != NULL) 1958 if (m_pipeout != NULL)
1960 { 1959 {
1961 fclose(m_pipeout); 1960 fclose(m_pipeout);
1962 } 1961 }
1963#endif 1962#endif
1964} 1963}
1965 1964
1966// 1965//
1967// Called when the print button is clicked. 1966// Called when the print button is clicked.
1968// 1967//
1969/* 1968/*
1970void QTReader::printIt() 1969void QTReader::printIt()
1971{ 1970{
1972#ifndef QT_NO_PRINTER 1971#ifndef QT_NO_PRINTER
1973 if ( printer->setup( this ) ) { 1972 if ( printer->setup( this ) ) {
1974 QPainter paint; 1973 QPainter paint;
1975 if ( !paint.begin( printer ) ) 1974 if ( !paint.begin( printer ) )
1976 return; 1975 return;
1977 drawIt( &paint ); 1976 drawIt( &paint );
1978 } 1977 }
1979#endif 1978#endif
1980} 1979}
1981*/ 1980*/
1982// 1981//
1983// Called when the widget needs to be updated. 1982// Called when the widget needs to be updated.
1984// 1983//
1985 1984
1986void QTReader::paintEvent( QPaintEvent * ) 1985void QTReader::paintEvent( QPaintEvent * )
1987{ 1986{
1988 drawFonts(); 1987 drawFonts();
1989} 1988}
1990 1989
1991// 1990//
1992// Called when the widget has been resized. 1991// Called when the widget has been resized.
1993// Moves the button group to the upper right corner 1992// Moves the button group to the upper right corner
1994// of the widget. 1993// of the widget.
1995 1994
1996/* 1995/*
1997void QTReader::resizeEvent( QResizeEvent * ) 1996void QTReader::resizeEvent( QResizeEvent * )
1998{ 1997{
1999// // qDebug("resize:(%u,%u)", width(), height()); 1998// // qDebug("resize:(%u,%u)", width(), height());
2000 // bgroup->move( width()-bgroup->width(), 0 ); 1999 // bgroup->move( width()-bgroup->width(), 0 );
2001} 2000}
2002*/ 2001*/
2003 2002
2004// 2003//
2005// Create and display our widget. 2004// Create and display our widget.
2006// 2005//
2007/* 2006/*
2008int main( int argc, tchar **argv ) 2007int main( int argc, tchar **argv )
2009{ 2008{
2010 QApplication app( argc, argv ); 2009 QApplication app( argc, argv );
2011 QTReader draw; 2010 QTReader draw;
2012 app.setMainWidget( &draw ); 2011 app.setMainWidget( &draw );
2013 draw.setCaption("Qt Example - Drawdemo"); 2012 draw.setCaption("Qt Example - Drawdemo");
2014 draw.show(); 2013 draw.show();
2015 return app.exec(); 2014 return app.exec();
2016} 2015}
2017*/ 2016*/
2018 2017
2019 2018
2020bool QTReader::locate(unsigned long n) { 2019bool QTReader::locate(unsigned long n) {
2021 //printf("Locate\n"); 2020 //printf("Locate\n");
2022 buffdoc.unsuspend(); 2021 buffdoc.unsuspend();
2023 buffdoc.locate(n); 2022 buffdoc.locate(n);
2024// // qDebug("&buffdoc.located"); 2023// // qDebug("&buffdoc.located");
2025 ResetScroll(); 2024 ResetScroll();
2026 fillbuffer(); 2025 fillbuffer();
2027// // qDebug("&Buffer filled"); 2026// // qDebug("&Buffer filled");
2028 update(); 2027 update();
2029// // qDebug("&Located"); 2028// // qDebug("&Located");
2030 emitRedraw(); 2029 emitRedraw();
2031 return true; 2030 return true;
2032} 2031}
2033 2032
2034unsigned int QTReader::screenlines() 2033unsigned int QTReader::screenlines()
2035{ 2034{
2036 // int linespacing = (tight) ? m_ascent : m_ascent+m_descent; 2035 // int linespacing = (tight) ? m_ascent : m_ascent+m_descent;
2037 // return (height()-m_descent)/(m_linespacing); 2036 // return (height()-m_descent)/(m_linespacing);
2038 return (height()-2)/(m_linespacing); 2037 return (height()-2)/(m_linespacing);
2039}; 2038};
2040 2039
2041bool QTReader::fillbuffer(int reuse, int ht, int newht) 2040bool QTReader::fillbuffer(int reuse, int ht, int newht)
2042{ 2041{
2043 buffdoc.unsuspend(); 2042 buffdoc.unsuspend();
2044 int hmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0); 2043 int hmargin = ((m_scrollpos == 1) ? _SBARHEIGHT : 0);
2045 if (hmargin < m_bottommargin) hmargin = m_bottommargin; 2044 if (hmargin < m_bottommargin) hmargin = m_bottommargin;
2046 if (ht < 0) ht = m_topmargin; 2045 if (ht < 0) ht = m_topmargin;
2047 if (buffdoc.empty()) return false; 2046 if (buffdoc.empty()) return false;
2048 if (newht < 0) 2047 if (newht < 0)
2049 m_lastheight = (m_rotated) ? width() : height(); 2048 m_lastheight = (m_rotated) ? width() : height();
2050 else 2049 else
2051 m_lastheight = newht; 2050 m_lastheight = newht;
2052 int ch; 2051 int ch;
2053 bool ret = false; 2052 bool ret = false;
2054 unsigned int oldpagepos = locnarray[reuse]; 2053 unsigned int oldpagepos = locnarray[reuse];
2055 int lastypos = ht, ypos = ht; 2054 int lastypos = ht, ypos = ht;
2056 numlines = reuse; 2055 numlines = reuse;
2057 while (ypos < m_lastheight - hmargin || numlines < 2) 2056 while (ypos < m_lastheight - hmargin || numlines < 2)
2058 { 2057 {
2059 lastypos = ypos; 2058 lastypos = ypos;
2060 if (textarray[numlines] == NULL) 2059 if (textarray[numlines] == NULL)
2061 { 2060 {
2062 textarray[numlines] = new CDrawBuffer(&m_fontControl); 2061 textarray[numlines] = new CDrawBuffer(&m_fontControl);
2063 } 2062 }
2064 locnarray[numlines] = locate(); 2063 locnarray[numlines] = locate();
2065 int ch = getline(textarray[numlines]); 2064 int ch = getline(textarray[numlines]);
2066 ypos += textarray[numlines]->lineSpacing(); 2065 ypos += textarray[numlines]->lineSpacing();
2067 numlines++; 2066 numlines++;
2068 if (!ch) 2067 if (!ch)
2069 { 2068 {
2070 if (numlines - reuse == 1 /*&& locnarray[numlines] == buffdoc.locate()*/) 2069 if (numlines - reuse == 1 /*&& locnarray[numlines] == buffdoc.locate()*/)
2071 { 2070 {
2072 qDebug("FALSE"); 2071 qDebug("FALSE");
2073 locate(oldpagepos); 2072 locate(oldpagepos);
2074 return false; 2073 return false;
2075 } 2074 }
2076 else 2075 else
2077 { 2076 {
2078 qDebug("TRUE"); 2077 qDebug("TRUE");
2079 --numlines; 2078 --numlines;
2080 mylastpos = locate(); 2079 mylastpos = locate();
2081 return true; 2080 return true;
2082 } 2081 }
2083 } 2082 }
2084 if (numlines > 1 && textarray[numlines-2]->isBop()) 2083 if (numlines > 1 && textarray[numlines-2]->isBop())
2085 { 2084 {
2086 --numlines; 2085 --numlines;
2087 mylastpos = locate(); 2086 mylastpos = locate();
2088 return true; 2087 return true;
2089 } 2088 }
2090 } 2089 }
2091 2090
2092 --numlines; 2091 --numlines;
2093 mylastpos = locate(); 2092 mylastpos = locate();
2094 m_scrollpart = m_lastheight - lastypos - hmargin; 2093 m_scrollpart = m_lastheight - lastypos - hmargin;
2095 if (m_autoScroll) 2094 if (m_autoScroll)
2096 { 2095 {
2097 CalculateScrollParameters(); 2096 CalculateScrollParameters();
2098 } 2097 }
2099 return true; 2098 return true;
2100} 2099}
2101 2100
2102void QTReader::dopagedn() 2101void QTReader::dopagedn()
2103{ 2102{
2104// qDebug("HEIGHT(2):%d", m_lastheight); 2103// qDebug("HEIGHT(2):%d", m_lastheight);
2105 buffdoc.unsuspend(); 2104 buffdoc.unsuspend();
2106 ResetScroll(); 2105 ResetScroll();
2107 int skip = 0, ypos = m_topmargin; 2106 int skip = 0, ypos = m_topmargin;
2108 if (locate() != mylastpos) 2107 if (locate() != mylastpos)
2109 { 2108 {
2110 jumpto(mylastpos); 2109 jumpto(mylastpos);
2111 } 2110 }
2112 CDrawBuffer* reusebuffer = textarray[numlines]; 2111 CDrawBuffer* reusebuffer = textarray[numlines];
2113 if (reusebuffer != NULL) 2112 if (reusebuffer != NULL)
2114 { 2113 {
2115 if (reusebuffer->eof()) return; 2114 if (reusebuffer->eof()) return;
2116 for (int i = 0; i <= m_overlap; i++) 2115 for (int i = 0; i <= m_overlap; i++)
2117 { 2116 {
2118 int offset = numlines - m_overlap + i; 2117 int offset = numlines - m_overlap + i;
2119 reusebuffer = textarray[offset]; 2118 reusebuffer = textarray[offset];
2120 size_t reuselocn = locnarray[offset]; 2119 size_t reuselocn = locnarray[offset];
2121 textarray[offset] = textarray[i]; 2120 textarray[offset] = textarray[i];
2122 textarray[i] = reusebuffer; 2121 textarray[i] = reusebuffer;
2123 // reusebuffer->empty(); 2122 // reusebuffer->empty();
2124 locnarray[offset] = locnarray[i]; 2123 locnarray[offset] = locnarray[i];
2125 locnarray[i] = reuselocn; 2124 locnarray[i] = reuselocn;
2126 ypos += textarray[i]->lineSpacing(); 2125 ypos += textarray[i]->lineSpacing();
2127 skip++; 2126 skip++;
2128 } 2127 }
2129 } 2128 }
2130 if (numlines <= 1) 2129 if (numlines <= 1)
2131 { 2130 {
2132 skip = 0; 2131 skip = 0;
2133 ypos = 0; 2132 ypos = 0;
2134 qDebug("Doing extra skip"); 2133 qDebug("Doing extra skip");
2135 } 2134 }
2136 if (fillbuffer(skip, ypos)) 2135 if (fillbuffer(skip, ypos))
2137 { 2136 {
2138 drawFonts(); 2137 drawFonts();
2139 } 2138 }
2140} 2139}
2141 2140
2142void QTReader::dopageup() 2141void QTReader::dopageup()
2143{ 2142{
2144 dopageup(locnarray[(m_overlap < numlines) ? m_overlap : numlines/2]); 2143 dopageup(locnarray[(m_overlap < numlines) ? m_overlap : numlines/2]);
2145} 2144}
2146 2145
2147bool QTReader::synch(size_t start, size_t end) 2146bool QTReader::synch(size_t start, size_t end)
2148{ 2147{
2149 jumpto(start); 2148 jumpto(start);
2150 while (start++ < end) 2149 while (start++ < end)
2151 { 2150 {
2152 tchar ch = getch(); 2151 tchar ch = getch();
2153 if (ch == 10) return true; 2152 if (ch == 10) return true;
2154 if (ch == UEOF) return false; 2153 if (ch == UEOF) return false;
2155 if (ch == 6) return false; 2154 if (ch == 6) return false;
2156 } 2155 }
2157 return false; 2156 return false;
2158} 2157}
2159 2158
2160void QTReader::dopageup(unsigned int target) 2159void QTReader::dopageup(unsigned int target)
2161{ 2160{
2162 buffdoc.unsuspend(); 2161 buffdoc.unsuspend();
2163 ResetScroll(); 2162 ResetScroll();
2164 CBufferFace<CDrawBuffer*> buff; 2163 CBufferFace<CDrawBuffer*> buff;
2165 CBufferFace<size_t> loc; 2164 CBufferFace<size_t> loc;
2166 2165
2167 size_t delta, guess = 2*(locate()-pagelocate()), lastdelta = 0; 2166 size_t delta, guess = 2*(locate()-pagelocate()), lastdelta = 0;
2168 bool ch = true; 2167 bool ch = true;
2169 int nbfl, ypos = m_topmargin; 2168 int nbfl, ypos = m_topmargin;
2170 if (guess < 128) guess = 128; 2169 if (guess < 128) guess = 128;
2171 while (1) 2170 while (1)
2172 { 2171 {
2173 // qDebug("Guess:%u", guess); 2172 // qDebug("Guess:%u", guess);
2174 2173
2175 ch = true; 2174 ch = true;
2176 if (target < guess) 2175 if (target < guess)
2177 { 2176 {
2178 delta = 0; // 0 is a flag to say don't guess any more 2177 delta = 0; // 0 is a flag to say don't guess any more
2179 jumpto( (m_continuousDocument) ? 0 : buffdoc.startSection() ); 2178 jumpto( (m_continuousDocument) ? 0 : buffdoc.startSection() );
2180 } 2179 }
2181 else if (!m_continuousDocument && (target - guess < buffdoc.startSection())) 2180 else if (!m_continuousDocument && (target - guess < buffdoc.startSection()))
2182 { 2181 {
2183 delta = 0; // 0 is a flag to say don't guess any more 2182 delta = 0; // 0 is a flag to say don't guess any more
2184 jumpto(buffdoc.startSection()); 2183 jumpto(buffdoc.startSection());
2185 } 2184 }
2186 else 2185 else
2187 { 2186 {
2188 delta = guess; 2187 delta = guess;
2189 if (!synch(target-delta, target-lastdelta)) 2188 if (!synch(target-delta, target-lastdelta))
2190 { 2189 {
2191 lastdelta = delta; 2190 lastdelta = delta;
2192 if (guess < 4000) 2191 if (guess < 4000)
2193 { 2192 {
2194 guess <<= 1; 2193 guess <<= 1;
2195 continue; 2194 continue;
2196 } 2195 }
2197 else 2196 else
2198 { 2197 {
2199 jumpto(target-delta); 2198 jumpto(target-delta);
2200 } 2199 }
2201 } 2200 }
2202 } 2201 }
2203 2202
2204 nbfl = 0; 2203 nbfl = 0;
2205 ypos = m_topmargin; 2204 ypos = m_topmargin;
2206 2205
2207 while (locate() < target) 2206 while (locate() < target)
2208 { 2207 {
2209 if (buff[nbfl] == NULL) buff[nbfl] = new CDrawBuffer(&m_fontControl); 2208 if (buff[nbfl] == NULL) buff[nbfl] = new CDrawBuffer(&m_fontControl);
2210 loc[nbfl] = locate(); 2209 loc[nbfl] = locate();
2211 ch = getline(buff[nbfl]); 2210 ch = getline(buff[nbfl]);
2212 ypos += buff[nbfl]->lineSpacing(); 2211 ypos += buff[nbfl]->lineSpacing();
2213 nbfl++; 2212 nbfl++;
2214 if (!ch) break; 2213 if (!ch) break;
2215 } 2214 }
2216 if (guess < 4000 && ypos < ((m_rotated) ? width() : height())-(m_bottommargin) && (delta != 0)) 2215 if (guess < 4000 && ypos < ((m_rotated) ? width() : height())-(m_bottommargin) && (delta != 0))
2217 { 2216 {
2218 for (int i = 0; i < nbfl; i++) 2217 for (int i = 0; i < nbfl; i++)
2219 { 2218 {
2220 delete buff[i]; 2219 delete buff[i];
2221 buff[i] = NULL; 2220 buff[i] = NULL;
2222 } 2221 }
2223 guess <<= 1; 2222 guess <<= 1;
2224 continue; 2223 continue;
2225 } 2224 }
2226 break; 2225 break;
2227 } 2226 }
2228 if (ch) 2227 if (ch)
2229 { 2228 {
2230 if (buff[nbfl] == NULL) buff[nbfl] = new CDrawBuffer(&m_fontControl); 2229 if (buff[nbfl] == NULL) buff[nbfl] = new CDrawBuffer(&m_fontControl);
2231 loc[nbfl] = locate(); 2230 loc[nbfl] = locate();
2232 int ch = getline(buff[nbfl]); 2231 int ch = getline(buff[nbfl]);
2233 nbfl++; 2232 nbfl++;
2234 } 2233 }
2235/* 2234/*
2236 ypos = 0; 2235 ypos = 0;
2237 numlines = 0; 2236 numlines = 0;
2238 while (ypos < height() && numlines <= nbfl-1) 2237 while (ypos < height() && numlines <= nbfl-1)
2239 { 2238 {
2240 ypos += buff[nbfl - numlines - 1]->lineSpacing(); 2239 ypos += buff[nbfl - numlines - 1]->lineSpacing();
2241 numlines++; 2240 numlines++;
2242 } 2241 }
2243 --numlines; 2242 --numlines;
2244*/ 2243*/
2245 2244
2246 ypos = m_topmargin; 2245 ypos = m_topmargin;
2247 numlines = 0; 2246 numlines = 0;
2248 while (ypos < ((m_rotated) ? width() : height())-m_bottommargin && numlines+2 <= nbfl) 2247 while (ypos < ((m_rotated) ? width() : height())-m_bottommargin && numlines+2 <= nbfl)
2249 { 2248 {
2250 ypos += buff[nbfl - numlines - 2]->lineSpacing(); 2249 ypos += buff[nbfl - numlines - 2]->lineSpacing();
2251 numlines++; 2250 numlines++;
2252 } 2251 }
2253 if (numlines > 0) --numlines; 2252 if (numlines > 0) --numlines;
2254 if (numlines == 0 && nbfl > 1) numlines = 1; 2253 if (numlines == 0 && nbfl > 1) numlines = 1;
2255 2254
2256 int offset = nbfl-1; 2255 int offset = nbfl-1;
2257 offset -= numlines; 2256 offset -= numlines;
2258 ypos = m_topmargin; 2257 ypos = m_topmargin;
2259 for (int i = 0; i <= numlines; i++) 2258 for (int i = 0; i <= numlines; i++)
2260 { 2259 {
2261 delete textarray[i]; 2260 delete textarray[i];
2262 textarray[i] = buff[offset+i]; 2261 textarray[i] = buff[offset+i];
2263 locnarray[i] = loc[offset + i]; 2262 locnarray[i] = loc[offset + i];
2264 ypos += textarray[i]->lineSpacing(); 2263 ypos += textarray[i]->lineSpacing();
2265 } 2264 }
2266#ifdef _WINDOWS 2265#ifdef _WINDOWS
2267 for (i = 0; i < nbfl - numlines - 1; i++) 2266 for (i = 0; i < nbfl - numlines - 1; i++)
2268#else 2267#else
2269 for (int i = 0; i < nbfl - numlines - 1; i++) 2268 for (int i = 0; i < nbfl - numlines - 1; i++)
2270#endif 2269#endif
2271 { 2270 {
2272 delete buff[i]; 2271 delete buff[i];
2273 } 2272 }
2274 2273
2275 while (ypos < ((m_rotated) ? width() : height())-m_bottommargin) 2274 while (ypos < ((m_rotated) ? width() : height())-m_bottommargin)
2276 { 2275 {
2277 numlines++; 2276 numlines++;
2278 locnarray[numlines] = locate(); 2277 locnarray[numlines] = locate();
2279 if (textarray[numlines] == NULL) textarray[numlines] = new CDrawBuffer(&m_fontControl); 2278 if (textarray[numlines] == NULL) textarray[numlines] = new CDrawBuffer(&m_fontControl);
2280 if (!getline(textarray[numlines])) break; 2279 if (!getline(textarray[numlines])) break;
2281 ypos += textarray[numlines]->lineSpacing(); 2280 ypos += textarray[numlines]->lineSpacing();
2282 } 2281 }
2283 2282
2284 mylastpos = locate(); 2283 mylastpos = locate();
2285 CalculateScrollParameters(); 2284 CalculateScrollParameters();
2286 drawFonts(); 2285 drawFonts();
2287 // repaint(); 2286 // repaint();
2288} 2287}
2289 2288
2290bool QTReader::load_file(const char *newfile, unsigned int _lcn) 2289bool QTReader::load_file(const char *newfile, unsigned int _lcn)
2291{ 2290{
2292// QMessageBox::information(this, "Name", name, 1); 2291// QMessageBox::information(this, "Name", name, 1);
2293// QMessageBox::information(this, "load_file", newfile, 1); 2292// QMessageBox::information(this, "load_file", newfile, 1);
2294 int prog = 0; 2293 int prog = 0;
2295 bool bRC = false; 2294 bool bRC = false;
2296 unsigned int lcn = _lcn; 2295 unsigned int lcn = _lcn;
2297 ResetScroll(); 2296 ResetScroll();
2298 if (m_lastfile == newfile) 2297 if (m_lastfile == newfile)
2299 { 2298 {
2300 lcn = m_lastposn; 2299 lcn = m_lastposn;
2301 } 2300 }
2302 // QMessageBox::information(0, "Opening...", newfile); 2301 // QMessageBox::information(0, "Opening...", newfile);
2303 if (m_rotated) 2302 if (m_rotated)
2304 { 2303 {
2305 m_lastwidth = height(); 2304 m_lastwidth = height();
2306 m_lastheight = width(); 2305 m_lastheight = width();
2307 } 2306 }
2308 else 2307 else
2309 { 2308 {
2310 m_lastwidth = width(); 2309 m_lastwidth = width();
2311 m_lastheight = height(); 2310 m_lastheight = height();
2312 } 2311 }
2313 if (buffdoc.openfile(this,newfile) == 0) 2312 if (buffdoc.openfile(this,newfile) == 0)
2314 { 2313 {
2315 m_lastfile = newfile; 2314 m_lastfile = newfile;
2316 buffdoc.setwidth(m_lastwidth-(m_left_border+m_right_border)); 2315 buffdoc.setwidth(m_lastwidth-(m_left_border+m_right_border));
2317 bRC = true; 2316 bRC = true;
2318 buffdoc.setContinuous(m_continuousDocument); 2317 buffdoc.setContinuous(m_continuousDocument);
2319 qDebug("buffdoc.openfile done"); 2318 qDebug("buffdoc.openfile done");
2320 locate(lcn); 2319 locate(lcn);
2321 qDebug("buffdoc.locate done"); 2320 qDebug("buffdoc.locate done");
2322 } 2321 }
2323 setfilter(getfilter()); 2322 setfilter(getfilter());
2324 qDebug("Updated"); 2323 qDebug("Updated");
2325 return bRC; 2324 return bRC;
2326} 2325}
2327 2326
2328void QTReader::lineDown() 2327void QTReader::lineDown()
2329{ 2328{
2330 int ypos = m_topmargin; 2329 int ypos = m_topmargin;
2331 ResetScroll(); 2330 ResetScroll();
2332 int offset = numlines; 2331 int offset = numlines;
2333 2332
2334 for (int i = 0; i <= numlines; i++) 2333 for (int i = 0; i <= numlines; i++)
2335 { 2334 {
2336 if ((ypos += textarray[numlines-i]->lineSpacing()) > ((m_rotated) ? width() : height())) 2335 if ((ypos += textarray[numlines-i]->lineSpacing()) > ((m_rotated) ? width() : height()))
2337 { 2336 {
2338 offset = i-1; 2337 offset = i-1;
2339 break; 2338 break;
2340 } 2339 }
2341 } 2340 }
2342 offset = numlines - offset; 2341 offset = numlines - offset;
2343#ifdef _WINDOWS 2342#ifdef _WINDOWS
2344 for (i = offset; i <= numlines; i++) 2343 for (i = offset; i <= numlines; i++)
2345#else 2344#else
2346 for (int i = offset; i <= numlines; i++) 2345 for (int i = offset; i <= numlines; i++)
2347#endif 2346#endif
2348 { 2347 {
2349 CDrawBuffer* buff = textarray[i-offset]; 2348 CDrawBuffer* buff = textarray[i-offset];
2350 textarray[i-offset] = textarray[i]; 2349 textarray[i-offset] = textarray[i];
2351 locnarray[i-offset] = locnarray[i]; 2350 locnarray[i-offset] = locnarray[i];
2352 textarray[i] = buff; 2351 textarray[i] = buff;
2353 } 2352 }
2354 numlines = numlines - offset + 1; 2353 numlines = numlines - offset + 1;
2355 locnarray[numlines] = locate(); 2354 locnarray[numlines] = locate();
2356 if (textarray[numlines] == NULL) 2355 if (textarray[numlines] == NULL)
2357 { 2356 {
2358 textarray[numlines] = new CDrawBuffer(&m_fontControl); 2357 textarray[numlines] = new CDrawBuffer(&m_fontControl);
2359 } 2358 }
2360 getline(textarray[numlines]); 2359 getline(textarray[numlines]);
2361 mylastpos = locate(); 2360 mylastpos = locate();
2362 update(); 2361 update();
2363} 2362}
2364/* 2363/*
2365void QTReader::lineUp() 2364void QTReader::lineUp()
2366{ 2365{
2367 CBuffer** buff = textarray; 2366 CBuffer** buff = textarray;
2368 unsigned int *loc = new unsigned int[numlines]; 2367 unsigned int *loc = new unsigned int[numlines];
2369 int cbptr = 0; 2368 int cbptr = 0;
2370 if (locate() != mylastpos) jumpto(mylastpos); 2369 if (locate() != mylastpos) jumpto(mylastpos);
2371 unsigned int target = locnarray[numlines-1]; 2370 unsigned int target = locnarray[numlines-1];
2372 if (buffdoc.hasrandomaccess()) 2371 if (buffdoc.hasrandomaccess())
2373 { 2372 {
2374 unsigned int delta = locate()-pagelocate(); 2373 unsigned int delta = locate()-pagelocate();
2375 if (delta < 64) delta = 64; 2374 if (delta < 64) delta = 64;
2376 do 2375 do
2377 { 2376 {
2378 delta <<= 1; 2377 delta <<= 1;
2379 if (delta >= target) 2378 if (delta >= target)
2380 { 2379 {
2381 delta = target; 2380 delta = target;
2382 jumpto(0); 2381 jumpto(0);
2383 for (int i = 0; i < numlines; i++) 2382 for (int i = 0; i < numlines; i++)
2384 { 2383 {
2385 loc[i] = locate(); 2384 loc[i] = locate();
2386 getline(buff[i]); 2385 getline(buff[i]);
2387 } 2386 }
2388 break; 2387 break;
2389 } 2388 }
2390 jumpto(target-delta); 2389 jumpto(target-delta);
2391 do 2390 do
2392 { 2391 {
2393 buffdoc.getline(buff[0],width()); 2392 buffdoc.getline(buff[0],width());
2394#ifdef WS 2393#ifdef WS
2395 //printf("Trying:%s\n",buff[0]); 2394 //printf("Trying:%s\n",buff[0]);
2396#endif 2395#endif
2397 if (locate() > target) continue; 2396 if (locate() > target) continue;
2398 } 2397 }
2399 while (!buffdoc.iseol()); 2398 while (!buffdoc.iseol());
2400 for (int i = 0; i < numlines; i++) 2399 for (int i = 0; i < numlines; i++)
2401 { 2400 {
2402 loc[i] = locate(); 2401 loc[i] = locate();
2403 buffdoc.getline(buff[i],width()); 2402 buffdoc.getline(buff[i],width());
2404#ifdef WS 2403#ifdef WS
2405 //printf("Filling:%s\n",buff[i]); 2404 //printf("Filling:%s\n",buff[i]);
2406#endif 2405#endif
2407 } 2406 }
2408 } 2407 }
2409 while (locate() >= target && delta < 4096); 2408 while (locate() >= target && delta < 4096);
2410#ifdef WS 2409#ifdef WS
2411 //printf("Delta:%u\n",delta); 2410 //printf("Delta:%u\n",delta);
2412#endif 2411#endif
2413 } 2412 }
2414 else 2413 else
2415 { 2414 {
2416 jumpto(0); 2415 jumpto(0);
2417 for (int i = 0; i < numlines; i++) 2416 for (int i = 0; i < numlines; i++)
2418 { 2417 {
2419 loc[i] = locate(); 2418 loc[i] = locate();
2420 buffdoc.getline(buff[i],width()); 2419 buffdoc.getline(buff[i],width());
2421 } 2420 }
2422 } 2421 }
2423 cbptr = 0; 2422 cbptr = 0;
2424 while (locate() < target) 2423 while (locate() < target)
2425 { 2424 {
2426 loc[cbptr] = locate(); 2425 loc[cbptr] = locate();
2427 buffdoc.getline(buff[cbptr], width()); 2426 buffdoc.getline(buff[cbptr], width());
2428#ifdef WS 2427#ifdef WS
2429 //printf("Adding:%s\n",buff[cbptr]->data()); 2428 //printf("Adding:%s\n",buff[cbptr]->data());
2430#endif 2429#endif
2431 cbptr = (cbptr+1) % numlines; 2430 cbptr = (cbptr+1) % numlines;
2432 } 2431 }
2433 pagepos = loc[cbptr]; 2432 pagepos = loc[cbptr];
2434 textarray = new CBuffer*[numlines]; 2433 textarray = new CBuffer*[numlines];
2435 for (int i = 0; i < numlines; i++) 2434 for (int i = 0; i < numlines; i++)
2436 { 2435 {
2437 int j = (cbptr+i)%numlines; 2436 int j = (cbptr+i)%numlines;
2438 textarray[i] = buff[j]; 2437 textarray[i] = buff[j];
2439 locnarray[i] = loc[j]; 2438 locnarray[i] = loc[j];
2440 } 2439 }
2441 delete [] buff; 2440 delete [] buff;
2442 delete [] loc; 2441 delete [] loc;
2443 mylastpos = locate(); 2442 mylastpos = locate();
2444 update(); 2443 update();
2445} 2444}
2446*/ 2445*/
2447 2446
2448void QTReader::ResetScroll() 2447void QTReader::ResetScroll()
2449{ 2448{
2450 m_totalscroll = 0; 2449 m_totalscroll = 0;
2451 m_scrolldy1 = 0; 2450 m_scrolldy1 = 0;
2452 m_scrolldy = m_topmargin; 2451 m_scrolldy = m_topmargin;
2453 if (m_autoScroll && ((m_scrolltype == 0) || !m_bgpm.isNull())) 2452 if (m_autoScroll && ((m_scrolltype == 0) || !m_bgpm.isNull()))
2454 { 2453 {
2455 setautoscroll(false); 2454 setautoscroll(false);
2456 } 2455 }
2457} 2456}
2458 2457
2459void QTReader::lineUp() 2458void QTReader::lineUp()
2460{ 2459{
2461 dopageup(locnarray[numlines-1]); 2460 dopageup(locnarray[numlines-1]);
2462 2461
2463 /* 2462 /*
2464 buffdoc.unsuspend(); 2463 buffdoc.unsuspend();
2465 ResetScroll(); 2464 ResetScroll();
2466 2465
2467 CDrawBuffer* buff = textarray[numlines]; 2466 CDrawBuffer* buff = textarray[numlines];
2468 unsigned int loc; 2467 unsigned int loc;
2469 unsigned int end = locnarray[numlines]; 2468 unsigned int end = locnarray[numlines];
2470 int cbptr = 0; 2469 int cbptr = 0;
2471 if (locate() != mylastpos) jumpto(mylastpos); 2470 if (locate() != mylastpos) jumpto(mylastpos);
2472 unsigned int target = locnarray[0]; 2471 unsigned int target = locnarray[0];
2473 if (target == 0) return; 2472 if (target == 0) return;
2474 if (!m_continuousDocument && (target == buffdoc.startSection())) return; 2473 if (!m_continuousDocument && (target == buffdoc.startSection())) return;
2475 if (buffdoc.hasrandomaccess()) 2474 if (buffdoc.hasrandomaccess())
2476 { 2475 {
2477 unsigned int delta = locate()-pagelocate(); 2476 unsigned int delta = locate()-pagelocate();
2478 if (delta < 64) delta = 64; 2477 if (delta < 64) delta = 64;
2479 do 2478 do
2480 { 2479 {
2481 delta <<= 1; 2480 delta <<= 1;
2482 if (delta >= target) 2481 if (delta >= target)
2483 { 2482 {
2484 delta = target; 2483 delta = target;
2485 jumpto(0); 2484 jumpto(0);
2486 loc = locate(); 2485 loc = locate();
2487 getline(buff); 2486 getline(buff);
2488 break; 2487 break;
2489 } 2488 }
2490 else if (!m_continuousDocument && (target - delta < buffdoc.startSection())) 2489 else if (!m_continuousDocument && (target - delta < buffdoc.startSection()))
2491 { 2490 {
2492 delta = target-buffdoc.startSection(); 2491 delta = target-buffdoc.startSection();
2493 jumpto(buffdoc.startSection()); 2492 jumpto(buffdoc.startSection());
2494 loc = locate(); 2493 loc = locate();
2495 getline(buff); 2494 getline(buff);
2496 break; 2495 break;
2497 } 2496 }
2498 jumpto(target-delta); 2497 jumpto(target-delta);
2499 do 2498 do
2500 { 2499 {
2501 getline(buff); 2500 getline(buff);
2502#ifdef WS 2501#ifdef WS
2503 //printf("Trying:%s\n",buff[0]); 2502 //printf("Trying:%s\n",buff[0]);
2504#endif 2503#endif
2505 if (locate() > target) continue; 2504 if (locate() > target) continue;
2506 } 2505 }
2507 while (!buffdoc.iseol()); 2506 while (!buffdoc.iseol());
2508 loc = locate(); 2507 loc = locate();
2509 getline(buff); 2508 getline(buff);
2510 } 2509 }
2511 while (locate() >= target && delta < 4096); 2510 while (locate() >= target && delta < 4096);
2512 } 2511 }
2513 else 2512 else
2514 { 2513 {
2515 jumpto(0); 2514 jumpto(0);
2516 loc = locate(); 2515 loc = locate();
2517 getline(buff); 2516 getline(buff);
2518 } 2517 }
2519 cbptr = 0; 2518 cbptr = 0;
2520 while (locate() < target) 2519 while (locate() < target)
2521 { 2520 {
2522 loc = locate(); 2521 loc = locate();
2523 getline(buff); 2522 getline(buff);
2524 } 2523 }
2525 for (int i = numlines; i > 0; i--) 2524 for (int i = numlines; i > 0; i--)
2526 { 2525 {
2527 textarray[i] = textarray[i-1]; 2526 textarray[i] = textarray[i-1];
2528 locnarray[i] = locnarray[i-1]; 2527 locnarray[i] = locnarray[i-1];
2529 } 2528 }
2530 textarray[0] = buff; 2529 textarray[0] = buff;
2531 locnarray[0] = loc; 2530 locnarray[0] = loc;
2532 int start = numlines; 2531 int start = numlines;
2533 int ypos = m_topmargin; 2532 int ypos = m_topmargin;
2534#ifdef _WINDOWS 2533#ifdef _WINDOWS
2535 for (i = 0; i <= numlines; i++) 2534 for (i = 0; i <= numlines; i++)
2536#else 2535#else
2537 for (int i = 0; i <= numlines; i++) 2536 for (int i = 0; i <= numlines; i++)
2538#endif 2537#endif
2539 { 2538 {
2540 ypos += textarray[i]->lineSpacing(); 2539 ypos += textarray[i]->lineSpacing();
2541 if (ypos > ((m_rotated) ? width() : height())) 2540 if (ypos > ((m_rotated) ? width() : height()))
2542 { 2541 {
2543 start = i; 2542 start = i;
2544 ypos -= textarray[i]->lineSpacing(); 2543 ypos -= textarray[i]->lineSpacing();
2545 break; 2544 break;
2546 } 2545 }
2547 } 2546 }
2548 jumpto(locnarray[start]); 2547 jumpto(locnarray[start]);
2549 fillbuffer(start, ypos); 2548 fillbuffer(start, ypos);
2550 repaint(); 2549 repaint();
2551 */ 2550 */
2552} 2551}
2553 2552
2554bool QTReader::empty() 2553bool QTReader::empty()
2555{ 2554{
2556 return buffdoc.empty(); 2555 return buffdoc.empty();
2557} 2556}
2558 2557
2559MarkupType QTReader::PreferredMarkup() 2558MarkupType QTReader::PreferredMarkup()
2560{ 2559{
2561 MarkupType m = buffdoc.PreferredMarkup(); 2560 MarkupType m = buffdoc.PreferredMarkup();
2562 if (m == cTEXT) 2561 if (m == cTEXT)
2563 { 2562 {
2564 int ext = m_lastfile.findRev('.'); 2563 int ext = m_lastfile.findRev('.');
2565 if (ext >= 0) 2564 if (ext >= 0)
2566 { 2565 {
2567 QString ft = m_lastfile.right(m_lastfile.length()-ext-1).upper(); 2566 QString ft = m_lastfile.right(m_lastfile.length()-ext-1).upper();
2568 if (ft.left(3) == "HTM") 2567 if (ft.left(3) == "HTM")
2569 { 2568 {
2570 m = cHTML; 2569 m = cHTML;
2571 } 2570 }
2572 } 2571 }
2573 } 2572 }
2574 return m; 2573 return m;
2575} 2574}
2576#ifdef DOUBLEBUFFER 2575#ifdef DOUBLEBUFFER
2577void QTReader::resizeEvent( QResizeEvent * p ) 2576void QTReader::resizeEvent( QResizeEvent * p )
2578{ 2577{
2579 if (m_rotated) 2578 if (m_rotated)
2580 { 2579 {
2581 dbuff->resize(p->size().height(),p->size().width()); 2580 dbuff->resize(p->size().height(),p->size().width());
2582 } 2581 }
2583 else 2582 else
2584 { 2583 {
2585 dbuff->resize(p->size()); 2584 dbuff->resize(p->size());
2586 } 2585 }
2587 m_bgIsScaled = false; 2586 m_bgIsScaled = false;
2588 if (m_bgtype == bgStretched) 2587 if (m_bgtype == bgStretched)
2589 { 2588 {
2590 emit RefreshBitmap(); 2589 emit RefreshBitmap();
2591 } 2590 }
2592 2591
2593 { 2592 {
2594 int h, w; 2593 int h, w;
2595 if (m_rotated) 2594 if (m_rotated)
2596 { 2595 {
2597 h = p->size().width(); 2596 h = p->size().width();
2598 w = p->size().height(); 2597 w = p->size().height();
2599 } 2598 }
2600 else 2599 else
2601 { 2600 {
2602 w = p->size().width(); 2601 w = p->size().width();
2603 h = p->size().height(); 2602 h = p->size().height();
2604 } 2603 }
2605 m_topmargin = (h*m_abstopmargin+500)/1000; 2604 m_topmargin = (h*m_abstopmargin+500)/1000;
2606 m_bottommargin = (h*m_absbottommargin+500)/1000; 2605 m_bottommargin = (h*m_absbottommargin+500)/1000;
2607 m_left_border = (w*m_absleft_border+500)/1000; 2606 m_left_border = (w*m_absleft_border+500)/1000;
2608 m_right_border = (w*m_absright_border+500)/1000; 2607 m_right_border = (w*m_absright_border+500)/1000;
2609 2608
2610 qDebug("Top margin:%u", m_topmargin ); 2609 qDebug("Top margin:%u", m_topmargin );
2611 qDebug("Bottom margin:%u", m_bottommargin ); 2610 qDebug("Bottom margin:%u", m_bottommargin );
2612 qDebug("Left margin:%u", m_left_border ); 2611 qDebug("Left margin:%u", m_left_border );
2613 qDebug("Right margin:%u", m_right_border ); 2612 qDebug("Right margin:%u", m_right_border );
2614 } 2613 }
2615} 2614}
2616#endif 2615#endif
2617 2616
2618void QTReader::setrotated(bool sfs) 2617void QTReader::setrotated(bool sfs)
2619{ 2618{
2620 m_rotated = sfs; 2619 m_rotated = sfs;
2621#ifdef DOUBLEBUFFER 2620#ifdef DOUBLEBUFFER
2622 if (m_rotated) 2621 if (m_rotated)
2623 { 2622 {
2624 dbuff->resize(height(), width()); 2623 dbuff->resize(height(), width());
2625 } 2624 }
2626 else 2625 else
2627 { 2626 {
2628 dbuff->resize(width(), height()); 2627 dbuff->resize(width(), height());
2629 } 2628 }
2630 m_bgIsScaled = false; 2629 m_bgIsScaled = false;
2631#endif 2630#endif
2632 int h, w; 2631 int h, w;
2633 if (m_rotated) 2632 if (m_rotated)
2634 { 2633 {
2635 h = width(); 2634 h = width();
2636 w = height(); 2635 w = height();
2637 } 2636 }
2638 else 2637 else
2639 { 2638 {
2640 w = width(); 2639 w = width();
2641 h = height(); 2640 h = height();
2642 } 2641 }
2643 m_topmargin = (h*m_abstopmargin+500)/1000; 2642 m_topmargin = (h*m_abstopmargin+500)/1000;
2644 m_bottommargin = (h*m_absbottommargin+500)/1000; 2643 m_bottommargin = (h*m_absbottommargin+500)/1000;
2645 m_left_border = (w*m_absleft_border+500)/1000; 2644 m_left_border = (w*m_absleft_border+500)/1000;
2646 m_right_border = (w*m_absright_border+500)/1000; 2645 m_right_border = (w*m_absright_border+500)/1000;
2647 2646
2648 qDebug("Top margin:%u", m_topmargin ); 2647 qDebug("Top margin:%u", m_topmargin );
2649 qDebug("Bottom margin:%u", m_bottommargin ); 2648 qDebug("Bottom margin:%u", m_bottommargin );
2650 qDebug("Left margin:%u", m_left_border ); 2649 qDebug("Left margin:%u", m_left_border );
2651 qDebug("Right margin:%u", m_right_border ); 2650 qDebug("Right margin:%u", m_right_border );
2652} 2651}
2653 2652
2654void QTReader::drawBackground() 2653void QTReader::drawBackground()
2655{ 2654{
2656 dbp->begin(dbuff); 2655 dbp->begin(dbuff);
2657 // dbp->setBackgroundMode(OpaqueMode); 2656 // dbp->setBackgroundMode(OpaqueMode);
2658 dbp->setBackgroundColor(m_bg); 2657 dbp->setBackgroundColor(m_bg);
2659 dbp->eraseRect(dbuff->rect()); 2658 dbp->eraseRect(dbuff->rect());
2660 if (!m_bgpm.isNull()) 2659 if (!m_bgpm.isNull())
2661 { 2660 {
2662 // dbp->setBackgroundMode(TransparentMode); 2661 // dbp->setBackgroundMode(TransparentMode);
2663 switch (m_bgtype) 2662 switch (m_bgtype)
2664 { 2663 {
2665 case bgCentred: 2664 case bgCentred:
2666 { 2665 {
2667 int w = (dbuff->rect().width()-m_bgpm.width())/2; 2666 int w = (dbuff->rect().width()-m_bgpm.width())/2;
2668 int h = (dbuff->rect().height()-m_bgpm.height())/2; 2667 int h = (dbuff->rect().height()-m_bgpm.height())/2;
2669 dbp->drawPixmap(w,h,m_bgpm); 2668 dbp->drawPixmap(w,h,m_bgpm);
2670 } 2669 }
2671 break; 2670 break;
2672 case bgTiled: 2671 case bgTiled:
2673 { 2672 {
2674 dbp->drawTiledPixmap(0,0,dbuff->rect().width(),dbuff->rect().height(),m_bgpm); 2673 dbp->drawTiledPixmap(0,0,dbuff->rect().width(),dbuff->rect().height(),m_bgpm);
2675 /* 2674 /*
2676 for (int h = 0; h < dbuff->rect().height(); h += m_bgpm.height()) 2675 for (int h = 0; h < dbuff->rect().height(); h += m_bgpm.height())
2677 { 2676 {
2678 for (int w = 0; w < dbuff->rect().width(); w += m_bgpm.width()) 2677 for (int w = 0; w < dbuff->rect().width(); w += m_bgpm.width())
2679 { 2678 {
2680 dbp->drawPixmap(w,h,m_bgpm); 2679 dbp->drawPixmap(w,h,m_bgpm);
2681 } 2680 }
2682 } 2681 }
2683 */ 2682 */
2684 } 2683 }
2685 break; 2684 break;
2686 case bgStretched: 2685 case bgStretched:
2687 { 2686 {
2688 if (!m_bgIsScaled) 2687 if (!m_bgIsScaled)
2689 { 2688 {
2690 m_bgIsScaled = true; 2689 m_bgIsScaled = true;
2691 QImage im = m_bgpm.convertToImage(); 2690 QImage im = m_bgpm.convertToImage();
2692 m_bgpm.convertFromImage(im.smoothScale(dbuff->rect().width(), dbuff->rect().height())); 2691 m_bgpm.convertFromImage(im.smoothScale(dbuff->rect().width(), dbuff->rect().height()));
2693 } 2692 }
2694 dbp->drawPixmap(0,0,m_bgpm); 2693 dbp->drawPixmap(0,0,m_bgpm);
2695 } 2694 }
2696 break; 2695 break;
2697 default: 2696 default:
2698 qDebug("Unknown background type"); 2697 qDebug("Unknown background type");
2699 } 2698 }
2700 // dbp->setBackgroundMode(OpaqueMode); 2699 // dbp->setBackgroundMode(OpaqueMode);
2701 } 2700 }
2702} 2701}
2703 2702
2704void QTReader::blitRot(int dx, int dy, int sw, int sh, CDrawBuffer* txt) 2703void QTReader::blitRot(int dx, int dy, int sw, int sh, CDrawBuffer* txt)
2705{ 2704{
2706 if (txt != NULL) 2705 if (txt != NULL)
2707 { 2706 {
2708 sh = txt->lineSpacing(); 2707 sh = txt->lineSpacing();
2709 } 2708 }
2710 int sy = width()-dx-sh; 2709 int sy = width()-dx-sh;
2711 if (m_autoScroll && !(m_scrolltype == 0)) 2710 if (m_autoScroll && !(m_scrolltype == 0))
2712 { 2711 {
2713 sy = (sy+m_totalscroll+1)%width(); 2712 sy = (sy+m_totalscroll+1)%width();
2714 } 2713 }
2715 2714
2716 QPixmap pm(sw, sh); 2715 QPixmap pm(sw, sh);
2717 2716
2718 QPainter pd(&pm, this); 2717 QPainter pd(&pm, this);
2719 if (m_bgpm.isNull()) 2718 if (m_bgpm.isNull())
2720 { 2719 {
2721 pd.eraseRect(pm.rect()); 2720 pd.eraseRect(pm.rect());
2722 } 2721 }
2723 else 2722 else
2724 { 2723 {
2725 if (sy+pm.height() > dbuff->height()) 2724 if (sy+pm.height() > dbuff->height())
2726 { 2725 {
2727 // pd.eraseRect(pm.rect()); 2726 // pd.eraseRect(pm.rect());
2728 int fh = dbuff->height() - sy; 2727 int fh = dbuff->height() - sy;
2729 if (sy+fh > dbuff->height()) 2728 if (sy+fh > dbuff->height())
2730 { 2729 {
2731 qDebug("Oh no!"); 2730 qDebug("Oh no!");
2732 } 2731 }
2733 2732
2734 if (fh > pm.height()) 2733 if (fh > pm.height())
2735 { 2734 {
2736 qDebug("Oh no! - 2"); 2735 qDebug("Oh no! - 2");
2737 } 2736 }
2738 2737
2739 bitBlt(&pm,0,0,dbuff,dy,sy,pm.width(),fh); 2738 bitBlt(&pm,0,0,dbuff,dy,sy,pm.width(),fh);
2740 bitBlt(&pm,0,fh,dbuff,dy,0,pm.width(),pm.height()-fh); 2739 bitBlt(&pm,0,fh,dbuff,dy,0,pm.width(),pm.height()-fh);
2741 } 2740 }
2742 else 2741 else
2743 { 2742 {
2744 bitBlt(&pm,0,0,dbuff,dy,sy,pm.width(),pm.height()); 2743 bitBlt(&pm,0,0,dbuff,dy,sy,pm.width(),pm.height());
2745 } 2744 }
2746 } 2745 }
2747 if (txt != NULL) 2746 if (txt != NULL)
2748 { 2747 {
2749 // txt->render(&pd, txt->lineSpacing() - txt->descent() - txt->lineExtraSpacing(), m_bMonoSpaced, m_charWidth, sw, m_left_border, m_right_border, m_bg); 2748 // txt->render(&pd, txt->lineSpacing() - txt->descent() - txt->lineExtraSpacing(), m_bMonoSpaced, m_charWidth, sw, m_left_border, m_right_border, m_bg);
2750 txt->render(&pd, txt->lineSpacing() - txt->descent() - txt->lineExtraSpacing(), m_bMonoSpaced, m_charWidth, sw, m_left_border, m_right_border, m_bg, width()-m_topmargin-m_bottommargin); 2749 txt->render(&pd, txt->lineSpacing() - txt->descent() - txt->lineExtraSpacing(), m_bMonoSpaced, m_charWidth, sw, m_left_border, m_right_border, m_bg, width()-m_topmargin-m_bottommargin);
2751 } 2750 }
2752 QWMatrix m; 2751 QWMatrix m;
2753 m.rotate(90); 2752 m.rotate(90);
2754 QPixmap rp = pm.xForm(m); 2753 QPixmap rp = pm.xForm(m);
2755 /* 2754 /*
2756 p.drawPixmap(QPoint(dx, dy), rp); 2755 p.drawPixmap(QPoint(dx, dy), rp);
2757 */ 2756 */
2758 bitBlt(this, dx, dy, &rp, 0, 0, -1, -1, CopyROP); 2757 bitBlt(this, dx, dy, &rp, 0, 0, -1, -1, CopyROP);
2759} 2758}
2760 2759
2761QString QTReader::about() 2760QString QTReader::about()
2762{ 2761{
2763 return QString("QTReader widget (c) Tim Wentford\n")+buffdoc.about() + "\nMini-scrollbar by Markus Gritsch\nNavigation History fixes by Frantisek Dufka"; 2762 return QString("QTReader widget (c) Tim Wentford\n")+buffdoc.about() + "\nMini-scrollbar by Markus Gritsch\nNavigation History fixes by Frantisek Dufka";
2764} 2763}
2765 2764
2766void QTReader::getNextLink() 2765void QTReader::getNextLink()
2767{ 2766{
2768 if (m_scrolldy != 0) 2767 if (m_scrolldy != 0)
2769 { 2768 {
2770 setautoscroll(false); 2769 setautoscroll(false);
2771 ResetScroll(); 2770 ResetScroll();
2772 redrawall(); 2771 redrawall();
2773 } 2772 }
2774 bool redraw = false; 2773 bool redraw = false;
2775 bool found = false; 2774 bool found = false;
2776 if (m_currentlink >= 0) 2775 if (m_currentlink >= 0)
2777 { 2776 {
2778 m_currentlinkoffset = textarray[m_currentlink]->invertLink(m_currentlinkoffset); 2777 m_currentlinkoffset = textarray[m_currentlink]->invertLink(m_currentlinkoffset);
2779 if ((m_currentlinkstyle = textarray[m_currentlink]->getNextLink(m_currentlinkoffset)) != NULL) 2778 if ((m_currentlinkstyle = textarray[m_currentlink]->getNextLink(m_currentlinkoffset)) != NULL)
2780 { 2779 {
2781 qDebug("Found a link at %u", m_currentlinkoffset); 2780 qDebug("Found a link at %u", m_currentlinkoffset);
2782 int offset = textarray[m_currentlink]->invertLink(m_currentlinkoffset); 2781 int offset = textarray[m_currentlink]->invertLink(m_currentlinkoffset);
2783 qDebug("Finishes at %u", offset); 2782 qDebug("Finishes at %u", offset);
2784 found = true; 2783 found = true;
2785 } 2784 }
2786 redraw = true; 2785 redraw = true;
2787 drawSingleLine(m_currentlink); 2786 drawSingleLine(m_currentlink);
2788 // if (found) return; 2787 // if (found) return;
2789 } 2788 }
2790 if (!found) 2789 if (!found)
2791 { 2790 {
2792 m_currentlinkoffset = -1; 2791 m_currentlinkoffset = -1;
2793 for (int i = m_currentlink+1; i < numlines; ++i) 2792 for (int i = m_currentlink+1; i < numlines; ++i)
2794 { 2793 {
2795 if ((m_currentlinkstyle = textarray[i]->getNextLink(m_currentlinkoffset)) != NULL) 2794 if ((m_currentlinkstyle = textarray[i]->getNextLink(m_currentlinkoffset)) != NULL)
2796 { 2795 {
2797 m_currentlink = i; 2796 m_currentlink = i;
2798 qDebug("Found a link at %u", m_currentlinkoffset); 2797 qDebug("Found a link at %u", m_currentlinkoffset);
2799 int offset = textarray[m_currentlink]->invertLink(m_currentlinkoffset); 2798 int offset = textarray[m_currentlink]->invertLink(m_currentlinkoffset);
2800 qDebug("Finishes at %u", offset); 2799 qDebug("Finishes at %u", offset);
2801 //drawSingleLine(i); 2800 //drawSingleLine(i);
2802 redraw = true; 2801 redraw = true;
2803 found = true; 2802 found = true;
2804 drawSingleLine(m_currentlink); 2803 drawSingleLine(m_currentlink);
2805 break; 2804 break;
2806 } 2805 }
2807 } 2806 }
2808 } 2807 }
2809 if (redraw) 2808 if (redraw)
2810 { 2809 {
2811 // redrawall(); 2810 // redrawall();
2812 } 2811 }
2813 if (!found) 2812 if (!found)
2814 { 2813 {
2815 m_currentlink = -1; 2814 m_currentlink = -1;
2816 m_currentlinkstyle = NULL; 2815 m_currentlinkstyle = NULL;
2817 m_currentlinkoffset = -1; 2816 m_currentlinkoffset = -1;
2818 dopagedn(); 2817 dopagedn();
2819 } 2818 }
2820} 2819}
2821 2820
2822void QTReader::emitRedraw() 2821void QTReader::emitRedraw()
2823{ 2822{
2824 m_currentlinkstyle = NULL; 2823 m_currentlinkstyle = NULL;
2825 m_currentlink = -1; 2824 m_currentlink = -1;
2826 m_currentlinkoffset = -1; 2825 m_currentlinkoffset = -1;
2827 emit OnRedraw(); 2826 emit OnRedraw();
2828}; 2827};
2829 2828
2830void QTReader::drawSingleLine(int lineno) 2829void QTReader::drawSingleLine(int lineno)
2831{ 2830{
2832 QPainter p( this ); 2831 QPainter p( this );
2833 int ypos = textarray[0]->ascent()+m_topmargin; 2832 int ypos = textarray[0]->ascent()+m_topmargin;
2834 if (lineno == 0) 2833 if (lineno == 0)
2835 { 2834 {
2836 if (m_rotated) 2835 if (m_rotated)
2837 { 2836 {
2838 blitRot(width()-(ypos+textarray[lineno]->descent()+textarray[lineno]->lineExtraSpacing()), 0, height(), -1, textarray[lineno]); 2837 blitRot(width()-(ypos+textarray[lineno]->descent()+textarray[lineno]->lineExtraSpacing()), 0, height(), -1, textarray[lineno]);
2839 } 2838 }
2840 else 2839 else
2841 { 2840 {
2842 if (m_bgpm.isNull()) 2841 if (m_bgpm.isNull())
2843 { 2842 {
2844 p.fillRect(m_left_border,ypos-textarray[lineno]->ascent(),width()-(m_left_border+m_right_border),textarray[lineno]->lineSpacing(),m_bg); 2843 p.fillRect(m_left_border,ypos-textarray[lineno]->ascent(),width()-(m_left_border+m_right_border),textarray[lineno]->lineSpacing(),m_bg);
2845 } 2844 }
2846 else 2845 else
2847 { 2846 {
2848 bitBlt(this, m_left_border, ypos-textarray[lineno]->ascent(), dbuff, m_left_border, ypos-textarray[lineno]->ascent(), width()-(m_left_border+m_right_border), textarray[lineno]->lineSpacing()); 2847 bitBlt(this, m_left_border, ypos-textarray[lineno]->ascent(), dbuff, m_left_border, ypos-textarray[lineno]->ascent(), width()-(m_left_border+m_right_border), textarray[lineno]->lineSpacing());
2849 } 2848 }
2850 textarray[lineno]->render( &p, ypos, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin); 2849 textarray[lineno]->render( &p, ypos, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin);
2851 } 2850 }
2852 } 2851 }
2853 for (int i = 1; i < numlines; i++) 2852 for (int i = 1; i < numlines; i++)
2854 { 2853 {
2855 ypos += (textarray[i-1]->descent() + textarray[i]->ascent())+ 2854 ypos += (textarray[i-1]->descent() + textarray[i]->ascent())+
2856 (textarray[i-1]->lineExtraSpacing() + textarray[i]->lineExtraSpacing())/2; 2855 (textarray[i-1]->lineExtraSpacing() + textarray[i]->lineExtraSpacing())/2;
2857 if (i == lineno) 2856 if (i == lineno)
2858 { 2857 {
2859 if (m_rotated) 2858 if (m_rotated)
2860 { 2859 {
2861 blitRot(width()-(ypos+textarray[i]->descent()+textarray[i]->lineExtraSpacing()), 0, height(), -1, textarray[i]); 2860 blitRot(width()-(ypos+textarray[i]->descent()+textarray[i]->lineExtraSpacing()), 0, height(), -1, textarray[i]);
2862 } 2861 }
2863 else 2862 else
2864 { 2863 {
2865 if (m_bgpm.isNull()) 2864 if (m_bgpm.isNull())
2866 { 2865 {
2867 p.fillRect(m_left_border,ypos-textarray[lineno]->ascent(),width()-(m_left_border+m_right_border),textarray[lineno]->lineSpacing(),m_bg); 2866 p.fillRect(m_left_border,ypos-textarray[lineno]->ascent(),width()-(m_left_border+m_right_border),textarray[lineno]->lineSpacing(),m_bg);
2868 } 2867 }
2869 else 2868 else
2870 { 2869 {
2871 bitBlt(this, m_left_border, ypos-textarray[lineno]->ascent(), dbuff, m_left_border, ypos-textarray[lineno]->ascent(), width()-(m_left_border+m_right_border), textarray[lineno]->lineSpacing()); 2870 bitBlt(this, m_left_border, ypos-textarray[lineno]->ascent(), dbuff, m_left_border, ypos-textarray[lineno]->ascent(), width()-(m_left_border+m_right_border), textarray[lineno]->lineSpacing());
2872 } 2871 }
2873 textarray[i]->render( &p, ypos, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin); 2872 textarray[i]->render( &p, ypos, m_bMonoSpaced, m_charWidth, width(), m_left_border, m_right_border, m_bg, height()-m_topmargin-m_bottommargin);
2874 } 2873 }
2875 } 2874 }
2876 } 2875 }
2877} 2876}
2878 2877
2879 2878
2880void QTReader::gotoLink() 2879void QTReader::gotoLink()
2881{ 2880{
2882 if (m_currentlinkstyle == NULL) return; 2881 if (m_currentlinkstyle == NULL) return;
2883 textarray[m_currentlink]->invertLink(m_currentlinkoffset); 2882 textarray[m_currentlink]->invertLink(m_currentlinkoffset);
2884 size_t saveposn = pagelocate(); 2883 size_t saveposn = pagelocate();
2885 QString href, nm; 2884 QString href, nm;
2886 unsigned long tgt = m_currentlinkstyle->getData(); 2885 unsigned long tgt = m_currentlinkstyle->getData();
2887 unsigned long tgtoffset = m_currentlinkstyle->getOffset(); 2886 unsigned long tgtoffset = m_currentlinkstyle->getOffset();
2888 linkType lt = buffdoc.hyperlink(tgt, tgtoffset, href, nm); 2887 linkType lt = buffdoc.hyperlink(tgt, tgtoffset, href, nm);
2889 qDebug("URL(1):%s", (const char*)href); 2888 qDebug("URL(1):%s", (const char*)href);
2890 if ((lt & eFile) != 0) 2889 if ((lt & eFile) != 0)
2891 { 2890 {
2892 buffdoc.saveposn(m_lastfile, saveposn); 2891 buffdoc.saveposn(m_lastfile, saveposn);
2893#ifdef USEQPE 2892#ifdef USEQPE
2894 { 2893 {
2895 QCopEnvelope e("QPE/System", "busy()"); 2894 QCopEnvelope e("QPE/System", "busy()");
2896 } 2895 }
2897#endif 2896#endif
2898 ResetScroll(); 2897 ResetScroll();
2899 if (!href.isEmpty()) 2898 if (!href.isEmpty())
2900 { 2899 {
2901 if (!buffdoc.getFile(href)) 2900 if (!buffdoc.getFile(href))
2902 { 2901 {
2903 emit NewFileRequest(href); 2902 emit NewFileRequest(href);
2904 } 2903 }
2905 else 2904 else
2906 { 2905 {
2907 ResetScroll(); 2906 ResetScroll();
2908 fillbuffer(); 2907 fillbuffer();
2909 update(); 2908 update();
2910 } 2909 }
2911 } 2910 }
2912 if (!nm.isEmpty()) 2911 if (!nm.isEmpty())
2913 { 2912 {
2914 qDebug("QTReader:Finding %s", (const char*)nm); 2913 qDebug("QTReader:Finding %s", (const char*)nm);
2915 if (buffdoc.findanchor(nm)) 2914 if (buffdoc.findanchor(nm))
2916 { 2915 {
2917 fillbuffer(); 2916 fillbuffer();
2918 update(); 2917 update();
2919 } 2918 }
2920 } 2919 }
2921 //fillbuffer(); 2920 //fillbuffer();
2922 //update(); 2921 //update();
2923#ifdef USEQPE 2922#ifdef USEQPE
2924 { 2923 {
2925 QCopEnvelope e("QPE/System", "notBusy()"); 2924 QCopEnvelope e("QPE/System", "notBusy()");
2926 } 2925 }
2927#endif 2926#endif
2928 } 2927 }
2929 else if ((lt & eLink) != 0) 2928 else if ((lt & eLink) != 0)
2930 { 2929 {
2931 buffdoc.saveposn(m_lastfile, saveposn); 2930 buffdoc.saveposn(m_lastfile, saveposn);
2932 ResetScroll(); 2931 ResetScroll();
2933 fillbuffer(); 2932 fillbuffer();
2934 update(); 2933 update();
2935 } 2934 }
2936 else 2935 else
2937 { 2936 {
2938 if ((lt & ePicture) != 0) 2937 if ((lt & ePicture) != 0)
2939 { 2938 {
2940 QImage* pm = buffdoc.getPicture(tgt); 2939 QImage* pm = buffdoc.getPicture(tgt);
2941 if (pm != NULL) 2940 if (pm != NULL)
2942 { 2941 {
2943 emit OnShowPicture(*pm); 2942 emit OnShowPicture(*pm);
2944 delete pm; 2943 delete pm;
2945 } 2944 }
2946 } 2945 }
2947 else 2946 else
2948 { 2947 {
2949 // QString anchortext = textarray[lineno]->getanchortext(startoffset); 2948 // QString anchortext = textarray[lineno]->getanchortext(startoffset);
2950 if (!href.isEmpty()) 2949 if (!href.isEmpty())
2951 { 2950 {
2952 emit OnURLSelected(href, tgt); 2951 emit OnURLSelected(href, tgt);
2953 } 2952 }
2954 } 2953 }
2955 locate(pagelocate()); 2954 locate(pagelocate());
2956 } 2955 }
2957 m_currentlinkstyle = NULL; 2956 m_currentlinkstyle = NULL;
2958 m_currentlink = -1; 2957 m_currentlink = -1;
2959 m_currentlinkoffset = -1; 2958 m_currentlinkoffset = -1;
2960} 2959}
2961 2960
2962void QTReader::refresh(bool full) 2961void QTReader::refresh(bool full)
2963{ 2962{
2964 int h, w; 2963 int h, w;
2965 if (m_rotated) 2964 if (m_rotated)
2966 { 2965 {
2967 h = width(); 2966 h = width();
2968 w = height(); 2967 w = height();
2969 } 2968 }
2970 else 2969 else
2971 { 2970 {
2972 w = width(); 2971 w = width();
2973 h = height(); 2972 h = height();
2974 } 2973 }
2975 m_topmargin = (h*m_abstopmargin+500)/1000; 2974 m_topmargin = (h*m_abstopmargin+500)/1000;
2976 m_bottommargin = (h*m_absbottommargin+500)/1000; 2975 m_bottommargin = (h*m_absbottommargin+500)/1000;
2977 m_left_border = (w*m_absleft_border+500)/1000; 2976 m_left_border = (w*m_absleft_border+500)/1000;
2978 m_right_border = (w*m_absright_border+500)/1000; 2977 m_right_border = (w*m_absright_border+500)/1000;
2979 2978
2980 qDebug("Top margin:%u", m_topmargin ); 2979 qDebug("Top margin:%u", m_topmargin );
2981 qDebug("Bottom margin:%u", m_bottommargin ); 2980 qDebug("Bottom margin:%u", m_bottommargin );
2982 qDebug("Left margin:%u", m_left_border ); 2981 qDebug("Left margin:%u", m_left_border );
2983 qDebug("Right margin:%u", m_right_border ); 2982 qDebug("Right margin:%u", m_right_border );
2984 if (full && m_highlightfilter) m_highlightfilter->refresh(pagelocate()); 2983 if (full && m_highlightfilter) m_highlightfilter->refresh(pagelocate());
2985 locate(pagelocate()); 2984 locate(pagelocate());
2986} 2985}
diff --git a/noncore/apps/opie-reader/QTReader.h b/noncore/apps/opie-reader/QTReader.h
index 7b0ebc8..3bcdde4 100644
--- a/noncore/apps/opie-reader/QTReader.h
+++ b/noncore/apps/opie-reader/QTReader.h
@@ -1,416 +1,415 @@
1#ifndef __QTREADER_H 1#ifndef __QTREADER_H
2#define __QTREADER_H 2#define __QTREADER_H
3 3
4//#define _SCROLLPIPE 4//#define _SCROLLPIPE
5#include "static.h"
6#include <qwidget.h> 5#include <qwidget.h>
7//#include <qpainter.h> 6//#include <qpainter.h>
8#include "my_list.h" 7#include "my_list.h"
9#include "BuffDoc.h" 8#include "BuffDoc.h"
10#include "FontControl.h" 9#include "FontControl.h"
11 10
12//#include <qtimer.h> 11//#include <qtimer.h>
13 12
14class CDrawBuffer; 13class CDrawBuffer;
15//class CBuffer; 14//class CBuffer;
16#include <qpixmap.h> 15#include <qpixmap.h>
17class QPainter; 16class QPainter;
18class QTimer; 17class QTimer;
19class QImage; 18class QImage;
20 19
21#include "BGType.h" 20#include "BGType.h"
22#include "striphtml.h" 21#include "striphtml.h"
23 22
24#define ROTATION_ENABLED 23#define ROTATION_ENABLED
25#define SPECIALSCROLL 24#define SPECIALSCROLL
26#define DOUBLEBUFFER 25#define DOUBLEBUFFER
27#ifdef DOUBLEBUFFER 26#ifdef DOUBLEBUFFER
28class QPainter; 27class QPainter;
29#endif 28#endif
30 29
31class CStyle; 30class CStyle;
32 31
33class QTReader : public QWidget 32class QTReader : public QWidget
34{ 33{
35 Q_OBJECT 34 Q_OBJECT
36 friend class QTReaderApp; 35 friend class QTReaderApp;
37#ifdef DOUBLEBUFFER 36#ifdef DOUBLEBUFFER
38 QPixmap *dbuff; 37 QPixmap *dbuff;
39 QPainter* dbp; 38 QPainter* dbp;
40#endif 39#endif
41 void drawSingleLine(int lineno); 40 void drawSingleLine(int lineno);
42 void gotoLink(); 41 void gotoLink();
43 void emitRedraw(); 42 void emitRedraw();
44 CStyle* m_currentlinkstyle; 43 CStyle* m_currentlinkstyle;
45 int m_currentlink; 44 int m_currentlink;
46 int m_currentlinkoffset; 45 int m_currentlinkoffset;
47 QPixmap m_bgpm; 46 QPixmap m_bgpm;
48 bool m_bgIsScaled; 47 bool m_bgIsScaled;
49 bground m_bgtype; 48 bground m_bgtype;
50 int m_scrollpos; 49 int m_scrollpos;
51 unsigned short m_scrollstep; 50 unsigned short m_scrollstep;
52 void blitRot(int dx, int sx, int sw, int sh, CDrawBuffer* txt); 51 void blitRot(int dx, int sx, int sw, int sh, CDrawBuffer* txt);
53 void setBackgroundBitmap(const QPixmap& _pm, bground bg) 52 void setBackgroundBitmap(const QPixmap& _pm, bground bg)
54 { 53 {
55 m_bgpm = _pm; 54 m_bgpm = _pm;
56 m_bgtype = bg; 55 m_bgtype = bg;
57 m_bgIsScaled = false; 56 m_bgIsScaled = false;
58 } 57 }
59 58
60 QColor m_bg, m_default_bg, m_default_fg, m_negative_fg; 59 QColor m_bg, m_default_bg, m_default_fg, m_negative_fg;
61 static tchar pluckernextpart[]; 60 static tchar pluckernextpart[];
62 static tchar jplucknextpart[]; 61 static tchar jplucknextpart[];
63 CList<Bkmk>* pBkmklist; 62 CList<Bkmk>* pBkmklist;
64 void setHyphenThreshold(int _v) { buffdoc.setHyphenThreshold(_v); } 63 void setHyphenThreshold(int _v) { buffdoc.setHyphenThreshold(_v); }
65 void ResetScroll(); 64 void ResetScroll();
66 void increaseScroll(); 65 void increaseScroll();
67 void reduceScroll(); 66 void reduceScroll();
68 void drawText(QPainter& p, int x, int y, tchar* text); 67 void drawText(QPainter& p, int x, int y, tchar* text);
69 void DrawScroll( QPainter *p, int w, int h ); 68 void DrawScroll( QPainter *p, int w, int h );
70 void dorollingscroll(bool); 69 void dorollingscroll(bool);
71 void doinplacescroll(); 70 void doinplacescroll();
72 void dostaticscroll(); 71 void dostaticscroll();
73 void suspend(); 72 void suspend();
74 void redrawScroll(QPainter* p); 73 void redrawScroll(QPainter* p);
75 int m_delay, m_scrolltype; 74 int m_delay, m_scrolltype;
76 unsigned int m_overlap; 75 unsigned int m_overlap;
77 bool m_autoScroll, m_swapmouse; 76 bool m_autoScroll, m_swapmouse;
78 void drawBackground(); 77 void drawBackground();
79#ifdef ROTATION_ENABLED 78#ifdef ROTATION_ENABLED
80 bool m_rotated; 79 bool m_rotated;
81 void setrotated(bool); 80 void setrotated(bool);
82#endif 81#endif
83 void autoscroll(); 82 void autoscroll();
84 QTimer* timer; 83 QTimer* timer;
85 int m_scrolldy1, m_scrolldy2, m_encd, m_scrollpart, m_totalscroll; 84 int m_scrolldy1, m_scrolldy2, m_encd, m_scrollpart, m_totalscroll;
86 void focusInEvent(QFocusEvent*); 85 void focusInEvent(QFocusEvent*);
87 void focusOutEvent(QFocusEvent*); 86 void focusOutEvent(QFocusEvent*);
88 void processmousepositionevent( QMouseEvent* _e ); 87 void processmousepositionevent( QMouseEvent* _e );
89 void processmousewordevent(size_t startpos, size_t startoffset, QMouseEvent* _e, int lineno); 88 void processmousewordevent(size_t startpos, size_t startoffset, QMouseEvent* _e, int lineno);
90 bool ChangeFont(int); 89 bool ChangeFont(int);
91 bool getline(CDrawBuffer*); 90 bool getline(CDrawBuffer*);
92 int m_charWidth; 91 int m_charWidth;
93 int m_charpc; 92 int m_charpc;
94 unsigned short m_absleft_border, m_absright_border; 93 unsigned short m_absleft_border, m_absright_border;
95 unsigned short m_left_border, m_right_border; 94 unsigned short m_left_border, m_right_border;
96 FontControl m_fontControl; 95 FontControl m_fontControl;
97 void setBaseSize(unsigned char _s) { m_fontControl.setBaseSize(_s); } 96 void setBaseSize(unsigned char _s) { m_fontControl.setBaseSize(_s); }
98 unsigned char getBaseSize() { return m_fontControl.getBaseSize(); } 97 unsigned char getBaseSize() { return m_fontControl.getBaseSize(); }
99#ifdef _SCROLLPIPE 98#ifdef _SCROLLPIPE
100 FILE* m_pipeout; 99 FILE* m_pipeout;
101 QString m_pipetarget; 100 QString m_pipetarget;
102 bool m_isPaused; 101 bool m_isPaused;
103 bool m_pauseAfterEachPara; 102 bool m_pauseAfterEachPara;
104#endif 103#endif
105public: 104public:
106 QTReader( QWidget *parent=0, const char *name=0, WFlags f = 0); 105 QTReader( QWidget *parent=0, const char *name=0, WFlags f = 0);
107 // QTReader( const QString& filename, QWidget *parent=0, const tchar *name=0, WFlags f = 0); 106 // QTReader( const QString& filename, QWidget *parent=0, const tchar *name=0, WFlags f = 0);
108 ~QTReader(); 107 ~QTReader();
109 QString about(); 108 QString about();
110 CList<Bkmk>* Bkmklist() { return pBkmklist; } 109 CList<Bkmk>* Bkmklist() { return pBkmklist; }
111 void setBackground(const QColor& _c) 110 void setBackground(const QColor& _c)
112 { 111 {
113 m_default_bg = _c; 112 m_default_bg = _c;
114 reset_bg(); 113 reset_bg();
115 } 114 }
116 void setForeground(const QColor& _c) 115 void setForeground(const QColor& _c)
117 { 116 {
118 m_default_fg = _c; 117 m_default_fg = _c;
119 int r,g,b; 118 int r,g,b;
120 m_default_fg.rgb(&r, &g, &b); 119 m_default_fg.rgb(&r, &g, &b);
121 r = 255-r; 120 r = 255-r;
122 g = 255-g; 121 g = 255-g;
123 b = 255-b; 122 b = 255-b;
124 m_negative_fg.setRgb(r,g,b); 123 m_negative_fg.setRgb(r,g,b);
125 } 124 }
126 void zoomin(); 125 void zoomin();
127 void zoomout(); 126 void zoomout();
128 void setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen) 127 void setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen)
129 { 128 {
130 buffdoc.setSaveData(data, len, src, srclen); 129 buffdoc.setSaveData(data, len, src, srclen);
131 } 130 }
132 void putSaveData(unsigned char*& src, unsigned short& srclen) 131 void putSaveData(unsigned char*& src, unsigned short& srclen)
133 { 132 {
134 buffdoc.putSaveData(src, srclen); 133 buffdoc.putSaveData(src, srclen);
135 } 134 }
136 bool empty(); 135 bool empty();
137 void setContinuous(bool _b); 136 void setContinuous(bool _b);
138 void toggle_autoscroll(); 137 void toggle_autoscroll();
139 void setautoscroll(bool); 138 void setautoscroll(bool);
140 void disableAutoscroll() { m_autoScroll = false; } 139 void disableAutoscroll() { m_autoScroll = false; }
141 void copy() 140 void copy()
142 { 141 {
143/* 142/*
144 size_t nd = locate(); 143 size_t nd = locate();
145 jumpto(m_mark); 144 jumpto(m_mark);
146 QString text; 145 QString text;
147 while (m_mark < nd) 146 while (m_mark < nd)
148 { 147 {
149 text += buffdoc.getch(); 148 text += buffdoc.getch();
150 m_mark++; 149 m_mark++;
151 } 150 }
152 QApplication::clipboard()->setText(text); 151 QApplication::clipboard()->setText(text);
153 jumpto(nd); 152 jumpto(nd);
154*/ 153*/
155 }; 154 };
156 void clear() {}; 155 void clear() {};
157 void setText(const QString& n, const QString& s) { m_string = n; load_file((const char*)s); }; 156 void setText(const QString& n, const QString& s) { m_string = n; load_file((const char*)s); };
158 /* 157 /*
159 void setText(bool oldfile) 158 void setText(bool oldfile)
160 { 159 {
161 if (oldfile) 160 if (oldfile)
162 { 161 {
163 m_string = m_lastfile; 162 m_string = m_lastfile;
164 load_file((const tchar*)m_string); 163 load_file((const tchar*)m_string);
165 } 164 }
166 else 165 else
167 { 166 {
168 m_string = QString::null; 167 m_string = QString::null;
169 } 168 }
170 }; 169 };
171 */ 170 */
172 void setlead(int _lead) 171 void setlead(int _lead)
173 { 172 {
174 m_fontControl.setlead(_lead); 173 m_fontControl.setlead(_lead);
175 } 174 }
176 int getlead() 175 int getlead()
177 { 176 {
178 return m_fontControl.getlead(); 177 return m_fontControl.getlead();
179 } 178 }
180 void setextraspace(int _lead) 179 void setextraspace(int _lead)
181 { 180 {
182 m_fontControl.setextraspace(_lead); 181 m_fontControl.setextraspace(_lead);
183 } 182 }
184 int getextraspace() 183 int getextraspace()
185 { 184 {
186 return m_fontControl.getextraspace(); 185 return m_fontControl.getextraspace();
187 } 186 }
188 void setpagemode(bool _b) 187 void setpagemode(bool _b)
189 { 188 {
190 m_bpagemode = _b; 189 m_bpagemode = _b;
191 } 190 }
192 void setmono(bool _b) 191 void setmono(bool _b)
193 { 192 {
194 m_bMonoSpaced = _b; 193 m_bMonoSpaced = _b;
195 ChangeFont(m_fontControl.currentsize()); 194 ChangeFont(m_fontControl.currentsize());
196 locate(pagelocate()); 195 locate(pagelocate());
197 } 196 }
198 void setencoding(int _f) 197 void setencoding(int _f)
199 { 198 {
200 m_encd = _f; 199 m_encd = _f;
201 setfilter(getfilter()); 200 setfilter(getfilter());
202 } 201 }
203 MarkupType PreferredMarkup(); 202 MarkupType PreferredMarkup();
204 CEncoding* getencoding() 203 CEncoding* getencoding()
205 { 204 {
206 // qDebug("m_encd:%d", m_encd); 205 // qDebug("m_encd:%d", m_encd);
207 switch (m_encd) 206 switch (m_encd)
208 { 207 {
209 case 4: 208 case 4:
210 // qDebug("palm"); 209 // qDebug("palm");
211 return new CPalm; 210 return new CPalm;
212 case 1: 211 case 1:
213 // qDebug("utf8"); 212 // qDebug("utf8");
214 return new CUtf8; 213 return new CUtf8;
215 case 2: 214 case 2:
216 // qDebug("ucs16be"); 215 // qDebug("ucs16be");
217 return new CUcs16be; 216 return new CUcs16be;
218 case 3: 217 case 3:
219 // qDebug("ucs16le"); 218 // qDebug("ucs16le");
220 return new CUcs16le; 219 return new CUcs16le;
221 case 0: 220 case 0:
222 // qDebug("ascii"); 221 // qDebug("ascii");
223 return new CAscii; 222 return new CAscii;
224 default: 223 default:
225 return new CGeneral8Bit(m_encd-MAX_ENCODING+1); 224 return new CGeneral8Bit(m_encd-MAX_ENCODING+1);
226 } 225 }
227 } 226 }
228 HighlightFilter* m_highlightfilter; 227 HighlightFilter* m_highlightfilter;
229 CFilterChain* getfilter() 228 CFilterChain* getfilter()
230 { 229 {
231 CFilterChain * filt = new CFilterChain(getencoding()); 230 CFilterChain * filt = new CFilterChain(getencoding());
232 if (bstripcr) filt->addfilter(new stripcr); 231 if (bstripcr) filt->addfilter(new stripcr);
233 232
234 if (btextfmt || (bautofmt && (PreferredMarkup() == cTEXT))) filt->addfilter(new textfmt); 233 if (btextfmt || (bautofmt && (PreferredMarkup() == cTEXT))) filt->addfilter(new textfmt);
235 if (bpeanut || (bautofmt && (PreferredMarkup() == cPML))) filt->addfilter(new PeanutFormatter); 234 if (bpeanut || (bautofmt && (PreferredMarkup() == cPML))) filt->addfilter(new PeanutFormatter);
236 // if (bstriphtml || (bautofmt && (PreferredMarkup() == cHTML))) filt->addfilter(new striphtml(m_lastfile)); 235 // if (bstriphtml || (bautofmt && (PreferredMarkup() == cHTML))) filt->addfilter(new striphtml(m_lastfile));
237 236
238#ifdef __STATIC 237#ifdef __STATIC
239 if (bstriphtml || (bautofmt && (PreferredMarkup() == cHTML))) filt->addfilter(new striphtml(m_lastfile)); 238 if (bstriphtml || (bautofmt && (PreferredMarkup() == cHTML))) filt->addfilter(new striphtml(m_lastfile));
240 if (bautofmt && (PreferredMarkup() == cCHM)) 239 if (bautofmt && (PreferredMarkup() == cCHM))
241 { 240 {
242 filt->addfilter(new striphtml(m_lastfile)); 241 filt->addfilter(new striphtml(m_lastfile));
243 } 242 }
244#else 243#else
245 if (bstriphtml || (bautofmt && (PreferredMarkup() == cHTML))) filt->addfilter(new ExternFilter("HTMLfilter", m_lastfile)); 244 if (bstriphtml || (bautofmt && (PreferredMarkup() == cHTML))) filt->addfilter(new ExternFilter("HTMLfilter", m_lastfile));
246 if (bautofmt && (PreferredMarkup() == cCHM)) 245 if (bautofmt && (PreferredMarkup() == cCHM))
247 { 246 {
248 ExternFilter* f = new ExternFilter("HTMLfilter",m_lastfile); 247 ExternFilter* f = new ExternFilter("HTMLfilter",m_lastfile);
249 ((striphtml*)f->filter())->setchm(true); 248 ((striphtml*)f->filter())->setchm(true);
250 filt->addfilter(f); 249 filt->addfilter(f);
251 } 250 }
252#endif 251#endif
253 m_highlightfilter = new HighlightFilter(this); 252 m_highlightfilter = new HighlightFilter(this);
254 filt->addfilter(m_highlightfilter); 253 filt->addfilter(m_highlightfilter);
255 254
256 if (bdehyphen) filt->addfilter(new dehyphen); 255 if (bdehyphen) filt->addfilter(new dehyphen);
257 if (bunindent) filt->addfilter(new unindent); 256 if (bunindent) filt->addfilter(new unindent);
258 if (brepara) filt->addfilter(new repara(m_reparastring)); 257 if (brepara) filt->addfilter(new repara(m_reparastring));
259 if (bonespace) filt->addfilter(new OnePara); 258 if (bonespace) filt->addfilter(new OnePara);
260 if (bindenter) filt->addfilter(new indenter(bindenter)); 259 if (bindenter) filt->addfilter(new indenter(bindenter));
261 if (bdblspce) filt->addfilter(new dblspce); 260 if (bdblspce) filt->addfilter(new dblspce);
262 if (bdepluck) filt->addfilter(new DePluck(pluckernextpart)); 261 if (bdepluck) filt->addfilter(new DePluck(pluckernextpart));
263 if (bdejpluck) filt->addfilter(new DePluck(jplucknextpart)); 262 if (bdejpluck) filt->addfilter(new DePluck(jplucknextpart));
264 if (brepalm) filt->addfilter(new repalm); 263 if (brepalm) filt->addfilter(new repalm);
265 if (bkern) filt->addfilter(new kern); 264 if (bkern) filt->addfilter(new kern);
266 if (bremap) filt->addfilter(new remap); 265 if (bremap) filt->addfilter(new remap);
267 if (bmakebold) filt->addfilter(new embolden); 266 if (bmakebold) filt->addfilter(new embolden);
268 if (bfulljust) filt->addfilter(new FullJust); 267 if (bfulljust) filt->addfilter(new FullJust);
269 int r,g,b; 268 int r,g,b;
270 m_default_bg.rgb(&r, &g, &b); 269 m_default_bg.rgb(&r, &g, &b);
271 if (r != 255 || g != 255 || b != 255) 270 if (r != 255 || g != 255 || b != 255)
272 filt->addfilter(new setbg(r,g,b)); 271 filt->addfilter(new setbg(r,g,b));
273 m_default_fg.rgb(&r, &g, &b); 272 m_default_fg.rgb(&r, &g, &b);
274 if (r != 0 || g != 0 || b != 0) 273 if (r != 0 || g != 0 || b != 0)
275 filt->addfilter(new setfg(r,g,b)); 274 filt->addfilter(new setfg(r,g,b));
276 // if (bNegative) filt->addfilter(new makeNegative); 275 // if (bNegative) filt->addfilter(new makeNegative);
277 if (bInverse) filt->addfilter(new makeInverse); 276 if (bInverse) filt->addfilter(new makeInverse);
278 return filt; 277 return filt;
279 } 278 }
280 279
281 280
282private slots: 281private slots:
283 void dopageup(); 282 void dopageup();
284 void lineDown(); 283 void lineDown();
285 void lineUp(); 284 void lineUp();
286 void dopagedn(); 285 void dopagedn();
287 void goHome(); 286 void goHome();
288 void goBack(); 287 void goBack();
289 void goForward(); 288 void goForward();
290 void doscroll(); 289 void doscroll();
291 void paintEvent( QPaintEvent * ); 290 void paintEvent( QPaintEvent * );
292#ifdef DOUBLEBUFFER 291#ifdef DOUBLEBUFFER
293 void resizeEvent( QResizeEvent * p ); 292 void resizeEvent( QResizeEvent * p );
294#endif 293#endif
295 void keyPressEvent(QKeyEvent*); 294 void keyPressEvent(QKeyEvent*);
296 private: 295 private:
297 // void drawIt( QPainter * ); 296 // void drawIt( QPainter * );
298 void redrawall(); 297 void redrawall();
299 void drawFonts(); 298 void drawFonts();
300 void DrawStraight(QPainter* p, int w, int h); 299 void DrawStraight(QPainter* p, int w, int h);
301 QColor m_scrollcolor, m_scrollbarcolor; 300 QColor m_scrollcolor, m_scrollbarcolor;
302 void setTwoTouch(bool _b); 301 void setTwoTouch(bool _b);
303 void init(); 302 void init();
304 void mousePressEvent( QMouseEvent* ); 303 void mousePressEvent( QMouseEvent* );
305 void mouseReleaseEvent( QMouseEvent* ); 304 void mouseReleaseEvent( QMouseEvent* );
306// void mouseDoubleClickEvent( QMouseEvent* ); 305// void mouseDoubleClickEvent( QMouseEvent* );
307 QString m_string, m_fontname, m_reparastring; 306 QString m_string, m_fontname, m_reparastring;
308 void setfont(); 307 void setfont();
309 //myoutput stuff 308 //myoutput stuff
310 private: 309 private:
311#ifdef SPECIALSCROLL 310#ifdef SPECIALSCROLL
312 int m_scrolldy; 311 int m_scrolldy;
313#endif 312#endif
314 bool mouseUpOn; 313 bool mouseUpOn;
315 linkType getcurrentpos(int x, int y, int w, int h, int& lineno, size_t& start, size_t& offset, size_t& tgt, size_t& tgtoffset, size_t& pictgt, QImage*&); 314 linkType getcurrentpos(int x, int y, int w, int h, int& lineno, size_t& start, size_t& offset, size_t& tgt, size_t& tgtoffset, size_t& pictgt, QImage*&);
316 bool m_twotouch, m_touchone; 315 bool m_twotouch, m_touchone;
317 size_t m_startpos, m_startoffset; 316 size_t m_startpos, m_startoffset;
318 void dopageup(unsigned int); 317 void dopageup(unsigned int);
319 long real_delay(); 318 long real_delay();
320 int m_textsize; 319 int m_textsize;
321 int m_lastwidth, m_lastheight; 320 int m_lastwidth, m_lastheight;
322 CBufferFace<CDrawBuffer*> textarray; 321 CBufferFace<CDrawBuffer*> textarray;
323 CBufferFace<size_t> locnarray; 322 CBufferFace<size_t> locnarray;
324 unsigned int numlines; 323 unsigned int numlines;
325// bool m_showlast; 324// bool m_showlast;
326 bool bstripcr, btextfmt, bstriphtml, bdehyphen, bdepluck, bdejpluck, bunindent, brepara, bdblspce, btight, bmakebold, bremap, bpeanut, bautofmt, bonespace, bfulljust, /*bNegative,*/ bInverse; 325 bool bstripcr, btextfmt, bstriphtml, bdehyphen, bdepluck, bdejpluck, bunindent, brepara, bdblspce, btight, bmakebold, bremap, bpeanut, bautofmt, bonespace, bfulljust, /*bNegative,*/ bInverse;
327 bool bkern, brepalm; 326 bool bkern, brepalm;
328 bool m_bpagemode, m_bMonoSpaced, m_continuousDocument; 327 bool m_bpagemode, m_bMonoSpaced, m_continuousDocument;
329 unsigned char bindenter; 328 unsigned char bindenter;
330 QString m_lastfile; 329 QString m_lastfile;
331 size_t m_lastposn; 330 size_t m_lastposn;
332 bool bDoUpdates; 331 bool bDoUpdates;
333 public: 332 public:
334 void setDoUpdates(bool b) { bDoUpdates = b; } 333 void setDoUpdates(bool b) { bDoUpdates = b; }
335 void setStripCR(bool b) { bstripcr = b; } 334 void setStripCR(bool b) { bstripcr = b; }
336 void NavUp(); 335 void NavUp();
337 void NavDown(); 336 void NavDown();
338 tchar getch() { return buffdoc.getch(); } 337 tchar getch() { return buffdoc.getch(); }
339 bool synch(size_t, size_t); 338 bool synch(size_t, size_t);
340 bool tight; 339 bool tight;
341 bool load_file(const char *newfile, unsigned int lcn=0); 340 bool load_file(const char *newfile, unsigned int lcn=0);
342 BuffDoc buffdoc; 341 BuffDoc buffdoc;
343 CList<Bkmk>* getbkmklist() { return buffdoc.getbkmklist(); } 342 CList<Bkmk>* getbkmklist() { return buffdoc.getbkmklist(); }
344 bool locate(unsigned long n); 343 bool locate(unsigned long n);
345 void jumpto(unsigned long n) { buffdoc.locate(n); } 344 void jumpto(unsigned long n) { buffdoc.locate(n); }
346 unsigned long locate() { return buffdoc.locate(); } 345 unsigned long locate() { return buffdoc.locate(); }
347 unsigned long explocate() { return buffdoc.explocate(); } 346 unsigned long explocate() { return buffdoc.explocate(); }
348 unsigned long pagelocate() { return locnarray[0]; } 347 unsigned long pagelocate() { return locnarray[0]; }
349 unsigned long mylastpos; 348 unsigned long mylastpos;
350 void getNextLink(); 349 void getNextLink();
351 void setfilter(CFilterChain *f) { buffdoc.setfilter(f); if (bDoUpdates) locate(pagelocate()); } 350 void setfilter(CFilterChain *f) { buffdoc.setfilter(f); if (bDoUpdates) locate(pagelocate()); }
352 void restore() { jumpto(mylastpos); } 351 void restore() { jumpto(mylastpos); }
353 void goUp(); 352 void goUp();
354 void refresh(bool full = false); 353 void refresh(bool full = false);
355 void goDown(); 354 void goDown();
356 // bool bold; 355 // bool bold;
357 int textsize() { return m_textsize; } 356 int textsize() { return m_textsize; }
358 void textsize(int ts) { m_textsize = ts; } 357 void textsize(int ts) { m_textsize = ts; }
359 bool fillbuffer(int ru = 0, int ht = -1, int newht = -1); 358 bool fillbuffer(int ru = 0, int ht = -1, int newht = -1);
360 void CalculateScrollParameters(); 359 void CalculateScrollParameters();
361 unsigned int screenlines(); 360 unsigned int screenlines();
362 void sizes(unsigned long& fs, unsigned long& ts) { buffdoc.sizes(fs,ts); } 361 void sizes(unsigned long& fs, unsigned long& ts) { buffdoc.sizes(fs,ts); }
363 static const char *fonts[]; 362 static const char *fonts[];
364// unsigned int *fontsizes; 363// unsigned int *fontsizes;
365 int m_ascent, m_descent, m_linespacing; 364 int m_ascent, m_descent, m_linespacing;
366 int m_topmargin, m_bottommargin; 365 int m_topmargin, m_bottommargin;
367 int m_abstopmargin, m_absbottommargin; 366 int m_abstopmargin, m_absbottommargin;
368 QFontMetrics* m_fm; 367 QFontMetrics* m_fm;
369 QString firstword(); 368 QString firstword();
370 bool hyphenate; 369 bool hyphenate;
371 void reset_bg() 370 void reset_bg()
372 { 371 {
373 int r,g,b; 372 int r,g,b;
374 m_default_bg.rgb(&r, &g, &b); 373 m_default_bg.rgb(&r, &g, &b);
375 if (bInverse) 374 if (bInverse)
376 { 375 {
377 r = 255-r; 376 r = 255-r;
378 g = 255-g; 377 g = 255-g;
379 b = 255-b; 378 b = 255-b;
380 } 379 }
381 m_bg.setRgb(r,g,b); 380 m_bg.setRgb(r,g,b);
382 /* 381 /*
383 int h,s,v; 382 int h,s,v;
384 m_bg.hsv(&h, &s, &v); 383 m_bg.hsv(&h, &s, &v);
385 if (bNegative) 384 if (bNegative)
386 { 385 {
387 v = 255-v; 386 v = 255-v;
388 m_bg.setHsv(h,s,v); 387 m_bg.setHsv(h,s,v);
389 } 388 }
390 */ 389 */
391 setBackgroundColor( m_bg ); 390 setBackgroundColor( m_bg );
392 } 391 }
393 void setInverse(bool b) 392 void setInverse(bool b)
394 { 393 {
395 bInverse = b; 394 bInverse = b;
396 reset_bg(); 395 reset_bg();
397 } 396 }
398 /* 397 /*
399 void setNegative() 398 void setNegative()
400 { 399 {
401 bNegative = !bNegative; 400 bNegative = !bNegative;
402 reset_bg(); 401 reset_bg();
403 } 402 }
404 */ 403 */
405 signals: 404 signals:
406 void OnRedraw(); 405 void OnRedraw();
407 void OnWordSelected(const QString&, size_t, size_t, const QString&); 406 void OnWordSelected(const QString&, size_t, size_t, const QString&);
408 void OnShowPicture(QImage&); 407 void OnShowPicture(QImage&);
409 void OnURLSelected(const QString&, const size_t); 408 void OnURLSelected(const QString&, const size_t);
410 void NewFileRequest(const QString&); 409 void NewFileRequest(const QString&);
411 void HandleKeyRequest(QKeyEvent*); 410 void HandleKeyRequest(QKeyEvent*);
412 void SetScrollState(bool); 411 void SetScrollState(bool);
413 void RefreshBitmap(); 412 void RefreshBitmap();
414}; 413};
415 414
416#endif 415#endif
diff --git a/noncore/apps/opie-reader/QTReaderApp.cpp b/noncore/apps/opie-reader/QTReaderApp.cpp
index ec7a29c..876b65a 100644
--- a/noncore/apps/opie-reader/QTReaderApp.cpp
+++ b/noncore/apps/opie-reader/QTReaderApp.cpp
@@ -1,3158 +1,3156 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. Allrights reserved. 2** Copyright (C) 2000 Trolltech AS. Allrights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include "useqpe.h"
21#include <qregexp.h> 20#include <qregexp.h>
22#include <qclipboard.h> 21#include <qclipboard.h>
23#include <qwidgetstack.h> 22#include <qwidgetstack.h>
24#ifdef USEQPE 23#ifdef USEQPE
25#include <qpe/qpemenubar.h> 24#include <qpe/qpemenubar.h>
26#include <qpe/qpetoolbar.h> 25#include <qpe/qpetoolbar.h>
27#endif 26#endif
28#include <qmenubar.h> 27#include <qmenubar.h>
29#include <qtoolbar.h> 28#include <qtoolbar.h>
30#ifdef USEQPE 29#ifdef USEQPE
31#include <qpe/menubutton.h> 30#include <qpe/menubutton.h>
32#endif 31#endif
33#include <qcombobox.h> 32#include <qcombobox.h>
34#include <qpopupmenu.h> 33#include <qpopupmenu.h>
35#include <qaction.h> 34#include <qaction.h>
36#include <qapplication.h> 35#include <qapplication.h>
37#include <qlineedit.h> 36#include <qlineedit.h>
38#include <qtoolbutton.h> 37#include <qtoolbutton.h>
39#include <qspinbox.h> 38#include <qspinbox.h>
40#include <qobjectlist.h> 39#include <qobjectlist.h>
41#include <qstatusbar.h> 40#include <qstatusbar.h>
42#ifdef USEQPE 41#ifdef USEQPE
43#include <qpe/global.h> 42#include <qpe/global.h>
44#include <qpe/applnk.h> 43#include <qpe/applnk.h>
45#endif 44#endif
46#include <qfileinfo.h> 45#include <qfileinfo.h>
47#include <stdlib.h> //getenv 46#include <stdlib.h> //getenv
48#include <qprogressbar.h> 47#include <qprogressbar.h>
49#ifdef USEQPE 48#ifdef USEQPE
50#include <qpe/config.h> 49#include <qpe/config.h>
51#endif 50#endif
52#include <qbuttongroup.h> 51#include <qbuttongroup.h>
53#include <qradiobutton.h> 52#include <qradiobutton.h>
54#ifdef USEQPE 53#ifdef USEQPE
55#include <qpe/qcopenvelope_qws.h> 54#include <qpe/qcopenvelope_qws.h>
56#endif 55#endif
57#include "QTReader.h" 56#include "QTReader.h"
58#include "GraphicWin.h" 57#include "GraphicWin.h"
59#include "Bkmks.h" 58#include "Bkmks.h"
60#include "cbkmkselector.h" 59#include "cbkmkselector.h"
61#include "infowin.h" 60#include "infowin.h"
62#include "ToolbarPrefs.h" 61#include "ToolbarPrefs.h"
63#include "Prefs.h" 62#include "Prefs.h"
64#include "CAnnoEdit.h" 63#include "CAnnoEdit.h"
65#include "QFloatBar.h" 64#include "QFloatBar.h"
66#include "FixedFont.h" 65#include "FixedFont.h"
67#include "URLDialog.h" 66#include "URLDialog.h"
68#include "util.h" 67#include "util.h"
69#include <qfontdatabase.h> 68#include <qfontdatabase.h>
70#ifdef USEQPE 69#ifdef USEQPE
71#include <qpe/resource.h> 70#include <qpe/resource.h>
72#ifdef OPIE 71#ifdef OPIE
73//#include <qpe/applnk.h> 72//#include <qpe/applnk.h>
74#include <opie2/ofiledialog.h> 73#include <opie2/ofiledialog.h>
75using namespace Opie::Ui; 74using namespace Opie::Ui;
76#else 75#else
77#include "fileBrowser.h" 76#include "fileBrowser.h"
78#endif 77#endif
79#else 78#else
80#include "qfiledialog.h" 79#include "qfiledialog.h"
81#endif 80#endif
82 81
83#include "QTReaderApp.h" 82#include "QTReaderApp.h"
84#include "CDrawBuffer.h" 83#include "CDrawBuffer.h"
85#include "Filedata.h" 84#include "Filedata.h"
86#include "useqpe.h"
87#include "names.h" 85#include "names.h"
88#include "CEncoding_tables.h" 86#include "CEncoding_tables.h"
89#include "CloseDialog.h" 87#include "CloseDialog.h"
90 88
91#include "ButtonPrefs.h" 89#include "ButtonPrefs.h"
92 90
93bool CheckVersion(int&, int&, char&); 91bool CheckVersion(int&, int&, char&);
94 92
95#ifdef _WINDOWS 93#ifdef _WINDOWS
96#define PICDIR "c:\\uqtreader\\pics\\" 94#define PICDIR "c:\\uqtreader\\pics\\"
97#else 95#else
98#ifdef USEQPE 96#ifdef USEQPE
99#define USEMSGS 97#define USEMSGS
100#define PICDIR "opie-reader/" 98#define PICDIR "opie-reader/"
101#else 99#else
102//#define PICDIR "/home/tim/uqtreader/pics/" 100//#define PICDIR "/home/tim/uqtreader/pics/"
103QString picdir() 101QString picdir()
104{ 102{
105 QString hd(getenv("READERDIR")); 103 QString hd(getenv("READERDIR"));
106 return hd + "/pics"; 104 return hd + "/pics";
107} 105}
108#define PICDIR picdir() 106#define PICDIR picdir()
109#endif 107#endif
110#endif 108#endif
111 109
112unsigned long QTReaderApp::m_uid = 0; 110unsigned long QTReaderApp::m_uid = 0;
113 111
114void QTReaderApp::setScrollState(bool _b) { m_scrollButton->setOn(_b); } 112void QTReaderApp::setScrollState(bool _b) { m_scrollButton->setOn(_b); }
115 113
116#ifdef USEQPE 114#ifdef USEQPE
117#define geticon(iconname) Resource::loadPixmap( iconname ) 115#define geticon(iconname) Resource::loadPixmap( iconname )
118#define getmyicon(iconname) Resource::loadPixmap( PICDIR iconname ) 116#define getmyicon(iconname) Resource::loadPixmap( PICDIR iconname )
119#else 117#else
120//#define geticon(iconname) QPixmap(PICDIR iconname ".png") 118//#define geticon(iconname) QPixmap(PICDIR iconname ".png")
121#define geticon(iconname) QPixmap(PICDIR +"/"+iconname+".png") 119#define geticon(iconname) QPixmap(PICDIR +"/"+iconname+".png")
122#define getmyicon(iconname) geticon(iconname) 120#define getmyicon(iconname) geticon(iconname)
123//#define geticon(iconname) QIconSet( QPixmap(PICDIR iconname) ) 121//#define geticon(iconname) QIconSet( QPixmap(PICDIR iconname) )
124#endif 122#endif
125 123
126#ifndef _WINDOWS 124#ifndef _WINDOWS
127#include <unistd.h> 125#include <unistd.h>
128#endif 126#endif
129#include <stddef.h> 127#include <stddef.h>
130#ifndef _WINDOWS 128#ifndef _WINDOWS
131#include <dirent.h> 129#include <dirent.h>
132#endif 130#endif
133 131
134void QTReaderApp::listBkmkFiles() 132void QTReaderApp::listBkmkFiles()
135{ 133{
136 bkmkselector->clear(); 134 bkmkselector->clear();
137 bkmkselector->setText("Cancel"); 135 bkmkselector->setText("Cancel");
138#ifndef USEQPE 136#ifndef USEQPE
139 int cnt = 0; 137 int cnt = 0;
140 138
141 QDir d = QDir::home(); // "/" 139 QDir d = QDir::home(); // "/"
142 if ( !d.cd(APPDIR) ) { // "/tmp" 140 if ( !d.cd(APPDIR) ) { // "/tmp"
143 qWarning( "Cannot find the \"~/" APPDIR "\" directory" ); 141 qWarning( "Cannot find the \"~/" APPDIR "\" directory" );
144 d = QDir::home(); 142 d = QDir::home();
145 d.mkdir(APPDIR); 143 d.mkdir(APPDIR);
146 d.cd(APPDIR); 144 d.cd(APPDIR);
147 } 145 }
148 146
149 147
150 148
151 149
152 d.setFilter( QDir::Files | QDir::NoSymLinks ); 150 d.setFilter( QDir::Files | QDir::NoSymLinks );
153// d.setSorting( QDir::Size | QDir::Reversed ); 151// d.setSorting( QDir::Size | QDir::Reversed );
154 152
155 const QFileInfoList *list = d.entryInfoList(); 153 const QFileInfoList *list = d.entryInfoList();
156 QFileInfoListIterator it( *list ); // create list iterator 154 QFileInfoListIterator it( *list ); // create list iterator
157 QFileInfo *fi; // pointer for traversing 155 QFileInfo *fi; // pointer for traversing
158 156
159 while ( (fi=it.current()) ) { // for each file... 157 while ( (fi=it.current()) ) { // for each file...
160 158
161 bkmkselector->insertItem(fi->fileName()); 159 bkmkselector->insertItem(fi->fileName());
162 cnt++; 160 cnt++;
163 161
164 //qDebug( "%10li %s", fi->size(), fi->fileName().data() ); 162 //qDebug( "%10li %s", fi->size(), fi->fileName().data() );
165 ++it; // goto next list element 163 ++it; // goto next list element
166 } 164 }
167 165
168#else /* USEQPE */ 166#else /* USEQPE */
169 int cnt = 0; 167 int cnt = 0;
170 DIR *d; 168 DIR *d;
171 d = opendir((const char *)Global::applicationFileName(APPDIR,"")); 169 d = opendir((const char *)Global::applicationFileName(APPDIR,""));
172 170
173 while(1) 171 while(1)
174 { 172 {
175 struct dirent* de; 173 struct dirent* de;
176 struct stat buf; 174 struct stat buf;
177 de = readdir(d); 175 de = readdir(d);
178 if (de == NULL) break; 176 if (de == NULL) break;
179 177
180 if (lstat((const char *)Global::applicationFileName(APPDIR,de->d_name),&buf) == 0 && S_ISREG(buf.st_mode)) 178 if (lstat((const char *)Global::applicationFileName(APPDIR,de->d_name),&buf) == 0 && S_ISREG(buf.st_mode))
181 { 179 {
182 bkmkselector->insertItem(de->d_name); 180 bkmkselector->insertItem(de->d_name);
183 cnt++; 181 cnt++;
184 } 182 }
185 } 183 }
186 184
187 closedir(d); 185 closedir(d);
188#endif 186#endif
189 if (cnt > 0) 187 if (cnt > 0)
190 { 188 {
191//tjw menu->hide(); 189//tjw menu->hide();
192 190
193 191
194 editorStack->raiseWidget( bkmkselector ); 192 editorStack->raiseWidget( bkmkselector );
195 hidetoolbars(); 193 hidetoolbars();
196 m_nBkmkAction = cRmBkmkFile; 194 m_nBkmkAction = cRmBkmkFile;
197 } 195 }
198 else 196 else
199 QMessageBox::information(this, PROGNAME, "No bookmark files"); 197 QMessageBox::information(this, PROGNAME, "No bookmark files");
200} 198}
201 199
202void QTReaderApp::hidetoolbars() 200void QTReaderApp::hidetoolbars()
203{ 201{
204 if (m_scrollbar != NULL) m_scrollbar->hide(); 202 if (m_scrollbar != NULL) m_scrollbar->hide();
205 if (m_prog != NULL) m_prog->hide(); 203 if (m_prog != NULL) m_prog->hide();
206 204
207#ifdef USEQPE 205#ifdef USEQPE
208 menubar->hide(); 206 menubar->hide();
209#endif 207#endif
210 208
211 if (m_scrollbar != NULL) m_scrollbar->hide(); 209 if (m_scrollbar != NULL) m_scrollbar->hide();
212 210
213 if (fileBar != NULL) fileBar->hide(); 211 if (fileBar != NULL) fileBar->hide();
214 if (viewBar != NULL) viewBar->hide(); 212 if (viewBar != NULL) viewBar->hide();
215 if (navBar != NULL) navBar->hide(); 213 if (navBar != NULL) navBar->hide();
216 if (markBar != NULL) markBar->hide(); 214 if (markBar != NULL) markBar->hide();
217 if (m_fontVisible) m_fontBar->hide(); 215 if (m_fontVisible) m_fontBar->hide();
218 if (regVisible) 216 if (regVisible)
219 { 217 {
220#ifdef USEQPE 218#ifdef USEQPE
221 Global::hideInputMethod(); 219 Global::hideInputMethod();
222#endif 220#endif
223 regBar->hide(); 221 regBar->hide();
224 } 222 }
225 if (searchVisible) 223 if (searchVisible)
226 { 224 {
227#ifdef USEQPE 225#ifdef USEQPE
228 Global::hideInputMethod(); 226 Global::hideInputMethod();
229#endif 227#endif
230 searchBar->hide(); 228 searchBar->hide();
231 } 229 }
232} 230}
233 231
234QTReaderApp::QTReaderApp( QWidget *parent, const char *name, WFlags f ) 232QTReaderApp::QTReaderApp( QWidget *parent, const char *name, WFlags f )
235 : QMainWindow( parent, name, f ), m_dontSave(false), 233 : QMainWindow( parent, name, f ), m_dontSave(false),
236 fileBar(NULL), navBar(NULL), viewBar(NULL), markBar(NULL), m_scrollbar(NULL), m_localscroll(2), m_hidebars(false), m_kmapchanged(false) 234 fileBar(NULL), navBar(NULL), viewBar(NULL), markBar(NULL), m_scrollbar(NULL), m_localscroll(2), m_hidebars(false), m_kmapchanged(false)
237{ 235{
238 { 236 {
239 setKeyCompression ( true ); 237 setKeyCompression ( true );
240#ifndef USEQPE 238#ifndef USEQPE
241 QDir d = QDir::home(); // "/" 239 QDir d = QDir::home(); // "/"
242 d.cd(APPDIR); 240 d.cd(APPDIR);
243 QFileInfo fi(d, ".keymap"); 241 QFileInfo fi(d, ".keymap");
244 FILE* f = fopen((const char *)fi.absFilePath(), "r"); 242 FILE* f = fopen((const char *)fi.absFilePath(), "r");
245#else /* USEQPE */ 243#else /* USEQPE */
246 FILE* f = fopen((const char *)Global::applicationFileName(APPDIR,".keymap"), "r"); 244 FILE* f = fopen((const char *)Global::applicationFileName(APPDIR,".keymap"), "r");
247#endif /* USEQPE */ 245#endif /* USEQPE */
248 if (f != NULL) 246 if (f != NULL)
249 { 247 {
250 uint cnt; 248 uint cnt;
251 if ((fread(&cnt, sizeof(cnt), 1, f) != 0) && (cnt == KEYMAPVERSION)) 249 if ((fread(&cnt, sizeof(cnt), 1, f) != 0) && (cnt == KEYMAPVERSION))
252 { 250 {
253 if (fread(&cnt, sizeof(cnt), 1, f) == 0) cnt = 0; 251 if (fread(&cnt, sizeof(cnt), 1, f) == 0) cnt = 0;
254 for (uint i = 0; i != cnt; i++) 252 for (uint i = 0; i != cnt; i++)
255 { 253 {
256 orKey key; 254 orKey key;
257 int data; 255 int data;
258 fread(&key, sizeof(key), 1, f); 256 fread(&key, sizeof(key), 1, f);
259 fread(&data, sizeof(data), 1, f); 257 fread(&data, sizeof(data), 1, f);
260 kmap[key] = data; 258 kmap[key] = data;
261 } 259 }
262 } 260 }
263 fclose(f); 261 fclose(f);
264 } 262 }
265 } 263 }
266 264
267 m_url_clipboard = false; 265 m_url_clipboard = false;
268 m_url_localfile = false; 266 m_url_localfile = false;
269 m_url_globalfile = false; 267 m_url_globalfile = false;
270 ftime(&m_lastkeytime); 268 ftime(&m_lastkeytime);
271//// qDebug("Application directory = %s", (const tchar *)QPEApplication::documentDir()); 269//// qDebug("Application directory = %s", (const tchar *)QPEApplication::documentDir());
272//// qDebug("Application directory = %s", (const tchar *)Global::applicationFileName("uqtreader","bkmks.xml")); 270//// qDebug("Application directory = %s", (const tchar *)Global::applicationFileName("uqtreader","bkmks.xml"));
273 271
274 m_bcloseDisabled = true; 272 m_bcloseDisabled = true;
275 m_disableesckey = false; 273 m_disableesckey = false;
276 pBkmklist = NULL; 274 pBkmklist = NULL;
277 pOpenlist = NULL; 275 pOpenlist = NULL;
278// doc = 0; 276// doc = 0;
279 277
280 m_fBkmksChanged = false; 278 m_fBkmksChanged = false;
281 279
282 QString lang = getenv( "LANG" ); 280 QString lang = getenv( "LANG" );
283 QString rot = getenv( "QWS_DISPLAY" ); 281 QString rot = getenv( "QWS_DISPLAY" );
284 282
285/* 283/*
286 int m_rot = 0; 284 int m_rot = 0;
287 if (rot.contains("Rot90")) 285 if (rot.contains("Rot90"))
288 { 286 {
289 m_rot = 90; 287 m_rot = 90;
290 } 288 }
291 else if (rot.contains("Rot180")) 289 else if (rot.contains("Rot180"))
292 { 290 {
293 m_rot = 180; 291 m_rot = 180;
294 } 292 }
295 else if (rot.contains("Rot270")) 293 else if (rot.contains("Rot270"))
296 { 294 {
297 m_rot = 270; 295 m_rot = 270;
298 } 296 }
299 297
300// qDebug("Initial Rotation(%d):%s", m_rot, (const char*)rot); 298// qDebug("Initial Rotation(%d):%s", m_rot, (const char*)rot);
301*/ 299*/
302 m_autogenstr = "^ *[A-Z].*[a-z] *$"; 300 m_autogenstr = "^ *[A-Z].*[a-z] *$";
303 301
304#ifdef USEQPE 302#ifdef USEQPE
305 setIcon( Resource::loadPixmap( PICDIR "uqtreader") ); 303 setIcon( Resource::loadPixmap( PICDIR "uqtreader") );
306#else 304#else
307 setIcon( QPixmap (PICDIR + "/uqtreader.png") ); 305 setIcon( QPixmap (PICDIR + "/uqtreader.png") );
308#endif /* USEQPE */ 306#endif /* USEQPE */
309 307
310// QPEToolBar *bar = new QPEToolBar( this ); 308// QPEToolBar *bar = new QPEToolBar( this );
311// menubar = new QPEToolBar( this ); 309// menubar = new QPEToolBar( this );
312#ifdef USEQPE 310#ifdef USEQPE
313 Config config( APPDIR ); 311 Config config( APPDIR );
314#else 312#else
315 QDir d = QDir::home(); // "/" 313 QDir d = QDir::home(); // "/"
316 if ( !d.cd(APPDIR) ) { // "/tmp" 314 if ( !d.cd(APPDIR) ) { // "/tmp"
317 qWarning( "Cannot find the \"~/" APPDIR "\" directory" ); 315 qWarning( "Cannot find the \"~/" APPDIR "\" directory" );
318 d = QDir::home(); 316 d = QDir::home();
319 d.mkdir(APPDIR); 317 d.mkdir(APPDIR);
320 d.cd(APPDIR); 318 d.cd(APPDIR);
321 } 319 }
322 QFileInfo fi(d, INIFILE); 320 QFileInfo fi(d, INIFILE);
323// qDebug("Path:%s", (const char*)fi.absFilePath()); 321// qDebug("Path:%s", (const char*)fi.absFilePath());
324 Config config(fi.absFilePath()); 322 Config config(fi.absFilePath());
325#endif 323#endif
326 config.setGroup("Toolbar"); 324 config.setGroup("Toolbar");
327 m_tbmovesave = m_tbmove = config.readBoolEntry("Movable", false); 325 m_tbmovesave = m_tbmove = config.readBoolEntry("Movable", false);
328 m_tbpolsave = m_tbpol = (ToolbarPolicy)config.readNumEntry("Policy", 1); 326 m_tbpolsave = m_tbpol = (ToolbarPolicy)config.readNumEntry("Policy", 1);
329 m_tbposition = (ToolBarDock)config.readNumEntry("Position", 2); 327 m_tbposition = (ToolBarDock)config.readNumEntry("Position", 2);
330 m_qtscroll = config.readNumEntry("QTScrollBar", false); 328 m_qtscroll = config.readNumEntry("QTScrollBar", false);
331 m_localscroll = config.readNumEntry("LocalScrollBar", false); 329 m_localscroll = config.readNumEntry("LocalScrollBar", false);
332 330
333// fileBar = new QToolBar("File", this); 331// fileBar = new QToolBar("File", this);
334// QToolBar* viewBar = new QToolBar("File", this); 332// QToolBar* viewBar = new QToolBar("File", this);
335// QToolBar* navBar = new QToolBar("File", this); 333// QToolBar* navBar = new QToolBar("File", this);
336// QToolBar* markBar = new QToolBar("File", this); 334// QToolBar* markBar = new QToolBar("File", this);
337 335
338#ifdef USEQPE 336#ifdef USEQPE
339 menubar = new QToolBar("Menus", this, m_tbposition); 337 menubar = new QToolBar("Menus", this, m_tbposition);
340 mb = new QPEMenuBar( menubar ); 338 mb = new QPEMenuBar( menubar );
341#else 339#else
342 mb = new QMenuBar( this ); 340 mb = new QMenuBar( this );
343#endif 341#endif
344 342
345#ifdef USEQPE 343#ifdef USEQPE
346 QPopupMenu* tmp = new QPopupMenu(mb); 344 QPopupMenu* tmp = new QPopupMenu(mb);
347 mb->insertItem( geticon( "AppsIcon" ), tmp ); 345 mb->insertItem( geticon( "AppsIcon" ), tmp );
348#else 346#else
349 QMenuBar* tmp = mb; 347 QMenuBar* tmp = mb;
350#endif 348#endif
351 349
352 QPopupMenu *file = new QPopupMenu( mb ); 350 QPopupMenu *file = new QPopupMenu( mb );
353 tmp->insertItem( tr( "File" ), file ); 351 tmp->insertItem( tr( "File" ), file );
354 352
355 QPopupMenu *navigation = new QPopupMenu(mb); 353 QPopupMenu *navigation = new QPopupMenu(mb);
356 tmp->insertItem( tr( "Navigation" ), navigation ); 354 tmp->insertItem( tr( "Navigation" ), navigation );
357 355
358 QPopupMenu *view = new QPopupMenu( mb ); 356 QPopupMenu *view = new QPopupMenu( mb );
359 tmp->insertItem( tr( "View" ), view ); 357 tmp->insertItem( tr( "View" ), view );
360 358
361 QPopupMenu *marks = new QPopupMenu( this ); 359 QPopupMenu *marks = new QPopupMenu( this );
362 tmp->insertItem( tr( "Marks" ), marks ); 360 tmp->insertItem( tr( "Marks" ), marks );
363 361
364 QPopupMenu *settings = new QPopupMenu( this ); 362 QPopupMenu *settings = new QPopupMenu( this );
365 tmp->insertItem( tr( "Settings" ), settings ); 363 tmp->insertItem( tr( "Settings" ), settings );
366 364
367// addToolBar(menubar, "Menus",QMainWindow::Top); 365// addToolBar(menubar, "Menus",QMainWindow::Top);
368// addToolBar(fileBar, "Toolbar",QMainWindow::Top); 366// addToolBar(fileBar, "Toolbar",QMainWindow::Top);
369 367
370 // QPopupMenu *edit = new QPopupMenu( this ); 368 // QPopupMenu *edit = new QPopupMenu( this );
371 369
372 /* 370 /*
373 QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, 0, this, 0 ); 371 QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, 0, this, 0 );
374 connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) ); 372 connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) );
375 a->addTo( bar ); 373 a->addTo( bar );
376 a->addTo( file ); 374 a->addTo( file );
377 */ 375 */
378 QWidget* widge = new QWidget(this); 376 QWidget* widge = new QWidget(this);
379 setCentralWidget( widge ); 377 setCentralWidget( widge );
380 QVBoxLayout* vlayout = new QVBoxLayout(widge); 378 QVBoxLayout* vlayout = new QVBoxLayout(widge);
381 m_layout = new QBoxLayout(QBoxLayout::LeftToRight); 379 m_layout = new QBoxLayout(QBoxLayout::LeftToRight);
382 m_prog = new QLabel(widge); 380 m_prog = new QLabel(widge);
383 vlayout->addLayout(m_layout, 1); 381 vlayout->addLayout(m_layout, 1);
384 vlayout->addWidget(m_prog); 382 vlayout->addWidget(m_prog);
385 383
386 editorStack = new QWidgetStack( widge ); 384 editorStack = new QWidgetStack( widge );
387 // setCentralWidget( editorStack ); 385 // setCentralWidget( editorStack );
388 386
389 searchVisible = FALSE; 387 searchVisible = FALSE;
390 regVisible = FALSE; 388 regVisible = FALSE;
391 m_fontVisible = false; 389 m_fontVisible = false;
392 390
393 m_buttonprefs = new CButtonPrefs(&kmap, this); 391 m_buttonprefs = new CButtonPrefs(&kmap, this);
394 editorStack->addWidget(m_buttonprefs, get_unique_id()); 392 editorStack->addWidget(m_buttonprefs, get_unique_id());
395 connect( m_buttonprefs, SIGNAL( Closed() ), this, SLOT( infoClose() ) ); 393 connect( m_buttonprefs, SIGNAL( Closed() ), this, SLOT( infoClose() ) );
396 394
397 395
398 m_annoWin = new CAnnoEdit(editorStack); 396 m_annoWin = new CAnnoEdit(editorStack);
399 editorStack->addWidget(m_annoWin, get_unique_id()); 397 editorStack->addWidget(m_annoWin, get_unique_id());
400 connect( m_annoWin, SIGNAL( finished(const QString&, const QString&) ), this, SLOT( addAnno(const QString&, const QString&) ) ); 398 connect( m_annoWin, SIGNAL( finished(const QString&, const QString&) ), this, SLOT( addAnno(const QString&, const QString&) ) );
401 connect( m_annoWin, SIGNAL( cancelled() ), this, SLOT( infoClose() ) ); 399 connect( m_annoWin, SIGNAL( cancelled() ), this, SLOT( infoClose() ) );
402 400
403 m_infoWin = new infowin(editorStack); 401 m_infoWin = new infowin(editorStack);
404 editorStack->addWidget(m_infoWin, get_unique_id()); 402 editorStack->addWidget(m_infoWin, get_unique_id());
405 connect( m_infoWin, SIGNAL( Close() ), this, SLOT( infoClose() ) ); 403 connect( m_infoWin, SIGNAL( Close() ), this, SLOT( infoClose() ) );
406 404
407 m_graphicwin = new GraphicWin(editorStack); 405 m_graphicwin = new GraphicWin(editorStack);
408 editorStack->addWidget(m_graphicwin, get_unique_id()); 406 editorStack->addWidget(m_graphicwin, get_unique_id());
409 connect( m_graphicwin, SIGNAL( Closed() ), this, SLOT( infoClose() ) ); 407 connect( m_graphicwin, SIGNAL( Closed() ), this, SLOT( infoClose() ) );
410 408
411// bkmkselector = new QListBox(editorStack, "Bookmarks"); 409// bkmkselector = new QListBox(editorStack, "Bookmarks");
412 bkmkselector = new CBkmkSelector(editorStack, "Bookmarks"); 410 bkmkselector = new CBkmkSelector(editorStack, "Bookmarks");
413 // connect(bkmkselector, SIGNAL( selected(const QString&) ), this, SLOT( gotobkmk(const QString&) ) ); 411 // connect(bkmkselector, SIGNAL( selected(const QString&) ), this, SLOT( gotobkmk(const QString&) ) );
414 connect(bkmkselector, SIGNAL( selected(int) ), this, SLOT( gotobkmk(int) ) ); 412 connect(bkmkselector, SIGNAL( selected(int) ), this, SLOT( gotobkmk(int) ) );
415 connect(bkmkselector, SIGNAL( cancelled() ), this, SLOT( cancelbkmk() ) ); 413 connect(bkmkselector, SIGNAL( cancelled() ), this, SLOT( cancelbkmk() ) );
416 editorStack->addWidget( bkmkselector, get_unique_id() ); 414 editorStack->addWidget( bkmkselector, get_unique_id() );
417 415
418/* 416/*
419 importSelector = new FileSelector( "*", editorStack, "importselector", false ); 417 importSelector = new FileSelector( "*", editorStack, "importselector", false );
420 connect( importSelector, SIGNAL( fileSelected( const DocLnk &) ), this, SLOT( importFile( const DocLnk & ) ) ); 418 connect( importSelector, SIGNAL( fileSelected( const DocLnk &) ), this, SLOT( importFile( const DocLnk & ) ) );
421 419
422 editorStack->addWidget( importSelector, get_unique_id() ); 420 editorStack->addWidget( importSelector, get_unique_id() );
423 421
424 // don't need the close visible, it is redundant... 422 // don't need the close visible, it is redundant...
425 importSelector->setCloseVisible( FALSE ); 423 importSelector->setCloseVisible( FALSE );
426*/ 424*/
427// qDebug("Reading file list"); 425// qDebug("Reading file list");
428 readfilelist(); 426 readfilelist();
429 427
430 reader = new QTReader( editorStack ); 428 reader = new QTReader( editorStack );
431 429
432 reader->setDoUpdates(false); 430 reader->setDoUpdates(false);
433 431
434#ifdef USEQPE 432#ifdef USEQPE
435 ((QPEApplication*)qApp)->setStylusOperation(reader, QPEApplication::RightOnHold); 433 ((QPEApplication*)qApp)->setStylusOperation(reader, QPEApplication::RightOnHold);
436#endif 434#endif
437 435
438// qDebug("Reading config"); 436// qDebug("Reading config");
439// Config config( APPDIR ); 437// Config config( APPDIR );
440 config.setGroup( "View" ); 438 config.setGroup( "View" );
441 m_debounce = config.readNumEntry("Debounce", 0); 439 m_debounce = config.readNumEntry("Debounce", 0);
442 m_buttonprefs->Debounce(m_debounce); 440 m_buttonprefs->Debounce(m_debounce);
443#ifdef USEQPE 441#ifdef USEQPE
444 m_bFloatingDialog = config.readBoolEntry("FloatDialogs", false); 442 m_bFloatingDialog = config.readBoolEntry("FloatDialogs", false);
445#else 443#else
446 m_bFloatingDialog = config.readBoolEntry("FloatDialogs", true); 444 m_bFloatingDialog = config.readBoolEntry("FloatDialogs", true);
447#endif 445#endif
448 reader->setStripCR(config.readBoolEntry( "StripCr", true )); 446 reader->setStripCR(config.readBoolEntry( "StripCr", true ));
449 reader->bfulljust = config.readBoolEntry( "FullJust", false ); 447 reader->bfulljust = config.readBoolEntry( "FullJust", false );
450 /* 448 /*
451 bool btmp = config.readBoolEntry("Negative", false); 449 bool btmp = config.readBoolEntry("Negative", false);
452 if (btmp) reader->setNegative(); 450 if (btmp) reader->setNegative();
453 */ 451 */
454 reader->bInverse = config.readBoolEntry("Inverse", false); 452 reader->bInverse = config.readBoolEntry("Inverse", false);
455 reader->m_fontControl.FixGraphics(config.readBoolEntry( "FixGraphics", false )); 453 reader->m_fontControl.FixGraphics(config.readBoolEntry( "FixGraphics", false ));
456 reader->setextraspace(config.readNumEntry( "ExtraSpace", 0 )); 454 reader->setextraspace(config.readNumEntry( "ExtraSpace", 0 ));
457 reader->setlead(config.readNumEntry( "ExtraLead", 0 )); 455 reader->setlead(config.readNumEntry( "ExtraLead", 0 ));
458 reader->btextfmt = config.readBoolEntry( "TextFmt", false ); 456 reader->btextfmt = config.readBoolEntry( "TextFmt", false );
459 reader->bautofmt = config.readBoolEntry( "AutoFmt", true ); 457 reader->bautofmt = config.readBoolEntry( "AutoFmt", true );
460 reader->bstriphtml = config.readBoolEntry( "StripHtml", false ); 458 reader->bstriphtml = config.readBoolEntry( "StripHtml", false );
461 reader->bpeanut = config.readBoolEntry( "Peanut", false ); 459 reader->bpeanut = config.readBoolEntry( "Peanut", false );
462 reader->bdehyphen = config.readBoolEntry( "Dehyphen", false ); 460 reader->bdehyphen = config.readBoolEntry( "Dehyphen", false );
463 reader->bdepluck = config.readBoolEntry( "Depluck", false ); 461 reader->bdepluck = config.readBoolEntry( "Depluck", false );
464 reader->bdejpluck = config.readBoolEntry( "Dejpluck", false ); 462 reader->bdejpluck = config.readBoolEntry( "Dejpluck", false );
465 reader->bonespace = config.readBoolEntry( "OneSpace", false ); 463 reader->bonespace = config.readBoolEntry( "OneSpace", false );
466 reader->bunindent = config.readBoolEntry( "Unindent", false ); 464 reader->bunindent = config.readBoolEntry( "Unindent", false );
467 reader->brepara = config.readBoolEntry( "Repara", false ); 465 reader->brepara = config.readBoolEntry( "Repara", false );
468 reader->m_reparastring = config.readEntry( "ReparaString", "\\n{[\\n \\t]}"); 466 reader->m_reparastring = config.readEntry( "ReparaString", "\\n{[\\n \\t]}");
469 m_bgtype = (bground)config.readNumEntry( "BackgroundType" , 0 ); 467 m_bgtype = (bground)config.readNumEntry( "BackgroundType" , 0 );
470 m_themename = config.readEntry("Theme", QString::null ); 468 m_themename = config.readEntry("Theme", QString::null );
471 reader->bdblspce = config.readBoolEntry( "DoubleSpace", false ); 469 reader->bdblspce = config.readBoolEntry( "DoubleSpace", false );
472 reader->bindenter = config.readNumEntry( "Indent", 0 ); 470 reader->bindenter = config.readNumEntry( "Indent", 0 );
473 reader->m_textsize = config.readNumEntry( "FontSize", 12 ); 471 reader->m_textsize = config.readNumEntry( "FontSize", 12 );
474 reader->m_delay = config.readNumEntry( "ScrollDelay", 5184); 472 reader->m_delay = config.readNumEntry( "ScrollDelay", 5184);
475 reader->m_scrollstep = config.readNumEntry( "ScrollStep", 1); 473 reader->m_scrollstep = config.readNumEntry( "ScrollStep", 1);
476 474
477 reader->m_lastfile = config.readEntry( "LastFile", QString::null ); 475 reader->m_lastfile = config.readEntry( "LastFile", QString::null );
478 reader->m_lastposn = config.readNumEntry( "LastPosn", 0 ); 476 reader->m_lastposn = config.readNumEntry( "LastPosn", 0 );
479 reader->m_bpagemode = config.readBoolEntry( "PageMode", true ); 477 reader->m_bpagemode = config.readBoolEntry( "PageMode", true );
480 reader->m_bMonoSpaced = config.readBoolEntry( "MonoSpaced", false); 478 reader->m_bMonoSpaced = config.readBoolEntry( "MonoSpaced", false);
481 reader->m_rotated = config.readBoolEntry( "IsRotated", false ); 479 reader->m_rotated = config.readBoolEntry( "IsRotated", false );
482 reader->m_scrolltype = config.readNumEntry( "ScrollType", 0 ); 480 reader->m_scrolltype = config.readNumEntry( "ScrollType", 0 );
483 m_statusstring = config.readEntry("StatusContent", "%P%% Doc:%d/%D %p%% %z%%"); 481 m_statusstring = config.readEntry("StatusContent", "%P%% Doc:%d/%D %p%% %z%%");
484 m_statusishidden = config.readBoolEntry("StatusHidden", false); 482 m_statusishidden = config.readBoolEntry("StatusHidden", false);
485 m_background = config.readNumEntry( "Background", 0 ); 483 m_background = config.readNumEntry( "Background", 0 );
486 reader->setBackground(getcolour(m_background)); 484 reader->setBackground(getcolour(m_background));
487 m_foreground = config.readNumEntry( "Foreground", 1 ); 485 m_foreground = config.readNumEntry( "Foreground", 1 );
488 reader->setForeground(getcolour(m_foreground)); 486 reader->setForeground(getcolour(m_foreground));
489 m_scrollcolor = config.readNumEntry( "ScrollColour", 5 ); 487 m_scrollcolor = config.readNumEntry( "ScrollColour", 5 );
490 setscrollcolour(); 488 setscrollcolour();
491 m_scrollbarcolor = config.readNumEntry( "ScrollBarColour", 5 ); 489 m_scrollbarcolor = config.readNumEntry( "ScrollBarColour", 5 );
492 setscrollbarcolour(); 490 setscrollbarcolour();
493 reader->hyphenate = config.readBoolEntry( "Hyphenate", false ); 491 reader->hyphenate = config.readBoolEntry( "Hyphenate", false );
494 reader->m_swapmouse = config.readBoolEntry( "SwapMouse", false); 492 reader->m_swapmouse = config.readBoolEntry( "SwapMouse", false);
495 reader->m_fontname = config.readEntry( "Fontname", "helvetica" ); 493 reader->m_fontname = config.readEntry( "Fontname", "helvetica" );
496 reader->m_encd = config.readNumEntry( "Encoding", 0 ); 494 reader->m_encd = config.readNumEntry( "Encoding", 0 );
497 reader->m_charpc = config.readNumEntry( "CharSpacing", 100 ); 495 reader->m_charpc = config.readNumEntry( "CharSpacing", 100 );
498 reader->m_overlap = config.readNumEntry( "Overlap", 0 ); 496 reader->m_overlap = config.readNumEntry( "Overlap", 0 );
499 reader->m_abstopmargin = config.readNumEntry( "Top Margin", 100 ); 497 reader->m_abstopmargin = config.readNumEntry( "Top Margin", 100 );
500 reader->m_absbottommargin = config.readNumEntry( "Bottom Margin", 100 ); 498 reader->m_absbottommargin = config.readNumEntry( "Bottom Margin", 100 );
501 reader->m_absleft_border = config.readNumEntry( "Left Margin", 100 ); 499 reader->m_absleft_border = config.readNumEntry( "Left Margin", 100 );
502 reader->m_absright_border = config.readNumEntry( "Right Margin", 100 ); 500 reader->m_absright_border = config.readNumEntry( "Right Margin", 100 );
503 501
504 m_scrollishidden = config.readBoolEntry( "HideScrollBar", false ); 502 m_scrollishidden = config.readBoolEntry( "HideScrollBar", false );
505 503
506 reader->brepalm = config.readBoolEntry( "Repalm", false ); 504 reader->brepalm = config.readBoolEntry( "Repalm", false );
507 reader->bkern = config.readBoolEntry( "Kern", false ); 505 reader->bkern = config.readBoolEntry( "Kern", false );
508 reader->bremap = config.readBoolEntry( "Remap", true ); 506 reader->bremap = config.readBoolEntry( "Remap", true );
509 reader->bmakebold = config.readBoolEntry( "MakeBold", false ); 507 reader->bmakebold = config.readBoolEntry( "MakeBold", false );
510 reader->setContinuous(config.readBoolEntry( "Continuous", true )); 508 reader->setContinuous(config.readBoolEntry( "Continuous", true ));
511 m_targetapp = config.readEntry( "TargetApp", QString::null ); 509 m_targetapp = config.readEntry( "TargetApp", QString::null );
512 m_targetmsg = config.readEntry( "TargetMsg", QString::null ); 510 m_targetmsg = config.readEntry( "TargetMsg", QString::null );
513#ifdef _SCROLLPIPE 511#ifdef _SCROLLPIPE
514 reader->m_pipetarget = config.readEntry( "PipeTarget", QString::null ); 512 reader->m_pipetarget = config.readEntry( "PipeTarget", QString::null );
515 reader->m_pauseAfterEachPara = config.readBoolEntry( "PauseAfterPara", true ); 513 reader->m_pauseAfterEachPara = config.readBoolEntry( "PauseAfterPara", true );
516#endif 514#endif
517 m_twoTouch = config.readBoolEntry( "TwoTouch", false); 515 m_twoTouch = config.readBoolEntry( "TwoTouch", false);
518 m_doAnnotation = config.readBoolEntry( "Annotation", false); 516 m_doAnnotation = config.readBoolEntry( "Annotation", false);
519 m_doDictionary = config.readBoolEntry( "Dictionary", false); 517 m_doDictionary = config.readBoolEntry( "Dictionary", false);
520 m_doClipboard = config.readBoolEntry( "Clipboard", false); 518 m_doClipboard = config.readBoolEntry( "Clipboard", false);
521 /* 519 /*
522 m_spaceTarget = (ActionTypes)config.readNumEntry("SpaceTarget", cesAutoScroll); 520 m_spaceTarget = (ActionTypes)config.readNumEntry("SpaceTarget", cesAutoScroll);
523 m_escapeTarget = (ActionTypes)config.readNumEntry("EscapeTarget", cesNone); 521 m_escapeTarget = (ActionTypes)config.readNumEntry("EscapeTarget", cesNone);
524 m_returnTarget = (ActionTypes)config.readNumEntry("ReturnTarget", cesFullScreen); 522 m_returnTarget = (ActionTypes)config.readNumEntry("ReturnTarget", cesFullScreen);
525 m_leftTarget = (ActionTypes)config.readNumEntry("LeftTarget", cesZoomOut); 523 m_leftTarget = (ActionTypes)config.readNumEntry("LeftTarget", cesZoomOut);
526 m_rightTarget = (ActionTypes)config.readNumEntry("RightTarget", cesZoomIn); 524 m_rightTarget = (ActionTypes)config.readNumEntry("RightTarget", cesZoomIn);
527 m_upTarget = (ActionTypes)config.readNumEntry("UpTarget", cesPageUp); 525 m_upTarget = (ActionTypes)config.readNumEntry("UpTarget", cesPageUp);
528 m_downTarget = (ActionTypes)config.readNumEntry("DownTarget", cesPageDown); 526 m_downTarget = (ActionTypes)config.readNumEntry("DownTarget", cesPageDown);
529 527
530 m_leftScroll = config.readBoolEntry("LeftScroll", false); 528 m_leftScroll = config.readBoolEntry("LeftScroll", false);
531 m_rightScroll = config.readBoolEntry("RightScroll", false); 529 m_rightScroll = config.readBoolEntry("RightScroll", false);
532 m_upScroll = config.readBoolEntry("UpScroll", true); 530 m_upScroll = config.readBoolEntry("UpScroll", true);
533 m_downScroll = config.readBoolEntry("DownScroll", true); 531 m_downScroll = config.readBoolEntry("DownScroll", true);
534 */ 532 */
535 m_propogatefontchange = config.readBoolEntry( "RequestorFontChange", false); 533 m_propogatefontchange = config.readBoolEntry( "RequestorFontChange", false);
536 reader->setBaseSize(config.readNumEntry( "Basesize", 10 )); 534 reader->setBaseSize(config.readNumEntry( "Basesize", 10 ));
537 reader->setHyphenThreshold(config.readNumEntry( "HyphenThreshold", 50 )); 535 reader->setHyphenThreshold(config.readNumEntry( "HyphenThreshold", 50 ));
538 // reader->buffdoc.setCustomHyphen(config.readBoolEntry( "CustomHyphen", false )); 536 // reader->buffdoc.setCustomHyphen(config.readBoolEntry( "CustomHyphen", false ));
539#ifndef USEQPE 537#ifndef USEQPE
540 config.setGroup( "Geometry" ); 538 config.setGroup( "Geometry" );
541 setGeometry(0,0, 539 setGeometry(0,0,
542 config.readNumEntry( "width", QApplication::desktop()->width()/2 ), 540 config.readNumEntry( "width", QApplication::desktop()->width()/2 ),
543 config.readNumEntry( "height", QApplication::desktop()->height()/2 )); 541 config.readNumEntry( "height", QApplication::desktop()->height()/2 ));
544 move( 542 move(
545 config.readNumEntry( "x", 20 ), 543 config.readNumEntry( "x", 20 ),
546 config.readNumEntry( "y", 20 )); 544 config.readNumEntry( "y", 20 ));
547#else 545#else
548 m_grabkeyboard = config.readBoolEntry( "GrabKeyboard", false); 546 m_grabkeyboard = config.readBoolEntry( "GrabKeyboard", false);
549#endif 547#endif
550 548
551 549
552 550
553 setTwoTouch(m_twoTouch); 551 setTwoTouch(m_twoTouch);
554 552
555 connect( reader, SIGNAL( OnShowPicture(QImage&) ), this, SLOT( showgraphic(QImage&) ) ); 553 connect( reader, SIGNAL( OnShowPicture(QImage&) ), this, SLOT( showgraphic(QImage&) ) );
556 554
557 connect( reader, SIGNAL( OnRedraw() ), this, SLOT( OnRedraw() ) ); 555 connect( reader, SIGNAL( OnRedraw() ), this, SLOT( OnRedraw() ) );
558 connect( reader, SIGNAL( OnWordSelected(const QString&, size_t, size_t, const QString&) ), this, SLOT( OnWordSelected(const QString&, size_t, size_t, const QString&) ) ); 556 connect( reader, SIGNAL( OnWordSelected(const QString&, size_t, size_t, const QString&) ), this, SLOT( OnWordSelected(const QString&, size_t, size_t, const QString&) ) );
559 connect( reader, SIGNAL( OnURLSelected(const QString&, const size_t) ), this, SLOT( OnURLSelected(const QString&, const size_t) ) ); 557 connect( reader, SIGNAL( OnURLSelected(const QString&, const size_t) ), this, SLOT( OnURLSelected(const QString&, const size_t) ) );
560 connect( reader, SIGNAL( NewFileRequest(const QString&) ), this, SLOT( forceopen(const QString&) ) ); 558 connect( reader, SIGNAL( NewFileRequest(const QString&) ), this, SLOT( forceopen(const QString&) ) );
561 connect( reader, SIGNAL( HandleKeyRequest(QKeyEvent*) ), this, SLOT( handlekey(QKeyEvent*) ) ); 559 connect( reader, SIGNAL( HandleKeyRequest(QKeyEvent*) ), this, SLOT( handlekey(QKeyEvent*) ) );
562 connect( reader, SIGNAL( SetScrollState(bool) ), this, SLOT( setScrollState(bool) ) ); 560 connect( reader, SIGNAL( SetScrollState(bool) ), this, SLOT( setScrollState(bool) ) );
563 connect( reader, SIGNAL(RefreshBitmap()), this, SLOT(setBackgroundBitmap())); 561 connect( reader, SIGNAL(RefreshBitmap()), this, SLOT(setBackgroundBitmap()));
564 editorStack->addWidget( reader, get_unique_id() ); 562 editorStack->addWidget( reader, get_unique_id() );
565 563
566 m_preferences_action = new QAction( tr( "Configuration" ), geticon( "SettingsIcon" ), QString::null, 0, this, NULL); 564 m_preferences_action = new QAction( tr( "Configuration" ), geticon( "SettingsIcon" ), QString::null, 0, this, NULL);
567 connect( m_preferences_action, SIGNAL( activated() ), this, SLOT( showprefs() ) ); 565 connect( m_preferences_action, SIGNAL( activated() ), this, SLOT( showprefs() ) );
568 m_preferences_action->addTo( settings ); 566 m_preferences_action->addTo( settings );
569 567
570 m_saveconfig_action = new QAction( tr( "Save Config" ), QString::null, 0, this, NULL); 568 m_saveconfig_action = new QAction( tr( "Save Config" ), QString::null, 0, this, NULL);
571 connect( m_saveconfig_action, SIGNAL( activated() ), this, SLOT( SaveConfig() ) ); 569 connect( m_saveconfig_action, SIGNAL( activated() ), this, SLOT( SaveConfig() ) );
572 m_saveconfig_action->addTo( settings ); 570 m_saveconfig_action->addTo( settings );
573 571
574 m_loadconfig_action = new QAction( tr( "Load Config" ), QString::null, 0, this, NULL); 572 m_loadconfig_action = new QAction( tr( "Load Config" ), QString::null, 0, this, NULL);
575 connect( m_loadconfig_action, SIGNAL( activated() ), this, SLOT( LoadConfig() ) ); 573 connect( m_loadconfig_action, SIGNAL( activated() ), this, SLOT( LoadConfig() ) );
576 m_loadconfig_action->addTo( settings ); 574 m_loadconfig_action->addTo( settings );
577 575
578 m_tidyconfig_action = new QAction( tr( "Delete Config" ), QString::null, 0, this, NULL); 576 m_tidyconfig_action = new QAction( tr( "Delete Config" ), QString::null, 0, this, NULL);
579 connect( m_tidyconfig_action, SIGNAL( activated() ), this, SLOT( TidyConfig() ) ); 577 connect( m_tidyconfig_action, SIGNAL( activated() ), this, SLOT( TidyConfig() ) );
580 m_tidyconfig_action->addTo( settings ); 578 m_tidyconfig_action->addTo( settings );
581 579
582 settings->insertSeparator(); 580 settings->insertSeparator();
583 m_toolbarprefs_action = new QAction( tr( "Toolbars" ), QString::null, 0, this, NULL); 581 m_toolbarprefs_action = new QAction( tr( "Toolbars" ), QString::null, 0, this, NULL);
584 connect( m_toolbarprefs_action, SIGNAL( activated() ), this, SLOT( showtoolbarprefs() ) ); 582 connect( m_toolbarprefs_action, SIGNAL( activated() ), this, SLOT( showtoolbarprefs() ) );
585 m_toolbarprefs_action->addTo( settings ); 583 m_toolbarprefs_action->addTo( settings );
586 584
587 m_buttonprefs_action = new QAction( tr( "Buttons" ), QString::null, 0, this, NULL); 585 m_buttonprefs_action = new QAction( tr( "Buttons" ), QString::null, 0, this, NULL);
588 connect( m_buttonprefs_action, SIGNAL( activated() ), this, SLOT( showbuttonprefs() ) ); 586 connect( m_buttonprefs_action, SIGNAL( activated() ), this, SLOT( showbuttonprefs() ) );
589 m_buttonprefs_action->addTo( settings ); 587 m_buttonprefs_action->addTo( settings );
590 588
591 m_loadtheme_action = new QAction( tr( "Load Theme" ), QString::null, 0, this, NULL); 589 m_loadtheme_action = new QAction( tr( "Load Theme" ), QString::null, 0, this, NULL);
592 connect( m_loadtheme_action, SIGNAL( activated() ), this, SLOT( LoadTheme() ) ); 590 connect( m_loadtheme_action, SIGNAL( activated() ), this, SLOT( LoadTheme() ) );
593 m_loadtheme_action->addTo( settings ); 591 m_loadtheme_action->addTo( settings );
594 592
595 m_repara_action = new QAction( tr( "EOP Marker" ), QString::null, 0, this, NULL); 593 m_repara_action = new QAction( tr( "EOP Marker" ), QString::null, 0, this, NULL);
596 connect( m_repara_action, SIGNAL( activated() ), this, SLOT( reparastring() ) ); 594 connect( m_repara_action, SIGNAL( activated() ), this, SLOT( reparastring() ) );
597 m_repara_action->addTo(settings); 595 m_repara_action->addTo(settings);
598 596
599#ifdef USEQPE 597#ifdef USEQPE
600 m_grab_action = new QAction( tr( "Grab Buttons" ), QString::null, 0, this, NULL, true ); 598 m_grab_action = new QAction( tr( "Grab Buttons" ), QString::null, 0, this, NULL, true );
601 connect( m_grab_action, SIGNAL( toggled(bool) ), this, SLOT( setgrab(bool) ) ); 599 connect( m_grab_action, SIGNAL( toggled(bool) ), this, SLOT( setgrab(bool) ) );
602 m_grab_action->setOn(m_grabkeyboard); 600 m_grab_action->setOn(m_grabkeyboard);
603 m_grab_action->addTo( settings ); 601 m_grab_action->addTo( settings );
604#endif 602#endif
605 603
606 m_open_action = new QAction( tr( "Open" ), geticon( "fileopen" ), QString::null, 0, this, 0 ); 604 m_open_action = new QAction( tr( "Open" ), geticon( "fileopen" ), QString::null, 0, this, 0 );
607 connect( m_open_action, SIGNAL( activated() ), this, SLOT( fileOpen() ) ); 605 connect( m_open_action, SIGNAL( activated() ), this, SLOT( fileOpen() ) );
608 m_open_action->addTo( file ); 606 m_open_action->addTo( file );
609 607
610 m_close_action = new QAction( tr( "Close" ), geticon( "close" ), QString::null, 0, this, 0 ); 608 m_close_action = new QAction( tr( "Close" ), geticon( "close" ), QString::null, 0, this, 0 );
611 connect( m_close_action, SIGNAL( activated() ), this, SLOT( fileClose() ) ); 609 connect( m_close_action, SIGNAL( activated() ), this, SLOT( fileClose() ) );
612 m_close_action->addTo( file ); 610 m_close_action->addTo( file );
613 611
614#ifdef _SCRIPT 612#ifdef _SCRIPT
615 a = new QAction( tr( "Run Script" ), QString::null, 0, this, NULL); 613 a = new QAction( tr( "Run Script" ), QString::null, 0, this, NULL);
616 connect( a, SIGNAL( activated() ), this, SLOT( RunScript() ) ); 614 connect( a, SIGNAL( activated() ), this, SLOT( RunScript() ) );
617 a->addTo( file ); 615 a->addTo( file );
618#endif 616#endif
619 /* 617 /*
620 a = new QAction( tr( "Revert" ), geticon( "close" ), QString::null, 0, this, 0 ); 618 a = new QAction( tr( "Revert" ), geticon( "close" ), QString::null, 0, this, 0 );
621 connect( a, SIGNAL( activated() ), this, SLOT( fileRevert() ) ); 619 connect( a, SIGNAL( activated() ), this, SLOT( fileRevert() ) );
622 a->addTo( file ); 620 a->addTo( file );
623 621
624 a = new QAction( tr( "Cut" ), geticon( "cut" ), QString::null, 0, this, 0 ); 622 a = new QAction( tr( "Cut" ), geticon( "cut" ), QString::null, 0, this, 0 );
625 connect( a, SIGNAL( activated() ), this, SLOT( editCut() ) ); 623 connect( a, SIGNAL( activated() ), this, SLOT( editCut() ) );
626 a->addTo( filebar() ); 624 a->addTo( filebar() );
627 a->addTo( edit ); 625 a->addTo( edit );
628 */ 626 */
629 627
630 m_info_action = new QAction( tr( "Info" ), geticon( "UtilsIcon" ), QString::null, 0, this, NULL); 628 m_info_action = new QAction( tr( "Info" ), geticon( "UtilsIcon" ), QString::null, 0, this, NULL);
631 connect( m_info_action, SIGNAL( activated() ), this, SLOT( showinfo() ) ); 629 connect( m_info_action, SIGNAL( activated() ), this, SLOT( showinfo() ) );
632 m_info_action->addTo( file ); 630 m_info_action->addTo( file );
633 631
634 m_touch_action = new QAction( tr( "Two/One Touch" ), geticon( "1to1" ), QString::null, 0, this, NULL, true ); 632 m_touch_action = new QAction( tr( "Two/One Touch" ), geticon( "1to1" ), QString::null, 0, this, NULL, true );
635 connect( m_touch_action, SIGNAL( toggled(bool) ), this, SLOT( setTwoTouch(bool) ) ); 633 connect( m_touch_action, SIGNAL( toggled(bool) ), this, SLOT( setTwoTouch(bool) ) );
636 m_touch_action->setOn(m_twoTouch); 634 m_touch_action->setOn(m_twoTouch);
637 m_touch_action->addTo( file ); 635 m_touch_action->addTo( file );
638 636
639 m_find_action = new QAction( tr( "Find..." ), geticon( "find" ), QString::null, 0, this, NULL); 637 m_find_action = new QAction( tr( "Find..." ), geticon( "find" ), QString::null, 0, this, NULL);
640 connect( m_find_action, SIGNAL( activated() ), this, SLOT( editFind() ) ); 638 connect( m_find_action, SIGNAL( activated() ), this, SLOT( editFind() ) );
641 file->insertSeparator(); 639 file->insertSeparator();
642// a->addTo( bar ); 640// a->addTo( bar );
643 m_find_action->addTo( file ); 641 m_find_action->addTo( file );
644 642
645 m_exportlinks_action = new QAction( tr( "Export Links" ), QString::null, 0, this, NULL); 643 m_exportlinks_action = new QAction( tr( "Export Links" ), QString::null, 0, this, NULL);
646 connect( m_exportlinks_action, SIGNAL( activated() ), this, SLOT( ExportLinks() ) ); 644 connect( m_exportlinks_action, SIGNAL( activated() ), this, SLOT( ExportLinks() ) );
647 m_exportlinks_action->addTo( file ); 645 m_exportlinks_action->addTo( file );
648 646
649 m_scrollButton = new QAction( tr( "Scroll" ), getmyicon( "panel-arrow-down" ), QString::null, 0, this, 0, true ); 647 m_scrollButton = new QAction( tr( "Scroll" ), getmyicon( "panel-arrow-down" ), QString::null, 0, this, 0, true );
650 connect( m_scrollButton, SIGNAL( toggled(bool) ), this, SLOT( autoScroll(bool) ) ); 648 connect( m_scrollButton, SIGNAL( toggled(bool) ), this, SLOT( autoScroll(bool) ) );
651 m_scrollButton->addTo(navigation); 649 m_scrollButton->addTo(navigation);
652 m_scrollButton->setOn(false); 650 m_scrollButton->setOn(false);
653 651
654 m_start_action = new QAction( tr( "Goto Start" ), geticon( "start" ), QString::null, 0, this, NULL); 652 m_start_action = new QAction( tr( "Goto Start" ), geticon( "start" ), QString::null, 0, this, NULL);
655 connect( m_start_action, SIGNAL( activated() ), this, SLOT( gotoStart() ) ); 653 connect( m_start_action, SIGNAL( activated() ), this, SLOT( gotoStart() ) );
656 m_start_action->addTo(navigation); 654 m_start_action->addTo(navigation);
657 655
658 m_end_action = new QAction( tr( "Goto End" ), geticon( "finish" ), QString::null, 0, this, NULL); 656 m_end_action = new QAction( tr( "Goto End" ), geticon( "finish" ), QString::null, 0, this, NULL);
659 connect( m_end_action, SIGNAL( activated() ), this, SLOT( gotoEnd() ) ); 657 connect( m_end_action, SIGNAL( activated() ), this, SLOT( gotoEnd() ) );
660 m_end_action->addTo(navigation); 658 m_end_action->addTo(navigation);
661 659
662 m_jump_action = new QAction( tr( "Jump" ), geticon( "rotate" ), QString::null, 0, this, NULL); 660 m_jump_action = new QAction( tr( "Jump" ), geticon( "rotate" ), QString::null, 0, this, NULL);
663 connect( m_jump_action, SIGNAL( activated() ), this, SLOT( jump() ) ); 661 connect( m_jump_action, SIGNAL( activated() ), this, SLOT( jump() ) );
664 m_jump_action->addTo(navigation); 662 m_jump_action->addTo(navigation);
665 663
666 m_pageline_action = new QAction( tr( "Page/Line Scroll" ), geticon( "pass" ), QString::null, 0, this, NULL, true ); 664 m_pageline_action = new QAction( tr( "Page/Line Scroll" ), geticon( "pass" ), QString::null, 0, this, NULL, true );
667 connect( m_pageline_action, SIGNAL( toggled(bool) ), this, SLOT( pagemode(bool) ) ); 665 connect( m_pageline_action, SIGNAL( toggled(bool) ), this, SLOT( pagemode(bool) ) );
668 m_pageline_action->addTo(navigation); 666 m_pageline_action->addTo(navigation);
669 m_pageline_action->setOn(reader->m_bpagemode); 667 m_pageline_action->setOn(reader->m_bpagemode);
670 668
671 m_pageup_action = new QAction( tr( "Up" ), geticon( "up" ), QString::null, 0, this, 0 ); 669 m_pageup_action = new QAction( tr( "Up" ), geticon( "up" ), QString::null, 0, this, 0 );
672 connect( m_pageup_action, SIGNAL( activated() ), this, SLOT( pageup() ) ); 670 connect( m_pageup_action, SIGNAL( activated() ), this, SLOT( pageup() ) );
673 m_pageup_action->addTo( navigation ); 671 m_pageup_action->addTo( navigation );
674 672
675 m_pagedn_action = new QAction( tr( "Down" ), geticon( "down" ), QString::null, 0, this, 0 ); 673 m_pagedn_action = new QAction( tr( "Down" ), geticon( "down" ), QString::null, 0, this, 0 );
676 connect( m_pagedn_action, SIGNAL( activated() ), this, SLOT( pagedn() ) ); 674 connect( m_pagedn_action, SIGNAL( activated() ), this, SLOT( pagedn() ) );
677 m_pagedn_action->addTo( navigation ); 675 m_pagedn_action->addTo( navigation );
678 676
679 m_back_action = new QAction( tr( "Back" ), geticon( "back" ), QString::null, 0, this, 0 ); 677 m_back_action = new QAction( tr( "Back" ), geticon( "back" ), QString::null, 0, this, 0 );
680 connect( m_back_action, SIGNAL( activated() ), reader, SLOT( goBack() ) ); 678 connect( m_back_action, SIGNAL( activated() ), reader, SLOT( goBack() ) );
681 m_back_action->addTo( navigation ); 679 m_back_action->addTo( navigation );
682 680
683 m_home_action = new QAction( tr( "Home" ), geticon( "home" ), QString::null, 0, this, 0 ); 681 m_home_action = new QAction( tr( "Home" ), geticon( "home" ), QString::null, 0, this, 0 );
684 connect( m_home_action, SIGNAL( activated() ), reader, SLOT( goHome() ) ); 682 connect( m_home_action, SIGNAL( activated() ), reader, SLOT( goHome() ) );
685 m_home_action->addTo( navigation ); 683 m_home_action->addTo( navigation );
686 684
687 m_forward_action = new QAction( tr( "Forward" ), geticon( "forward" ), QString::null, 0, this, 0 ); 685 m_forward_action = new QAction( tr( "Forward" ), geticon( "forward" ), QString::null, 0, this, 0 );
688 connect( m_forward_action, SIGNAL( activated() ), reader, SLOT( goForward() ) ); 686 connect( m_forward_action, SIGNAL( activated() ), reader, SLOT( goForward() ) );
689 m_forward_action->addTo( navigation ); 687 m_forward_action->addTo( navigation );
690 688
691 /* 689 /*
692 a = new QAction( tr( "Find" ), QString::null, 0, this, NULL, true ); 690 a = new QAction( tr( "Find" ), QString::null, 0, this, NULL, true );
693 // connect( a, SIGNAL( activated() ), this, SLOT( pagedn() ) ); 691 // connect( a, SIGNAL( activated() ), this, SLOT( pagedn() ) );
694 a->addTo( file ); 692 a->addTo( file );
695 693
696 a = new QAction( tr( "Find Again" ), QString::null, 0, this, NULL, true ); 694 a = new QAction( tr( "Find Again" ), QString::null, 0, this, NULL, true );
697 // connect( a, SIGNAL( activated() ), this, SLOT( pagedn() ) ); 695 // connect( a, SIGNAL( activated() ), this, SLOT( pagedn() ) );
698 a->addTo( file ); 696 a->addTo( file );
699 */ 697 */
700 698
701// file->insertSeparator(); 699// file->insertSeparator();
702 700
703#ifdef _SCROLLPIPE 701#ifdef _SCROLLPIPE
704 702
705 QActionGroup* ag = new QActionGroup(this); 703 QActionGroup* ag = new QActionGroup(this);
706 ag->setExclusive(false); 704 ag->setExclusive(false);
707 spacemenu = new QPopupMenu(this); 705 spacemenu = new QPopupMenu(this);
708 file->insertItem( tr( "Scrolling" ), spacemenu ); 706 file->insertItem( tr( "Scrolling" ), spacemenu );
709 707
710 a = new QAction( tr( "Set Target" ), QString::null, 0, ag, NULL); 708 a = new QAction( tr( "Set Target" ), QString::null, 0, ag, NULL);
711 connect( a, SIGNAL( activated() ), this, SLOT( setpipetarget() ) ); 709 connect( a, SIGNAL( activated() ), this, SLOT( setpipetarget() ) );
712 710
713 a = new QAction( tr( "Pause Paras" ), QString::null, 0, ag, NULL, true ); 711 a = new QAction( tr( "Pause Paras" ), QString::null, 0, ag, NULL, true );
714 connect( a, SIGNAL( toggled(bool) ), this, SLOT( setpause(bool) ) ); 712 connect( a, SIGNAL( toggled(bool) ), this, SLOT( setpause(bool) ) );
715 a->setOn(reader->m_pauseAfterEachPara); 713 a->setOn(reader->m_pauseAfterEachPara);
716 714
717 ag->addTo(spacemenu); 715 ag->addTo(spacemenu);
718// file->insertSeparator(); 716// file->insertSeparator();
719 717
720#endif 718#endif
721 719
722/* 720/*
723 a = new QAction( tr( "Import" ), QString::null, 0, this, NULL ); 721 a = new QAction( tr( "Import" ), QString::null, 0, this, NULL );
724 connect( a, SIGNAL( activated() ), this, SLOT( importFiles() ) ); 722 connect( a, SIGNAL( activated() ), this, SLOT( importFiles() ) );
725 a->addTo( file ); 723 a->addTo( file );
726*/ 724*/
727 725
728 /* 726 /*
729 a = new QAction( tr( "Paste" ), geticon( "paste" ), QString::null, 0, this, 0 ); 727 a = new QAction( tr( "Paste" ), geticon( "paste" ), QString::null, 0, this, 0 );
730 connect( a, SIGNAL( activated() ), this, SLOT( editPaste() ) ); 728 connect( a, SIGNAL( activated() ), this, SLOT( editPaste() ) );
731 a->addTo( fileBar ); 729 a->addTo( fileBar );
732 a->addTo( edit ); 730 a->addTo( edit );
733 */ 731 */
734 732
735// a = new QAction( tr( "Find..." ), geticon( "find" ), QString::null, 0, this, 0 ); 733// a = new QAction( tr( "Find..." ), geticon( "find" ), QString::null, 0, this, 0 );
736 734
737 m_fullscreen = false; 735 m_fullscreen = false;
738 m_actFullscreen = new QAction( tr( "Fullscreen" ), geticon( "fullscreen" ), QString::null, 0, this, NULL, true ); 736 m_actFullscreen = new QAction( tr( "Fullscreen" ), geticon( "fullscreen" ), QString::null, 0, this, NULL, true );
739 connect( m_actFullscreen, SIGNAL( toggled(bool) ), this, SLOT( setfullscreen(bool) ) ); 737 connect( m_actFullscreen, SIGNAL( toggled(bool) ), this, SLOT( setfullscreen(bool) ) );
740 m_actFullscreen->setOn(m_fullscreen); 738 m_actFullscreen->setOn(m_fullscreen);
741 m_actFullscreen->addTo( view ); 739 m_actFullscreen->addTo( view );
742 740
743 m_rotate_action = new QAction( tr( "Rotate" ), geticon( "repeat" ), QString::null, 0, this, NULL, true ); 741 m_rotate_action = new QAction( tr( "Rotate" ), geticon( "repeat" ), QString::null, 0, this, NULL, true );
744 connect( m_rotate_action, SIGNAL( toggled(bool) ), this, SLOT( setrotated(bool) ) ); 742 connect( m_rotate_action, SIGNAL( toggled(bool) ), this, SLOT( setrotated(bool) ) );
745 m_rotate_action->setOn(reader->m_rotated); 743 m_rotate_action->setOn(reader->m_rotated);
746 m_rotate_action->addTo( view ); 744 m_rotate_action->addTo( view );
747 745
748 m_inverse_action = new QAction( tr( "Invert" ), getmyicon( "invert" ), QString::null, 0, this, NULL, true ); 746 m_inverse_action = new QAction( tr( "Invert" ), getmyicon( "invert" ), QString::null, 0, this, NULL, true );
749 connect( m_inverse_action, SIGNAL( toggled(bool) ), this, SLOT( setinverted(bool) ) ); 747 connect( m_inverse_action, SIGNAL( toggled(bool) ), this, SLOT( setinverted(bool) ) );
750 m_inverse_action->setOn(reader->bInverse); 748 m_inverse_action->setOn(reader->bInverse);
751 m_inverse_action->addTo( view ); 749 m_inverse_action->addTo( view );
752 750
753 view->insertSeparator(); 751 view->insertSeparator();
754 752
755 m_zoomin_action = new QAction( tr( "Zoom In" ), geticon( "zoom" ), QString::null, 0, this); 753 m_zoomin_action = new QAction( tr( "Zoom In" ), geticon( "zoom" ), QString::null, 0, this);
756 connect( m_zoomin_action, SIGNAL( activated() ), this, SLOT( zoomin() ) ); 754 connect( m_zoomin_action, SIGNAL( activated() ), this, SLOT( zoomin() ) );
757 m_zoomin_action->addTo( view ); 755 m_zoomin_action->addTo( view );
758 756
759 m_zoomout_action = new QAction( tr( "Zoom Out" ), geticon( "mag" ), QString::null, 0, this); 757 m_zoomout_action = new QAction( tr( "Zoom Out" ), geticon( "mag" ), QString::null, 0, this);
760 connect( m_zoomout_action, SIGNAL( activated() ), this, SLOT( zoomout() ) ); 758 connect( m_zoomout_action, SIGNAL( activated() ), this, SLOT( zoomout() ) );
761 m_zoomout_action->addTo( view ); 759 m_zoomout_action->addTo( view );
762 760
763 view->insertSeparator(); 761 view->insertSeparator();
764 m_setfont_action = new QAction( tr( "Set Font" ), getmyicon( "font" ), QString::null, 0, this); 762 m_setfont_action = new QAction( tr( "Set Font" ), getmyicon( "font" ), QString::null, 0, this);
765 connect( m_setfont_action, SIGNAL( activated() ), this, SLOT( setfont() ) ); 763 connect( m_setfont_action, SIGNAL( activated() ), this, SLOT( setfont() ) );
766 m_setfont_action->addTo( view ); 764 m_setfont_action->addTo( view );
767 765
768 view->insertSeparator(); 766 view->insertSeparator();
769 m_setenc_action = new QAction( tr( "Set Encoding" ), getmyicon( "charset" ), QString::null, 0, this); 767 m_setenc_action = new QAction( tr( "Set Encoding" ), getmyicon( "charset" ), QString::null, 0, this);
770 connect( m_setenc_action, SIGNAL( activated() ), this, SLOT( chooseencoding() ) ); 768 connect( m_setenc_action, SIGNAL( activated() ), this, SLOT( chooseencoding() ) );
771 m_setenc_action->addTo( view ); 769 m_setenc_action->addTo( view );
772 770
773 m_setmono_action = new QAction( tr( "Ideogram" ), getmyicon( "ideogram" ), QString::null, 0, this, NULL, true); 771 m_setmono_action = new QAction( tr( "Ideogram" ), getmyicon( "ideogram" ), QString::null, 0, this, NULL, true);
774 connect( m_setmono_action, SIGNAL( toggled(bool) ), this, SLOT( monospace(bool) ) ); 772 connect( m_setmono_action, SIGNAL( toggled(bool) ), this, SLOT( monospace(bool) ) );
775 m_setmono_action->addTo( view ); 773 m_setmono_action->addTo( view );
776 m_setmono_action->setOn(reader->m_bMonoSpaced); 774 m_setmono_action->setOn(reader->m_bMonoSpaced);
777 775
778 776
779 // a = new QAction( tr( "Zoom" ), QString::null, 0, this, NULL, true ); 777 // a = new QAction( tr( "Zoom" ), QString::null, 0, this, NULL, true );
780 // a = new QAction( tr( "Zoom" ), geticon( "mag" ), QString::null, 0, this, 0 ); 778 // a = new QAction( tr( "Zoom" ), geticon( "mag" ), QString::null, 0, this, 0 );
781 779
782 780
783 781
784 // a->addTo( filebar() ); 782 // a->addTo( filebar() );
785// view->insertSeparator(); 783// view->insertSeparator();
786 784
787/* 785/*
788 a = new QAction( tr( "Ideogram/Word" ), QString::null, 0, this, NULL, true ); 786 a = new QAction( tr( "Ideogram/Word" ), QString::null, 0, this, NULL, true );
789 connect( a, SIGNAL( toggled(bool) ), this, SLOT( monospace(bool) ) ); 787 connect( a, SIGNAL( toggled(bool) ), this, SLOT( monospace(bool) ) );
790 a->setOn(reader->m_bMonoSpaced); 788 a->setOn(reader->m_bMonoSpaced);
791 a->addTo( view ); 789 a->addTo( view );
792*/ 790*/
793/* 791/*
794 a = new QAction( tr( "Set Width" ), QString::null, 0, this, NULL); 792 a = new QAction( tr( "Set Width" ), QString::null, 0, this, NULL);
795 connect( a, SIGNAL( activated() ), this, SLOT( setspacing() ) ); 793 connect( a, SIGNAL( activated() ), this, SLOT( setspacing() ) );
796 a->addTo( view ); 794 a->addTo( view );
797*/ 795*/
798 796
799 m_mark_action = new QAction( tr( "Bookmark" ), getmyicon( "bookmark" ), QString::null, 0, this, NULL); 797 m_mark_action = new QAction( tr( "Bookmark" ), getmyicon( "bookmark" ), QString::null, 0, this, NULL);
800 connect( m_mark_action, SIGNAL( activated() ), this, SLOT( addbkmk() ) ); 798 connect( m_mark_action, SIGNAL( activated() ), this, SLOT( addbkmk() ) );
801 m_mark_action->addTo( marks ); 799 m_mark_action->addTo( marks );
802 800
803 m_annotate_action = new QAction( tr( "Annotate" ), getmyicon( "annotate" ), QString::null, 0, this, NULL); 801 m_annotate_action = new QAction( tr( "Annotate" ), getmyicon( "annotate" ), QString::null, 0, this, NULL);
804 connect( m_annotate_action, SIGNAL( activated() ), this, SLOT( addanno() ) ); 802 connect( m_annotate_action, SIGNAL( activated() ), this, SLOT( addanno() ) );
805 m_annotate_action->addTo( marks ); 803 m_annotate_action->addTo( marks );
806 804
807 m_goto_action = new QAction( tr( "Goto" ), getmyicon( "bookmark_goto" ), QString::null, 0, this, NULL, false ); 805 m_goto_action = new QAction( tr( "Goto" ), getmyicon( "bookmark_goto" ), QString::null, 0, this, NULL, false );
808 connect( m_goto_action, SIGNAL( activated() ), this, SLOT( do_gotomark() ) ); 806 connect( m_goto_action, SIGNAL( activated() ), this, SLOT( do_gotomark() ) );
809 m_goto_action->addTo( marks ); 807 m_goto_action->addTo( marks );
810 808
811 m_delete_action = new QAction( tr( "Delete" ), getmyicon( "bookmark_delete" ), QString::null, 0, this, NULL); 809 m_delete_action = new QAction( tr( "Delete" ), getmyicon( "bookmark_delete" ), QString::null, 0, this, NULL);
812 connect( m_delete_action, SIGNAL( activated() ), this, SLOT( do_delmark() ) ); 810 connect( m_delete_action, SIGNAL( activated() ), this, SLOT( do_delmark() ) );
813 m_delete_action->addTo( marks ); 811 m_delete_action->addTo( marks );
814 812
815 m_autogen_action = new QAction( tr( "Autogen" ), geticon( "exec" ), QString::null, 0, this, NULL, false ); 813 m_autogen_action = new QAction( tr( "Autogen" ), geticon( "exec" ), QString::null, 0, this, NULL, false );
816 connect( m_autogen_action, SIGNAL( activated() ), this, SLOT( do_autogen() ) ); 814 connect( m_autogen_action, SIGNAL( activated() ), this, SLOT( do_autogen() ) );
817 marks->insertSeparator(); 815 marks->insertSeparator();
818 m_autogen_action->addTo( marks ); 816 m_autogen_action->addTo( marks );
819 817
820 m_clear_action = new QAction( tr( "Clear" ), getmyicon( "bookmark_clear" ), QString::null, 0, this, NULL); 818 m_clear_action = new QAction( tr( "Clear" ), getmyicon( "bookmark_clear" ), QString::null, 0, this, NULL);
821 connect( m_clear_action, SIGNAL( activated() ), this, SLOT( clearBkmkList() ) ); 819 connect( m_clear_action, SIGNAL( activated() ), this, SLOT( clearBkmkList() ) );
822 m_clear_action->addTo( marks ); 820 m_clear_action->addTo( marks );
823 821
824 m_save_action = new QAction( tr( "Save" ), getmyicon( "bookmark_save" ), QString::null, 0, this, NULL ); 822 m_save_action = new QAction( tr( "Save" ), getmyicon( "bookmark_save" ), QString::null, 0, this, NULL );
825 connect( m_save_action, SIGNAL( activated() ), this, SLOT( savebkmks() ) ); 823 connect( m_save_action, SIGNAL( activated() ), this, SLOT( savebkmks() ) );
826 m_save_action->addTo( marks ); 824 m_save_action->addTo( marks );
827 825
828 m_tidy_action = new QAction( tr( "Tidy" ), getmyicon( "bookmark_tidy" ), QString::null, 0, this, NULL); 826 m_tidy_action = new QAction( tr( "Tidy" ), getmyicon( "bookmark_tidy" ), QString::null, 0, this, NULL);
829 connect( m_tidy_action, SIGNAL( activated() ), this, SLOT( listBkmkFiles() ) ); 827 connect( m_tidy_action, SIGNAL( activated() ), this, SLOT( listBkmkFiles() ) );
830 marks->insertSeparator(); 828 marks->insertSeparator();
831 m_tidy_action->addTo( marks ); 829 m_tidy_action->addTo( marks );
832 830
833 m_startBlock_action = new QAction( tr( "Start Block" ), geticon( "new" ), QString::null, 0, this, NULL); 831 m_startBlock_action = new QAction( tr( "Start Block" ), geticon( "new" ), QString::null, 0, this, NULL);
834 connect( m_startBlock_action, SIGNAL( activated() ), this, SLOT( editMark() ) ); 832 connect( m_startBlock_action, SIGNAL( activated() ), this, SLOT( editMark() ) );
835 marks->insertSeparator(); 833 marks->insertSeparator();
836 m_startBlock_action->addTo( marks ); 834 m_startBlock_action->addTo( marks );
837 835
838 m_endBlock_action = new QAction( tr( "Copy Block" ), geticon( "copy" ), QString::null, 0, this, NULL); 836 m_endBlock_action = new QAction( tr( "Copy Block" ), geticon( "copy" ), QString::null, 0, this, NULL);
839 connect( m_endBlock_action, SIGNAL( activated() ), this, SLOT( editCopy() ) ); 837 connect( m_endBlock_action, SIGNAL( activated() ), this, SLOT( editCopy() ) );
840 m_endBlock_action->addTo( marks ); 838 m_endBlock_action->addTo( marks );
841 839
842 m_bkmkAvail = NULL; 840 m_bkmkAvail = NULL;
843 841
844 842
845 setToolBarsMovable(m_tbmove); 843 setToolBarsMovable(m_tbmove);
846 addtoolbars(&config); 844 addtoolbars(&config);
847 845
848 pbar = new QProgressBar(this); 846 pbar = new QProgressBar(this);
849 pbar->hide(); 847 pbar->hide();
850 848
851 searchBar = new QFloatBar( "Search", this, QMainWindow::Top, TRUE ); 849 searchBar = new QFloatBar( "Search", this, QMainWindow::Top, TRUE );
852 850
853 searchBar->setHorizontalStretchable( TRUE ); 851 searchBar->setHorizontalStretchable( TRUE );
854 852
855 connect(searchBar, SIGNAL( OnHide() ), this, SLOT( restoreFocus() )); 853 connect(searchBar, SIGNAL( OnHide() ), this, SLOT( restoreFocus() ));
856 854
857 searchEdit = new QLineEdit( searchBar, "searchEdit" ); 855 searchEdit = new QLineEdit( searchBar, "searchEdit" );
858// QFont f("unifont", 16 /*, QFont::Bold*/); 856// QFont f("unifont", 16 /*, QFont::Bold*/);
859// searchEdit->setFont( f ); 857// searchEdit->setFont( f );
860 searchBar->setStretchableWidget( searchEdit ); 858 searchBar->setStretchableWidget( searchEdit );
861 859
862 860
863#ifdef __ISEARCH 861#ifdef __ISEARCH
864 connect( searchEdit, SIGNAL( textChanged( const QString & ) ), 862 connect( searchEdit, SIGNAL( textChanged( const QString & ) ),
865 this, SLOT( search( const QString& ) ) ); 863 this, SLOT( search( const QString& ) ) );
866#else 864#else
867 connect( searchEdit, SIGNAL( returnPressed( ) ), 865 connect( searchEdit, SIGNAL( returnPressed( ) ),
868 this, SLOT( search( ) ) ); 866 this, SLOT( search( ) ) );
869#endif 867#endif
870 QAction*a = new QAction( tr( "Find Next" ), geticon( "next" ), QString::null, 0, this, 0 ); 868 QAction*a = new QAction( tr( "Find Next" ), geticon( "next" ), QString::null, 0, this, 0 );
871 connect( a, SIGNAL( activated() ), this, SLOT( findNext() ) ); 869 connect( a, SIGNAL( activated() ), this, SLOT( findNext() ) );
872 a->addTo( searchBar ); 870 a->addTo( searchBar );
873 871
874 a = new QAction( tr( "Close Find" ), geticon( "close" ), QString::null, 0, this, 0 ); 872 a = new QAction( tr( "Close Find" ), geticon( "close" ), QString::null, 0, this, 0 );
875 connect( a, SIGNAL( activated() ), this, SLOT( findClose() ) ); 873 connect( a, SIGNAL( activated() ), this, SLOT( findClose() ) );
876 a->addTo( searchBar ); 874 a->addTo( searchBar );
877 875
878 searchBar->hide(); 876 searchBar->hide();
879 877
880 regBar = new QFloatBar( "Autogen", this, QMainWindow::Top, TRUE ); 878 regBar = new QFloatBar( "Autogen", this, QMainWindow::Top, TRUE );
881 connect(regBar, SIGNAL( OnHide() ), this, SLOT( restoreFocus() )); 879 connect(regBar, SIGNAL( OnHide() ), this, SLOT( restoreFocus() ));
882 880
883 regBar->setHorizontalStretchable( TRUE ); 881 regBar->setHorizontalStretchable( TRUE );
884 882
885 regEdit = new QLineEdit( regBar, "regEdit" ); 883 regEdit = new QLineEdit( regBar, "regEdit" );
886// regEdit->setFont( f ); 884// regEdit->setFont( f );
887 885
888 regBar->setStretchableWidget( regEdit ); 886 regBar->setStretchableWidget( regEdit );
889 887
890 connect( regEdit, SIGNAL( returnPressed( ) ), 888 connect( regEdit, SIGNAL( returnPressed( ) ),
891 this, SLOT( do_regaction() ) ); 889 this, SLOT( do_regaction() ) );
892 890
893 a = new QAction( tr( "Do Reg" ), geticon( "enter" ), QString::null, 0, this, 0 ); 891 a = new QAction( tr( "Do Reg" ), geticon( "enter" ), QString::null, 0, this, 0 );
894 connect( a, SIGNAL( activated() ), this, SLOT( do_regaction() ) ); 892 connect( a, SIGNAL( activated() ), this, SLOT( do_regaction() ) );
895 a->addTo( regBar ); 893 a->addTo( regBar );
896 894
897 a = new QAction( tr( "Close Edit" ), geticon( "close" ), QString::null, 0, this, 0 ); 895 a = new QAction( tr( "Close Edit" ), geticon( "close" ), QString::null, 0, this, 0 );
898 connect( a, SIGNAL( activated() ), this, SLOT( regClose() ) ); 896 connect( a, SIGNAL( activated() ), this, SLOT( regClose() ) );
899 a->addTo( regBar ); 897 a->addTo( regBar );
900 898
901 regBar->hide(); 899 regBar->hide();
902 900
903 m_fontBar = new QToolBar( "Autogen", this, QMainWindow::Top, TRUE ); 901 m_fontBar = new QToolBar( "Autogen", this, QMainWindow::Top, TRUE );
904 902
905 m_fontBar->setHorizontalStretchable( TRUE ); 903 m_fontBar->setHorizontalStretchable( TRUE );
906 904
907// qDebug("Font selector"); 905// qDebug("Font selector");
908 m_fontSelector = new QComboBox(false, m_fontBar); 906 m_fontSelector = new QComboBox(false, m_fontBar);
909 m_fontBar->setStretchableWidget( m_fontSelector ); 907 m_fontBar->setStretchableWidget( m_fontSelector );
910 { 908 {
911 QFontDatabase f; 909 QFontDatabase f;
912 QStringList flist = f.families(); 910 QStringList flist = f.families();
913 bool realfont = false; 911 bool realfont = false;
914 for (QStringList::Iterator nm = flist.begin(); nm != flist.end(); nm++) 912 for (QStringList::Iterator nm = flist.begin(); nm != flist.end(); nm++)
915 { 913 {
916 if (reader->m_fontname == *nm) 914 if (reader->m_fontname == *nm)
917 { 915 {
918 realfont = true; 916 realfont = true;
919 } 917 }
920 if ((*nm).contains(FIXEDFONT,false)) reader->m_fontControl.hasCourier(true, *nm); 918 if ((*nm).contains(FIXEDFONT,false)) reader->m_fontControl.hasCourier(true, *nm);
921 } 919 }
922 if (!realfont) reader->m_fontname = flist[0]; 920 if (!realfont) reader->m_fontname = flist[0];
923 } // delete the FontDatabase!!! 921 } // delete the FontDatabase!!!
924 connect( m_fontSelector, SIGNAL( activated(const QString& ) ), 922 connect( m_fontSelector, SIGNAL( activated(const QString& ) ),
925 this, SLOT( do_setfont(const QString&) ) ); 923 this, SLOT( do_setfont(const QString&) ) );
926 connect( m_fontSelector, SIGNAL( activated(int ) ), 924 connect( m_fontSelector, SIGNAL( activated(int ) ),
927 this, SLOT( do_setencoding(int) ) ); 925 this, SLOT( do_setencoding(int) ) );
928 926
929 m_fontBar->hide(); 927 m_fontBar->hide();
930 m_fontVisible = false; 928 m_fontVisible = false;
931#ifdef USEMSGS 929#ifdef USEMSGS
932 connect(qApp, SIGNAL( appMessage(const QCString&, const QByteArray& ) ), 930 connect(qApp, SIGNAL( appMessage(const QCString&, const QByteArray& ) ),
933 this, SLOT( msgHandler(const QCString&, const QByteArray&) ) ); 931 this, SLOT( msgHandler(const QCString&, const QByteArray&) ) );
934#endif 932#endif
935// qDebug("Initing"); 933// qDebug("Initing");
936 934
937 m_layout->addWidget(editorStack); 935 m_layout->addWidget(editorStack);
938 if (m_qtscroll != 0) 936 if (m_qtscroll != 0)
939 { 937 {
940 /* 938 /*
941 m_scrollbar = new QToolBar( "Autogen", this, (m_localscrollbar) ? QMainWindow::Left : QMainWindow::Right, TRUE ); 939 m_scrollbar = new QToolBar( "Autogen", this, (m_localscrollbar) ? QMainWindow::Left : QMainWindow::Right, TRUE );
942 940
943 m_scrollbar->setVerticalStretchable( TRUE ); 941 m_scrollbar->setVerticalStretchable( TRUE );
944 */ 942 */
945 scrollbar = m_scrollbar = new QScrollBar(QScrollBar::Vertical, widge); 943 scrollbar = m_scrollbar = new QScrollBar(QScrollBar::Vertical, widge);
946 m_layout->addWidget(scrollbar); 944 m_layout->addWidget(scrollbar);
947 scrollbar->setTracking(false); 945 scrollbar->setTracking(false);
948 //connect(scrollbar, SIGNAL(sliderMoved(int)), this, SLOT(actionscroll(int)) ); 946 //connect(scrollbar, SIGNAL(sliderMoved(int)), this, SLOT(actionscroll(int)) );
949 //m_scrollbar->setStretchableWidget( scrollbar ); 947 //m_scrollbar->setStretchableWidget( scrollbar );
950 if (m_scrollishidden) 948 if (m_scrollishidden)
951 { 949 {
952 m_scrollbar->hide(); 950 m_scrollbar->hide();
953 } 951 }
954 else 952 else
955 { 953 {
956 m_scrollbar->show(); 954 m_scrollbar->show();
957 } 955 }
958 956
959 setrotated(reader->m_rotated); 957 setrotated(reader->m_rotated);
960 } 958 }
961 else 959 else
962 { 960 {
963 m_scrollbar = NULL; 961 m_scrollbar = NULL;
964 } 962 }
965 setBackgroundBitmap(); 963 setBackgroundBitmap();
966 m_inverse_action->setOn(reader->bInverse); 964 m_inverse_action->setOn(reader->bInverse);
967 reader->init(); 965 reader->init();
968 966
969// qDebug("Inited"); 967// qDebug("Inited");
970// m_buttonAction[m_spaceTarget]->setOn(true); 968// m_buttonAction[m_spaceTarget]->setOn(true);
971// qDebug("fonting"); 969// qDebug("fonting");
972 do_setfont(reader->m_fontname); 970 do_setfont(reader->m_fontname);
973 // qDebug("fonted"); 971 // qDebug("fonted");
974 QFont progfont(reader->m_fontname, reader->m_fontControl.getsize(0)); 972 QFont progfont(reader->m_fontname, reader->m_fontControl.getsize(0));
975 m_prog->setFont( progfont ); 973 m_prog->setFont( progfont );
976 if (m_statusishidden) m_prog->hide(); 974 if (m_statusishidden) m_prog->hide();
977 if (!reader->m_lastfile.isEmpty()) 975 if (!reader->m_lastfile.isEmpty())
978 { 976 {
979 //qDebug("doclnk"); 977 //qDebug("doclnk");
980 //doc = new DocLnk(reader->m_lastfile); 978 //doc = new DocLnk(reader->m_lastfile);
981 //qDebug("doclnk done"); 979 //qDebug("doclnk done");
982 if (pOpenlist != NULL) 980 if (pOpenlist != NULL)
983 { 981 {
984 982
985/* 983/*
986 int ind = 0; 984 int ind = 0;
987 Bkmk* p = (*pOpenlist)[ind]; 985 Bkmk* p = (*pOpenlist)[ind];
988 while (p != NULL && toQString(CFiledata(p->anno()).name()) != reader->m_lastfile) 986 while (p != NULL && toQString(CFiledata(p->anno()).name()) != reader->m_lastfile)
989 { 987 {
990 p = (*pOpenlist)[++ind]; 988 p = (*pOpenlist)[++ind];
991 } 989 }
992*/ 990*/
993 Bkmk* p = NULL; 991 Bkmk* p = NULL;
994 for (CList<Bkmk>::iterator iter = pOpenlist->begin(); iter != pOpenlist->end(); iter++) 992 for (CList<Bkmk>::iterator iter = pOpenlist->begin(); iter != pOpenlist->end(); iter++)
995 { 993 {
996 p = iter.pContent(); 994 p = iter.pContent();
997 if (toQString(CFiledata(p->anno()).name()) == reader->m_lastfile) 995 if (toQString(CFiledata(p->anno()).name()) == reader->m_lastfile)
998 { 996 {
999 break; 997 break;
1000 } 998 }
1001 // qDebug("Item:%s", (const char*)toQString(CFiledata(p->anno()).name())); 999 // qDebug("Item:%s", (const char*)toQString(CFiledata(p->anno()).name()));
1002 p = NULL; 1000 p = NULL;
1003 } 1001 }
1004 if (p != NULL) 1002 if (p != NULL)
1005 { 1003 {
1006 if (!openfrombkmk(p)) 1004 if (!openfrombkmk(p))
1007 { 1005 {
1008 showEditTools(); 1006 showEditTools();
1009 } 1007 }
1010 } 1008 }
1011 else 1009 else
1012 { 1010 {
1013 openFile( reader->m_lastfile ); 1011 openFile( reader->m_lastfile );
1014 } 1012 }
1015 } 1013 }
1016 else 1014 else
1017 { 1015 {
1018 if (!reader->m_lastfile.isEmpty()) 1016 if (!reader->m_lastfile.isEmpty())
1019 { 1017 {
1020 openFile( reader->m_lastfile ); 1018 openFile( reader->m_lastfile );
1021 } 1019 }
1022 } 1020 }
1023 } 1021 }
1024 else 1022 else
1025 { 1023 {
1026 showEditTools(); 1024 showEditTools();
1027 } 1025 }
1028// qApp->processEvents(); 1026// qApp->processEvents();
1029 if (m_scrollbar == NULL || m_scrollbar->isHidden()) 1027 if (m_scrollbar == NULL || m_scrollbar->isHidden())
1030 { 1028 {
1031 reader->m_scrollpos = m_localscroll; 1029 reader->m_scrollpos = m_localscroll;
1032 } 1030 }
1033 else 1031 else
1034 { 1032 {
1035 reader->m_scrollpos = (m_qtscroll == 0) ? m_localscroll : 0; 1033 reader->m_scrollpos = (m_qtscroll == 0) ? m_localscroll : 0;
1036 } 1034 }
1037 reader->bDoUpdates = true; 1035 reader->bDoUpdates = true;
1038 reader->update(); 1036 reader->update();
1039 config.setGroup("Version"); 1037 config.setGroup("Version");
1040 int major = config.readNumEntry("Major", 0); 1038 int major = config.readNumEntry("Major", 0);
1041 int bkmktype = config.readNumEntry("BkmkType", 0); 1039 int bkmktype = config.readNumEntry("BkmkType", 0);
1042 char minor = config.readNumEntry("Minor", 0); 1040 char minor = config.readNumEntry("Minor", 0);
1043 if (CheckVersion(major, bkmktype, minor)) 1041 if (CheckVersion(major, bkmktype, minor))
1044 { 1042 {
1045 config.writeEntry("Major", major); 1043 config.writeEntry("Major", major);
1046 config.writeEntry("BkmkType", bkmktype); 1044 config.writeEntry("BkmkType", bkmktype);
1047 config.writeEntry("Minor", (int)minor); 1045 config.writeEntry("Minor", (int)minor);
1048 } 1046 }
1049// qDebug("finished update"); 1047// qDebug("finished update");
1050 if (kmap.isEmpty()) 1048 if (kmap.isEmpty())
1051 { 1049 {
1052 QMessageBox::warning(this, PROGNAME, "You haven't mapped any keys yet!\n\nYou will be taken to the key\nmapping dialog.\nA few defaults are provided\nbut you can change then to\nsuit yourself.\n\nYou can change the key\nmapping at any time by\nselecting the Settings/Button\noption on the menu."); 1050 QMessageBox::warning(this, PROGNAME, "You haven't mapped any keys yet!\n\nYou will be taken to the key\nmapping dialog.\nA few defaults are provided\nbut you can change then to\nsuit yourself.\n\nYou can change the key\nmapping at any time by\nselecting the Settings/Button\noption on the menu.");
1053 1051
1054 m_buttonprefs->mapkey(Qt::NoButton, Key_Up, cesPageUp); 1052 m_buttonprefs->mapkey(Qt::NoButton, Key_Up, cesPageUp);
1055 m_buttonprefs->mapkey(Qt::NoButton, Key_Down, cesPageDown); 1053 m_buttonprefs->mapkey(Qt::NoButton, Key_Down, cesPageDown);
1056 1054
1057 m_buttonprefs->mapkey(Qt::NoButton, Key_Right, cesZoomIn); 1055 m_buttonprefs->mapkey(Qt::NoButton, Key_Right, cesZoomIn);
1058 m_buttonprefs->mapkey(Qt::NoButton, Key_Left, cesZoomOut); 1056 m_buttonprefs->mapkey(Qt::NoButton, Key_Left, cesZoomOut);
1059 1057
1060 showbuttonprefs(); 1058 showbuttonprefs();
1061 } 1059 }
1062} 1060}
1063 1061
1064void QTReaderApp::addtoolbars(Config* config) 1062void QTReaderApp::addtoolbars(Config* config)
1065{ 1063{
1066 config->setGroup("Toolbar"); 1064 config->setGroup("Toolbar");
1067 1065
1068 if (fileBar != NULL) 1066 if (fileBar != NULL)
1069 { 1067 {
1070#ifdef USEQPE 1068#ifdef USEQPE
1071 if (fileBar != menubar) 1069 if (fileBar != menubar)
1072 { 1070 {
1073 fileBar->clear(); 1071 fileBar->clear();
1074 } 1072 }
1075 else 1073 else
1076 { 1074 {
1077 m_preferences_action->removeFrom( filebar() ); 1075 m_preferences_action->removeFrom( filebar() );
1078 m_open_action->removeFrom( filebar() ); 1076 m_open_action->removeFrom( filebar() );
1079 m_close_action->removeFrom( filebar() ); 1077 m_close_action->removeFrom( filebar() );
1080 m_info_action->removeFrom( filebar() ); 1078 m_info_action->removeFrom( filebar() );
1081 m_touch_action->removeFrom( filebar() ); 1079 m_touch_action->removeFrom( filebar() );
1082 m_find_action->removeFrom( filebar() ); 1080 m_find_action->removeFrom( filebar() );
1083 } 1081 }
1084#else 1082#else
1085 fileBar->clear(); 1083 fileBar->clear();
1086#endif 1084#endif
1087 } 1085 }
1088 1086
1089 m_preferences_action->addTo( filebar() ); 1087 m_preferences_action->addTo( filebar() );
1090 addfilebar(config, "Open", m_open_action); 1088 addfilebar(config, "Open", m_open_action);
1091 addfilebar(config, "Close", m_close_action); 1089 addfilebar(config, "Close", m_close_action);
1092 addfilebar(config, "Info", m_info_action); 1090 addfilebar(config, "Info", m_info_action);
1093 addfilebar(config, "Two/One Touch", m_touch_action); 1091 addfilebar(config, "Two/One Touch", m_touch_action);
1094 addfilebar(config, "Find", m_find_action); 1092 addfilebar(config, "Find", m_find_action);
1095 1093
1096 if (navBar != NULL) 1094 if (navBar != NULL)
1097 { 1095 {
1098#ifdef USEQPE 1096#ifdef USEQPE
1099 if ((navBar == fileBar) && (fileBar == menubar)) 1097 if ((navBar == fileBar) && (fileBar == menubar))
1100#else 1098#else
1101 if (navBar == fileBar) 1099 if (navBar == fileBar)
1102#endif 1100#endif
1103 { 1101 {
1104 m_scrollButton->removeFrom( navbar() ); 1102 m_scrollButton->removeFrom( navbar() );
1105 m_start_action->removeFrom( navbar() ); 1103 m_start_action->removeFrom( navbar() );
1106 m_end_action->removeFrom( navbar() ); 1104 m_end_action->removeFrom( navbar() );
1107 m_jump_action->removeFrom( navbar() ); 1105 m_jump_action->removeFrom( navbar() );
1108 m_pageline_action->removeFrom( navbar() ); 1106 m_pageline_action->removeFrom( navbar() );
1109 m_pageup_action->removeFrom( navbar() ); 1107 m_pageup_action->removeFrom( navbar() );
1110 m_pagedn_action->removeFrom( navbar() ); 1108 m_pagedn_action->removeFrom( navbar() );
1111 m_back_action->removeFrom( navbar() ); 1109 m_back_action->removeFrom( navbar() );
1112 m_home_action->removeFrom( navbar() ); 1110 m_home_action->removeFrom( navbar() );
1113 m_forward_action->removeFrom( navbar() ); 1111 m_forward_action->removeFrom( navbar() );
1114 } 1112 }
1115 else if (navBar != fileBar) 1113 else if (navBar != fileBar)
1116 { 1114 {
1117 navBar->clear(); 1115 navBar->clear();
1118 } 1116 }
1119 } 1117 }
1120 1118
1121 addnavbar(config, "Scroll", m_scrollButton); 1119 addnavbar(config, "Scroll", m_scrollButton);
1122 addnavbar(config, "Goto Start", m_start_action); 1120 addnavbar(config, "Goto Start", m_start_action);
1123 addnavbar(config, "Goto End", m_end_action); 1121 addnavbar(config, "Goto End", m_end_action);
1124 1122
1125 addnavbar(config, "Jump", m_jump_action); 1123 addnavbar(config, "Jump", m_jump_action);
1126 addnavbar(config, "Page/Line Scroll", m_pageline_action); 1124 addnavbar(config, "Page/Line Scroll", m_pageline_action);
1127 1125
1128 addnavbar(config, "Page Up", m_pageup_action); 1126 addnavbar(config, "Page Up", m_pageup_action);
1129 addnavbar(config, "Page Down", m_pagedn_action); 1127 addnavbar(config, "Page Down", m_pagedn_action);
1130 1128
1131 addnavbar(config, "Back", m_back_action); 1129 addnavbar(config, "Back", m_back_action);
1132 addnavbar(config, "Home", m_home_action); 1130 addnavbar(config, "Home", m_home_action);
1133 addnavbar(config, "Forward", m_forward_action); 1131 addnavbar(config, "Forward", m_forward_action);
1134 1132
1135 if (viewBar != NULL) 1133 if (viewBar != NULL)
1136 { 1134 {
1137#ifdef USEQPE 1135#ifdef USEQPE
1138 if ((viewBar == fileBar) && (fileBar == menubar)) 1136 if ((viewBar == fileBar) && (fileBar == menubar))
1139#else 1137#else
1140 if (viewBar == fileBar) 1138 if (viewBar == fileBar)
1141#endif 1139#endif
1142 { 1140 {
1143 m_actFullscreen->removeFrom( filebar() ); 1141 m_actFullscreen->removeFrom( filebar() );
1144 m_rotate_action->removeFrom( viewbar() ); 1142 m_rotate_action->removeFrom( viewbar() );
1145 m_inverse_action->removeFrom( viewbar() ); 1143 m_inverse_action->removeFrom( viewbar() );
1146 m_zoomin_action->removeFrom( viewbar() ); 1144 m_zoomin_action->removeFrom( viewbar() );
1147 m_zoomout_action->removeFrom( viewbar() ); 1145 m_zoomout_action->removeFrom( viewbar() );
1148 m_setfont_action->removeFrom( viewbar() ); 1146 m_setfont_action->removeFrom( viewbar() );
1149 m_setenc_action->removeFrom( viewbar() ); 1147 m_setenc_action->removeFrom( viewbar() );
1150 m_setmono_action->removeFrom( viewbar() ); 1148 m_setmono_action->removeFrom( viewbar() );
1151 } 1149 }
1152 else if (viewBar != fileBar) 1150 else if (viewBar != fileBar)
1153 { 1151 {
1154 viewBar->clear(); 1152 viewBar->clear();
1155 } 1153 }
1156 } 1154 }
1157 1155
1158 addviewbar(config, "Fullscreen", m_actFullscreen); 1156 addviewbar(config, "Fullscreen", m_actFullscreen);
1159 addviewbar(config, "Rotate", m_rotate_action); 1157 addviewbar(config, "Rotate", m_rotate_action);
1160 addviewbar(config, "Invert Action", m_inverse_action); 1158 addviewbar(config, "Invert Action", m_inverse_action);
1161 addviewbar(config, "Zoom In", m_zoomin_action); 1159 addviewbar(config, "Zoom In", m_zoomin_action);
1162 addviewbar(config, "Zoom Out", m_zoomout_action); 1160 addviewbar(config, "Zoom Out", m_zoomout_action);
1163 addviewbar(config, "Set Font", m_setfont_action); 1161 addviewbar(config, "Set Font", m_setfont_action);
1164 addviewbar(config, "Encoding Select", m_setenc_action); 1162 addviewbar(config, "Encoding Select", m_setenc_action);
1165 addviewbar(config, "Ideogram Mode", m_setmono_action); 1163 addviewbar(config, "Ideogram Mode", m_setmono_action);
1166 1164
1167 if (markBar != NULL) 1165 if (markBar != NULL)
1168 { 1166 {
1169#ifdef USEQPE 1167#ifdef USEQPE
1170 if ((markBar == fileBar) && (fileBar == menubar)) 1168 if ((markBar == fileBar) && (fileBar == menubar))
1171#else 1169#else
1172 if (markBar == fileBar) 1170 if (markBar == fileBar)
1173#endif 1171#endif
1174 { 1172 {
1175 m_mark_action->removeFrom( markbar() ); 1173 m_mark_action->removeFrom( markbar() );
1176 m_annotate_action->removeFrom( markbar()); 1174 m_annotate_action->removeFrom( markbar());
1177 m_goto_action->removeFrom( markbar() ); 1175 m_goto_action->removeFrom( markbar() );
1178 m_delete_action->removeFrom( markbar() ); 1176 m_delete_action->removeFrom( markbar() );
1179 m_autogen_action->removeFrom( markbar() ); 1177 m_autogen_action->removeFrom( markbar() );
1180 m_clear_action->removeFrom( markbar() ); 1178 m_clear_action->removeFrom( markbar() );
1181 m_save_action->removeFrom( markbar() ); 1179 m_save_action->removeFrom( markbar() );
1182 m_tidy_action->removeFrom( markbar() ); 1180 m_tidy_action->removeFrom( markbar() );
1183 m_startBlock_action->removeFrom( markbar() ); 1181 m_startBlock_action->removeFrom( markbar() );
1184 m_endBlock_action->removeFrom( markbar() ); 1182 m_endBlock_action->removeFrom( markbar() );
1185 } 1183 }
1186 else if (markBar != fileBar) 1184 else if (markBar != fileBar)
1187 { 1185 {
1188 markBar->clear(); 1186 markBar->clear();
1189 } 1187 }
1190 } 1188 }
1191 addmarkbar(config, "Mark", m_mark_action); 1189 addmarkbar(config, "Mark", m_mark_action);
1192 addmarkbar(config, "Annotate", m_annotate_action); 1190 addmarkbar(config, "Annotate", m_annotate_action);
1193 addmarkbar(config, "Goto", m_goto_action); 1191 addmarkbar(config, "Goto", m_goto_action);
1194 addmarkbar(config, "Delete", m_delete_action); 1192 addmarkbar(config, "Delete", m_delete_action);
1195 addmarkbar(config, "Autogen", m_autogen_action); 1193 addmarkbar(config, "Autogen", m_autogen_action);
1196 addmarkbar(config, "Clear", m_clear_action); 1194 addmarkbar(config, "Clear", m_clear_action);
1197 addmarkbar(config, "Save", m_save_action); 1195 addmarkbar(config, "Save", m_save_action);
1198 addmarkbar(config, "Tidy", m_tidy_action); 1196 addmarkbar(config, "Tidy", m_tidy_action);
1199 addmarkbar(config, "Start Block", m_startBlock_action); 1197 addmarkbar(config, "Start Block", m_startBlock_action);
1200 addmarkbar(config, "Copy Block", m_endBlock_action); 1198 addmarkbar(config, "Copy Block", m_endBlock_action);
1201 if (checkbar(config, "Annotation indicator")) 1199 if (checkbar(config, "Annotation indicator"))
1202 { 1200 {
1203 if (m_bkmkAvail == NULL) 1201 if (m_bkmkAvail == NULL)
1204 { 1202 {
1205 m_bkmkAvail = new QAction( tr( "Annotation" ), geticon( "find" ), QString::null, 0, this, 0 ); 1203 m_bkmkAvail = new QAction( tr( "Annotation" ), geticon( "find" ), QString::null, 0, this, 0 );
1206 connect( m_bkmkAvail, SIGNAL( activated() ), this, SLOT( showAnnotation() ) ); 1204 connect( m_bkmkAvail, SIGNAL( activated() ), this, SLOT( showAnnotation() ) );
1207 1205
1208 m_bkmkAvail->setEnabled(false); 1206 m_bkmkAvail->setEnabled(false);
1209 } 1207 }
1210 QLabel *spacer = new QLabel(markBar, ""); 1208 QLabel *spacer = new QLabel(markBar, "");
1211 markbar()->setStretchableWidget(spacer); 1209 markbar()->setStretchableWidget(spacer);
1212 m_bkmkAvail->removeFrom( markbar() ); 1210 m_bkmkAvail->removeFrom( markbar() );
1213 m_bkmkAvail->addTo( markbar() ); 1211 m_bkmkAvail->addTo( markbar() );
1214 } 1212 }
1215 else 1213 else
1216 { 1214 {
1217 if (m_bkmkAvail != NULL) 1215 if (m_bkmkAvail != NULL)
1218 { 1216 {
1219 m_bkmkAvail->removeFrom( markbar() ); 1217 m_bkmkAvail->removeFrom( markbar() );
1220 delete m_bkmkAvail; 1218 delete m_bkmkAvail;
1221 m_bkmkAvail = NULL; 1219 m_bkmkAvail = NULL;
1222 } 1220 }
1223 } 1221 }
1224} 1222}
1225 1223
1226bool QTReaderApp::checkbar(Config* _config, const QString& key) 1224bool QTReaderApp::checkbar(Config* _config, const QString& key)
1227{ 1225{
1228 return _config->readBoolEntry(key, false); 1226 return _config->readBoolEntry(key, false);
1229} 1227}
1230 1228
1231 1229
1232QToolBar* QTReaderApp::filebar() 1230QToolBar* QTReaderApp::filebar()
1233{ 1231{
1234 if (fileBar == NULL) 1232 if (fileBar == NULL)
1235 { 1233 {
1236 switch (m_tbpol) 1234 switch (m_tbpol)
1237 { 1235 {
1238#ifdef USEQPE 1236#ifdef USEQPE
1239 case cesSingle: 1237 case cesSingle:
1240 // qDebug("Setting filebar to menubar"); 1238 // qDebug("Setting filebar to menubar");
1241 fileBar = menubar; 1239 fileBar = menubar;
1242 break; 1240 break;
1243#endif 1241#endif
1244 default: 1242 default:
1245 qDebug("Incorrect toolbar policy set"); 1243 qDebug("Incorrect toolbar policy set");
1246 case cesMenuTool: 1244 case cesMenuTool:
1247 case cesMultiple: 1245 case cesMultiple:
1248 // qDebug("Creating new file bar"); 1246 // qDebug("Creating new file bar");
1249 fileBar = new QToolBar("File", this, m_tbposition); 1247 fileBar = new QToolBar("File", this, m_tbposition);
1250 break; 1248 break;
1251 } 1249 }
1252 //fileBar->setHorizontalStretchable( true ); 1250 //fileBar->setHorizontalStretchable( true );
1253 } 1251 }
1254 return fileBar; 1252 return fileBar;
1255} 1253}
1256QToolBar* QTReaderApp::viewbar() 1254QToolBar* QTReaderApp::viewbar()
1257{ 1255{
1258 if (viewBar == NULL) 1256 if (viewBar == NULL)
1259 { 1257 {
1260 switch (m_tbpol) 1258 switch (m_tbpol)
1261 { 1259 {
1262 case cesMultiple: 1260 case cesMultiple:
1263 viewBar = new QToolBar("View", this, m_tbposition); 1261 viewBar = new QToolBar("View", this, m_tbposition);
1264 break; 1262 break;
1265 default: 1263 default:
1266 qDebug("Incorrect toolbar policy set"); 1264 qDebug("Incorrect toolbar policy set");
1267#ifdef USEQPE 1265#ifdef USEQPE
1268 case cesSingle: 1266 case cesSingle:
1269#endif 1267#endif
1270 case cesMenuTool: 1268 case cesMenuTool:
1271 viewBar = fileBar; 1269 viewBar = fileBar;
1272 break; 1270 break;
1273 } 1271 }
1274 } 1272 }
1275 return viewBar; 1273 return viewBar;
1276} 1274}
1277QToolBar* QTReaderApp::navbar() 1275QToolBar* QTReaderApp::navbar()
1278{ 1276{
1279 if (navBar == NULL) 1277 if (navBar == NULL)
1280 { 1278 {
1281 switch (m_tbpol) 1279 switch (m_tbpol)
1282 { 1280 {
1283 case cesMultiple: 1281 case cesMultiple:
1284 // qDebug("Creating new nav bar"); 1282 // qDebug("Creating new nav bar");
1285 navBar = new QToolBar("Navigation", this, m_tbposition); 1283 navBar = new QToolBar("Navigation", this, m_tbposition);
1286 break; 1284 break;
1287 default: 1285 default:
1288 qDebug("Incorrect toolbar policy set"); 1286 qDebug("Incorrect toolbar policy set");
1289#ifdef USEQPE 1287#ifdef USEQPE
1290 case cesSingle: 1288 case cesSingle:
1291#endif 1289#endif
1292 case cesMenuTool: 1290 case cesMenuTool:
1293 navBar = fileBar; 1291 navBar = fileBar;
1294 // qDebug("Setting navbar to filebar"); 1292 // qDebug("Setting navbar to filebar");
1295 break; 1293 break;
1296 } 1294 }
1297 } 1295 }
1298 return navBar; 1296 return navBar;
1299} 1297}
1300QToolBar* QTReaderApp::markbar() 1298QToolBar* QTReaderApp::markbar()
1301{ 1299{
1302 if (markBar == NULL) 1300 if (markBar == NULL)
1303 { 1301 {
1304 switch (m_tbpol) 1302 switch (m_tbpol)
1305 { 1303 {
1306 case cesMultiple: 1304 case cesMultiple:
1307 markBar = new QToolBar("Marks", this, m_tbposition); 1305 markBar = new QToolBar("Marks", this, m_tbposition);
1308 break; 1306 break;
1309 default: 1307 default:
1310 qDebug("Incorrect toolbar policy set"); 1308 qDebug("Incorrect toolbar policy set");
1311#ifdef USEQPE 1309#ifdef USEQPE
1312 case cesSingle: 1310 case cesSingle:
1313#endif 1311#endif
1314 case cesMenuTool: 1312 case cesMenuTool:
1315 markBar = fileBar; 1313 markBar = fileBar;
1316 break; 1314 break;
1317 } 1315 }
1318 } 1316 }
1319 return markBar; 1317 return markBar;
1320} 1318}
1321 1319
1322void QTReaderApp::addfilebar(Config* _config, const QString& key, QAction* a) 1320void QTReaderApp::addfilebar(Config* _config, const QString& key, QAction* a)
1323{ 1321{
1324 if (_config->readBoolEntry(key, false)) a->addTo( filebar() ); 1322 if (_config->readBoolEntry(key, false)) a->addTo( filebar() );
1325} 1323}
1326void QTReaderApp::addnavbar(Config* _config, const QString& key, QAction* a) 1324void QTReaderApp::addnavbar(Config* _config, const QString& key, QAction* a)
1327{ 1325{
1328 if (_config->readBoolEntry(key, false)) a->addTo( navbar() ); 1326 if (_config->readBoolEntry(key, false)) a->addTo( navbar() );
1329} 1327}
1330void QTReaderApp::addmarkbar(Config* _config, const QString& key, QAction* a) 1328void QTReaderApp::addmarkbar(Config* _config, const QString& key, QAction* a)
1331{ 1329{
1332 if (_config->readBoolEntry(key, false)) a->addTo( markbar() ); 1330 if (_config->readBoolEntry(key, false)) a->addTo( markbar() );
1333} 1331}
1334void QTReaderApp::addviewbar(Config* _config, const QString& key, QAction* a) 1332void QTReaderApp::addviewbar(Config* _config, const QString& key, QAction* a)
1335{ 1333{
1336 if (_config->readBoolEntry(key, false)) a->addTo( viewbar() ); 1334 if (_config->readBoolEntry(key, false)) a->addTo( viewbar() );
1337} 1335}
1338 1336
1339void QTReaderApp::suspend() { reader->suspend(); } 1337void QTReaderApp::suspend() { reader->suspend(); }
1340 1338
1341void QTReaderApp::msgHandler(const QCString& _msg, const QByteArray& _data) 1339void QTReaderApp::msgHandler(const QCString& _msg, const QByteArray& _data)
1342{ 1340{
1343#ifndef USEMSGS 1341#ifndef USEMSGS
1344 return; 1342 return;
1345#else 1343#else
1346 QString msg = QString::fromUtf8(_msg); 1344 QString msg = QString::fromUtf8(_msg);
1347 1345
1348 qDebug("Received:%s", (const char*)msg); 1346 qDebug("Received:%s", (const char*)msg);
1349 QDataStream stream( _data, IO_ReadOnly ); 1347 QDataStream stream( _data, IO_ReadOnly );
1350 if ( msg == "suspend()" ) 1348 if ( msg == "suspend()" )
1351 { 1349 {
1352 qDebug("Suspending"); 1350 qDebug("Suspending");
1353 suspend(); 1351 suspend();
1354 qDebug("Suspendedb"); 1352 qDebug("Suspendedb");
1355 } 1353 }
1356 return; 1354 return;
1357 /* 1355 /*
1358 QDataStream stream( _data, IO_ReadOnly ); 1356 QDataStream stream( _data, IO_ReadOnly );
1359 if ( msg == "info(QString)" ) 1357 if ( msg == "info(QString)" )
1360 { 1358 {
1361 QString info; 1359 QString info;
1362 stream >> info; 1360 stream >> info;
1363 QMessageBox::information(this, PROGNAME, info); 1361 QMessageBox::information(this, PROGNAME, info);
1364 } 1362 }
1365 else if ( msg == "Update(int)" ) 1363 else if ( msg == "Update(int)" )
1366 { 1364 {
1367 int info; 1365 int info;
1368 stream >> info; 1366 stream >> info;
1369 if (info) 1367 if (info)
1370 { 1368 {
1371 reader->bDoUpdates = true; 1369 reader->bDoUpdates = true;
1372 reader->refresh(); 1370 reader->refresh();
1373 } 1371 }
1374 else 1372 else
1375 { 1373 {
1376 reader->bDoUpdates = false; 1374 reader->bDoUpdates = false;
1377 } 1375 }
1378 } 1376 }
1379 else if ( msg == "warn(QString)" ) 1377 else if ( msg == "warn(QString)" )
1380 { 1378 {
1381 QString info; 1379 QString info;
1382 stream >> info; 1380 stream >> info;
1383 QMessageBox::warning(this, PROGNAME, info); 1381 QMessageBox::warning(this, PROGNAME, info);
1384 } 1382 }
1385 else if ( msg == "exit()" ) 1383 else if ( msg == "exit()" )
1386 { 1384 {
1387 m_dontSave = true; 1385 m_dontSave = true;
1388 close(); 1386 close();
1389 } 1387 }
1390 else if ( msg == "pageDown()" ) 1388 else if ( msg == "pageDown()" )
1391 { 1389 {
1392 reader->dopagedn(); 1390 reader->dopagedn();
1393 } 1391 }
1394 else if ( msg == "pageUp()" ) 1392 else if ( msg == "pageUp()" )
1395 { 1393 {
1396 reader->dopageup(); 1394 reader->dopageup();
1397 } 1395 }
1398 else if ( msg == "lineDown()" ) 1396 else if ( msg == "lineDown()" )
1399 { 1397 {
1400 reader->lineDown(); 1398 reader->lineDown();
1401 } 1399 }
1402 else if ( msg == "lineUp()" ) 1400 else if ( msg == "lineUp()" )
1403 { 1401 {
1404 reader->lineUp(); 1402 reader->lineUp();
1405 } 1403 }
1406 else if ( msg == "showText()" ) 1404 else if ( msg == "showText()" )
1407 { 1405 {
1408 showEditTools(); 1406 showEditTools();
1409 } 1407 }
1410 else if ( msg == "home()" ) 1408 else if ( msg == "home()" )
1411 { 1409 {
1412 reader->goHome(); 1410 reader->goHome();
1413 } 1411 }
1414 else if ( msg == "back()" ) 1412 else if ( msg == "back()" )
1415 { 1413 {
1416 reader->goBack(); 1414 reader->goBack();
1417 } 1415 }
1418 else if ( msg == "forward()" ) 1416 else if ( msg == "forward()" )
1419 { 1417 {
1420 reader->goForward(); 1418 reader->goForward();
1421 } 1419 }
1422 else if ( msg == "File/Open(QString)" ) 1420 else if ( msg == "File/Open(QString)" )
1423 { 1421 {
1424 QString info; 1422 QString info;
1425 stream >> info; 1423 stream >> info;
1426 openFile( info ); 1424 openFile( info );
1427 } 1425 }
1428 else if ( msg == "File/Info()" ) 1426 else if ( msg == "File/Info()" )
1429 { 1427 {
1430 showinfo(); 1428 showinfo();
1431 } 1429 }
1432 else if ( msg == "File/Action(QString)" ) 1430 else if ( msg == "File/Action(QString)" )
1433 { 1431 {
1434 QString info; 1432 QString info;
1435 stream >> info; 1433 stream >> info;
1436 m_spaceTarget = ActNameToInt(info); 1434 m_spaceTarget = ActNameToInt(info);
1437 } 1435 }
1438 else if ( msg == "Navigation/Scroll(int)" ) 1436 else if ( msg == "Navigation/Scroll(int)" )
1439 { 1437 {
1440 int info; 1438 int info;
1441 stream >> info; 1439 stream >> info;
1442 autoScroll(info); 1440 autoScroll(info);
1443 } 1441 }
1444 1442
1445 else if ( msg == "Navigation/GotoStart()" ) 1443 else if ( msg == "Navigation/GotoStart()" )
1446 { 1444 {
1447 gotoStart(); 1445 gotoStart();
1448 } 1446 }
1449 else if ( msg == "Navigation/GotoEnd()" ) 1447 else if ( msg == "Navigation/GotoEnd()" )
1450 { 1448 {
1451 gotoEnd(); 1449 gotoEnd();
1452 } 1450 }
1453 else if ( msg == "Navigation/Jump(int)" ) 1451 else if ( msg == "Navigation/Jump(int)" )
1454 { 1452 {
1455 int info; 1453 int info;
1456 stream >> info; 1454 stream >> info;
1457 reader->locate(info); 1455 reader->locate(info);
1458 } 1456 }
1459 else if ( msg == "Navigation/Page/LineScroll(int)" ) 1457 else if ( msg == "Navigation/Page/LineScroll(int)" )
1460 { 1458 {
1461 int info; 1459 int info;
1462 stream >> info; 1460 stream >> info;
1463 pagemode(info); 1461 pagemode(info);
1464 } 1462 }
1465 else if ( msg == "Navigation/SetOverlap(int)" ) 1463 else if ( msg == "Navigation/SetOverlap(int)" )
1466 { 1464 {
1467 int info; 1465 int info;
1468 stream >> info; 1466 stream >> info;
1469 reader->m_overlap = info; 1467 reader->m_overlap = info;
1470 } 1468 }
1471 else if ( msg == "Navigation/SetMargin(int)" ) 1469 else if ( msg == "Navigation/SetMargin(int)" )
1472 { 1470 {
1473 int info; 1471 int info;
1474 stream >> info; 1472 stream >> info;
1475 do_margin(info); 1473 do_margin(info);
1476 } 1474 }
1477 else if ( msg == "File/SetDictionary(QString)" ) 1475 else if ( msg == "File/SetDictionary(QString)" )
1478 { 1476 {
1479 QString info; 1477 QString info;
1480 stream >> info; 1478 stream >> info;
1481 do_settarget(info); 1479 do_settarget(info);
1482 } 1480 }
1483#ifdef _SCROLLPIPE 1481#ifdef _SCROLLPIPE
1484 else if ( msg == "File/SetScrollTarget(QString)" ) 1482 else if ( msg == "File/SetScrollTarget(QString)" )
1485 { 1483 {
1486 QString info; 1484 QString info;
1487 stream >> info; 1485 stream >> info;
1488 reader->m_pipetarget = info; 1486 reader->m_pipetarget = info;
1489 } 1487 }
1490#endif 1488#endif
1491 else if ( msg == "File/Two/OneTouch(int)" ) 1489 else if ( msg == "File/Two/OneTouch(int)" )
1492 { 1490 {
1493 int info; 1491 int info;
1494 stream >> info; 1492 stream >> info;
1495 setTwoTouch(info); 1493 setTwoTouch(info);
1496 } 1494 }
1497 else if ( msg == "Target/Annotation(int)" ) 1495 else if ( msg == "Target/Annotation(int)" )
1498 { 1496 {
1499 int info; 1497 int info;
1500 stream >> info; 1498 stream >> info;
1501 OnAnnotation(info); 1499 OnAnnotation(info);
1502 } 1500 }
1503 else if ( msg == "Target/Dictionary(int)" ) 1501 else if ( msg == "Target/Dictionary(int)" )
1504 { 1502 {
1505 int info; 1503 int info;
1506 stream >> info; 1504 stream >> info;
1507 OnDictionary(info); 1505 OnDictionary(info);
1508 } 1506 }
1509 else if ( msg == "Target/Clipboard(int)" ) 1507 else if ( msg == "Target/Clipboard(int)" )
1510 { 1508 {
1511 int info; 1509 int info;
1512 stream >> info; 1510 stream >> info;
1513 OnClipboard(info); 1511 OnClipboard(info);
1514 } 1512 }
1515 else if ( msg == "File/Find(QString)" ) 1513 else if ( msg == "File/Find(QString)" )
1516 { 1514 {
1517 QString info; 1515 QString info;
1518 stream >> info; 1516 stream >> info;
1519 QRegExp arg(info); 1517 QRegExp arg(info);
1520 size_t pos = reader->pagelocate(); 1518 size_t pos = reader->pagelocate();
1521 size_t start = pos; 1519 size_t start = pos;
1522 CDrawBuffer test(&(reader->m_fontControl)); 1520 CDrawBuffer test(&(reader->m_fontControl));
1523 reader->getline(&test); 1521 reader->getline(&test);
1524 while (arg.match(toQString(test.data())) == -1) 1522 while (arg.match(toQString(test.data())) == -1)
1525 { 1523 {
1526 pos = reader->locate(); 1524 pos = reader->locate();
1527 if (!reader->getline(&test)) 1525 if (!reader->getline(&test))
1528 { 1526 {
1529 QMessageBox::information(this, PROGNAME, QString("Can't find\n")+info); 1527 QMessageBox::information(this, PROGNAME, QString("Can't find\n")+info);
1530 pos = start; 1528 pos = start;
1531 break; 1529 break;
1532 } 1530 }
1533 } 1531 }
1534 reader->locate(pos); 1532 reader->locate(pos);
1535 } 1533 }
1536 else if ( msg == "File/Fullscreen(int)" ) 1534 else if ( msg == "File/Fullscreen(int)" )
1537 { 1535 {
1538 int info; 1536 int info;
1539 stream >> info; 1537 stream >> info;
1540 setfullscreen(info); 1538 setfullscreen(info);
1541 } 1539 }
1542 else if ( msg == "File/Continuous(int)" ) 1540 else if ( msg == "File/Continuous(int)" )
1543 { 1541 {
1544 int info; 1542 int info;
1545 stream >> info; 1543 stream >> info;
1546 setcontinuous(info); 1544 setcontinuous(info);
1547 } 1545 }
1548 else if ( msg == "Markup(QString)" ) 1546 else if ( msg == "Markup(QString)" )
1549 { 1547 {
1550 QString info; 1548 QString info;
1551 stream >> info; 1549 stream >> info;
1552 if (info == "Auto") 1550 if (info == "Auto")
1553 { 1551 {
1554 autofmt(true); 1552 autofmt(true);
1555 } 1553 }
1556 if (info == "None") 1554 if (info == "None")
1557 { 1555 {
1558 autofmt(false); 1556 autofmt(false);
1559 textfmt(false); 1557 textfmt(false);
1560 striphtml(false); 1558 striphtml(false);
1561 peanut(false); 1559 peanut(false);
1562 } 1560 }
1563 if (info == "Text") 1561 if (info == "Text")
1564 { 1562 {
1565 textfmt(true); 1563 textfmt(true);
1566 } 1564 }
1567 if (info == "HTML") 1565 if (info == "HTML")
1568 { 1566 {
1569 striphtml(true); 1567 striphtml(true);
1570 } 1568 }
1571 if (info == "Peanut/PML") 1569 if (info == "Peanut/PML")
1572 { 1570 {
1573 peanut(true); 1571 peanut(true);
1574 } 1572 }
1575 } 1573 }
1576 else if ( msg == "Layout/StripCR(int)" ) 1574 else if ( msg == "Layout/StripCR(int)" )
1577 { 1575 {
1578 int info; 1576 int info;
1579 stream >> info; 1577 stream >> info;
1580 stripcr(info); 1578 stripcr(info);
1581 } 1579 }
1582 else if ( msg == "Layout/Dehyphen(int)" ) 1580 else if ( msg == "Layout/Dehyphen(int)" )
1583 { 1581 {
1584 int info; 1582 int info;
1585 stream >> info; 1583 stream >> info;
1586 dehyphen(info); 1584 dehyphen(info);
1587 } 1585 }
1588 else if ( msg == "Layout/Depluck(int)" ) 1586 else if ( msg == "Layout/Depluck(int)" )
1589 { 1587 {
1590 int info; 1588 int info;
1591 stream >> info; 1589 stream >> info;
1592 depluck(info); 1590 depluck(info);
1593 } 1591 }
1594 else if ( msg == "Layout/Dejpluck(int)" ) 1592 else if ( msg == "Layout/Dejpluck(int)" )
1595 { 1593 {
1596 int info; 1594 int info;
1597 stream >> info; 1595 stream >> info;
1598 dejpluck(info); 1596 dejpluck(info);
1599 } 1597 }
1600 else if ( msg == "Layout/SingleSpace(int)" ) 1598 else if ( msg == "Layout/SingleSpace(int)" )
1601 { 1599 {
1602 int info; 1600 int info;
1603 stream >> info; 1601 stream >> info;
1604 onespace(info); 1602 onespace(info);
1605 } 1603 }
1606 else if ( msg == "Layout/Repalm(int)" ) 1604 else if ( msg == "Layout/Repalm(int)" )
1607 { 1605 {
1608 int info; 1606 int info;
1609 stream >> info; 1607 stream >> info;
1610 repalm(info); 1608 repalm(info);
1611 } 1609 }
1612 else if ( msg == "Layout/Unindent(int)" ) 1610 else if ( msg == "Layout/Unindent(int)" )
1613 { 1611 {
1614 int info; 1612 int info;
1615 stream >> info; 1613 stream >> info;
1616 unindent(info); 1614 unindent(info);
1617 } 1615 }
1618 else if ( msg == "Layout/Re-paragraph(int)" ) 1616 else if ( msg == "Layout/Re-paragraph(int)" )
1619 { 1617 {
1620 int info; 1618 int info;
1621 stream >> info; 1619 stream >> info;
1622 repara(info); 1620 repara(info);
1623 } 1621 }
1624 else if ( msg == "Layout/DoubleSpace(int)" ) 1622 else if ( msg == "Layout/DoubleSpace(int)" )
1625 { 1623 {
1626 int info; 1624 int info;
1627 stream >> info; 1625 stream >> info;
1628 dblspce(info); 1626 dblspce(info);
1629 } 1627 }
1630 else if ( msg == "Layout/Indent(int)" ) 1628 else if ( msg == "Layout/Indent(int)" )
1631 { 1629 {
1632 int info; 1630 int info;
1633 stream >> info; 1631 stream >> info;
1634 reader->bindenter = info; 1632 reader->bindenter = info;
1635 reader->setfilter(reader->getfilter()); 1633 reader->setfilter(reader->getfilter());
1636 } 1634 }
1637 else if ( msg == "Layout/Remap(int)" ) 1635 else if ( msg == "Layout/Remap(int)" )
1638 { 1636 {
1639 int info; 1637 int info;
1640 stream >> info; 1638 stream >> info;
1641 remap(info); 1639 remap(info);
1642 } 1640 }
1643 else if ( msg == "Layout/Embolden(int)" ) 1641 else if ( msg == "Layout/Embolden(int)" )
1644 { 1642 {
1645 int info; 1643 int info;
1646 stream >> info; 1644 stream >> info;
1647 embolden(info); 1645 embolden(info);
1648 } 1646 }
1649 else if ( msg == "Format/Ideogram/Word(int)" ) 1647 else if ( msg == "Format/Ideogram/Word(int)" )
1650 { 1648 {
1651 int info; 1649 int info;
1652 stream >> info; 1650 stream >> info;
1653 monospace(info); 1651 monospace(info);
1654 } 1652 }
1655 else if ( msg == "Format/SetWidth(int)" ) 1653 else if ( msg == "Format/SetWidth(int)" )
1656 { 1654 {
1657 int info; 1655 int info;
1658 stream >> info; 1656 stream >> info;
1659 reader->m_charpc = info; 1657 reader->m_charpc = info;
1660 reader->setfont(); 1658 reader->setfont();
1661 reader->refresh(); 1659 reader->refresh();
1662 } 1660 }
1663 else if ( msg == "Format/SetFont(QString,int)" ) 1661 else if ( msg == "Format/SetFont(QString,int)" )
1664 { 1662 {
1665 QString fontname; 1663 QString fontname;
1666 int size; 1664 int size;
1667 stream >> fontname; 1665 stream >> fontname;
1668 stream >> size; 1666 stream >> size;
1669 setfontHelper(fontname, size); 1667 setfontHelper(fontname, size);
1670 } 1668 }
1671 else if ( msg == "Marks/Autogen(QString)" ) 1669 else if ( msg == "Marks/Autogen(QString)" )
1672 { 1670 {
1673 QString info; 1671 QString info;
1674 stream >> info; 1672 stream >> info;
1675 do_autogen(info); 1673 do_autogen(info);
1676 } 1674 }
1677 else if ( msg == "File/StartBlock()" ) 1675 else if ( msg == "File/StartBlock()" )
1678 { 1676 {
1679 editMark(); 1677 editMark();
1680 } 1678 }
1681 else if ( msg == "File/CopyBlock()" ) 1679 else if ( msg == "File/CopyBlock()" )
1682 { 1680 {
1683 editCopy(); 1681 editCopy();
1684 } 1682 }
1685 */ 1683 */
1686#endif 1684#endif
1687} 1685}
1688 1686
1689ActionTypes QTReaderApp::ActNameToInt(const QString& _enc) 1687ActionTypes QTReaderApp::ActNameToInt(const QString& _enc)
1690{ 1688{
1691 for (int i = 0; i < MAX_ACTIONS; i++) 1689 for (int i = 0; i < MAX_ACTIONS; i++)
1692 { 1690 {
1693 if (m_buttonAction[i]->text() == _enc) return (ActionTypes)i; 1691 if (m_buttonAction[i]->text() == _enc) return (ActionTypes)i;
1694 } 1692 }
1695 return cesAutoScroll; 1693 return cesAutoScroll;
1696} 1694}
1697 1695
1698void QTReaderApp::setinverted(bool sfs) 1696void QTReaderApp::setinverted(bool sfs)
1699{ 1697{
1700 reader->setInverse(sfs); 1698 reader->setInverse(sfs);
1701 reader->setfilter(reader->getfilter()); 1699 reader->setfilter(reader->getfilter());
1702 reader->refresh(); 1700 reader->refresh();
1703} 1701}
1704 1702
1705void QTReaderApp::setrotated(bool sfs) 1703void QTReaderApp::setrotated(bool sfs)
1706{ 1704{
1707 reader->setrotated(sfs); 1705 reader->setrotated(sfs);
1708 if (sfs) 1706 if (sfs)
1709 { 1707 {
1710 m_layout->setDirection( (m_qtscroll == 2) ? QBoxLayout::BottomToTop : QBoxLayout::TopToBottom ); 1708 m_layout->setDirection( (m_qtscroll == 2) ? QBoxLayout::BottomToTop : QBoxLayout::TopToBottom );
1711 if (m_scrollbar != NULL) 1709 if (m_scrollbar != NULL)
1712 { 1710 {
1713 scrollbar->disconnect(); 1711 scrollbar->disconnect();
1714 m_scrollbar->setOrientation(Qt::Horizontal); 1712 m_scrollbar->setOrientation(Qt::Horizontal);
1715 connect(scrollbar, SIGNAL(nextLine()), reader, SLOT(lineUp()) ); 1713 connect(scrollbar, SIGNAL(nextLine()), reader, SLOT(lineUp()) );
1716 connect(scrollbar, SIGNAL(prevLine()), reader, SLOT(lineDown()) ); 1714 connect(scrollbar, SIGNAL(prevLine()), reader, SLOT(lineDown()) );
1717 connect(scrollbar, SIGNAL(nextPage()), reader, SLOT(dopageup()) ); 1715 connect(scrollbar, SIGNAL(nextPage()), reader, SLOT(dopageup()) );
1718 connect(scrollbar, SIGNAL(prevPage()), reader, SLOT(dopagedn()) ); 1716 connect(scrollbar, SIGNAL(prevPage()), reader, SLOT(dopagedn()) );
1719 connect(scrollbar, SIGNAL(sliderMoved(int)), this, SLOT(actionscroll(int)) ); 1717 connect(scrollbar, SIGNAL(sliderMoved(int)), this, SLOT(actionscroll(int)) );
1720 } 1718 }
1721 //reader->repaint(0, reader->m_left_border, reader->width(), reader->height()-2*reader->m_border); 1719 //reader->repaint(0, reader->m_left_border, reader->width(), reader->height()-2*reader->m_border);
1722 reader->repaint(); 1720 reader->repaint();
1723 } 1721 }
1724 else 1722 else
1725 { 1723 {
1726 m_layout->setDirection( (m_qtscroll == 2) ? QBoxLayout::RightToLeft : QBoxLayout::LeftToRight ); 1724 m_layout->setDirection( (m_qtscroll == 2) ? QBoxLayout::RightToLeft : QBoxLayout::LeftToRight );
1727 if (m_scrollbar != NULL) 1725 if (m_scrollbar != NULL)
1728 { 1726 {
1729 scrollbar->disconnect(); 1727 scrollbar->disconnect();
1730 m_scrollbar->setOrientation(Qt::Vertical); 1728 m_scrollbar->setOrientation(Qt::Vertical);
1731 connect(scrollbar, SIGNAL(nextLine()), reader, SLOT(lineDown()) ); 1729 connect(scrollbar, SIGNAL(nextLine()), reader, SLOT(lineDown()) );
1732 connect(scrollbar, SIGNAL(prevLine()), reader, SLOT(lineUp()) ); 1730 connect(scrollbar, SIGNAL(prevLine()), reader, SLOT(lineUp()) );
1733 connect(scrollbar, SIGNAL(nextPage()), reader, SLOT(dopagedn()) ); 1731 connect(scrollbar, SIGNAL(nextPage()), reader, SLOT(dopagedn()) );
1734 connect(scrollbar, SIGNAL(prevPage()), reader, SLOT(dopageup()) ); 1732 connect(scrollbar, SIGNAL(prevPage()), reader, SLOT(dopageup()) );
1735 connect(scrollbar, SIGNAL(sliderMoved(int)), this, SLOT(actionscroll(int)) ); 1733 connect(scrollbar, SIGNAL(sliderMoved(int)), this, SLOT(actionscroll(int)) );
1736 } 1734 }
1737 //reader->repaint(reader->m_border, 0, reader->width()-2*reader->m_border, reader->height()); 1735 //reader->repaint(reader->m_border, 0, reader->width()-2*reader->m_border, reader->height());
1738 reader->repaint(); 1736 reader->repaint();
1739 } 1737 }
1740 // reader->update(); 1738 // reader->update();
1741} 1739}
1742 1740
1743void QTReaderApp::setgrab(bool sfs) 1741void QTReaderApp::setgrab(bool sfs)
1744{ 1742{
1745#ifdef USEQPE 1743#ifdef USEQPE
1746 m_grabkeyboard = sfs; 1744 m_grabkeyboard = sfs;
1747 if (m_grabkeyboard) 1745 if (m_grabkeyboard)
1748 { 1746 {
1749 ((QPEApplication*)qApp)->grabKeyboard(); 1747 ((QPEApplication*)qApp)->grabKeyboard();
1750 } 1748 }
1751 else 1749 else
1752 { 1750 {
1753 ((QPEApplication*)qApp)->ungrabKeyboard(); 1751 ((QPEApplication*)qApp)->ungrabKeyboard();
1754 } 1752 }
1755#endif 1753#endif
1756} 1754}
1757 1755
1758void QTReaderApp::setfullscreen(bool sfs) 1756void QTReaderApp::setfullscreen(bool sfs)
1759{ 1757{
1760 reader->bDoUpdates = false; 1758 reader->bDoUpdates = false;
1761 m_fullscreen = sfs; 1759 m_fullscreen = sfs;
1762 showEditTools(); 1760 showEditTools();
1763// qApp->processEvents(); 1761// qApp->processEvents();
1764 reader->bDoUpdates = true; 1762 reader->bDoUpdates = true;
1765 reader->update(); 1763 reader->update();
1766} 1764}
1767/* 1765/*
1768void QTReaderApp::buttonActionSelected(QAction* _a) 1766void QTReaderApp::buttonActionSelected(QAction* _a)
1769{ 1767{
1770//// qDebug("es:%x : %s (%u)", _a, (const char *)(_a->text()), ActNameToInt(_a->text())); 1768//// qDebug("es:%x : %s (%u)", _a, (const char *)(_a->text()), ActNameToInt(_a->text()));
1771 m_spaceTarget = ActNameToInt(_a->text()); 1769 m_spaceTarget = ActNameToInt(_a->text());
1772} 1770}
1773*/ 1771*/
1774QTReaderApp::~QTReaderApp() 1772QTReaderApp::~QTReaderApp()
1775{ 1773{
1776} 1774}
1777 1775
1778void QTReaderApp::autoScroll(bool _b) 1776void QTReaderApp::autoScroll(bool _b)
1779{ 1777{
1780 reader->setautoscroll(_b); 1778 reader->setautoscroll(_b);
1781 setScrollState(reader->m_autoScroll); 1779 setScrollState(reader->m_autoScroll);
1782} 1780}
1783 1781
1784void QTReaderApp::zoomin() 1782void QTReaderApp::zoomin()
1785{ 1783{
1786 reader->zoomin(); 1784 reader->zoomin();
1787 QFont f(reader->m_fontname, reader->m_fontControl.getsize(0)); 1785 QFont f(reader->m_fontname, reader->m_fontControl.getsize(0));
1788 m_prog->setFont( f ); 1786 m_prog->setFont( f );
1789} 1787}
1790 1788
1791void QTReaderApp::zoomout() 1789void QTReaderApp::zoomout()
1792{ 1790{
1793 reader->zoomout(); 1791 reader->zoomout();
1794 QFont f(reader->m_fontname, reader->m_fontControl.getsize(0)); 1792 QFont f(reader->m_fontname, reader->m_fontControl.getsize(0));
1795 m_prog->setFont( f ); 1793 m_prog->setFont( f );
1796} 1794}
1797 1795
1798void QTReaderApp::clearBkmkList() 1796void QTReaderApp::clearBkmkList()
1799{ 1797{
1800 delete pBkmklist; 1798 delete pBkmklist;
1801 reader->pBkmklist = pBkmklist = NULL; 1799 reader->pBkmklist = pBkmklist = NULL;
1802 m_fBkmksChanged = false; 1800 m_fBkmksChanged = false;
1803 reader->refresh(true); 1801 reader->refresh(true);
1804} 1802}
1805 1803
1806void QTReaderApp::fileClose() 1804void QTReaderApp::fileClose()
1807{ 1805{
1808 CCloseDialog* cd = new CCloseDialog(reader->m_string, false, this); 1806 CCloseDialog* cd = new CCloseDialog(reader->m_string, false, this);
1809 if (cd->exec()) 1807 if (cd->exec())
1810 { 1808 {
1811 if (pOpenlist != NULL) 1809 if (pOpenlist != NULL)
1812 { 1810 {
1813 int ind = 0; 1811 int ind = 0;
1814 Bkmk* p = (*pOpenlist)[ind]; 1812 Bkmk* p = (*pOpenlist)[ind];
1815 while (p != NULL && toQString(CFiledata(p->anno()).name()) != reader->m_lastfile) 1813 while (p != NULL && toQString(CFiledata(p->anno()).name()) != reader->m_lastfile)
1816 { 1814 {
1817 p = (*pOpenlist)[++ind]; 1815 p = (*pOpenlist)[++ind];
1818 } 1816 }
1819 if (p != NULL) pOpenlist->erase(ind); 1817 if (p != NULL) pOpenlist->erase(ind);
1820 if (cd->delFile()) 1818 if (cd->delFile())
1821 { 1819 {
1822 unlink((const char*)reader->m_lastfile); 1820 unlink((const char*)reader->m_lastfile);
1823 } 1821 }
1824 if (cd->delMarks()) 1822 if (cd->delMarks())
1825 { 1823 {
1826#ifndef USEQPE 1824#ifndef USEQPE
1827 QDir d = QDir::home(); // "/" 1825 QDir d = QDir::home(); // "/"
1828 d.cd(APPDIR); 1826 d.cd(APPDIR);
1829 d.remove(reader->m_string); 1827 d.remove(reader->m_string);
1830#else /* USEQPE */ 1828#else /* USEQPE */
1831 unlink((const char *)Global::applicationFileName(APPDIR,reader->m_string)); 1829 unlink((const char *)Global::applicationFileName(APPDIR,reader->m_string));
1832#endif /* USEQPE */ 1830#endif /* USEQPE */
1833 } 1831 }
1834 if (cd->delConfig()) 1832 if (cd->delConfig())
1835 { 1833 {
1836#ifndef USEQPE 1834#ifndef USEQPE
1837 QDir d = QDir::home(); // "/" 1835 QDir d = QDir::home(); // "/"
1838 d.cd(APPDIR "/configs"); 1836 d.cd(APPDIR "/configs");
1839 d.remove(reader->m_string); 1837 d.remove(reader->m_string);
1840#else /* USEQPE */ 1838#else /* USEQPE */
1841 unlink((const char *)Global::applicationFileName(APPDIR "/configs",reader->m_string)); 1839 unlink((const char *)Global::applicationFileName(APPDIR "/configs",reader->m_string));
1842#endif /* USEQPE */ 1840#endif /* USEQPE */
1843 } 1841 }
1844 } 1842 }
1845 1843
1846 fileOpen2(); 1844 fileOpen2();
1847 } 1845 }
1848 delete cd; 1846 delete cd;
1849} 1847}
1850 1848
1851void QTReaderApp::updatefileinfo() 1849void QTReaderApp::updatefileinfo()
1852{ 1850{
1853 if (reader->m_string.isEmpty()) return; 1851 if (reader->m_string.isEmpty()) return;
1854 if (reader->m_lastfile.isEmpty()) return; 1852 if (reader->m_lastfile.isEmpty()) return;
1855 tchar* nm = fromQString(reader->m_string); 1853 tchar* nm = fromQString(reader->m_string);
1856 tchar* fl = fromQString(reader->m_lastfile); 1854 tchar* fl = fromQString(reader->m_lastfile);
1857// qDebug("Lastfile:%x", fl); 1855// qDebug("Lastfile:%x", fl);
1858 bool notadded = true; 1856 bool notadded = true;
1859 if (pOpenlist == NULL) pOpenlist = new CList<Bkmk>; 1857 if (pOpenlist == NULL) pOpenlist = new CList<Bkmk>;
1860 else 1858 else
1861 { 1859 {
1862 for (CList<Bkmk>::iterator iter = pOpenlist->begin(); iter != pOpenlist->end(); iter++) 1860 for (CList<Bkmk>::iterator iter = pOpenlist->begin(); iter != pOpenlist->end(); iter++)
1863 { 1861 {
1864 if (ustrcmp(CFiledata(iter->anno()).name(), fl) == 0) 1862 if (ustrcmp(CFiledata(iter->anno()).name(), fl) == 0)
1865 { 1863 {
1866 iter->value(reader->pagelocate()); 1864 iter->value(reader->pagelocate());
1867 unsigned short dlen; 1865 unsigned short dlen;
1868 unsigned char* data; 1866 unsigned char* data;
1869 CFiledata fd(iter->anno()); 1867 CFiledata fd(iter->anno());
1870 reader->setSaveData(data, dlen, fd.content(), fd.length()); 1868 reader->setSaveData(data, dlen, fd.content(), fd.length());
1871 // qDebug("Filedata(1):%u, %u", fd.length(), dlen); 1869 // qDebug("Filedata(1):%u, %u", fd.length(), dlen);
1872 // getstate(data, dlen); 1870 // getstate(data, dlen);
1873 iter->setAnno(data, dlen); 1871 iter->setAnno(data, dlen);
1874 notadded = false; 1872 notadded = false;
1875 delete [] data; 1873 delete [] data;
1876 break; 1874 break;
1877 } 1875 }
1878 } 1876 }
1879 } 1877 }
1880// qDebug("Added?:%x", notadded); 1878// qDebug("Added?:%x", notadded);
1881 if (notadded) 1879 if (notadded)
1882 { 1880 {
1883 struct stat fnstat; 1881 struct stat fnstat;
1884 stat((const char *)reader->m_lastfile, &fnstat); 1882 stat((const char *)reader->m_lastfile, &fnstat);
1885 CFiledata fd(fnstat.st_mtime, fl); 1883 CFiledata fd(fnstat.st_mtime, fl);
1886 unsigned short dlen; 1884 unsigned short dlen;
1887 unsigned char* data; 1885 unsigned char* data;
1888 reader->setSaveData(data, dlen, fd.content(), fd.length()); 1886 reader->setSaveData(data, dlen, fd.content(), fd.length());
1889 pOpenlist->push_front(Bkmk(nm, data, dlen, reader->pagelocate())); 1887 pOpenlist->push_front(Bkmk(nm, data, dlen, reader->pagelocate()));
1890 //qDebug("Filedata(2):%u, %u", fd.length(), dlen); 1888 //qDebug("Filedata(2):%u, %u", fd.length(), dlen);
1891 delete [] data; 1889 delete [] data;
1892 } 1890 }
1893 delete [] nm; 1891 delete [] nm;
1894 delete [] fl; 1892 delete [] fl;
1895} 1893}
1896 1894
1897void QTReaderApp::fileOpen() 1895void QTReaderApp::fileOpen()
1898{ 1896{
1899/* 1897/*
1900 menu->hide(); 1898 menu->hide();
1901 fileBar->hide(); 1899 fileBar->hide();
1902 if (regVisible) regBar->hide(); 1900 if (regVisible) regBar->hide();
1903 if (searchVisible) searchBar->hide(); 1901 if (searchVisible) searchBar->hide();
1904*/ 1902*/
1905// qDebug("fileOpen"); 1903// qDebug("fileOpen");
1906// if (!reader->m_lastfile.isEmpty()) 1904// if (!reader->m_lastfile.isEmpty())
1907 updatefileinfo(); 1905 updatefileinfo();
1908 fileOpen2(); 1906 fileOpen2();
1909} 1907}
1910 1908
1911void QTReaderApp::fileOpen2() 1909void QTReaderApp::fileOpen2()
1912{ 1910{
1913 if (pBkmklist != NULL) 1911 if (pBkmklist != NULL)
1914 { 1912 {
1915 if (m_fBkmksChanged) 1913 if (m_fBkmksChanged)
1916 { 1914 {
1917 if (QMessageBox::warning(this, PROGNAME, "Save bookmarks?", "Save", "Don't bother") == 0) 1915 if (QMessageBox::warning(this, PROGNAME, "Save bookmarks?", "Save", "Don't bother") == 0)
1918 savebkmks(); 1916 savebkmks();
1919 } 1917 }
1920 delete pBkmklist; 1918 delete pBkmklist;
1921 reader->pBkmklist = pBkmklist = NULL; 1919 reader->pBkmklist = pBkmklist = NULL;
1922 m_fBkmksChanged = false; 1920 m_fBkmksChanged = false;
1923 } 1921 }
1924 reader->disableAutoscroll(); 1922 reader->disableAutoscroll();
1925/* 1923/*
1926 editorStack->raiseWidget( fileSelector ); 1924 editorStack->raiseWidget( fileSelector );
1927 fileSelector->reread(); 1925 fileSelector->reread();
1928*/ 1926*/
1929 bool usebrowser = true; 1927 bool usebrowser = true;
1930 if (pOpenlist != NULL) 1928 if (pOpenlist != NULL)
1931 { 1929 {
1932 m_nBkmkAction = cOpenFile; 1930 m_nBkmkAction = cOpenFile;
1933 if (listbkmk(pOpenlist, "Browse")) usebrowser = false; 1931 if (listbkmk(pOpenlist, "Browse")) usebrowser = false;
1934 } 1932 }
1935 if (usebrowser) 1933 if (usebrowser)
1936 { 1934 {
1937 QString fn = usefilebrowser(); 1935 QString fn = usefilebrowser();
1938 //qApp->processEvents(); 1936 //qApp->processEvents();
1939 if (!fn.isEmpty() && QFileInfo(fn).isFile()) 1937 if (!fn.isEmpty() && QFileInfo(fn).isFile())
1940 { 1938 {
1941 openFile(fn); 1939 openFile(fn);
1942 } 1940 }
1943 reader->setFocus(); 1941 reader->setFocus();
1944 } 1942 }
1945// reader->refresh(); 1943// reader->refresh();
1946// qDebug("HEIGHT:%d", reader->m_lastheight); 1944// qDebug("HEIGHT:%d", reader->m_lastheight);
1947} 1945}
1948 1946
1949QString QTReaderApp::usefilebrowser() 1947QString QTReaderApp::usefilebrowser()
1950{ 1948{
1951#ifndef USEQPE 1949#ifndef USEQPE
1952 QString s( QFileDialog::getOpenFileName( reader->m_lastfile, QString::null, this ) ); 1950 QString s( QFileDialog::getOpenFileName( reader->m_lastfile, QString::null, this ) );
1953 return s; 1951 return s;
1954#else 1952#else
1955 QString fn; 1953 QString fn;
1956#ifdef OPIE 1954#ifdef OPIE
1957 QMap<QString, QStringList> mimeTypes; 1955 QMap<QString, QStringList> mimeTypes;
1958 QStringList etypes; 1956 QStringList etypes;
1959 etypes << "etext/*"; 1957 etypes << "etext/*";
1960 mimeTypes.insert( tr("eText"), etypes ); 1958 mimeTypes.insert( tr("eText"), etypes );
1961 QStringList types; 1959 QStringList types;
1962 types << "text/*"; 1960 types << "text/*";
1963 mimeTypes.insert( tr("Text"), types ); 1961 mimeTypes.insert( tr("Text"), types );
1964 mimeTypes.insert( tr("All"), "*/*" ); 1962 mimeTypes.insert( tr("All"), "*/*" );
1965 fn = OFileDialog::getOpenFileName(OFileSelector::EXTENDED_ALL, QFileInfo(reader->m_lastfile).dirPath(true), QString::null, mimeTypes, 0, "OpieReader"); 1963 fn = OFileDialog::getOpenFileName(OFileSelector::EXTENDED_ALL, QFileInfo(reader->m_lastfile).dirPath(true), QString::null, mimeTypes, 0, "OpieReader");
1966#else 1964#else
1967 fileBrowser* fb = new fileBrowser(false, this,"OpieReader",!m_bFloatingDialog, 1965 fileBrowser* fb = new fileBrowser(false, this,"OpieReader",!m_bFloatingDialog,
1968 0, 1966 0,
1969 // WStyle_Customize | WStyle_NoBorderEx, 1967 // WStyle_Customize | WStyle_NoBorderEx,
1970 "*", QFileInfo(reader->m_lastfile).dirPath(true)); 1968 "*", QFileInfo(reader->m_lastfile).dirPath(true));
1971 1969
1972 1970
1973 if (fb->exec()) 1971 if (fb->exec())
1974 { 1972 {
1975 fn = fb->getCurrentFile(); 1973 fn = fb->getCurrentFile();
1976 } 1974 }
1977// qDebug("Selected %s", (const char*)fn); 1975// qDebug("Selected %s", (const char*)fn);
1978 delete fb; 1976 delete fb;
1979#endif 1977#endif
1980 showEditTools(); 1978 showEditTools();
1981 return fn; 1979 return fn;
1982#endif 1980#endif
1983} 1981}
1984 1982
1985void QTReaderApp::showgraphic(QImage& pm) 1983void QTReaderApp::showgraphic(QImage& pm)
1986{ 1984{
1987 m_graphicwin->setImage(pm); 1985 m_graphicwin->setImage(pm);
1988 editorStack->raiseWidget( m_graphicwin ); 1986 editorStack->raiseWidget( m_graphicwin );
1989 hidetoolbars(); 1987 hidetoolbars();
1990 m_graphicwin->setFocus(); 1988 m_graphicwin->setFocus();
1991} 1989}
1992 1990
1993void QTReaderApp::showbuttonprefs() 1991void QTReaderApp::showbuttonprefs()
1994{ 1992{
1995 editorStack->raiseWidget( m_buttonprefs ); 1993 editorStack->raiseWidget( m_buttonprefs );
1996 hidetoolbars(); 1994 hidetoolbars();
1997 m_buttonprefs->setFocus(); 1995 m_buttonprefs->setFocus();
1998 m_kmapchanged = true; 1996 m_kmapchanged = true;
1999} 1997}
2000 1998
2001void QTReaderApp::showprefs() 1999void QTReaderApp::showprefs()
2002{ 2000{
2003 CPrefs* prefwin = new CPrefs(reader->width(), !m_bFloatingDialog, this); 2001 CPrefs* prefwin = new CPrefs(reader->width(), !m_bFloatingDialog, this);
2004 2002
2005 // prefwin->Debounce(m_debounce); 2003 // prefwin->Debounce(m_debounce);
2006 prefwin->bgtype(m_bgtype); 2004 prefwin->bgtype(m_bgtype);
2007 prefwin->repalm(reader->brepalm); 2005 prefwin->repalm(reader->brepalm);
2008 prefwin->kern(reader->bkern); 2006 prefwin->kern(reader->bkern);
2009 prefwin->hyphenate(reader->hyphenate); 2007 prefwin->hyphenate(reader->hyphenate);
2010 // prefwin->customhyphen(reader->buffdoc.getCustomHyphen()); 2008 // prefwin->customhyphen(reader->buffdoc.getCustomHyphen());
2011 prefwin->scrolltype(reader->m_scrolltype); 2009 prefwin->scrolltype(reader->m_scrolltype);
2012 prefwin->scrollstep(reader->m_scrollstep); 2010 prefwin->scrollstep(reader->m_scrollstep);
2013 prefwin->scrollcolor(m_scrollcolor); 2011 prefwin->scrollcolor(m_scrollcolor);
2014 prefwin->minibarcol(m_scrollbarcolor); 2012 prefwin->minibarcol(m_scrollbarcolor);
2015 prefwin->foreground(m_foreground); 2013 prefwin->foreground(m_foreground);
2016 prefwin->background(m_background); 2014 prefwin->background(m_background);
2017 prefwin->twotouch(m_twoTouch); 2015 prefwin->twotouch(m_twoTouch);
2018 prefwin->propfontchange(m_propogatefontchange); 2016 prefwin->propfontchange(m_propogatefontchange);
2019 prefwin->StripCR(reader->bstripcr); 2017 prefwin->StripCR(reader->bstripcr);
2020 prefwin->Dehyphen(reader->bdehyphen); 2018 prefwin->Dehyphen(reader->bdehyphen);
2021 prefwin->SingleSpace(reader->bonespace); 2019 prefwin->SingleSpace(reader->bonespace);
2022 prefwin->Unindent(reader->bunindent); 2020 prefwin->Unindent(reader->bunindent);
2023 prefwin->Reparagraph(reader->brepara); 2021 prefwin->Reparagraph(reader->brepara);
2024 prefwin->DoubleSpace(reader->bdblspce); 2022 prefwin->DoubleSpace(reader->bdblspce);
2025 prefwin->Remap(reader->bremap); 2023 prefwin->Remap(reader->bremap);
2026 prefwin->Embolden(reader->bmakebold); 2024 prefwin->Embolden(reader->bmakebold);
2027 prefwin->FullJustify(reader->bfulljust); 2025 prefwin->FullJustify(reader->bfulljust);
2028 // prefwin->Inverse(reader->bInverse); 2026 // prefwin->Inverse(reader->bInverse);
2029 // prefwin->Negative(reader->bNegative); 2027 // prefwin->Negative(reader->bNegative);
2030 prefwin->FixGraphics(reader->m_fontControl.FixGraphics()); 2028 prefwin->FixGraphics(reader->m_fontControl.FixGraphics());
2031 prefwin->ParaLead(reader->getextraspace()); 2029 prefwin->ParaLead(reader->getextraspace());
2032 prefwin->LineLead(reader->getlead()); 2030 prefwin->LineLead(reader->getlead());
2033 prefwin->TopMargin(reader->m_abstopmargin); 2031 prefwin->TopMargin(reader->m_abstopmargin);
2034 prefwin->BottomMargin(reader->m_absbottommargin); 2032 prefwin->BottomMargin(reader->m_absbottommargin);
2035 prefwin->LeftMargin(reader->m_absleft_border); 2033 prefwin->LeftMargin(reader->m_absleft_border);
2036 prefwin->RightMargin(reader->m_absright_border); 2034 prefwin->RightMargin(reader->m_absright_border);
2037 prefwin->Indent(reader->bindenter); 2035 prefwin->Indent(reader->bindenter);
2038 if (reader->bautofmt) 2036 if (reader->bautofmt)
2039 { 2037 {
2040 prefwin->Markup(0); 2038 prefwin->Markup(0);
2041 } 2039 }
2042 else if (reader->btextfmt) 2040 else if (reader->btextfmt)
2043 { 2041 {
2044 prefwin->Markup(2); 2042 prefwin->Markup(2);
2045 } 2043 }
2046 else if (reader->bstriphtml) 2044 else if (reader->bstriphtml)
2047 { 2045 {
2048 prefwin->Markup(3); 2046 prefwin->Markup(3);
2049 } 2047 }
2050 else if (reader->bpeanut) 2048 else if (reader->bpeanut)
2051 { 2049 {
2052 prefwin->Markup(4); 2050 prefwin->Markup(4);
2053 } 2051 }
2054 else 2052 else
2055 { 2053 {
2056 prefwin->Markup(1); 2054 prefwin->Markup(1);
2057 } 2055 }
2058 prefwin->Depluck(reader->bdepluck); 2056 prefwin->Depluck(reader->bdepluck);
2059 prefwin->Dejpluck(reader->bdejpluck); 2057 prefwin->Dejpluck(reader->bdejpluck);
2060 prefwin->Continuous(reader->m_continuousDocument); 2058 prefwin->Continuous(reader->m_continuousDocument);
2061 2059
2062 prefwin->dictApplication(m_targetapp); 2060 prefwin->dictApplication(m_targetapp);
2063 prefwin->dictMessage(m_targetmsg); 2061 prefwin->dictMessage(m_targetmsg);
2064 2062
2065 /* 2063 /*
2066 prefwin->leftScroll(m_leftScroll); 2064 prefwin->leftScroll(m_leftScroll);
2067 prefwin->rightScroll(m_rightScroll); 2065 prefwin->rightScroll(m_rightScroll);
2068 prefwin->upScroll(m_upScroll); 2066 prefwin->upScroll(m_upScroll);
2069 prefwin->downScroll(m_downScroll); 2067 prefwin->downScroll(m_downScroll);
2070 */ 2068 */
2071 2069
2072 prefwin->miscannotation(m_doAnnotation); 2070 prefwin->miscannotation(m_doAnnotation);
2073 prefwin->miscdictionary(m_doDictionary); 2071 prefwin->miscdictionary(m_doDictionary);
2074 prefwin->miscclipboard(m_doClipboard); 2072 prefwin->miscclipboard(m_doClipboard);
2075 2073
2076 prefwin->SwapMouse(reader->m_swapmouse); 2074 prefwin->SwapMouse(reader->m_swapmouse);
2077 2075
2078 prefwin->Font(reader->m_fontname); 2076 prefwin->Font(reader->m_fontname);
2079 2077
2080 prefwin->gfxsize(reader->getBaseSize()); 2078 prefwin->gfxsize(reader->getBaseSize());
2081 2079
2082 prefwin->pageoverlap(reader->m_overlap); 2080 prefwin->pageoverlap(reader->m_overlap);
2083 2081
2084 prefwin->ideogram(reader->m_bMonoSpaced); 2082 prefwin->ideogram(reader->m_bMonoSpaced);
2085 2083
2086 prefwin->encoding(reader->m_encd); 2084 prefwin->encoding(reader->m_encd);
2087 2085
2088 prefwin->ideogramwidth(reader->m_charpc); 2086 prefwin->ideogramwidth(reader->m_charpc);
2089 2087
2090 if (prefwin->exec()) 2088 if (prefwin->exec())
2091 { 2089 {
2092 // m_debounce = prefwin->Debounce(); 2090 // m_debounce = prefwin->Debounce();
2093 reader->brepalm = prefwin->repalm(); 2091 reader->brepalm = prefwin->repalm();
2094 reader->bkern = prefwin->kern(); 2092 reader->bkern = prefwin->kern();
2095 reader->hyphenate = prefwin->hyphenate(); 2093 reader->hyphenate = prefwin->hyphenate();
2096 // reader->buffdoc.setCustomHyphen(prefwin->customhyphen()); 2094 // reader->buffdoc.setCustomHyphen(prefwin->customhyphen());
2097 reader->m_scrolltype = prefwin->scrolltype(); 2095 reader->m_scrolltype = prefwin->scrolltype();
2098 reader->m_scrollstep = prefwin->scrollstep(); 2096 reader->m_scrollstep = prefwin->scrollstep();
2099 m_scrollcolor = prefwin->scrollcolor(); 2097 m_scrollcolor = prefwin->scrollcolor();
2100 setscrollcolour(); 2098 setscrollcolour();
2101 m_scrollbarcolor = prefwin->minibarcol(); 2099 m_scrollbarcolor = prefwin->minibarcol();
2102 setscrollbarcolour(); 2100 setscrollbarcolour();
2103 m_foreground = prefwin->foreground(); 2101 m_foreground = prefwin->foreground();
2104 reader->setForeground(getcolour(m_foreground)); 2102 reader->setForeground(getcolour(m_foreground));
2105 m_background = prefwin->background(); 2103 m_background = prefwin->background();
2106 reader->setBackground(getcolour(m_background)); 2104 reader->setBackground(getcolour(m_background));
2107 m_twoTouch = prefwin->twotouch(); 2105 m_twoTouch = prefwin->twotouch();
2108 reader->setTwoTouch(m_twoTouch); 2106 reader->setTwoTouch(m_twoTouch);
2109 m_touch_action->setOn(m_twoTouch); 2107 m_touch_action->setOn(m_twoTouch);
2110 2108
2111 reader->bstripcr = prefwin->StripCR(); 2109 reader->bstripcr = prefwin->StripCR();
2112 reader->bdehyphen = prefwin->Dehyphen(); 2110 reader->bdehyphen = prefwin->Dehyphen();
2113 reader->bonespace = prefwin->SingleSpace(); 2111 reader->bonespace = prefwin->SingleSpace();
2114 reader->bunindent = prefwin->Unindent(); 2112 reader->bunindent = prefwin->Unindent();
2115 reader->brepara = prefwin->Reparagraph(); 2113 reader->brepara = prefwin->Reparagraph();
2116 reader->bdblspce = prefwin->DoubleSpace(); 2114 reader->bdblspce = prefwin->DoubleSpace();
2117 reader->bremap = prefwin->Remap(); 2115 reader->bremap = prefwin->Remap();
2118 reader->bmakebold = prefwin->Embolden(); 2116 reader->bmakebold = prefwin->Embolden();
2119 reader->bfulljust = prefwin->FullJustify(); 2117 reader->bfulljust = prefwin->FullJustify();
2120 //if (reader->bInverse != prefwin->Inverse()) reader->setInverse(prefwin->Inverse()); 2118 //if (reader->bInverse != prefwin->Inverse()) reader->setInverse(prefwin->Inverse());
2121 //if (reader->bNegative != prefwin->Negative()) reader->setNegative(); 2119 //if (reader->bNegative != prefwin->Negative()) reader->setNegative();
2122 reader->m_fontControl.FixGraphics(prefwin->FixGraphics()); 2120 reader->m_fontControl.FixGraphics(prefwin->FixGraphics());
2123 2121
2124 reader->setextraspace(prefwin->ParaLead()); 2122 reader->setextraspace(prefwin->ParaLead());
2125 reader->setlead(prefwin->LineLead()); 2123 reader->setlead(prefwin->LineLead());
2126 reader->m_abstopmargin = prefwin->TopMargin(); 2124 reader->m_abstopmargin = prefwin->TopMargin();
2127 reader->m_absbottommargin = prefwin->BottomMargin(); 2125 reader->m_absbottommargin = prefwin->BottomMargin();
2128 reader->m_absleft_border = prefwin->LeftMargin(); 2126 reader->m_absleft_border = prefwin->LeftMargin();
2129 reader->m_absright_border = prefwin->RightMargin(); 2127 reader->m_absright_border = prefwin->RightMargin();
2130 reader->bindenter = prefwin->Indent(); 2128 reader->bindenter = prefwin->Indent();
2131 reader->bautofmt = reader->btextfmt = reader->bstriphtml = reader->bpeanut = false; 2129 reader->bautofmt = reader->btextfmt = reader->bstriphtml = reader->bpeanut = false;
2132 switch (prefwin->Markup()) 2130 switch (prefwin->Markup())
2133 { 2131 {
2134 case 0: 2132 case 0:
2135 reader->bautofmt = true; 2133 reader->bautofmt = true;
2136 break; 2134 break;
2137 case 1: 2135 case 1:
2138 break; 2136 break;
2139 case 2: 2137 case 2:
2140 reader->btextfmt = true; 2138 reader->btextfmt = true;
2141 break; 2139 break;
2142 case 3: 2140 case 3:
2143 reader->bstriphtml = true; 2141 reader->bstriphtml = true;
2144 break; 2142 break;
2145 case 4: 2143 case 4:
2146 reader->bpeanut = true; 2144 reader->bpeanut = true;
2147 break; 2145 break;
2148 default: 2146 default:
2149 qDebug("Format out of range"); 2147 qDebug("Format out of range");
2150 } 2148 }
2151 reader->bdepluck = prefwin->Depluck(); 2149 reader->bdepluck = prefwin->Depluck();
2152 reader->bdejpluck = prefwin->Dejpluck(); 2150 reader->bdejpluck = prefwin->Dejpluck();
2153 reader->setContinuous(prefwin->Continuous()); 2151 reader->setContinuous(prefwin->Continuous());
2154 2152
2155 /* 2153 /*
2156 m_leftScroll = prefwin->leftScroll(); 2154 m_leftScroll = prefwin->leftScroll();
2157 m_rightScroll = prefwin->rightScroll(); 2155 m_rightScroll = prefwin->rightScroll();
2158 m_upScroll = prefwin->upScroll(); 2156 m_upScroll = prefwin->upScroll();
2159 m_downScroll = prefwin->downScroll(); 2157 m_downScroll = prefwin->downScroll();
2160 */ 2158 */
2161 m_targetapp = prefwin->dictApplication(); 2159 m_targetapp = prefwin->dictApplication();
2162 m_targetmsg = prefwin->dictMessage(); 2160 m_targetmsg = prefwin->dictMessage();
2163 2161
2164 m_doAnnotation = prefwin->miscannotation(); 2162 m_doAnnotation = prefwin->miscannotation();
2165 m_doDictionary = prefwin->miscdictionary(); 2163 m_doDictionary = prefwin->miscdictionary();
2166 m_doClipboard = prefwin->miscclipboard(); 2164 m_doClipboard = prefwin->miscclipboard();
2167 reader->m_swapmouse = prefwin->SwapMouse(); 2165 reader->m_swapmouse = prefwin->SwapMouse();
2168 reader->setBaseSize(prefwin->gfxsize()); 2166 reader->setBaseSize(prefwin->gfxsize());
2169 reader->m_overlap = prefwin->pageoverlap(); 2167 reader->m_overlap = prefwin->pageoverlap();
2170 reader->m_bMonoSpaced = prefwin->ideogram(); 2168 reader->m_bMonoSpaced = prefwin->ideogram();
2171 m_setmono_action->setOn(reader->m_bMonoSpaced); 2169 m_setmono_action->setOn(reader->m_bMonoSpaced);
2172 reader->m_encd = prefwin->encoding(); 2170 reader->m_encd = prefwin->encoding();
2173 reader->m_charpc = prefwin->ideogramwidth(); 2171 reader->m_charpc = prefwin->ideogramwidth();
2174 2172
2175 if ( 2173 if (
2176 reader->m_fontname != prefwin->Font() 2174 reader->m_fontname != prefwin->Font()
2177 || 2175 ||
2178 m_propogatefontchange != prefwin->propfontchange()) 2176 m_propogatefontchange != prefwin->propfontchange())
2179 { 2177 {
2180 m_propogatefontchange = prefwin->propfontchange(); 2178 m_propogatefontchange = prefwin->propfontchange();
2181 setfontHelper(prefwin->Font()); 2179 setfontHelper(prefwin->Font());
2182 } 2180 }
2183 if (m_bgtype != (bground)prefwin->bgtype()) 2181 if (m_bgtype != (bground)prefwin->bgtype())
2184 { 2182 {
2185 m_bgtype = (bground)prefwin->bgtype(); 2183 m_bgtype = (bground)prefwin->bgtype();
2186 setBackgroundBitmap(); 2184 setBackgroundBitmap();
2187 } 2185 }
2188 delete prefwin; 2186 delete prefwin;
2189 reader->setfilter(reader->getfilter()); 2187 reader->setfilter(reader->getfilter());
2190 reader->refresh(); 2188 reader->refresh();
2191 } 2189 }
2192 else 2190 else
2193 { 2191 {
2194 delete prefwin; 2192 delete prefwin;
2195 } 2193 }
2196} 2194}
2197 2195
2198void QTReaderApp::showtoolbarprefs() 2196void QTReaderApp::showtoolbarprefs()
2199{ 2197{
2200#ifdef USEQPE 2198#ifdef USEQPE
2201 CBarPrefs* prefwin = new CBarPrefs(APPDIR, !m_bFloatingDialog, this); 2199 CBarPrefs* prefwin = new CBarPrefs(APPDIR, !m_bFloatingDialog, this);
2202#else 2200#else
2203 QFileInfo fi; 2201 QFileInfo fi;
2204 QDir d = QDir::home(); // "/" 2202 QDir d = QDir::home(); // "/"
2205 if ( !d.cd(APPDIR) ) 2203 if ( !d.cd(APPDIR) )
2206 { // "/tmp" 2204 { // "/tmp"
2207 qWarning( "Cannot find the \"~/%s\" directory", APPDIR ); 2205 qWarning( "Cannot find the \"~/%s\" directory", APPDIR );
2208 d = QDir::home(); 2206 d = QDir::home();
2209 d.mkdir(APPDIR); 2207 d.mkdir(APPDIR);
2210 d.cd(APPDIR); 2208 d.cd(APPDIR);
2211 } 2209 }
2212 fi.setFile(d, INIFILE); 2210 fi.setFile(d, INIFILE);
2213 CBarPrefs* prefwin = new CBarPrefs(fi.absFilePath(), !m_bFloatingDialog, this); 2211 CBarPrefs* prefwin = new CBarPrefs(fi.absFilePath(), !m_bFloatingDialog, this);
2214#endif 2212#endif
2215 prefwin->tbpolicy(m_tbpolsave); 2213 prefwin->tbpolicy(m_tbpolsave);
2216 prefwin->tbposition(m_tbposition-2); 2214 prefwin->tbposition(m_tbposition-2);
2217 prefwin->tbmovable(m_tbmovesave); 2215 prefwin->tbmovable(m_tbmovesave);
2218 prefwin->floating(m_bFloatingDialog); 2216 prefwin->floating(m_bFloatingDialog);
2219 prefwin->qtscroll(m_qtscroll); 2217 prefwin->qtscroll(m_qtscroll);
2220 prefwin->localscroll(m_localscroll); 2218 prefwin->localscroll(m_localscroll);
2221 if (prefwin->exec()) 2219 if (prefwin->exec())
2222 { 2220 {
2223 m_bFloatingDialog = prefwin->floating(); 2221 m_bFloatingDialog = prefwin->floating();
2224 if ( 2222 if (
2225 m_tbpolsave != (ToolbarPolicy)prefwin->tbpolicy() 2223 m_tbpolsave != (ToolbarPolicy)prefwin->tbpolicy()
2226 || 2224 ||
2227 m_tbposition != (ToolBarDock)(prefwin->tbposition()+2) 2225 m_tbposition != (ToolBarDock)(prefwin->tbposition()+2)
2228 || 2226 ||
2229 m_tbmovesave != prefwin->tbmovable() 2227 m_tbmovesave != prefwin->tbmovable()
2230 || 2228 ||
2231 m_qtscroll != prefwin->qtscroll() 2229 m_qtscroll != prefwin->qtscroll()
2232 // || 2230 // ||
2233 // m_localscrollbar != prefwin->scrollonleft() 2231 // m_localscrollbar != prefwin->scrollonleft()
2234 ) 2232 )
2235 { 2233 {
2236 QMessageBox::warning(this, PROGNAME, "Some changes won't take effect\nuntil the next time the\napplication is started"); 2234 QMessageBox::warning(this, PROGNAME, "Some changes won't take effect\nuntil the next time the\napplication is started");
2237 } 2235 }
2238 m_tbpolsave = (ToolbarPolicy)prefwin->tbpolicy(); 2236 m_tbpolsave = (ToolbarPolicy)prefwin->tbpolicy();
2239 m_tbposition = (ToolBarDock)(prefwin->tbposition()+2); 2237 m_tbposition = (ToolBarDock)(prefwin->tbposition()+2);
2240 m_tbmovesave = prefwin->tbmovable(); 2238 m_tbmovesave = prefwin->tbmovable();
2241 reader->m_scrollpos = m_localscroll = prefwin->localscroll(); 2239 reader->m_scrollpos = m_localscroll = prefwin->localscroll();
2242 if (m_qtscroll != prefwin->qtscroll()) 2240 if (m_qtscroll != prefwin->qtscroll())
2243 { 2241 {
2244 m_qtscroll = prefwin->qtscroll(); 2242 m_qtscroll = prefwin->qtscroll();
2245 setrotated(reader->m_rotated); 2243 setrotated(reader->m_rotated);
2246 } 2244 }
2247 if (m_scrollbar == NULL || m_scrollbar->isHidden()) 2245 if (m_scrollbar == NULL || m_scrollbar->isHidden())
2248 { 2246 {
2249 reader->m_scrollpos = m_localscroll; 2247 reader->m_scrollpos = m_localscroll;
2250 } 2248 }
2251 else 2249 else
2252 { 2250 {
2253 reader->m_scrollpos = (m_qtscroll == 0) ? m_localscroll : 0; 2251 reader->m_scrollpos = (m_qtscroll == 0) ? m_localscroll : 0;
2254 } 2252 }
2255 bool isChanged = prefwin->isChanged(); 2253 bool isChanged = prefwin->isChanged();
2256 delete prefwin; 2254 delete prefwin;
2257#ifdef USEQPE 2255#ifdef USEQPE
2258 Config config( APPDIR ); 2256 Config config( APPDIR );
2259#else 2257#else
2260 QFileInfo fi; 2258 QFileInfo fi;
2261 QDir d = QDir::home(); // "/" 2259 QDir d = QDir::home(); // "/"
2262 if ( !d.cd(APPDIR) ) 2260 if ( !d.cd(APPDIR) )
2263 { // "/tmp" 2261 { // "/tmp"
2264 qWarning( "Cannot find the \"~/%s\" directory", APPDIR ); 2262 qWarning( "Cannot find the \"~/%s\" directory", APPDIR );
2265 d = QDir::home(); 2263 d = QDir::home();
2266 d.mkdir(APPDIR); 2264 d.mkdir(APPDIR);
2267 d.cd(APPDIR); 2265 d.cd(APPDIR);
2268 } 2266 }
2269 fi.setFile(d, INIFILE); 2267 fi.setFile(d, INIFILE);
2270 Config config( fi.absFilePath() ); 2268 Config config( fi.absFilePath() );
2271#endif 2269#endif
2272 if (isChanged) addtoolbars(&config); 2270 if (isChanged) addtoolbars(&config);
2273 } 2271 }
2274 else 2272 else
2275 { 2273 {
2276 delete prefwin; 2274 delete prefwin;
2277 } 2275 }
2278} 2276}
2279 2277
2280void QTReaderApp::showinfo() 2278void QTReaderApp::showinfo()
2281{ 2279{
2282 unsigned long ds, fs, ts, pl, dl; 2280 unsigned long ds, fs, ts, pl, dl;
2283 if (reader->empty()) 2281 if (reader->empty())
2284 { 2282 {
2285 QMessageBox::information(this, PROGNAME, "No file loaded", 1); 2283 QMessageBox::information(this, PROGNAME, "No file loaded", 1);
2286 } 2284 }
2287 else 2285 else
2288 { 2286 {
2289 reader->sizes(fs,ts); 2287 reader->sizes(fs,ts);
2290 ds = reader->buffdoc.endSection() - reader->buffdoc.startSection(); 2288 ds = reader->buffdoc.endSection() - reader->buffdoc.startSection();
2291 pl = reader->pagelocate(); 2289 pl = reader->pagelocate();
2292 dl = pl - reader->buffdoc.startSection(); 2290 dl = pl - reader->buffdoc.startSection();
2293 m_infoWin->setFileSize(fs); 2291 m_infoWin->setFileSize(fs);
2294 m_infoWin->setTextSize(ts); 2292 m_infoWin->setTextSize(ts);
2295 m_infoWin->setRatio(100-(100*fs + (ts >> 1))/ts); 2293 m_infoWin->setRatio(100-(100*fs + (ts >> 1))/ts);
2296 m_infoWin->setLocation(pl); 2294 m_infoWin->setLocation(pl);
2297 m_infoWin->setRead((100*pl + (ts >> 1))/ts); 2295 m_infoWin->setRead((100*pl + (ts >> 1))/ts);
2298 m_infoWin->setDocSize(ds); 2296 m_infoWin->setDocSize(ds);
2299 m_infoWin->setDocLocation(dl); 2297 m_infoWin->setDocLocation(dl);
2300 m_infoWin->setDocRead((100*dl + (ds >> 1))/ds); 2298 m_infoWin->setDocRead((100*dl + (ds >> 1))/ds);
2301 m_infoWin->setZoom(reader->m_fontControl.currentsize()*10); 2299 m_infoWin->setZoom(reader->m_fontControl.currentsize()*10);
2302 m_infoWin->setAbout(QString("\nApplication (c) Tim Wentford\n")+reader->about()); 2300 m_infoWin->setAbout(QString("\nApplication (c) Tim Wentford\n")+reader->about());
2303 editorStack->raiseWidget( m_infoWin ); 2301 editorStack->raiseWidget( m_infoWin );
2304 hidetoolbars(); 2302 hidetoolbars();
2305 m_infoWin->setFocus(); 2303 m_infoWin->setFocus();
2306 } 2304 }
2307} 2305}
2308 2306
2309void QTReaderApp::addAnno(const QString& name, const QString& text, size_t posn, size_t posn2) 2307void QTReaderApp::addAnno(const QString& name, const QString& text, size_t posn, size_t posn2)
2310{ 2308{
2311 if (pBkmklist == NULL) reader->pBkmklist = pBkmklist = new CList<Bkmk>; 2309 if (pBkmklist == NULL) reader->pBkmklist = pBkmklist = new CList<Bkmk>;
2312#ifdef _UNICODE 2310#ifdef _UNICODE
2313 CBuffer buff(name.length()+1); 2311 CBuffer buff(name.length()+1);
2314 int i; 2312 int i;
2315 for (i = 0; i < name.length(); i++) 2313 for (i = 0; i < name.length(); i++)
2316 { 2314 {
2317 buff[i] = name[i].unicode(); 2315 buff[i] = name[i].unicode();
2318 } 2316 }
2319 buff[i] = 0; 2317 buff[i] = 0;
2320 CBuffer buff2(text.length()+1); 2318 CBuffer buff2(text.length()+1);
2321 for (i = 0; i < text.length(); i++) 2319 for (i = 0; i < text.length(); i++)
2322 { 2320 {
2323 buff2[i] = text[i].unicode(); 2321 buff2[i] = text[i].unicode();
2324 } 2322 }
2325 buff2[i] = 0; 2323 buff2[i] = 0;
2326 Bkmk b(buff.data(), buff2.data(), posn, posn2); 2324 Bkmk b(buff.data(), buff2.data(), posn, posn2);
2327 QColor c = m_annoWin->getColor(); 2325 QColor c = m_annoWin->getColor();
2328 int red,green,blue; 2326 int red,green,blue;
2329 c.rgb(&red, &green, &blue); 2327 c.rgb(&red, &green, &blue);
2330 b.red(red); 2328 b.red(red);
2331 b.green(green); 2329 b.green(green);
2332 b.blue(blue); 2330 b.blue(blue);
2333 pBkmklist->push_front(b); 2331 pBkmklist->push_front(b);
2334#else 2332#else
2335 pBkmklist->push_front(Bkmk((const tchar*)text,posn)); 2333 pBkmklist->push_front(Bkmk((const tchar*)text,posn));
2336#endif 2334#endif
2337 m_fBkmksChanged = true; 2335 m_fBkmksChanged = true;
2338 pBkmklist->sort(); 2336 pBkmklist->sort();
2339} 2337}
2340 2338
2341void QTReaderApp::addAnno(const QString& name, const QString& text) 2339void QTReaderApp::addAnno(const QString& name, const QString& text)
2342{ 2340{
2343 if (m_annoIsEditing) 2341 if (m_annoIsEditing)
2344 { 2342 {
2345 if (name.isEmpty()) 2343 if (name.isEmpty())
2346 { 2344 {
2347 QMessageBox::information(this, PROGNAME, "Need a name for the bookmark\nPlease try again", 1); 2345 QMessageBox::information(this, PROGNAME, "Need a name for the bookmark\nPlease try again", 1);
2348 } 2346 }
2349 else 2347 else
2350 { 2348 {
2351 addAnno(name, text, m_annoWin->getPosn(), m_annoWin->getPosn2()); 2349 addAnno(name, text, m_annoWin->getPosn(), m_annoWin->getPosn2());
2352 } 2350 }
2353 showEditTools(); 2351 showEditTools();
2354 } 2352 }
2355 else 2353 else
2356 { 2354 {
2357 if (m_annoWin->edited()) 2355 if (m_annoWin->edited())
2358 { 2356 {
2359 CBuffer buff(text.length()+1); 2357 CBuffer buff(text.length()+1);
2360 int i; 2358 int i;
2361 for (i = 0; i < text.length(); i++) 2359 for (i = 0; i < text.length(); i++)
2362 { 2360 {
2363 buff[i] = text[i].unicode(); 2361 buff[i] = text[i].unicode();
2364 } 2362 }
2365 buff[i] = 0; 2363 buff[i] = 0;
2366 m_fBkmksChanged = true; 2364 m_fBkmksChanged = true;
2367 m_anno->setAnno(buff.data()); 2365 m_anno->setAnno(buff.data());
2368 } 2366 }
2369 QColor c = m_annoWin->getColor(); 2367 QColor c = m_annoWin->getColor();
2370 int red,green,blue; 2368 int red,green,blue;
2371 c.rgb(&red, &green, &blue); 2369 c.rgb(&red, &green, &blue);
2372 m_anno->red(red); 2370 m_anno->red(red);
2373 m_anno->green(green); 2371 m_anno->green(green);
2374 m_anno->blue(blue); 2372 m_anno->blue(blue);
2375 bool found = findNextBookmark(m_anno->value()+1); 2373 bool found = findNextBookmark(m_anno->value()+1);
2376 if (found) 2374 if (found)
2377 { 2375 {
2378 m_annoWin->setName(toQString(m_anno->name())); 2376 m_annoWin->setName(toQString(m_anno->name()));
2379 m_annoWin->setAnno(toQString(m_anno->anno())); 2377 m_annoWin->setAnno(toQString(m_anno->anno()));
2380 m_annoWin->setColor(QColor(m_anno->red(), m_anno->green(), m_anno->blue())); 2378 m_annoWin->setColor(QColor(m_anno->red(), m_anno->green(), m_anno->blue()));
2381 } 2379 }
2382 else 2380 else
2383 { 2381 {
2384 showEditTools(); 2382 showEditTools();
2385 } 2383 }
2386 } 2384 }
2387} 2385}
2388 2386
2389bool QTReaderApp::findNextBookmark(size_t start) 2387bool QTReaderApp::findNextBookmark(size_t start)
2390{ 2388{
2391 bool found = false; 2389 bool found = false;
2392 for (CList<Bkmk>::iterator iter = pBkmklist->begin(); iter != pBkmklist->end(); iter++) 2390 for (CList<Bkmk>::iterator iter = pBkmklist->begin(); iter != pBkmklist->end(); iter++)
2393 { 2391 {
2394 if (iter->value() >= start) 2392 if (iter->value() >= start)
2395 { 2393 {
2396 if (iter->value() < reader->locate()) 2394 if (iter->value() < reader->locate())
2397 { 2395 {
2398 found = true; 2396 found = true;
2399 m_anno = iter.pContent(); 2397 m_anno = iter.pContent();
2400 } 2398 }
2401 break; 2399 break;
2402 } 2400 }
2403 } 2401 }
2404 return found; 2402 return found;
2405} 2403}
2406 2404
2407void QTReaderApp::addanno() 2405void QTReaderApp::addanno()
2408{ 2406{
2409 if (reader->empty()) 2407 if (reader->empty())
2410 { 2408 {
2411 QMessageBox::information(this, PROGNAME, "No file loaded", 1); 2409 QMessageBox::information(this, PROGNAME, "No file loaded", 1);
2412 } 2410 }
2413 else 2411 else
2414 { 2412 {
2415 m_annoWin->setName(""); 2413 m_annoWin->setName("");
2416 m_annoWin->setAnno(""); 2414 m_annoWin->setAnno("");
2417 m_annoWin->setPosn(reader->pagelocate()); 2415 m_annoWin->setPosn(reader->pagelocate());
2418 m_annoIsEditing = true; 2416 m_annoIsEditing = true;
2419 editorStack->raiseWidget( m_annoWin ); 2417 editorStack->raiseWidget( m_annoWin );
2420 hidetoolbars(); 2418 hidetoolbars();
2421#ifdef USEQPE 2419#ifdef USEQPE
2422 Global::showInputMethod(); 2420 Global::showInputMethod();
2423#endif 2421#endif
2424 m_annoWin->setFocus(); 2422 m_annoWin->setFocus();
2425 } 2423 }
2426} 2424}
2427 2425
2428void QTReaderApp::infoClose() 2426void QTReaderApp::infoClose()
2429{ 2427{
2430 m_debounce = m_buttonprefs->Debounce(); 2428 m_debounce = m_buttonprefs->Debounce();
2431 if (m_kmapchanged) 2429 if (m_kmapchanged)
2432 { 2430 {
2433 m_kmapchanged = false; 2431 m_kmapchanged = false;
2434#ifndef USEQPE 2432#ifndef USEQPE
2435 QDir d = QDir::home(); // "/" 2433 QDir d = QDir::home(); // "/"
2436 d.cd(APPDIR); 2434 d.cd(APPDIR);
2437 QFileInfo fi(d, ".keymap"); 2435 QFileInfo fi(d, ".keymap");
2438 FILE* f = fopen((const char *)fi.absFilePath(), "w"); 2436 FILE* f = fopen((const char *)fi.absFilePath(), "w");
2439#else /* USEQPE */ 2437#else /* USEQPE */
2440 FILE* f = fopen((const char *)Global::applicationFileName(APPDIR,".keymap"), "w"); 2438 FILE* f = fopen((const char *)Global::applicationFileName(APPDIR,".keymap"), "w");
2441#endif /* USEQPE */ 2439#endif /* USEQPE */
2442 if (f != NULL) 2440 if (f != NULL)
2443 { 2441 {
2444 uint cnt = KEYMAPVERSION; 2442 uint cnt = KEYMAPVERSION;
2445 fwrite(&cnt, sizeof(cnt), 1, f); 2443 fwrite(&cnt, sizeof(cnt), 1, f);
2446 cnt = kmap.count(); 2444 cnt = kmap.count();
2447 fwrite(&cnt, sizeof(cnt), 1, f); 2445 fwrite(&cnt, sizeof(cnt), 1, f);
2448 for (QMap<orKey,int>::Iterator i = kmap.begin(); i != kmap.end(); i++) 2446 for (QMap<orKey,int>::Iterator i = kmap.begin(); i != kmap.end(); i++)
2449 { 2447 {
2450 orKey key = i.key(); 2448 orKey key = i.key();
2451 int data = i.data(); 2449 int data = i.data();
2452 fwrite(&key, sizeof(key), 1, f); 2450 fwrite(&key, sizeof(key), 1, f);
2453 fwrite(&data, sizeof(data), 1, f); 2451 fwrite(&data, sizeof(data), 1, f);
2454 qDebug("Saved %s as %u", (const char*)key.text(), data); 2452 qDebug("Saved %s as %u", (const char*)key.text(), data);
2455 } 2453 }
2456 fclose(f); 2454 fclose(f);
2457 } 2455 }
2458 } 2456 }
2459 showEditTools(); 2457 showEditTools();
2460} 2458}
2461 2459
2462/* 2460/*
2463void QTReaderApp::fileRevert() 2461void QTReaderApp::fileRevert()
2464{ 2462{
2465 clear(); 2463 clear();
2466 fileOpen(); 2464 fileOpen();
2467} 2465}
2468 2466
2469void QTReaderApp::editCut() 2467void QTReaderApp::editCut()
2470{ 2468{
2471#ifndef QT_NO_CLIPBOARD 2469#ifndef QT_NO_CLIPBOARD
2472 editor->cut(); 2470 editor->cut();
2473#endif 2471#endif
2474} 2472}
2475*/ 2473*/
2476void QTReaderApp::editMark() 2474void QTReaderApp::editMark()
2477{ 2475{
2478 m_savedpos = reader->pagelocate(); 2476 m_savedpos = reader->pagelocate();
2479} 2477}
2480 2478
2481void QTReaderApp::editCopy() 2479void QTReaderApp::editCopy()
2482{ 2480{
2483 QClipboard* cb = QApplication::clipboard(); 2481 QClipboard* cb = QApplication::clipboard();
2484 QString text; 2482 QString text;
2485 int ch; 2483 int ch;
2486 unsigned long currentpos = reader->pagelocate(); 2484 unsigned long currentpos = reader->pagelocate();
2487 unsigned long endpos = reader->locate(); 2485 unsigned long endpos = reader->locate();
2488 if (m_savedpos == 0xffffffff) 2486 if (m_savedpos == 0xffffffff)
2489 { 2487 {
2490 m_savedpos = currentpos; 2488 m_savedpos = currentpos;
2491 } 2489 }
2492 reader->jumpto(m_savedpos); 2490 reader->jumpto(m_savedpos);
2493 while (reader->explocate() < endpos && (ch = reader->getch()) != UEOF) 2491 while (reader->explocate() < endpos && (ch = reader->getch()) != UEOF)
2494 { 2492 {
2495 text += ch; 2493 text += ch;
2496 } 2494 }
2497 cb->setText(text); 2495 cb->setText(text);
2498 reader->locate(currentpos); 2496 reader->locate(currentpos);
2499 m_savedpos = 0xffffffff; 2497 m_savedpos = 0xffffffff;
2500} 2498}
2501 2499
2502void QTReaderApp::gotoStart() 2500void QTReaderApp::gotoStart()
2503{ 2501{
2504 reader->locate(reader->buffdoc.startSection()); 2502 reader->locate(reader->buffdoc.startSection());
2505} 2503}
2506 2504
2507void QTReaderApp::gotoEnd() 2505void QTReaderApp::gotoEnd()
2508{ 2506{
2509 reader->dopageup(reader->buffdoc.endSection()); 2507 reader->dopageup(reader->buffdoc.endSection());
2510} 2508}
2511 2509
2512void QTReaderApp::pageup() 2510void QTReaderApp::pageup()
2513{ 2511{
2514 reader->NavUp(); 2512 reader->NavUp();
2515} 2513}
2516 2514
2517void QTReaderApp::pagedn() 2515void QTReaderApp::pagedn()
2518{ 2516{
2519 reader->NavDown(); 2517 reader->NavDown();
2520} 2518}
2521 2519
2522void QTReaderApp::pagemode(bool _b) 2520void QTReaderApp::pagemode(bool _b)
2523{ 2521{
2524 reader->setpagemode(_b); 2522 reader->setpagemode(_b);
2525} 2523}
2526 2524
2527/* 2525/*
2528void QTReaderApp::setspacing() 2526void QTReaderApp::setspacing()
2529{ 2527{
2530 m_nRegAction = cMonoSpace; 2528 m_nRegAction = cMonoSpace;
2531 char lcn[20]; 2529 char lcn[20];
2532 sprintf(lcn, "%lu", reader->m_charpc); 2530 sprintf(lcn, "%lu", reader->m_charpc);
2533 regEdit->setText(lcn); 2531 regEdit->setText(lcn);
2534 do_regedit(); 2532 do_regedit();
2535} 2533}
2536*/ 2534*/
2537void QTReaderApp::settarget() 2535void QTReaderApp::settarget()
2538{ 2536{
2539 m_nRegAction = cSetTarget; 2537 m_nRegAction = cSetTarget;
2540 QString text = ((m_targetapp.isEmpty()) ? QString("") : m_targetapp) 2538 QString text = ((m_targetapp.isEmpty()) ? QString("") : m_targetapp)
2541 + "/" 2539 + "/"
2542 + ((m_targetmsg.isEmpty()) ? QString("") : m_targetmsg); 2540 + ((m_targetmsg.isEmpty()) ? QString("") : m_targetmsg);
2543 regEdit->setText(text); 2541 regEdit->setText(text);
2544 do_regedit(); 2542 do_regedit();
2545} 2543}
2546 2544
2547/* 2545/*
2548void QTReaderApp::do_mono(const QString& lcn) 2546void QTReaderApp::do_mono(const QString& lcn)
2549{ 2547{
2550 bool ok; 2548 bool ok;
2551 unsigned long ulcn = lcn.toULong(&ok); 2549 unsigned long ulcn = lcn.toULong(&ok);
2552 if (ok) 2550 if (ok)
2553 { 2551 {
2554 reader->m_charpc = ulcn; 2552 reader->m_charpc = ulcn;
2555 reader->setfont(); 2553 reader->setfont();
2556 reader->refresh(); 2554 reader->refresh();
2557 //reader->setmono(true); 2555 //reader->setmono(true);
2558 } 2556 }
2559 else 2557 else
2560 QMessageBox::information(this, PROGNAME, "Must be a number"); 2558 QMessageBox::information(this, PROGNAME, "Must be a number");
2561} 2559}
2562*/ 2560*/
2563/* 2561/*
2564void QTReaderApp::editPaste() 2562void QTReaderApp::editPaste()
2565{ 2563{
2566#ifndef QT_NO_CLIPBOARD 2564#ifndef QT_NO_CLIPBOARD
2567 editor->paste(); 2565 editor->paste();
2568#endif 2566#endif
2569} 2567}
2570*/ 2568*/
2571 2569
2572void QTReaderApp::editFind() 2570void QTReaderApp::editFind()
2573{ 2571{
2574 searchStart = reader->pagelocate(); 2572 searchStart = reader->pagelocate();
2575#ifdef __ISEARCH 2573#ifdef __ISEARCH
2576 searchStack = new QStack<searchrecord>; 2574 searchStack = new QStack<searchrecord>;
2577#endif 2575#endif
2578#ifdef USEQPE 2576#ifdef USEQPE
2579 Global::showInputMethod(); 2577 Global::showInputMethod();
2580#endif 2578#endif
2581 searchBar->show(); 2579 searchBar->show();
2582 searchVisible = TRUE; 2580 searchVisible = TRUE;
2583 searchEdit->setFocus(); 2581 searchEdit->setFocus();
2584#ifdef __ISEARCH 2582#ifdef __ISEARCH
2585 searchStack->push(new searchrecord("",reader->pagelocate())); 2583 searchStack->push(new searchrecord("",reader->pagelocate()));
2586#endif 2584#endif
2587} 2585}
2588 2586
2589void QTReaderApp::findNext() 2587void QTReaderApp::findNext()
2590{ 2588{
2591// // qDebug("findNext called\n"); 2589// // qDebug("findNext called\n");
2592#ifdef __ISEARCH 2590#ifdef __ISEARCH
2593 QString arg = searchEdit->text(); 2591 QString arg = searchEdit->text();
2594#else 2592#else
2595 QRegExp arg = searchEdit->text(); 2593 QRegExp arg = searchEdit->text();
2596#endif 2594#endif
2597 CDrawBuffer test(&(reader->m_fontControl)); 2595 CDrawBuffer test(&(reader->m_fontControl));
2598 size_t start = reader->pagelocate(); 2596 size_t start = reader->pagelocate();
2599 reader->jumpto(start); 2597 reader->jumpto(start);
2600 reader->getline(&test); 2598 reader->getline(&test);
2601 dosearch(start, test, arg); 2599 dosearch(start, test, arg);
2602} 2600}
2603 2601
2604void QTReaderApp::findClose() 2602void QTReaderApp::findClose()
2605{ 2603{
2606 searchVisible = FALSE; 2604 searchVisible = FALSE;
2607 searchEdit->setText(""); 2605 searchEdit->setText("");
2608#ifdef USEQPE 2606#ifdef USEQPE
2609 Global::hideInputMethod(); 2607 Global::hideInputMethod();
2610#endif 2608#endif
2611 searchBar->hide(); 2609 searchBar->hide();
2612#ifdef __ISEARCH 2610#ifdef __ISEARCH
2613// searchStack = new QStack<searchrecord>; 2611// searchStack = new QStack<searchrecord>;
2614 while (!searchStack->isEmpty()) 2612 while (!searchStack->isEmpty())
2615 { 2613 {
2616 delete searchStack->pop(); 2614 delete searchStack->pop();
2617 } 2615 }
2618 delete searchStack; 2616 delete searchStack;
2619#endif 2617#endif
2620 reader->setFocus(); 2618 reader->setFocus();
2621} 2619}
2622 2620
2623void QTReaderApp::regClose() 2621void QTReaderApp::regClose()
2624{ 2622{
2625 regVisible = FALSE; 2623 regVisible = FALSE;
2626 regEdit->setText(""); 2624 regEdit->setText("");
2627 regBar->hide(); 2625 regBar->hide();
2628#ifdef USEQPE 2626#ifdef USEQPE
2629 Global::hideInputMethod(); 2627 Global::hideInputMethod();
2630#endif 2628#endif
2631 reader->setFocus(); 2629 reader->setFocus();
2632} 2630}
2633 2631
2634#ifdef __ISEARCH 2632#ifdef __ISEARCH
2635bool QTReaderApp::dosearch(size_t start, CDrawBuffer& test, const QString& arg) 2633bool QTReaderApp::dosearch(size_t start, CDrawBuffer& test, const QString& arg)
2636#else 2634#else
2637bool QTReaderApp::dosearch(size_t start, CDrawBuffer& test, const QRegExp& arg) 2635bool QTReaderApp::dosearch(size_t start, CDrawBuffer& test, const QRegExp& arg)
2638#endif 2636#endif
2639{ 2637{
2640 bool ret = true; 2638 bool ret = true;
2641 unsigned long fs, ts; 2639 unsigned long fs, ts;
2642 reader->sizes(fs,ts); 2640 reader->sizes(fs,ts);
2643 size_t pos = reader->locate(); 2641 size_t pos = reader->locate();
2644 pbar->setGeometry(searchBar->x(),searchBar->y(),searchBar->width(), searchBar->height()); 2642 pbar->setGeometry(searchBar->x(),searchBar->y(),searchBar->width(), searchBar->height());
2645 pbar->show(); 2643 pbar->show();
2646 pbar->raise(); 2644 pbar->raise();
2647 pbar->reset(); 2645 pbar->reset();
2648 int offset; 2646 int offset;
2649 int lastpc = (100*pos)/ts; 2647 int lastpc = (100*pos)/ts;
2650 pbar->setProgress(lastpc); 2648 pbar->setProgress(lastpc);
2651// qApp->processEvents(); 2649// qApp->processEvents();
2652 if (reader->buffdoc.getpara(test) >= 0) 2650 if (reader->buffdoc.getpara(test) >= 0)
2653 { 2651 {
2654 reader->setFocus(); 2652 reader->setFocus();
2655#ifdef __ISEARCH 2653#ifdef __ISEARCH
2656 while (strstr(test.data(),(const tchar*)arg) == NULL) 2654 while (strstr(test.data(),(const tchar*)arg) == NULL)
2657#else 2655#else
2658#ifdef _UNICODE 2656#ifdef _UNICODE
2659 while ((offset = arg.match(toQString(test.data()))) == -1) 2657 while ((offset = arg.match(toQString(test.data()))) == -1)
2660#else 2658#else
2661 while (arg.match(test.data()) == -1) 2659 while (arg.match(test.data()) == -1)
2662#endif 2660#endif
2663#endif 2661#endif
2664 { 2662 {
2665 pos = reader->locate(); 2663 pos = reader->locate();
2666 int pc = (100*pos)/ts; 2664 int pc = (100*pos)/ts;
2667 if (pc != lastpc) 2665 if (pc != lastpc)
2668 { 2666 {
2669 pbar->setProgress(pc); 2667 pbar->setProgress(pc);
2670 qApp->processEvents(); 2668 qApp->processEvents();
2671 reader->setFocus(); 2669 reader->setFocus();
2672 lastpc = pc; 2670 lastpc = pc;
2673 } 2671 }
2674 2672
2675 if (reader->buffdoc.getpara(test) < 0) 2673 if (reader->buffdoc.getpara(test) < 0)
2676 { 2674 {
2677 if (QMessageBox::warning(this, "Can't find", searchEdit->text(), 1, 2) == 2) 2675 if (QMessageBox::warning(this, "Can't find", searchEdit->text(), 1, 2) == 2)
2678 pos = searchStart; 2676 pos = searchStart;
2679 else 2677 else
2680 pos = start; 2678 pos = start;
2681 findClose(); 2679 findClose();
2682 pbar->hide(); 2680 pbar->hide();
2683 reader->locate(pos); 2681 reader->locate(pos);
2684 return false; 2682 return false;
2685 } 2683 }
2686 } 2684 }
2687// qDebug("Found it at %u:%u", pos, offset); 2685// qDebug("Found it at %u:%u", pos, offset);
2688 pbar->hide(); 2686 pbar->hide();
2689// qDebug("Hid"); 2687// qDebug("Hid");
2690 reader->locate(pos+offset); 2688 reader->locate(pos+offset);
2691// qDebug("Loacted"); 2689// qDebug("Loacted");
2692// qDebug("page up"); 2690// qDebug("page up");
2693 ret = true; 2691 ret = true;
2694 } 2692 }
2695 else 2693 else
2696 { 2694 {
2697 if (QMessageBox::warning(this, "Can't find", searchEdit->text(), 1, 2) == 2) 2695 if (QMessageBox::warning(this, "Can't find", searchEdit->text(), 1, 2) == 2)
2698 pos = searchStart; 2696 pos = searchStart;
2699 else 2697 else
2700 pos = start; 2698 pos = start;
2701 ret = false; 2699 ret = false;
2702 findClose(); 2700 findClose();
2703 } 2701 }
2704 return ret; 2702 return ret;
2705} 2703}
2706 2704
2707#ifdef __ISEARCH 2705#ifdef __ISEARCH
2708void QTReaderApp::search(const QString & arg) 2706void QTReaderApp::search(const QString & arg)
2709{ 2707{
2710 searchrecord* ss = searchStack->top(); 2708 searchrecord* ss = searchStack->top();
2711 CBuffer test; 2709 CBuffer test;
2712 size_t start = reader->pagelocate(); 2710 size_t start = reader->pagelocate();
2713 bool haspopped = false; 2711 bool haspopped = false;
2714 while (arg.left(ss->s.length()) != ss->s) 2712 while (arg.left(ss->s.length()) != ss->s)
2715 { 2713 {
2716 haspopped = true; 2714 haspopped = true;
2717 start = ss->pos; 2715 start = ss->pos;
2718// reader->locate(start); 2716// reader->locate(start);
2719 searchStack->pop(); 2717 searchStack->pop();
2720 delete ss; 2718 delete ss;
2721 } 2719 }
2722 if (haspopped) reader->locate(start); 2720 if (haspopped) reader->locate(start);
2723/* 2721/*
2724 if (arg.length() < ss->len) 2722 if (arg.length() < ss->len)
2725 { 2723 {
2726 start = ss->pos; 2724 start = ss->pos;
2727 reader->locate(start); 2725 reader->locate(start);
2728 searchStack->pop(); 2726 searchStack->pop();
2729 delete ss; 2727 delete ss;
2730 } 2728 }
2731*/ 2729*/
2732 else 2730 else
2733 { 2731 {
2734 start = reader->pagelocate(); 2732 start = reader->pagelocate();
2735 reader->jumpto(start); 2733 reader->jumpto(start);
2736 searchStack->push(new searchrecord(arg,start)); 2734 searchStack->push(new searchrecord(arg,start));
2737 } 2735 }
2738 dosearch(start, test, arg); 2736 dosearch(start, test, arg);
2739} 2737}
2740#else 2738#else
2741void QTReaderApp::search() 2739void QTReaderApp::search()
2742{ 2740{
2743 findNext(); 2741 findNext();
2744} 2742}
2745#endif 2743#endif
2746 2744
2747void QTReaderApp::openFile( const QString &f ) 2745void QTReaderApp::openFile( const QString &f )
2748{ 2746{
2749// qDebug("File:%s", (const char*)f); 2747// qDebug("File:%s", (const char*)f);
2750// openFile(DocLnk(f)); 2748// openFile(DocLnk(f));
2751//} 2749//}
2752// 2750//
2753//void QTReaderApp::openFile( const DocLnk &f ) 2751//void QTReaderApp::openFile( const DocLnk &f )
2754//{ 2752//{
2755 clear(); 2753 clear();
2756 QFileInfo fm(f); 2754 QFileInfo fm(f);
2757 if ( fm.exists() ) 2755 if ( fm.exists() )
2758 { 2756 {
2759// QMessageBox::information(0, "Progress", "Calling fileNew()"); 2757// QMessageBox::information(0, "Progress", "Calling fileNew()");
2760#ifdef USEQPE 2758#ifdef USEQPE
2761 if (fm.extension( FALSE ) == "desktop") 2759 if (fm.extension( FALSE ) == "desktop")
2762 { 2760 {
2763 DocLnk d(f); 2761 DocLnk d(f);
2764 QFileInfo fnew(d.file()); 2762 QFileInfo fnew(d.file());
2765 fm = fnew; 2763 fm = fnew;
2766 if (!fm.exists()) return; 2764 if (!fm.exists()) return;
2767 } 2765 }
2768#endif 2766#endif
2769 clear(); 2767 clear();
2770 reader->setText(fm.baseName(), fm.absFilePath()); 2768 reader->setText(fm.baseName(), fm.absFilePath());
2771 m_loadedconfig = readconfig(APPDIR "/configs", reader->m_string, false); 2769 m_loadedconfig = readconfig(APPDIR "/configs", reader->m_string, false);
2772 qDebug("Showing tools"); 2770 qDebug("Showing tools");
2773 showEditTools(); 2771 showEditTools();
2774 qDebug("Shown tools"); 2772 qDebug("Shown tools");
2775 readbkmks(); 2773 readbkmks();
2776 qDebug("read markss"); 2774 qDebug("read markss");
2777 m_savedpos = 0xffffffff; 2775 m_savedpos = 0xffffffff;
2778 } 2776 }
2779 else 2777 else
2780 { 2778 {
2781 QString msg = f; 2779 QString msg = f;
2782 msg += "\nFile does not exist"; 2780 msg += "\nFile does not exist";
2783 QMessageBox::information(this, PROGNAME, msg); 2781 QMessageBox::information(this, PROGNAME, msg);
2784 reader->m_lastfile = QString::null; 2782 reader->m_lastfile = QString::null;
2785 } 2783 }
2786 2784
2787} 2785}
2788/* 2786/*
2789void QTReaderApp::resizeEvent(QResizeEvent* e) 2787void QTReaderApp::resizeEvent(QResizeEvent* e)
2790{ 2788{
2791 if (m_fullscreen) 2789 if (m_fullscreen)
2792 { 2790 {
2793 showNormal(); 2791 showNormal();
2794 showFullScreen(); 2792 showFullScreen();
2795 } 2793 }
2796} 2794}
2797*/ 2795*/
2798void QTReaderApp::handlekey(QKeyEvent* e) 2796void QTReaderApp::handlekey(QKeyEvent* e)
2799{ 2797{
2800// qDebug("Keypress event"); 2798// qDebug("Keypress event");
2801 timeb now; 2799 timeb now;
2802 ftime(&now); 2800 ftime(&now);
2803 unsigned long etime = (1000*(now.time - m_lastkeytime.time) + now.millitm)-m_lastkeytime.millitm; 2801 unsigned long etime = (1000*(now.time - m_lastkeytime.time) + now.millitm)-m_lastkeytime.millitm;
2804 if (etime < m_debounce) 2802 if (etime < m_debounce)
2805 { 2803 {
2806 return; 2804 return;
2807 } 2805 }
2808 switch(e->key()) 2806 switch(e->key())
2809 { 2807 {
2810 case Key_Escape: 2808 case Key_Escape:
2811 // qDebug("escape event"); 2809 // qDebug("escape event");
2812 if (m_disableesckey) 2810 if (m_disableesckey)
2813 { 2811 {
2814 m_disableesckey = false; 2812 m_disableesckey = false;
2815 } 2813 }
2816 else 2814 else
2817 { 2815 {
2818 m_bcloseDisabled = true; 2816 m_bcloseDisabled = true;
2819 if (m_fullscreen) 2817 if (m_fullscreen)
2820 { 2818 {
2821 m_actFullscreen->setOn(false); 2819 m_actFullscreen->setOn(false);
2822 e->accept(); 2820 e->accept();
2823 } 2821 }
2824 else 2822 else
2825 { 2823 {
2826 // qDebug("escape action"); 2824 // qDebug("escape action");
2827 doAction(e); 2825 doAction(e);
2828 } 2826 }
2829 } 2827 }
2830 break; 2828 break;
2831 /* 2829 /*
2832 case Key_Left: 2830 case Key_Left:
2833 { 2831 {
2834 if (reader->m_autoScroll) 2832 if (reader->m_autoScroll)
2835 { 2833 {
2836 reader->reduceScroll(); 2834 reader->reduceScroll();
2837 } 2835 }
2838 else 2836 else
2839 { 2837 {
2840 doAction(e); 2838 doAction(e);
2841 } 2839 }
2842 } 2840 }
2843 break; 2841 break;
2844 case Key_Right: 2842 case Key_Right:
2845 { 2843 {
2846 if (reader->m_autoScroll) 2844 if (reader->m_autoScroll)
2847 { 2845 {
2848 reader->increaseScroll(); 2846 reader->increaseScroll();
2849 } 2847 }
2850 else 2848 else
2851 { 2849 {
2852 doAction(e); 2850 doAction(e);
2853 } 2851 }
2854 } 2852 }
2855 break; 2853 break;
2856 case Key_Up: 2854 case Key_Up:
2857 { 2855 {
2858 if (reader->m_autoScroll) 2856 if (reader->m_autoScroll)
2859 { 2857 {
2860 reader->increaseScroll(); 2858 reader->increaseScroll();
2861 } 2859 }
2862 else 2860 else
2863 { 2861 {
2864 doAction(e); 2862 doAction(e);
2865 } 2863 }
2866 } 2864 }
2867 break; 2865 break;
2868 case Key_Down: 2866 case Key_Down:
2869 { 2867 {
2870 if (reader->m_autoScroll) 2868 if (reader->m_autoScroll)
2871 { 2869 {
2872 reader->reduceScroll(); 2870 reader->reduceScroll();
2873 } 2871 }
2874 else 2872 else
2875 { 2873 {
2876 doAction(e); 2874 doAction(e);
2877 } 2875 }
2878 } 2876 }
2879 break; 2877 break;
2880 */ 2878 */
2881 default: 2879 default:
2882 { 2880 {
2883 doAction(e); 2881 doAction(e);
2884 } 2882 }
2885 2883
2886/* 2884/*
2887 QString msg("Key press was:"); 2885 QString msg("Key press was:");
2888 QString key; 2886 QString key;
2889 msg += key.setNum(e->key()); 2887 msg += key.setNum(e->key());
2890 QMessageBox::information(this, PROGNAME, msg); 2888 QMessageBox::information(this, PROGNAME, msg);
2891*/ 2889*/
2892 } 2890 }
2893 ftime(&m_lastkeytime); 2891 ftime(&m_lastkeytime);
2894} 2892}
2895 2893
2896#ifdef NEWFULLSCREEN 2894#ifdef NEWFULLSCREEN
2897void QTReaderApp::enableFullscreen() 2895void QTReaderApp::enableFullscreen()
2898{ 2896{
2899 setFixedSize(qApp->desktop()->size()); 2897 setFixedSize(qApp->desktop()->size());
2900 showNormal(); 2898 showNormal();
2901 reparent(0, WStyle_Customize | WStyle_NoBorder, QPoint(0,0)); 2899 reparent(0, WStyle_Customize | WStyle_NoBorder, QPoint(0,0));
2902 showFullScreen(); 2900 showFullScreen();
2903} 2901}
2904 2902
2905void QTReaderApp::resizeEvent(QResizeEvent *) 2903void QTReaderApp::resizeEvent(QResizeEvent *)
2906{ 2904{
2907 if (m_fullscreen && (size() != qApp->desktop()->size())) 2905 if (m_fullscreen && (size() != qApp->desktop()->size()))
2908 { 2906 {
2909 enableFullscreen(); 2907 enableFullscreen();
2910 } 2908 }
2911} 2909}
2912 2910
2913void QTReaderApp::focusInEvent(QFocusEvent*) 2911void QTReaderApp::focusInEvent(QFocusEvent*)
2914{ 2912{
2915 if (m_fullscreen) 2913 if (m_fullscreen)
2916 { 2914 {
2917 enableFullscreen(); 2915 enableFullscreen();
2918 raise(); 2916 raise();
2919 } 2917 }
2920} 2918}
2921#endif 2919#endif
2922 2920
2923void QTReaderApp::showEditTools() 2921void QTReaderApp::showEditTools()
2924{ 2922{
2925// if ( !doc ) 2923// if ( !doc )
2926 //close(); 2924 //close();
2927 if (m_fullscreen) 2925 if (m_fullscreen)
2928 { 2926 {
2929#ifdef USEQPE 2927#ifdef USEQPE
2930 if (menubar != NULL) menubar->hide(); 2928 if (menubar != NULL) menubar->hide();
2931#endif 2929#endif
2932 if (fileBar != NULL) fileBar->hide(); 2930 if (fileBar != NULL) fileBar->hide();
2933 if (viewBar != NULL) viewBar->hide(); 2931 if (viewBar != NULL) viewBar->hide();
2934 if (navBar != NULL) navBar->hide(); 2932 if (navBar != NULL) navBar->hide();
2935 if (markBar != NULL) markBar->hide(); 2933 if (markBar != NULL) markBar->hide();
2936 if (m_prog != NULL) 2934 if (m_prog != NULL)
2937 { 2935 {
2938 // qDebug("Hiding status"); 2936 // qDebug("Hiding status");
2939 m_prog->hide(); 2937 m_prog->hide();
2940 } 2938 }
2941 searchBar->hide(); 2939 searchBar->hide();
2942 regBar->hide(); 2940 regBar->hide();
2943#ifdef USEQPE 2941#ifdef USEQPE
2944 Global::hideInputMethod(); 2942 Global::hideInputMethod();
2945#endif 2943#endif
2946 if (m_scrollbar != NULL) m_scrollbar->hide(); 2944 if (m_scrollbar != NULL) m_scrollbar->hide();
2947 m_fontBar->hide(); 2945 m_fontBar->hide();
2948 //showNormal(); 2946 //showNormal();
2949#ifdef NEWFULLSCREEN 2947#ifdef NEWFULLSCREEN
2950 enableFullscreen(); 2948 enableFullscreen();
2951#else 2949#else
2952 showFullScreen(); 2950 showFullScreen();
2953#endif 2951#endif
2954 } 2952 }
2955 else 2953 else
2956 { 2954 {
2957 //qDebug("him"); 2955 //qDebug("him");
2958#ifdef USEQPE 2956#ifdef USEQPE
2959 Global::hideInputMethod(); 2957 Global::hideInputMethod();
2960#endif 2958#endif
2961 //qDebug("eb"); 2959 //qDebug("eb");
2962 if (m_scrollbar != NULL) 2960 if (m_scrollbar != NULL)
2963 { 2961 {
2964 if (m_scrollishidden) 2962 if (m_scrollishidden)
2965 { 2963 {
2966 m_scrollbar->hide(); 2964 m_scrollbar->hide();
2967 } 2965 }
2968 else 2966 else
2969 { 2967 {
2970 m_scrollbar->show(); 2968 m_scrollbar->show();
2971 } 2969 }
2972 } 2970 }
2973 if (!m_hidebars) 2971 if (!m_hidebars)
2974 { 2972 {
2975#ifdef USEQPE 2973#ifdef USEQPE
2976 menubar->show(); 2974 menubar->show();
2977#endif 2975#endif
2978 if (fileBar != NULL) fileBar->show(); 2976 if (fileBar != NULL) fileBar->show();
2979 if (viewBar != NULL) viewBar->show(); 2977 if (viewBar != NULL) viewBar->show();
2980 if (navBar != NULL) navBar->show(); 2978 if (navBar != NULL) navBar->show();
2981 if (markBar != NULL) markBar->show(); 2979 if (markBar != NULL) markBar->show();
2982 if (m_prog != NULL && !m_statusishidden) 2980 if (m_prog != NULL && !m_statusishidden)
2983 { 2981 {
2984 // qDebug("Showing status"); 2982 // qDebug("Showing status");
2985 m_prog->show(); 2983 m_prog->show();
2986 // qDebug("Shown status"); 2984 // qDebug("Shown status");
2987 } 2985 }
2988 // qDebug("Showing mb"); 2986 // qDebug("Showing mb");
2989 mb->show(); 2987 mb->show();
2990 } 2988 }
2991 if ( searchVisible ) 2989 if ( searchVisible )
2992 { 2990 {
2993#ifdef USEQPE 2991#ifdef USEQPE
2994 Global::showInputMethod(); 2992 Global::showInputMethod();
2995#endif 2993#endif
2996 searchBar->show(); 2994 searchBar->show();
2997 } 2995 }
2998 if ( regVisible ) 2996 if ( regVisible )
2999 { 2997 {
3000#ifdef USEQPE 2998#ifdef USEQPE
3001 Global::showInputMethod(); 2999 Global::showInputMethod();
3002#endif 3000#endif
3003 regBar->show(); 3001 regBar->show();
3004 } 3002 }
3005 if (m_fontVisible) m_fontBar->show(); 3003 if (m_fontVisible) m_fontBar->show();
3006 //qDebug("sn"); 3004 //qDebug("sn");
3007 showNormal(); 3005 showNormal();
3008 //qDebug("sm"); 3006 //qDebug("sm");
3009#ifdef USEQPE 3007#ifdef USEQPE
3010 showMaximized(); 3008 showMaximized();
3011#endif 3009#endif
3012 //setCentralWidget(reader); 3010 //setCentralWidget(reader);
3013 } 3011 }
3014 3012
3015 // qDebug("uc"); 3013 // qDebug("uc");
3016 updateCaption(); 3014 updateCaption();
3017 // qDebug("rw"); 3015 // qDebug("rw");
3018 editorStack->raiseWidget( reader ); 3016 editorStack->raiseWidget( reader );
3019 // qDebug("sf"); 3017 // qDebug("sf");
3020 reader->setFocus(); 3018 reader->setFocus();
3021 // qDebug("ref"); 3019 // qDebug("ref");
3022 reader->refresh(true); 3020 reader->refresh(true);
3023 // qDebug("done"); 3021 // qDebug("done");
3024} 3022}
3025/* 3023/*
3026void QTReaderApp::save() 3024void QTReaderApp::save()
3027{ 3025{
3028 if ( !doc ) 3026 if ( !doc )
3029 return; 3027 return;
3030 if ( !editor->edited() ) 3028 if ( !editor->edited() )
3031 return; 3029 return;
3032 3030
3033 QString rt = editor->text(); 3031 QString rt = editor->text();
3034 QString pt = rt; 3032 QString pt = rt;
3035 3033
3036 if ( doc->name().isEmpty() ) { 3034 if ( doc->name().isEmpty() ) {
3037 unsigned ispace = pt.find( ' ' ); 3035 unsigned ispace = pt.find( ' ' );
3038 unsigned ienter = pt.find( '\n' ); 3036 unsigned ienter = pt.find( '\n' );
3039 int i = (ispace < ienter) ? ispace : ienter; 3037 int i = (ispace < ienter) ? ispace : ienter;
3040 QString docname; 3038 QString docname;
3041 if ( i == -1 ) { 3039 if ( i == -1 ) {
3042 if ( pt.isEmpty() ) 3040 if ( pt.isEmpty() )
3043 docname = "Empty Text"; 3041 docname = "Empty Text";
3044 else 3042 else
3045 docname = pt; 3043 docname = pt;
3046 } else { 3044 } else {
3047 docname = pt.left( i ); 3045 docname = pt.left( i );
3048 } 3046 }
3049 doc->setName(docname); 3047 doc->setName(docname);
3050 } 3048 }
3051 FileManager fm; 3049 FileManager fm;
3052 fm.saveFile( *doc, rt ); 3050 fm.saveFile( *doc, rt );
3053} 3051}
3054*/ 3052*/
3055 3053
3056void QTReaderApp::clear() 3054void QTReaderApp::clear()
3057{ 3055{
3058// if (doc != 0) 3056// if (doc != 0)
3059// { 3057// {
3060// QMessageBox::information(this, PROGNAME, "Deleting doc", 1); 3058// QMessageBox::information(this, PROGNAME, "Deleting doc", 1);
3061 //delete doc; 3059 //delete doc;
3062// QMessageBox::information(this, PROGNAME, "Deleted doc", 1); 3060// QMessageBox::information(this, PROGNAME, "Deleted doc", 1);
3063 //doc = 0; 3061 //doc = 0;
3064 // } 3062 // }
3065 reader->clear(); 3063 reader->clear();
3066} 3064}
3067 3065
3068void QTReaderApp::updateCaption() 3066void QTReaderApp::updateCaption()
3069{ 3067{
3070// if ( !doc ) 3068// if ( !doc )
3071 //setCaption( tr("QTReader") ); 3069 //setCaption( tr("QTReader") );
3072// else { 3070// else {
3073 //QString s = doc->name(); 3071 //QString s = doc->name();
3074 //if ( s.isEmpty() ) 3072 //if ( s.isEmpty() )
3075 // s = tr( "Unnamed" ); 3073 // s = tr( "Unnamed" );
3076 setCaption( reader->m_string + " - " + tr(SHORTPROGNAME) ); 3074 setCaption( reader->m_string + " - " + tr(SHORTPROGNAME) );
3077// } 3075// }
3078} 3076}
3079 3077
3080void QTReaderApp::setDocument(const QString& fileref) 3078void QTReaderApp::setDocument(const QString& fileref)
3081{ 3079{
3082//QMessageBox::information(0, "setDocument", fileref); 3080//QMessageBox::information(0, "setDocument", fileref);
3083 openFile(fileref); 3081 openFile(fileref);
3084// showEditTools(); 3082// showEditTools();
3085} 3083}
3086 3084
3087void QTReaderApp::closeEvent( QCloseEvent *e ) 3085void QTReaderApp::closeEvent( QCloseEvent *e )
3088{ 3086{
3089// qDebug("Close event"); 3087// qDebug("Close event");
3090 if (m_fullscreen) 3088 if (m_fullscreen)
3091 { 3089 {
3092 m_fullscreen = false; 3090 m_fullscreen = false;
3093 showEditTools(); 3091 showEditTools();
3094 e->ignore(); 3092 e->ignore();
3095 } 3093 }
3096 else if (editorStack->visibleWidget() == m_buttonprefs) 3094 else if (editorStack->visibleWidget() == m_buttonprefs)
3097 { 3095 {
3098 m_buttonprefs->mapkey(Qt::NoButton, Key_Escape); 3096 m_buttonprefs->mapkey(Qt::NoButton, Key_Escape);
3099 e->ignore(); 3097 e->ignore();
3100 } 3098 }
3101 else if (m_dontSave) 3099 else if (m_dontSave)
3102 { 3100 {
3103 e->accept(); 3101 e->accept();
3104 } 3102 }
3105 else 3103 else
3106 { 3104 {
3107 if (editorStack->visibleWidget() == reader) 3105 if (editorStack->visibleWidget() == reader)
3108 { 3106 {
3109 if ((kmap.find(orKey(Qt::NoButton,Key_Escape,false)) != kmap.end()) && m_bcloseDisabled) 3107 if ((kmap.find(orKey(Qt::NoButton,Key_Escape,false)) != kmap.end()) && m_bcloseDisabled)
3110 { 3108 {
3111 //qDebug("Close disabled"); 3109 //qDebug("Close disabled");
3112 m_bcloseDisabled = false; 3110 m_bcloseDisabled = false;
3113 e->ignore(); 3111 e->ignore();
3114 } 3112 }
3115 else 3113 else
3116 { 3114 {
3117 if (m_fontVisible) 3115 if (m_fontVisible)
3118 { 3116 {
3119 m_fontBar->hide(); 3117 m_fontBar->hide();
3120 m_fontVisible = false; 3118 m_fontVisible = false;
3121 e->ignore(); 3119 e->ignore();
3122 return; 3120 return;
3123 } 3121 }
3124 if (regVisible) 3122 if (regVisible)
3125 { 3123 {
3126 regBar->hide(); 3124 regBar->hide();
3127#ifdef USEQPE 3125#ifdef USEQPE
3128 Global::hideInputMethod(); 3126 Global::hideInputMethod();
3129#endif 3127#endif
3130 regVisible = false; 3128 regVisible = false;
3131 e->ignore(); 3129 e->ignore();
3132 return; 3130 return;
3133 } 3131 }
3134 if (searchVisible) 3132 if (searchVisible)
3135 { 3133 {
3136 searchBar->hide(); 3134 searchBar->hide();
3137#ifdef USEQPE 3135#ifdef USEQPE
3138 Global::hideInputMethod(); 3136 Global::hideInputMethod();
3139#endif 3137#endif
3140 searchVisible = false; 3138 searchVisible = false;
3141 e->ignore(); 3139 e->ignore();
3142 return; 3140 return;
3143 } 3141 }
3144 if (m_fBkmksChanged && pBkmklist != NULL) 3142 if (m_fBkmksChanged && pBkmklist != NULL)
3145 { 3143 {
3146 if (QMessageBox::warning(this, PROGNAME, "Save bookmarks?", "Save", "Don't bother") == 0) 3144 if (QMessageBox::warning(this, PROGNAME, "Save bookmarks?", "Save", "Don't bother") == 0)
3147 savebkmks(); 3145 savebkmks();
3148 delete pBkmklist; 3146 delete pBkmklist;
3149 reader->pBkmklist = pBkmklist = NULL; 3147 reader->pBkmklist = pBkmklist = NULL;
3150 m_fBkmksChanged = false; 3148 m_fBkmksChanged = false;
3151 } 3149 }
3152 updatefileinfo(); 3150 updatefileinfo();
3153 saveprefs(); 3151 saveprefs();
3154 e->accept(); 3152 e->accept();
3155 } 3153 }
3156 } 3154 }
3157 else 3155 else
3158 { 3156 {
diff --git a/noncore/apps/opie-reader/QTReaderApp.h b/noncore/apps/opie-reader/QTReaderApp.h
index 5ecc42d..ad47fc9 100644
--- a/noncore/apps/opie-reader/QTReaderApp.h
+++ b/noncore/apps/opie-reader/QTReaderApp.h
@@ -1,485 +1,484 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qt Palmtop Environment. 4** This file is part of Qt Palmtop Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#ifndef __QTREADERAPP_H 20#ifndef __QTREADERAPP_H
21#define __QTREADERAPP_H 21#define __QTREADERAPP_H
22 22
23//#define _SCROLLPIPE 23//#define _SCROLLPIPE
24//#define __ISEARCH 24//#define __ISEARCH
25 25
26//#define MAX_ENCODING 6 26//#define MAX_ENCODING 6
27#define MAX_ACTIONS 5 27#define MAX_ACTIONS 5
28 28
29#include "useqpe.h"
30#include <sys/timeb.h> 29#include <sys/timeb.h>
31#include <qmainwindow.h> 30#include <qmainwindow.h>
32#include "CExpander.h" 31#include "CExpander.h"
33#include "CEncoding.h" 32#include "CEncoding.h"
34#include <qlist.h> 33#include <qlist.h>
35//#include <qpe/filemanager.h> 34//#include <qpe/filemanager.h>
36#include <qmap.h> 35#include <qmap.h>
37#include <qlineedit.h> 36#include <qlineedit.h>
38#include <qstack.h> 37#include <qstack.h>
39#include <qlistbox.h> 38#include <qlistbox.h>
40#ifdef USEQPE 39#ifdef USEQPE
41#include <qpe/qpeapplication.h> 40#include <qpe/qpeapplication.h>
42#endif 41#endif
43#include "orkey.h" 42#include "orkey.h"
44//#include "Queue.h" 43//#include "Queue.h"
45#include "BGType.h" 44#include "BGType.h"
46 45
47class QBoxLayout; 46class QBoxLayout;
48class QWidgetStack; 47class QWidgetStack;
49class QToolButton; 48class QToolButton;
50class QPopupMenu; 49class QPopupMenu;
51class QToolBar; 50class QToolBar;
52#ifdef USEQPE 51#ifdef USEQPE
53class QPEToolBar; 52class QPEToolBar;
54class QPEMenuBar; 53class QPEMenuBar;
55#endif 54#endif
56class QScrollBar; 55class QScrollBar;
57class CBkmkSelector; 56class CBkmkSelector;
58class QProgressBar; 57class QProgressBar;
59class QAction; 58class QAction;
60class CAnnoEdit; 59class CAnnoEdit;
61class QFloatBar; 60class QFloatBar;
62class CDrawBuffer; 61class CDrawBuffer;
63class QTReader; 62class QTReader;
64class QImage; 63class QImage;
65class Config; 64class Config;
66class CButtonPrefs; 65class CButtonPrefs;
67 66
68#ifdef USEQPE 67#ifdef USEQPE
69enum ToolbarPolicy 68enum ToolbarPolicy
70{ 69{
71 cesSingle = 0, 70 cesSingle = 0,
72 cesMenuTool, 71 cesMenuTool,
73 cesMultiple 72 cesMultiple
74}; 73};
75#else 74#else
76enum ToolbarPolicy 75enum ToolbarPolicy
77{ 76{
78 cesMenuTool = 0, 77 cesMenuTool = 0,
79 cesMultiple 78 cesMultiple
80}; 79};
81#endif 80#endif
82 81
83enum regedit_type 82enum regedit_type
84{ 83{
85 cAutoGen, 84 cAutoGen,
86 cAddBkmk, 85 cAddBkmk,
87 cJump, 86 cJump,
88 cMonoSpace, 87 cMonoSpace,
89 cSetTarget, 88 cSetTarget,
90#ifdef _SCROLLPIPE 89#ifdef _SCROLLPIPE
91 cSetPipeTarget, 90 cSetPipeTarget,
92#endif 91#endif
93 cSetConfigName, 92 cSetConfigName,
94 cMargin, 93 cMargin,
95 cExtraSpace, 94 cExtraSpace,
96 cExtraLead, 95 cExtraLead,
97 cRepara 96 cRepara
98}; 97};
99 98
100enum bkmk_action 99enum bkmk_action
101{ 100{
102 cOpenFile, 101 cOpenFile,
103 cGotoBkmk, 102 cGotoBkmk,
104 cDelBkmk, 103 cDelBkmk,
105 cRmBkmkFile, 104 cRmBkmkFile,
106 cLdConfig, 105 cLdConfig,
107 cRmConfig, 106 cRmConfig,
108 cExportLinks, 107 cExportLinks,
109 cLdTheme 108 cLdTheme
110}; 109};
111 110
112enum fontselector_action 111enum fontselector_action
113{ 112{
114 cChooseFont, 113 cChooseFont,
115 cChooseEncoding 114 cChooseEncoding
116}; 115};
117 116
118#ifdef __ISEARCH 117#ifdef __ISEARCH
119struct searchrecord 118struct searchrecord
120{ 119{
121 QString s; 120 QString s;
122 size_t pos; 121 size_t pos;
123 searchrecord(const QString& _s, size_t _pos) : s(_s), pos(_pos) {} 122 searchrecord(const QString& _s, size_t _pos) : s(_s), pos(_pos) {}
124}; 123};
125#endif 124#endif
126 125
127class infowin; 126class infowin;
128class GraphicWin; 127class GraphicWin;
129 128
130class QTReaderApp : public QMainWindow 129class QTReaderApp : public QMainWindow
131{ 130{
132 Q_OBJECT 131 Q_OBJECT
133 132
134 QColor getcolour(int c); 133 QColor getcolour(int c);
135 134
136 QMap<orKey, int> kmap; 135 QMap<orKey, int> kmap;
137 unsigned long m_savedpos; 136 unsigned long m_savedpos;
138 int m_debounce; 137 int m_debounce;
139 bool m_kmapchanged; 138 bool m_kmapchanged;
140 bground m_bgtype; 139 bground m_bgtype;
141 timeb m_lastkeytime; 140 timeb m_lastkeytime;
142 QScrollBar* m_scrollbar; 141 QScrollBar* m_scrollbar;
143 QScrollBar* scrollbar; 142 QScrollBar* scrollbar;
144 int m_qtscroll, m_localscroll; 143 int m_qtscroll, m_localscroll;
145 bool m_hidebars, m_scrollishidden, m_statusishidden; 144 bool m_hidebars, m_scrollishidden, m_statusishidden;
146 QBoxLayout *m_layout; 145 QBoxLayout *m_layout;
147 QLabel* m_prog; 146 QLabel* m_prog;
148 bool m_annoIsEditing; 147 bool m_annoIsEditing;
149 bool m_propogatefontchange, m_bFloatingDialog; 148 bool m_propogatefontchange, m_bFloatingDialog;
150 bool m_url_clipboard, m_url_localfile, m_url_globalfile; 149 bool m_url_clipboard, m_url_localfile, m_url_globalfile;
151 CButtonPrefs* m_buttonprefs; 150 CButtonPrefs* m_buttonprefs;
152 fontselector_action m_fontAction; 151 fontselector_action m_fontAction;
153 void doAction(QKeyEvent* e); 152 void doAction(QKeyEvent* e);
154 153
155 public: 154 public:
156 QTReaderApp( QWidget *parent = 0, const char *name = 0, WFlags f = 0 ); 155 QTReaderApp( QWidget *parent = 0, const char *name = 0, WFlags f = 0 );
157 ~QTReaderApp(); 156 ~QTReaderApp();
158 157
159 void hideEvent(QHideEvent*) 158 void hideEvent(QHideEvent*)
160 { 159 {
161#ifdef USEQPE 160#ifdef USEQPE
162 if (m_grabkeyboard) 161 if (m_grabkeyboard)
163 { 162 {
164 ((QPEApplication*)qApp)->ungrabKeyboard(); 163 ((QPEApplication*)qApp)->ungrabKeyboard();
165 } 164 }
166#endif 165#endif
167 suspend(); 166 suspend();
168 } 167 }
169#ifdef USEQPE 168#ifdef USEQPE
170 void showEvent(QShowEvent*) 169 void showEvent(QShowEvent*)
171 { 170 {
172 if (m_grabkeyboard) 171 if (m_grabkeyboard)
173 { 172 {
174 ((QPEApplication*)qApp)->grabKeyboard(); 173 ((QPEApplication*)qApp)->grabKeyboard();
175 } 174 }
176 } 175 }
177#endif 176#endif
178 void suspend(); 177 void suspend();
179 void openFile( const QString & ); 178 void openFile( const QString & );
180 179
181 180
182 protected: 181 protected:
183 void setfontHelper(const QString& lcn, int size = 0); 182 void setfontHelper(const QString& lcn, int size = 0);
184 QAction* m_bkmkAvail, *m_actFullscreen; 183 QAction* m_bkmkAvail, *m_actFullscreen;
185 CAnnoEdit* m_annoWin; 184 CAnnoEdit* m_annoWin;
186 Bkmk* m_anno; 185 Bkmk* m_anno;
187 int m_scrollcolor, m_scrollbarcolor, m_background, m_foreground; 186 int m_scrollcolor, m_scrollbarcolor, m_background, m_foreground;
188// void resizeEvent(QResizeEvent* e); 187// void resizeEvent(QResizeEvent* e);
189 void closeEvent( QCloseEvent *e ); 188 void closeEvent( QCloseEvent *e );
190#ifdef NEWFULLSCREEN 189#ifdef NEWFULLSCREEN
191 void resizeEvent(QResizeEvent *); 190 void resizeEvent(QResizeEvent *);
192 void focusInEvent(QFocusEvent*); 191 void focusInEvent(QFocusEvent*);
193 void enableFullscreen(); 192 void enableFullscreen();
194#endif 193#endif
195 void readbkmks(); 194 void readbkmks();
196 void do_mono(const QString&); 195 void do_mono(const QString&);
197 void do_jump(const QString&); 196 void do_jump(const QString&);
198 void do_reparastring(const QString&); 197 void do_reparastring(const QString&);
199 void do_settarget(const QString&); 198 void do_settarget(const QString&);
200#ifdef _SCROLLPIPE 199#ifdef _SCROLLPIPE
201 //void do_setpipetarget(const QString&); 200 //void do_setpipetarget(const QString&);
202#endif 201#endif
203 void do_saveconfig(const QString&, bool); 202 void do_saveconfig(const QString&, bool);
204 bool readconfig(const QString&, const QString&, bool); 203 bool readconfig(const QString&, const QString&, bool);
205 bool PopulateConfig(const char*, bool usedirs = false); 204 bool PopulateConfig(const char*, bool usedirs = false);
206 ActionTypes ActNameToInt(const QString&); 205 ActionTypes ActNameToInt(const QString&);
207#ifdef USEQPE 206#ifdef USEQPE
208 bool m_grabkeyboard; 207 bool m_grabkeyboard;
209#endif 208#endif
210 bool m_doAnnotation; 209 bool m_doAnnotation;
211 bool m_doDictionary; 210 bool m_doDictionary;
212 bool m_doClipboard; 211 bool m_doClipboard;
213 bool m_fullscreen; 212 bool m_fullscreen;
214 bool m_loadedconfig; 213 bool m_loadedconfig;
215 public: 214 public:
216 void saveprefs(); 215 void saveprefs();
217public slots: 216public slots:
218 void setBackgroundBitmap(); 217 void setBackgroundBitmap();
219 void UpdateStatus(); 218 void UpdateStatus();
220 void setScrollState(bool _b); 219 void setScrollState(bool _b);
221 void handlekey(QKeyEvent* e); 220 void handlekey(QKeyEvent* e);
222 void forceopen(const QString& filename); 221 void forceopen(const QString& filename);
223 void setDocument(const QString&); 222 void setDocument(const QString&);
224private slots: 223private slots:
225#ifdef _SCRIPT 224#ifdef _SCRIPT
226// void RunScript(); 225// void RunScript();
227#endif 226#endif
228 void actionscroll(int v); 227 void actionscroll(int v);
229 void SaveConfig(); 228 void SaveConfig();
230 void LoadTheme(); 229 void LoadTheme();
231 void LoadConfig(); 230 void LoadConfig();
232 void TidyConfig(); 231 void TidyConfig();
233 void ExportLinks(); 232 void ExportLinks();
234 void zoomin(); 233 void zoomin();
235 void zoomout(); 234 void zoomout();
236 void chooseencoding(); 235 void chooseencoding();
237 void setfullscreen(bool sfs); 236 void setfullscreen(bool sfs);
238 void setrotated(bool sfs); 237 void setrotated(bool sfs);
239 void setinverted(bool sfs); 238 void setinverted(bool sfs);
240 void setgrab(bool sfs); 239 void setgrab(bool sfs);
241// void setcontinuous(bool sfs); 240// void setcontinuous(bool sfs);
242 void setTwoTouch(bool _b); 241 void setTwoTouch(bool _b);
243 void restoreFocus(); 242 void restoreFocus();
244 void OnAnnotation(bool _b) 243 void OnAnnotation(bool _b)
245 { 244 {
246 m_doAnnotation = _b; 245 m_doAnnotation = _b;
247 } 246 }
248 void OnDictionary(bool _b) 247 void OnDictionary(bool _b)
249 { 248 {
250 m_doDictionary = _b; 249 m_doDictionary = _b;
251 } 250 }
252 void OnClipboard(bool _b) 251 void OnClipboard(bool _b)
253 { 252 {
254 m_doClipboard = _b; 253 m_doClipboard = _b;
255 } 254 }
256 void OnWordSelected(const QString&, size_t, size_t, const QString&); 255 void OnWordSelected(const QString&, size_t, size_t, const QString&);
257 void OnURLSelected(const QString& href, const size_t tgt); 256 void OnURLSelected(const QString& href, const size_t tgt);
258 void showgraphic(QImage&); 257 void showgraphic(QImage&);
259 void addAnno(const QString&, const QString&, size_t, size_t); 258 void addAnno(const QString&, const QString&, size_t, size_t);
260 void addAnno(const QString&, const QString&); 259 void addAnno(const QString&, const QString&);
261 void addanno(); 260 void addanno();
262 void showAnnotation(); 261 void showAnnotation();
263 void do_setencoding(int i); 262 void do_setencoding(int i);
264 void do_setfont(const QString&); 263 void do_setfont(const QString&);
265 //void buttonActionSelected(QAction*); 264 //void buttonActionSelected(QAction*);
266 void msgHandler(const QCString&, const QByteArray&); 265 void msgHandler(const QCString&, const QByteArray&);
267 void monospace(bool); 266 void monospace(bool);
268 void jump(); 267 void jump();
269 void reparastring(); 268 void reparastring();
270 void settarget(); 269 void settarget();
271#ifdef _SCROLLPIPE 270#ifdef _SCROLLPIPE
272 //void setpipetarget(); 271 //void setpipetarget();
273 //void setpause(bool); 272 //void setpause(bool);
274#endif 273#endif
275 //void setspacing(); 274 //void setspacing();
276 void setfont(); 275 void setfont();
277 void clearBkmkList(); 276 void clearBkmkList();
278 void listBkmkFiles(); 277 void listBkmkFiles();
279 void editMark(); 278 void editMark();
280 void autoScroll(bool); 279 void autoScroll(bool);
281 void addbkmk(); 280 void addbkmk();
282 void savebkmks(); 281 void savebkmks();
283 //void importFiles(); 282 //void importFiles();
284 void showprefs(); 283 void showprefs();
285 void showtoolbarprefs(); 284 void showtoolbarprefs();
286 void showbuttonprefs(); 285 void showbuttonprefs();
287 void infoClose(); 286 void infoClose();
288 // void oldFile(); 287 // void oldFile();
289 void showinfo(); 288 void showinfo();
290 289
291// void indentplus(); 290// void indentplus();
292// void indentminus(); 291// void indentminus();
293 292
294 void fileOpen(); 293 void fileOpen();
295 void fileClose(); 294 void fileClose();
296 295
297 void editCopy(); 296 void editCopy();
298 void editFind(); 297 void editFind();
299 298
300 void gotoStart(); 299 void gotoStart();
301 void gotoEnd(); 300 void gotoEnd();
302 301
303 void pageup(); 302 void pageup();
304 void pagedn(); 303 void pagedn();
305 304
306 void findNext(); 305 void findNext();
307 void findClose(); 306 void findClose();
308 307
309 void regClose(); 308 void regClose();
310 309
311#ifdef __ISEARCH 310#ifdef __ISEARCH
312// void search( const QString& ); 311// void search( const QString& );
313#else 312#else
314 void search(); 313 void search();
315#endif 314#endif
316 315
317 void showEditTools(); 316 void showEditTools();
318 317
319// void stripcr(bool); 318// void stripcr(bool);
320// void setfulljust(bool); 319// void setfulljust(bool);
321// void onespace(bool); 320// void onespace(bool);
322// void repalm(bool); 321// void repalm(bool);
323// void peanut(bool _b); 322// void peanut(bool _b);
324// void remap(bool); 323// void remap(bool);
325// void embolden(bool); 324// void embolden(bool);
326// void autofmt(bool); 325// void autofmt(bool);
327// void textfmt(bool); 326// void textfmt(bool);
328// void striphtml(bool); 327// void striphtml(bool);
329// void dehyphen(bool); 328// void dehyphen(bool);
330// void depluck(bool); 329// void depluck(bool);
331// void dejpluck(bool); 330// void dejpluck(bool);
332// void unindent(bool); 331// void unindent(bool);
333// void repara(bool); 332// void repara(bool);
334// void dblspce(bool); 333// void dblspce(bool);
335 void pagemode(bool); 334 void pagemode(bool);
336 // void gotobkmk(const QString& bm); 335 // void gotobkmk(const QString& bm);
337 void gotobkmk(int); 336 void gotobkmk(int);
338 void cancelbkmk(); 337 void cancelbkmk();
339 void do_gotomark(); 338 void do_gotomark();
340 void do_delmark(); 339 void do_delmark();
341 void do_autogen(); 340 void do_autogen();
342 void do_regaction(); 341 void do_regaction();
343 void OnRedraw(); 342 void OnRedraw();
344 343
345 private: 344 private:
346 void setscrollcolour(); 345 void setscrollcolour();
347 void setscrollbarcolour(); 346 void setscrollbarcolour();
348 void writeUrl(const QString& file, const QString& href); 347 void writeUrl(const QString& file, const QString& href);
349 QAction *m_preferences_action, *m_open_action, *m_close_action; 348 QAction *m_preferences_action, *m_open_action, *m_close_action;
350 QAction *m_info_action, *m_touch_action, *m_find_action, *m_start_action; 349 QAction *m_info_action, *m_touch_action, *m_find_action, *m_start_action;
351 QAction *m_end_action, *m_jump_action, *m_pageline_action; 350 QAction *m_end_action, *m_jump_action, *m_pageline_action;
352 QAction *m_pageup_action, *m_pagedn_action, *m_back_action; 351 QAction *m_pageup_action, *m_pagedn_action, *m_back_action;
353 QAction *m_home_action, *m_forward_action, *m_zoomin_action; 352 QAction *m_home_action, *m_forward_action, *m_zoomin_action;
354 QAction *m_zoomout_action, *m_setfont_action, *m_mark_action; 353 QAction *m_zoomout_action, *m_setfont_action, *m_mark_action;
355 QAction *m_annotate_action, *m_goto_action, *m_delete_action; 354 QAction *m_annotate_action, *m_goto_action, *m_delete_action;
356 QAction *m_autogen_action, *m_clear_action, *m_save_action; 355 QAction *m_autogen_action, *m_clear_action, *m_save_action;
357 QAction *m_tidy_action, *m_startBlock_action, *m_endBlock_action; 356 QAction *m_tidy_action, *m_startBlock_action, *m_endBlock_action;
358 QAction *m_setenc_action, *m_setmono_action, *m_saveconfig_action; 357 QAction *m_setenc_action, *m_setmono_action, *m_saveconfig_action;
359 QAction *m_loadconfig_action, *m_loadtheme_action, *m_toolbarprefs_action, *m_tidyconfig_action; 358 QAction *m_loadconfig_action, *m_loadtheme_action, *m_toolbarprefs_action, *m_tidyconfig_action;
360 QAction *m_exportlinks_action, *m_rotate_action, *m_buttonprefs_action, *m_inverse_action; 359 QAction *m_exportlinks_action, *m_rotate_action, *m_buttonprefs_action, *m_inverse_action;
361 QAction *m_repara_action; 360 QAction *m_repara_action;
362#ifdef USEQPE 361#ifdef USEQPE
363 QAction *m_grab_action; 362 QAction *m_grab_action;
364#endif 363#endif
365 void addtoolbars(Config* config); 364 void addtoolbars(Config* config);
366 ToolbarPolicy m_tbpol, m_tbpolsave; 365 ToolbarPolicy m_tbpol, m_tbpolsave;
367 ToolBarDock m_tbposition; 366 ToolBarDock m_tbposition;
368 bool m_tbmove, m_tbmovesave; 367 bool m_tbmove, m_tbmovesave;
369 QToolBar* filebar(); 368 QToolBar* filebar();
370 QToolBar* viewbar(); 369 QToolBar* viewbar();
371 QToolBar* navbar(); 370 QToolBar* navbar();
372 QToolBar* markbar(); 371 QToolBar* markbar();
373 void hidetoolbars(); 372 void hidetoolbars();
374 void addfilebar(Config* _config, const QString& key, QAction* a); 373 void addfilebar(Config* _config, const QString& key, QAction* a);
375 void addviewbar(Config* _config, const QString& key, QAction* a); 374 void addviewbar(Config* _config, const QString& key, QAction* a);
376 void addnavbar(Config* _config, const QString& key, QAction* a); 375 void addnavbar(Config* _config, const QString& key, QAction* a);
377 void addmarkbar(Config* _config, const QString& key, QAction* a); 376 void addmarkbar(Config* _config, const QString& key, QAction* a);
378 bool checkbar(Config* _config, const QString& key); 377 bool checkbar(Config* _config, const QString& key);
379#ifdef _SCRIPT 378#ifdef _SCRIPT
380 void SaveScript(const char* sname); 379 void SaveScript(const char* sname);
381#endif 380#endif
382/* 381/*
383 void setstate(unsigned char* _sd, unsigned short _sdlen); 382 void setstate(unsigned char* _sd, unsigned short _sdlen);
384 void getstate(unsigned char*& data, unsigned short& len); 383 void getstate(unsigned char*& data, unsigned short& len);
385*/ 384*/
386 void fileOpen2(); 385 void fileOpen2();
387 void readfilelist(); 386 void readfilelist();
388 void savefilelist(); 387 void savefilelist();
389 void updatefileinfo(); 388 void updatefileinfo();
390 bool openfrombkmk(Bkmk*); 389 bool openfrombkmk(Bkmk*);
391 QString m_targetapp, m_targetmsg, m_statusstring, m_themename; 390 QString m_targetapp, m_targetmsg, m_statusstring, m_themename;
392 bool listbkmk(CList<Bkmk>*, const QString& _lab = QString::null); 391 bool listbkmk(CList<Bkmk>*, const QString& _lab = QString::null);
393 QString usefilebrowser(); 392 QString usefilebrowser();
394 void do_regedit(); 393 void do_regedit();
395 void colorChanged( const QColor &c ); 394 void colorChanged( const QColor &c );
396 void clear(); 395 void clear();
397 void updateCaption(); 396 void updateCaption();
398 void do_autogen(const QString&); 397 void do_autogen(const QString&);
399 void do_addbkmk(const QString&); 398 void do_addbkmk(const QString&);
400 bool findNextBookmark(size_t start); 399 bool findNextBookmark(size_t start);
401 400
402 private: 401 private:
403 402
404 QAction* m_scrollButton; 403 QAction* m_scrollButton;
405 404
406 QAction* m_buttonAction[MAX_ACTIONS]; 405 QAction* m_buttonAction[MAX_ACTIONS];
407 406
408 CBkmkSelector* bkmkselector; 407 CBkmkSelector* bkmkselector;
409 408
410 // ActionTypes m_spaceTarget, m_escapeTarget, m_returnTarget, m_leftTarget, m_rightTarget, 409 // ActionTypes m_spaceTarget, m_escapeTarget, m_returnTarget, m_leftTarget, m_rightTarget,
411 //m_upTarget, m_downTarget; 410 //m_upTarget, m_downTarget;
412 //bool m_leftScroll, m_rightScroll, m_upScroll, m_downScroll; 411 //bool m_leftScroll, m_rightScroll, m_upScroll, m_downScroll;
413 bool m_bcloseDisabled, m_disableesckey; 412 bool m_bcloseDisabled, m_disableesckey;
414 size_t searchStart; 413 size_t searchStart;
415#ifdef __ISEARCH 414#ifdef __ISEARCH
416 QStack<searchrecord>* searchStack; 415 QStack<searchrecord>* searchStack;
417 bool dosearch(size_t start, CDrawBuffer& test, const QString& arg); 416 bool dosearch(size_t start, CDrawBuffer& test, const QString& arg);
418#else 417#else
419 bool dosearch(size_t start, CDrawBuffer& test, const QRegExp& arg); 418 bool dosearch(size_t start, CDrawBuffer& test, const QRegExp& arg);
420#endif 419#endif
421 QWidgetStack *editorStack; 420 QWidgetStack *editorStack;
422 QTReader* reader; 421 QTReader* reader;
423 QComboBox* m_fontSelector; 422 QComboBox* m_fontSelector;
424// QPEToolBar /* *menu,*/ *fileBar; 423// QPEToolBar /* *menu,*/ *fileBar;
425#ifdef USEQPE 424#ifdef USEQPE
426 QToolBar *menubar; 425 QToolBar *menubar;
427#endif 426#endif
428 QToolBar *fileBar, *navBar, *viewBar, *markBar; 427 QToolBar *fileBar, *navBar, *viewBar, *markBar;
429#ifdef USEQPE 428#ifdef USEQPE
430 QPEMenuBar *mb; 429 QPEMenuBar *mb;
431#else 430#else
432 QMenuBar *mb; 431 QMenuBar *mb;
433#endif 432#endif
434 QFloatBar *searchBar, *regBar/*, *m_fontBar*/; 433 QFloatBar *searchBar, *regBar/*, *m_fontBar*/;
435 QToolBar /* *searchBar, *regBar,*/ *m_fontBar; 434 QToolBar /* *searchBar, *regBar,*/ *m_fontBar;
436 QLineEdit *searchEdit, *regEdit; 435 QLineEdit *searchEdit, *regEdit;
437 bool searchVisible; 436 bool searchVisible;
438 bool regVisible; 437 bool regVisible;
439 bool m_fontVisible, m_twoTouch; 438 bool m_fontVisible, m_twoTouch;
440 static unsigned long m_uid; 439 static unsigned long m_uid;
441 long unsigned get_unique_id() { return m_uid++; } 440 long unsigned get_unique_id() { return m_uid++; }
442 /* 441 /*
443 void resizeEvent( QResizeEvent * r) 442 void resizeEvent( QResizeEvent * r)
444 { 443 {
445// qDebug("resize:(%u,%u)", r->oldSize().width(), r->oldSize().height()); 444// qDebug("resize:(%u,%u)", r->oldSize().width(), r->oldSize().height());
446// qDebug("resize:(%u,%u)", r->size().width(), r->size().height()); 445// qDebug("resize:(%u,%u)", r->size().width(), r->size().height());
447 // bgroup->move( width()-bgroup->width(), 0 ); 446 // bgroup->move( width()-bgroup->width(), 0 );
448 } 447 }
449 */ 448 */
450 CList<Bkmk>* pBkmklist; 449 CList<Bkmk>* pBkmklist;
451 CList<Bkmk>* pOpenlist; 450 CList<Bkmk>* pOpenlist;
452 infowin* m_infoWin; 451 infowin* m_infoWin;
453 GraphicWin* m_graphicwin; 452 GraphicWin* m_graphicwin;
454 QProgressBar* pbar; 453 QProgressBar* pbar;
455 bool m_fBkmksChanged; 454 bool m_fBkmksChanged;
456// int m_nRegAction; 455// int m_nRegAction;
457 regedit_type m_nRegAction; 456 regedit_type m_nRegAction;
458 bkmk_action m_nBkmkAction; 457 bkmk_action m_nBkmkAction;
459 QString m_autogenstr; 458 QString m_autogenstr;
460 bool m_dontSave; 459 bool m_dontSave;
461}; 460};
462 461
463//const int cAutoGen = 0; 462//const int cAutoGen = 0;
464//const int cAddBkmk = 1; 463//const int cAddBkmk = 1;
465//const int cDelBkmk = 2; 464//const int cDelBkmk = 2;
466//const int cGotoBkmk = 3; 465//const int cGotoBkmk = 3;
467//const int cRmBkmkFile = 4; 466//const int cRmBkmkFile = 4;
468//const int cJump = 5; 467//const int cJump = 5;
469//const int cMonoSpace = 6; 468//const int cMonoSpace = 6;
470//const int cOverlap = 7; 469//const int cOverlap = 7;
471//const int cSetTarget = 8; 470//const int cSetTarget = 8;
472//const int cOpenFile = 9; 471//const int cOpenFile = 9;
473//const int cSetPipeTarget = 10; 472//const int cSetPipeTarget = 10;
474//const int cSetConfigName = 11; 473//const int cSetConfigName = 11;
475//const int cMargin = 12; 474//const int cMargin = 12;
476//const int cExtraSpace = 14; 475//const int cExtraSpace = 14;
477//const int cExtraLead = 15; 476//const int cExtraLead = 15;
478//const int cGfxSize = 16; 477//const int cGfxSize = 16;
479//const int cChooseFont = 2; 478//const int cChooseFont = 2;
480//const int cChooseEncoding = 1; 479//const int cChooseEncoding = 1;
481 480
482#endif 481#endif
483 482
484 483
485 484
diff --git a/noncore/apps/opie-reader/ToolbarPrefs.cpp b/noncore/apps/opie-reader/ToolbarPrefs.cpp
index 5cf220a..56c4e9b 100644
--- a/noncore/apps/opie-reader/ToolbarPrefs.cpp
+++ b/noncore/apps/opie-reader/ToolbarPrefs.cpp
@@ -1,547 +1,546 @@
1/**************************************************************************** 1/****************************************************************************
2** Form implementation generated from reading ui file 'Prefs.ui' 2** Form implementation generated from reading ui file 'Prefs.ui'
3** 3**
4** Created: Tue Feb 11 23:53:35 2003 4** Created: Tue Feb 11 23:53:35 2003
5** by: The User Interface Compiler (uic) 5** by: The User Interface Compiler (uic)
6** 6**
7** WARNING! All changes made in this file will be lost! 7** WARNING! All changes made in this file will be lost!
8****************************************************************************/ 8****************************************************************************/
9#include "useqpe.h"
10#include "ToolbarPrefs.h" 9#include "ToolbarPrefs.h"
11 10
12#include <qcheckbox.h> 11#include <qcheckbox.h>
13#include <qlabel.h> 12#include <qlabel.h>
14#include <qpushbutton.h> 13#include <qpushbutton.h>
15#include <qspinbox.h> 14#include <qspinbox.h>
16#include <qlayout.h> 15#include <qlayout.h>
17#include <qvariant.h> 16#include <qvariant.h>
18#include <qtooltip.h> 17#include <qtooltip.h>
19#include <qwhatsthis.h> 18#include <qwhatsthis.h>
20#include <qcombobox.h> 19#include <qcombobox.h>
21#include <qbuttongroup.h> 20#include <qbuttongroup.h>
22#include <qlineedit.h> 21#include <qlineedit.h>
23#ifdef USEQPE 22#ifdef USEQPE
24#include <qpe/menubutton.h> 23#include <qpe/menubutton.h>
25#endif 24#endif
26 25
27CBarPrefs::CBarPrefs(const QString& appdir, bool fs, QWidget* parent, const char* name) : QDialog(parent, name, true), config( appdir ) 26CBarPrefs::CBarPrefs(const QString& appdir, bool fs, QWidget* parent, const char* name) : QDialog(parent, name, true), config( appdir )
28{ 27{
29 setCaption(tr( "Toolbar Settings" ) ); 28 setCaption(tr( "Toolbar Settings" ) );
30 QTabWidget* td = new QTabWidget(this); 29 QTabWidget* td = new QTabWidget(this);
31 misc = new CMiscBarPrefs(this); 30 misc = new CMiscBarPrefs(this);
32 filebar = new CFileBarPrefs(config, this); 31 filebar = new CFileBarPrefs(config, this);
33 navbar = new CNavBarPrefs(config, this); 32 navbar = new CNavBarPrefs(config, this);
34 viewbar = new CViewBarPrefs(config, this); 33 viewbar = new CViewBarPrefs(config, this);
35 markbar = new CMarkBarPrefs(config, this); 34 markbar = new CMarkBarPrefs(config, this);
36 indbar = new CIndBarPrefs(config, this); 35 indbar = new CIndBarPrefs(config, this);
37 td->addTab(filebar, tr("File")); 36 td->addTab(filebar, tr("File"));
38 td->addTab(navbar, tr("Navigation")); 37 td->addTab(navbar, tr("Navigation"));
39 td->addTab(viewbar, tr("View")); 38 td->addTab(viewbar, tr("View"));
40 td->addTab(markbar, tr("Marks")); 39 td->addTab(markbar, tr("Marks"));
41 td->addTab(indbar, tr("Indicators")); 40 td->addTab(indbar, tr("Indicators"));
42 td->addTab(misc, tr("Policy")); 41 td->addTab(misc, tr("Policy"));
43 QVBoxLayout* v = new QVBoxLayout(this); 42 QVBoxLayout* v = new QVBoxLayout(this);
44 v->addWidget(td); 43 v->addWidget(td);
45 44
46 if (fs) showMaximized(); 45 if (fs) showMaximized();
47} 46}
48 47
49/* 48/*
50CBarPrefs1::CBarPrefs1( Config& _config, QWidget* parent, const char* name, WFlags fl ) 49CBarPrefs1::CBarPrefs1( Config& _config, QWidget* parent, const char* name, WFlags fl )
51 : QWidget( parent, name, fl ), config(_config) 50 : QWidget( parent, name, fl ), config(_config)
52{ 51{
53 config.setGroup( "Toolbar" ); 52 config.setGroup( "Toolbar" );
54 QVBoxLayout* vb = new QVBoxLayout(this); 53 QVBoxLayout* vb = new QVBoxLayout(this);
55 54
56 QGroupBox* bg = new QGroupBox(3, Qt::Horizontal, "File", this); 55 QGroupBox* bg = new QGroupBox(3, Qt::Horizontal, "File", this);
57 vb->addWidget(bg); 56 vb->addWidget(bg);
58 57
59 open = new QCheckBox( tr("Open"), bg ); 58 open = new QCheckBox( tr("Open"), bg );
60 open->setChecked(config.readBoolEntry( "Open", false )); 59 open->setChecked(config.readBoolEntry( "Open", false ));
61 connect(open, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 60 connect(open, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
62 close = new QCheckBox( tr("Close"), bg ); 61 close = new QCheckBox( tr("Close"), bg );
63 close->setChecked(config.readBoolEntry( "Close", false )); 62 close->setChecked(config.readBoolEntry( "Close", false ));
64 connect(close, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 63 connect(close, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
65 info = new QCheckBox( tr("Info"), bg ); 64 info = new QCheckBox( tr("Info"), bg );
66 info->setChecked(config.readBoolEntry( "Info", false )); 65 info->setChecked(config.readBoolEntry( "Info", false ));
67 connect(info, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 66 connect(info, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
68 twotouch = new QCheckBox( tr("Two/One\nTouch"), bg ); 67 twotouch = new QCheckBox( tr("Two/One\nTouch"), bg );
69 twotouch->setChecked(config.readBoolEntry( "Two/One Touch", false )); 68 twotouch->setChecked(config.readBoolEntry( "Two/One Touch", false ));
70 connect(twotouch, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 69 connect(twotouch, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
71 find = new QCheckBox( tr("Find"), bg ); 70 find = new QCheckBox( tr("Find"), bg );
72 find->setChecked(config.readBoolEntry( "Find", false )); 71 find->setChecked(config.readBoolEntry( "Find", false ));
73 connect(find, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 72 connect(find, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
74 73
75 bg = new QGroupBox(2, Qt::Horizontal, "Navigation", this); 74 bg = new QGroupBox(2, Qt::Horizontal, "Navigation", this);
76 vb->addWidget(bg); 75 vb->addWidget(bg);
77 scroll = new QCheckBox( tr("Scroll"), bg ); 76 scroll = new QCheckBox( tr("Scroll"), bg );
78 scroll->setChecked(config.readBoolEntry( "Scroll", false )); 77 scroll->setChecked(config.readBoolEntry( "Scroll", false ));
79 connect(scroll, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 78 connect(scroll, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
80 navigation = new QCheckBox( tr("Back/Home/Forward"), bg ); 79 navigation = new QCheckBox( tr("Back/Home/Forward"), bg );
81 navigation->setChecked(config.readBoolEntry( "Back/Home/Forward", false )); 80 navigation->setChecked(config.readBoolEntry( "Back/Home/Forward", false ));
82 connect(navigation, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 81 connect(navigation, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
83 page = new QCheckBox( tr("Page\nUp/Down"), bg ); 82 page = new QCheckBox( tr("Page\nUp/Down"), bg );
84 page->setChecked(config.readBoolEntry( "Page Up/Down", false )); 83 page->setChecked(config.readBoolEntry( "Page Up/Down", false ));
85 connect(page, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 84 connect(page, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
86 startend = new QCheckBox( tr("Goto Start/End"), bg ); 85 startend = new QCheckBox( tr("Goto Start/End"), bg );
87 startend->setChecked(config.readBoolEntry( "Goto Start/End", false )); 86 startend->setChecked(config.readBoolEntry( "Goto Start/End", false ));
88 connect(startend, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 87 connect(startend, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
89 jump = new QCheckBox( tr("Jump"), bg ); 88 jump = new QCheckBox( tr("Jump"), bg );
90 jump->setChecked(config.readBoolEntry( "Jump", false )); 89 jump->setChecked(config.readBoolEntry( "Jump", false ));
91 connect(jump, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 90 connect(jump, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
92 pageline = new QCheckBox( tr("Page/Line Scroll"), bg ); 91 pageline = new QCheckBox( tr("Page/Line Scroll"), bg );
93 pageline->setChecked(config.readBoolEntry( "Page/Line Scroll", false )); 92 pageline->setChecked(config.readBoolEntry( "Page/Line Scroll", false ));
94 connect(pageline, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 93 connect(pageline, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
95 m_isChanged = false; 94 m_isChanged = false;
96} 95}
97 96
98void CBarPrefs1::saveall() 97void CBarPrefs1::saveall()
99{ 98{
100 config.setGroup( "Toolbar" ); 99 config.setGroup( "Toolbar" );
101 config.writeEntry( "Open", open->isChecked()); 100 config.writeEntry( "Open", open->isChecked());
102 config.writeEntry( "Close", close->isChecked()); 101 config.writeEntry( "Close", close->isChecked());
103 config.writeEntry( "Info", info->isChecked()); 102 config.writeEntry( "Info", info->isChecked());
104 config.writeEntry( "Two/One Touch", twotouch->isChecked()); 103 config.writeEntry( "Two/One Touch", twotouch->isChecked());
105 config.writeEntry( "Find", find->isChecked()); 104 config.writeEntry( "Find", find->isChecked());
106 config.writeEntry( "Scroll", scroll->isChecked()); 105 config.writeEntry( "Scroll", scroll->isChecked());
107 config.writeEntry( "Back/Home/Forward", navigation->isChecked()); 106 config.writeEntry( "Back/Home/Forward", navigation->isChecked());
108 config.writeEntry( "Page Up/Down", page->isChecked()); 107 config.writeEntry( "Page Up/Down", page->isChecked());
109 config.writeEntry( "Goto Start/End", startend->isChecked()); 108 config.writeEntry( "Goto Start/End", startend->isChecked());
110 config.writeEntry( "Jump", jump->isChecked()); 109 config.writeEntry( "Jump", jump->isChecked());
111 config.writeEntry( "Page/Line Scroll", pageline->isChecked()); 110 config.writeEntry( "Page/Line Scroll", pageline->isChecked());
112} 111}
113 112
114CBarPrefs1::~CBarPrefs1() 113CBarPrefs1::~CBarPrefs1()
115{ 114{
116} 115}
117*/ 116*/
118/* 117/*
119CBarPrefs2::CBarPrefs2( Config& _config, QWidget* parent, const char* name, WFlags fl ) 118CBarPrefs2::CBarPrefs2( Config& _config, QWidget* parent, const char* name, WFlags fl )
120 : QWidget( parent, name, fl ), config(_config) 119 : QWidget( parent, name, fl ), config(_config)
121{ 120{
122 QVBoxLayout* vb = new QVBoxLayout(this); 121 QVBoxLayout* vb = new QVBoxLayout(this);
123 122
124 QGroupBox* bg = new QGroupBox(3, Qt::Horizontal, "View", this); 123 QGroupBox* bg = new QGroupBox(3, Qt::Horizontal, "View", this);
125 vb->addWidget(bg); 124 vb->addWidget(bg);
126 125
127 config.setGroup( "Toolbar" ); 126 config.setGroup( "Toolbar" );
128 127
129 fullscreen = new QCheckBox( tr("Fullscreen"), bg ); 128 fullscreen = new QCheckBox( tr("Fullscreen"), bg );
130 fullscreen->setChecked(config.readBoolEntry( "Fullscreen", false )); 129 fullscreen->setChecked(config.readBoolEntry( "Fullscreen", false ));
131 connect(fullscreen, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 130 connect(fullscreen, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
132 rotate = new QCheckBox( tr("Rotate"), bg ); 131 rotate = new QCheckBox( tr("Rotate"), bg );
133 rotate->setChecked(config.readBoolEntry( "Rotate", false )); 132 rotate->setChecked(config.readBoolEntry( "Rotate", false ));
134 connect(rotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 133 connect(rotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
135 134
136 invert = new QCheckBox( tr("Invert"), bg ); 135 invert = new QCheckBox( tr("Invert"), bg );
137 invert->setChecked(config.readBoolEntry( "Invert Action", false )); 136 invert->setChecked(config.readBoolEntry( "Invert Action", false ));
138 connect(invert, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 137 connect(invert, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
139 138
140 zoom = new QCheckBox( tr("Zoom"), bg ); 139 zoom = new QCheckBox( tr("Zoom"), bg );
141 zoom->setChecked(config.readBoolEntry( "Zoom In/Out", false )); 140 zoom->setChecked(config.readBoolEntry( "Zoom In/Out", false ));
142 connect(zoom, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 141 connect(zoom, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
143 setfont = new QCheckBox( tr("Set Font"), bg ); 142 setfont = new QCheckBox( tr("Set Font"), bg );
144 setfont->setChecked(config.readBoolEntry( "Set Font", false )); 143 setfont->setChecked(config.readBoolEntry( "Set Font", false ));
145 connect(setfont, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 144 connect(setfont, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
146 145
147 encoding = new QCheckBox( tr("Encoding"), bg ); 146 encoding = new QCheckBox( tr("Encoding"), bg );
148 encoding->setChecked(config.readBoolEntry("Encoding Select", false)); 147 encoding->setChecked(config.readBoolEntry("Encoding Select", false));
149 connect(encoding, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 148 connect(encoding, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
150 ideogram = new QCheckBox( tr("Ideogram"), bg ); 149 ideogram = new QCheckBox( tr("Ideogram"), bg );
151 ideogram->setChecked(config.readBoolEntry("Ideogram Mode", false)); 150 ideogram->setChecked(config.readBoolEntry("Ideogram Mode", false));
152 connect(ideogram, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 151 connect(ideogram, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
153 152
154 bg = new QGroupBox(3, Qt::Horizontal, "Marks", this); 153 bg = new QGroupBox(3, Qt::Horizontal, "Marks", this);
155 vb->addWidget(bg); 154 vb->addWidget(bg);
156 mark = new QCheckBox( tr("Bookmark"), bg ); 155 mark = new QCheckBox( tr("Bookmark"), bg );
157 mark->setChecked(config.readBoolEntry( "Mark", false )); 156 mark->setChecked(config.readBoolEntry( "Mark", false ));
158 connect(mark, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 157 connect(mark, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
159 annotate = new QCheckBox( tr("Annotate"), bg ); 158 annotate = new QCheckBox( tr("Annotate"), bg );
160 annotate->setChecked(config.readBoolEntry( "Annotate", false )); 159 annotate->setChecked(config.readBoolEntry( "Annotate", false ));
161 connect(annotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 160 connect(annotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
162 go_to = new QCheckBox( tr("Goto"), bg ); 161 go_to = new QCheckBox( tr("Goto"), bg );
163 go_to->setChecked(config.readBoolEntry( "Goto", false )); 162 go_to->setChecked(config.readBoolEntry( "Goto", false ));
164 connect(go_to, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 163 connect(go_to, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
165 Delete = new QCheckBox( tr("Delete"), bg ); 164 Delete = new QCheckBox( tr("Delete"), bg );
166 Delete->setChecked(config.readBoolEntry( "Delete", false )); 165 Delete->setChecked(config.readBoolEntry( "Delete", false ));
167 connect(Delete, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 166 connect(Delete, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
168 autogen = new QCheckBox( tr("Autogen"), bg ); 167 autogen = new QCheckBox( tr("Autogen"), bg );
169 autogen->setChecked(config.readBoolEntry( "Autogen", false )); 168 autogen->setChecked(config.readBoolEntry( "Autogen", false ));
170 connect(autogen, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 169 connect(autogen, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
171 clear = new QCheckBox( tr("Clear"), bg ); 170 clear = new QCheckBox( tr("Clear"), bg );
172 clear->setChecked(config.readBoolEntry( "Clear", false )); 171 clear->setChecked(config.readBoolEntry( "Clear", false ));
173 connect(clear, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 172 connect(clear, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
174 save = new QCheckBox( tr("Save"), bg ); 173 save = new QCheckBox( tr("Save"), bg );
175 save->setChecked(config.readBoolEntry( "Save", false )); 174 save->setChecked(config.readBoolEntry( "Save", false ));
176 connect(save, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 175 connect(save, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
177 tidy = new QCheckBox( tr("Tidy"), bg ); 176 tidy = new QCheckBox( tr("Tidy"), bg );
178 tidy->setChecked(config.readBoolEntry( "Tidy", false )); 177 tidy->setChecked(config.readBoolEntry( "Tidy", false ));
179 connect(tidy, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 178 connect(tidy, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
180 block = new QCheckBox( tr("Mark/Copy"), bg ); 179 block = new QCheckBox( tr("Mark/Copy"), bg );
181 block->setChecked(config.readBoolEntry( "Start/Copy Block", false )); 180 block->setChecked(config.readBoolEntry( "Start/Copy Block", false ));
182 connect(block, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 181 connect(block, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
183 182
184 bg = new QGroupBox(1, Qt::Horizontal, "Indicators", this); 183 bg = new QGroupBox(1, Qt::Horizontal, "Indicators", this);
185 vb->addWidget(bg); 184 vb->addWidget(bg);
186 indannotate = new QCheckBox( tr("Annotation"), bg ); 185 indannotate = new QCheckBox( tr("Annotation"), bg );
187 indannotate->setChecked(config.readBoolEntry( "Annotation indicator", false )); 186 indannotate->setChecked(config.readBoolEntry( "Annotation indicator", false ));
188 connect(indannotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 187 connect(indannotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
189 m_isChanged = false; 188 m_isChanged = false;
190} 189}
191 190
192void CBarPrefs2::saveall() 191void CBarPrefs2::saveall()
193{ 192{
194 config.setGroup( "Toolbar" ); 193 config.setGroup( "Toolbar" );
195 config.writeEntry( "Fullscreen", fullscreen->isChecked()); 194 config.writeEntry( "Fullscreen", fullscreen->isChecked());
196 config.writeEntry( "Rotate", rotate->isChecked()); 195 config.writeEntry( "Rotate", rotate->isChecked());
197 config.writeEntry( "Invert Action", invert->isChecked()); 196 config.writeEntry( "Invert Action", invert->isChecked());
198 config.writeEntry( "Zoom In/Out", zoom->isChecked()); 197 config.writeEntry( "Zoom In/Out", zoom->isChecked());
199 config.writeEntry( "Set Font", setfont->isChecked()); 198 config.writeEntry( "Set Font", setfont->isChecked());
200 config.writeEntry("Encoding Select", encoding->isChecked()); 199 config.writeEntry("Encoding Select", encoding->isChecked());
201 config.writeEntry("Ideogram Mode", ideogram->isChecked()); 200 config.writeEntry("Ideogram Mode", ideogram->isChecked());
202 201
203 config.writeEntry( "Mark", mark->isChecked()); 202 config.writeEntry( "Mark", mark->isChecked());
204 config.writeEntry( "Annotate", annotate->isChecked()); 203 config.writeEntry( "Annotate", annotate->isChecked());
205 config.writeEntry( "Goto", go_to->isChecked()); 204 config.writeEntry( "Goto", go_to->isChecked());
206 config.writeEntry( "Delete", Delete->isChecked()); 205 config.writeEntry( "Delete", Delete->isChecked());
207 config.writeEntry( "Autogen", autogen->isChecked()); 206 config.writeEntry( "Autogen", autogen->isChecked());
208 config.writeEntry( "Clear", clear->isChecked()); 207 config.writeEntry( "Clear", clear->isChecked());
209 config.writeEntry( "Save", save->isChecked()); 208 config.writeEntry( "Save", save->isChecked());
210 config.writeEntry( "Tidy", tidy->isChecked()); 209 config.writeEntry( "Tidy", tidy->isChecked());
211 config.writeEntry( "Start/Copy Block", block->isChecked()); 210 config.writeEntry( "Start/Copy Block", block->isChecked());
212 config.writeEntry( "Annotation indicator", indannotate->isChecked()); 211 config.writeEntry( "Annotation indicator", indannotate->isChecked());
213} 212}
214 213
215CBarPrefs2::~CBarPrefs2() 214CBarPrefs2::~CBarPrefs2()
216{ 215{
217} 216}
218*/ 217*/
219 218
220CFileBarPrefs::CFileBarPrefs( Config& _config, QWidget* parent, const char* name, WFlags fl ) 219CFileBarPrefs::CFileBarPrefs( Config& _config, QWidget* parent, const char* name, WFlags fl )
221 : QWidget( parent, name, fl ), config(_config) 220 : QWidget( parent, name, fl ), config(_config)
222{ 221{
223 config.setGroup( "Toolbar" ); 222 config.setGroup( "Toolbar" );
224 QVBoxLayout* vb = new QVBoxLayout(this); 223 QVBoxLayout* vb = new QVBoxLayout(this);
225 224
226 QGroupBox* bg = new QGroupBox(2, Qt::Horizontal, "File", this); 225 QGroupBox* bg = new QGroupBox(2, Qt::Horizontal, "File", this);
227 vb->addWidget(bg); 226 vb->addWidget(bg);
228 227
229 open = new QCheckBox( tr("Open"), bg ); 228 open = new QCheckBox( tr("Open"), bg );
230 open->setChecked(config.readBoolEntry( "Open", false )); 229 open->setChecked(config.readBoolEntry( "Open", false ));
231 connect(open, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 230 connect(open, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
232 close = new QCheckBox( tr("Close"), bg ); 231 close = new QCheckBox( tr("Close"), bg );
233 close->setChecked(config.readBoolEntry( "Close", false )); 232 close->setChecked(config.readBoolEntry( "Close", false ));
234 connect(close, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 233 connect(close, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
235 info = new QCheckBox( tr("Info"), bg ); 234 info = new QCheckBox( tr("Info"), bg );
236 info->setChecked(config.readBoolEntry( "Info", false )); 235 info->setChecked(config.readBoolEntry( "Info", false ));
237 connect(info, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 236 connect(info, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
238 twotouch = new QCheckBox( tr("Two/One\nTouch"), bg ); 237 twotouch = new QCheckBox( tr("Two/One\nTouch"), bg );
239 twotouch->setChecked(config.readBoolEntry( "Two/One Touch", false )); 238 twotouch->setChecked(config.readBoolEntry( "Two/One Touch", false ));
240 connect(twotouch, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 239 connect(twotouch, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
241 find = new QCheckBox( tr("Find"), bg ); 240 find = new QCheckBox( tr("Find"), bg );
242 find->setChecked(config.readBoolEntry( "Find", false )); 241 find->setChecked(config.readBoolEntry( "Find", false ));
243 connect(find, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 242 connect(find, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
244 m_isChanged = false; 243 m_isChanged = false;
245} 244}
246 245
247void CFileBarPrefs::saveall() 246void CFileBarPrefs::saveall()
248{ 247{
249 config.setGroup( "Toolbar" ); 248 config.setGroup( "Toolbar" );
250 config.writeEntry( "Open", open->isChecked()); 249 config.writeEntry( "Open", open->isChecked());
251 config.writeEntry( "Close", close->isChecked()); 250 config.writeEntry( "Close", close->isChecked());
252 config.writeEntry( "Info", info->isChecked()); 251 config.writeEntry( "Info", info->isChecked());
253 config.writeEntry( "Two/One Touch", twotouch->isChecked()); 252 config.writeEntry( "Two/One Touch", twotouch->isChecked());
254 config.writeEntry( "Find", find->isChecked()); 253 config.writeEntry( "Find", find->isChecked());
255} 254}
256 255
257CFileBarPrefs::~CFileBarPrefs() 256CFileBarPrefs::~CFileBarPrefs()
258{ 257{
259} 258}
260 259
261CNavBarPrefs::CNavBarPrefs( Config& _config, QWidget* parent, const char* name, WFlags fl ) 260CNavBarPrefs::CNavBarPrefs( Config& _config, QWidget* parent, const char* name, WFlags fl )
262 : QWidget( parent, name, fl ), config(_config) 261 : QWidget( parent, name, fl ), config(_config)
263{ 262{
264 config.setGroup( "Toolbar" ); 263 config.setGroup( "Toolbar" );
265 QVBoxLayout* vb = new QVBoxLayout(this); 264 QVBoxLayout* vb = new QVBoxLayout(this);
266 265
267 QGroupBox* bg = new QGroupBox(2, Qt::Horizontal, "Navigation", this); 266 QGroupBox* bg = new QGroupBox(2, Qt::Horizontal, "Navigation", this);
268 vb->addWidget(bg); 267 vb->addWidget(bg);
269 scroll = new QCheckBox( tr("Scroll"), bg ); 268 scroll = new QCheckBox( tr("Scroll"), bg );
270 scroll->setChecked(config.readBoolEntry( "Scroll", false )); 269 scroll->setChecked(config.readBoolEntry( "Scroll", false ));
271 connect(scroll, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 270 connect(scroll, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
272 271
273 navback = new QCheckBox( tr("Back"), bg ); 272 navback = new QCheckBox( tr("Back"), bg );
274 navback->setChecked(config.readBoolEntry( "Back", false )); 273 navback->setChecked(config.readBoolEntry( "Back", false ));
275 connect(navback, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 274 connect(navback, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
276 navhome = new QCheckBox( tr("Home"), bg ); 275 navhome = new QCheckBox( tr("Home"), bg );
277 navhome->setChecked(config.readBoolEntry( "Home", false )); 276 navhome->setChecked(config.readBoolEntry( "Home", false ));
278 connect(navhome, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 277 connect(navhome, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
279 navforward = new QCheckBox( tr("Forward"), bg ); 278 navforward = new QCheckBox( tr("Forward"), bg );
280 navforward->setChecked(config.readBoolEntry( "Forward", false )); 279 navforward->setChecked(config.readBoolEntry( "Forward", false ));
281 connect(navforward, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 280 connect(navforward, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
282 281
283 pageup = new QCheckBox( tr("Page Up"), bg ); 282 pageup = new QCheckBox( tr("Page Up"), bg );
284 pageup->setChecked(config.readBoolEntry( "Page Up", false )); 283 pageup->setChecked(config.readBoolEntry( "Page Up", false ));
285 connect(pageup, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 284 connect(pageup, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
286 pagedown = new QCheckBox( tr("Page Down"), bg ); 285 pagedown = new QCheckBox( tr("Page Down"), bg );
287 pagedown->setChecked(config.readBoolEntry( "Page Down", false )); 286 pagedown->setChecked(config.readBoolEntry( "Page Down", false ));
288 connect(pagedown, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 287 connect(pagedown, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
289 gotostart = new QCheckBox( tr("Goto Start"), bg ); 288 gotostart = new QCheckBox( tr("Goto Start"), bg );
290 gotostart->setChecked(config.readBoolEntry( "Goto Start", false )); 289 gotostart->setChecked(config.readBoolEntry( "Goto Start", false ));
291 connect(gotostart, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 290 connect(gotostart, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
292 gotoend = new QCheckBox( tr("Goto End"), bg ); 291 gotoend = new QCheckBox( tr("Goto End"), bg );
293 gotoend->setChecked(config.readBoolEntry( "Goto End", false )); 292 gotoend->setChecked(config.readBoolEntry( "Goto End", false ));
294 connect(gotoend, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 293 connect(gotoend, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
295 jump = new QCheckBox( tr("Jump"), bg ); 294 jump = new QCheckBox( tr("Jump"), bg );
296 jump->setChecked(config.readBoolEntry( "Jump", false )); 295 jump->setChecked(config.readBoolEntry( "Jump", false ));
297 connect(jump, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 296 connect(jump, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
298 pageline = new QCheckBox( tr("Page/Line Scroll"), bg ); 297 pageline = new QCheckBox( tr("Page/Line Scroll"), bg );
299 pageline->setChecked(config.readBoolEntry( "Page/Line Scroll", false )); 298 pageline->setChecked(config.readBoolEntry( "Page/Line Scroll", false ));
300 connect(pageline, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 299 connect(pageline, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
301 m_isChanged = false; 300 m_isChanged = false;
302} 301}
303 302
304void CNavBarPrefs::saveall() 303void CNavBarPrefs::saveall()
305{ 304{
306 config.setGroup( "Toolbar" ); 305 config.setGroup( "Toolbar" );
307 config.writeEntry( "Scroll", scroll->isChecked()); 306 config.writeEntry( "Scroll", scroll->isChecked());
308 config.writeEntry( "Back", navback->isChecked()); 307 config.writeEntry( "Back", navback->isChecked());
309 config.writeEntry( "Home", navhome->isChecked()); 308 config.writeEntry( "Home", navhome->isChecked());
310 config.writeEntry( "Forward", navforward->isChecked()); 309 config.writeEntry( "Forward", navforward->isChecked());
311 config.writeEntry( "Page Up", pageup->isChecked()); 310 config.writeEntry( "Page Up", pageup->isChecked());
312 config.writeEntry( "Page Down", pagedown->isChecked()); 311 config.writeEntry( "Page Down", pagedown->isChecked());
313 config.writeEntry( "Goto Start", gotostart->isChecked()); 312 config.writeEntry( "Goto Start", gotostart->isChecked());
314 config.writeEntry( "Goto End", gotoend->isChecked()); 313 config.writeEntry( "Goto End", gotoend->isChecked());
315 config.writeEntry( "Jump", jump->isChecked()); 314 config.writeEntry( "Jump", jump->isChecked());
316 config.writeEntry( "Page/Line Scroll", pageline->isChecked()); 315 config.writeEntry( "Page/Line Scroll", pageline->isChecked());
317} 316}
318 317
319CNavBarPrefs::~CNavBarPrefs() 318CNavBarPrefs::~CNavBarPrefs()
320{ 319{
321} 320}
322 321
323CViewBarPrefs::CViewBarPrefs( Config& _config, QWidget* parent, const char* name, WFlags fl ) 322CViewBarPrefs::CViewBarPrefs( Config& _config, QWidget* parent, const char* name, WFlags fl )
324 : QWidget( parent, name, fl ), config(_config) 323 : QWidget( parent, name, fl ), config(_config)
325{ 324{
326 QVBoxLayout* vb = new QVBoxLayout(this); 325 QVBoxLayout* vb = new QVBoxLayout(this);
327 326
328 QGroupBox* bg = new QGroupBox(2, Qt::Horizontal, "View", this); 327 QGroupBox* bg = new QGroupBox(2, Qt::Horizontal, "View", this);
329 vb->addWidget(bg); 328 vb->addWidget(bg);
330 329
331 config.setGroup( "Toolbar" ); 330 config.setGroup( "Toolbar" );
332 331
333 fullscreen = new QCheckBox( tr("Fullscreen"), bg ); 332 fullscreen = new QCheckBox( tr("Fullscreen"), bg );
334 fullscreen->setChecked(config.readBoolEntry( "Fullscreen", false )); 333 fullscreen->setChecked(config.readBoolEntry( "Fullscreen", false ));
335 connect(fullscreen, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 334 connect(fullscreen, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
336 rotate = new QCheckBox( tr("Rotate"), bg ); 335 rotate = new QCheckBox( tr("Rotate"), bg );
337 rotate->setChecked(config.readBoolEntry( "Rotate", false )); 336 rotate->setChecked(config.readBoolEntry( "Rotate", false ));
338 connect(rotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 337 connect(rotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
339 338
340 invert = new QCheckBox( tr("Invert"), bg ); 339 invert = new QCheckBox( tr("Invert"), bg );
341 invert->setChecked(config.readBoolEntry( "Invert Action", false )); 340 invert->setChecked(config.readBoolEntry( "Invert Action", false ));
342 connect(invert, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 341 connect(invert, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
343 342
344 zoomin = new QCheckBox( tr("Zoom In"), bg ); 343 zoomin = new QCheckBox( tr("Zoom In"), bg );
345 zoomin->setChecked(config.readBoolEntry( "Zoom In", false )); 344 zoomin->setChecked(config.readBoolEntry( "Zoom In", false ));
346 connect(zoomin, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 345 connect(zoomin, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
347 zoomout = new QCheckBox( tr("Zoom Out"), bg ); 346 zoomout = new QCheckBox( tr("Zoom Out"), bg );
348 zoomout->setChecked(config.readBoolEntry( "Zoom Out", false )); 347 zoomout->setChecked(config.readBoolEntry( "Zoom Out", false ));
349 connect(zoomout, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 348 connect(zoomout, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
350 setfont = new QCheckBox( tr("Set Font"), bg ); 349 setfont = new QCheckBox( tr("Set Font"), bg );
351 setfont->setChecked(config.readBoolEntry( "Set Font", false )); 350 setfont->setChecked(config.readBoolEntry( "Set Font", false ));
352 connect(setfont, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 351 connect(setfont, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
353 352
354 encoding = new QCheckBox( tr("Encoding"), bg ); 353 encoding = new QCheckBox( tr("Encoding"), bg );
355 encoding->setChecked(config.readBoolEntry("Encoding Select", false)); 354 encoding->setChecked(config.readBoolEntry("Encoding Select", false));
356 connect(encoding, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 355 connect(encoding, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
357 ideogram = new QCheckBox( tr("Ideogram"), bg ); 356 ideogram = new QCheckBox( tr("Ideogram"), bg );
358 ideogram->setChecked(config.readBoolEntry("Ideogram Mode", false)); 357 ideogram->setChecked(config.readBoolEntry("Ideogram Mode", false));
359 connect(ideogram, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 358 connect(ideogram, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
360 m_isChanged = false; 359 m_isChanged = false;
361} 360}
362 361
363void CViewBarPrefs::saveall() 362void CViewBarPrefs::saveall()
364{ 363{
365 config.setGroup( "Toolbar" ); 364 config.setGroup( "Toolbar" );
366 config.writeEntry( "Fullscreen", fullscreen->isChecked()); 365 config.writeEntry( "Fullscreen", fullscreen->isChecked());
367 config.writeEntry( "Rotate", rotate->isChecked()); 366 config.writeEntry( "Rotate", rotate->isChecked());
368 config.writeEntry( "Invert Action", invert->isChecked()); 367 config.writeEntry( "Invert Action", invert->isChecked());
369 config.writeEntry( "Zoom In", zoomin->isChecked()); 368 config.writeEntry( "Zoom In", zoomin->isChecked());
370 config.writeEntry( "Zoom Out", zoomout->isChecked()); 369 config.writeEntry( "Zoom Out", zoomout->isChecked());
371 config.writeEntry( "Set Font", setfont->isChecked()); 370 config.writeEntry( "Set Font", setfont->isChecked());
372 config.writeEntry("Encoding Select", encoding->isChecked()); 371 config.writeEntry("Encoding Select", encoding->isChecked());
373 config.writeEntry("Ideogram Mode", ideogram->isChecked()); 372 config.writeEntry("Ideogram Mode", ideogram->isChecked());
374} 373}
375 374
376CViewBarPrefs::~CViewBarPrefs() 375CViewBarPrefs::~CViewBarPrefs()
377{ 376{
378} 377}
379 378
380CMarkBarPrefs::CMarkBarPrefs( Config& _config, QWidget* parent, const char* name, WFlags fl ) 379CMarkBarPrefs::CMarkBarPrefs( Config& _config, QWidget* parent, const char* name, WFlags fl )
381 : QWidget( parent, name, fl ), config(_config) 380 : QWidget( parent, name, fl ), config(_config)
382{ 381{
383 QVBoxLayout* vb = new QVBoxLayout(this); 382 QVBoxLayout* vb = new QVBoxLayout(this);
384 383
385 QGroupBox* bg = new QGroupBox(2, Qt::Horizontal, "Marks", this); 384 QGroupBox* bg = new QGroupBox(2, Qt::Horizontal, "Marks", this);
386 vb->addWidget(bg); 385 vb->addWidget(bg);
387 mark = new QCheckBox( tr("Bookmark"), bg ); 386 mark = new QCheckBox( tr("Bookmark"), bg );
388 mark->setChecked(config.readBoolEntry( "Mark", false )); 387 mark->setChecked(config.readBoolEntry( "Mark", false ));
389 connect(mark, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 388 connect(mark, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
390 annotate = new QCheckBox( tr("Annotate"), bg ); 389 annotate = new QCheckBox( tr("Annotate"), bg );
391 annotate->setChecked(config.readBoolEntry( "Annotate", false )); 390 annotate->setChecked(config.readBoolEntry( "Annotate", false ));
392 connect(annotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 391 connect(annotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
393 go_to = new QCheckBox( tr("Goto"), bg ); 392 go_to = new QCheckBox( tr("Goto"), bg );
394 go_to->setChecked(config.readBoolEntry( "Goto", false )); 393 go_to->setChecked(config.readBoolEntry( "Goto", false ));
395 connect(go_to, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 394 connect(go_to, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
396 Delete = new QCheckBox( tr("Delete"), bg ); 395 Delete = new QCheckBox( tr("Delete"), bg );
397 Delete->setChecked(config.readBoolEntry( "Delete", false )); 396 Delete->setChecked(config.readBoolEntry( "Delete", false ));
398 connect(Delete, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 397 connect(Delete, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
399 autogen = new QCheckBox( tr("Autogen"), bg ); 398 autogen = new QCheckBox( tr("Autogen"), bg );
400 autogen->setChecked(config.readBoolEntry( "Autogen", false )); 399 autogen->setChecked(config.readBoolEntry( "Autogen", false ));
401 connect(autogen, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 400 connect(autogen, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
402 clear = new QCheckBox( tr("Clear"), bg ); 401 clear = new QCheckBox( tr("Clear"), bg );
403 clear->setChecked(config.readBoolEntry( "Clear", false )); 402 clear->setChecked(config.readBoolEntry( "Clear", false ));
404 connect(clear, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 403 connect(clear, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
405 save = new QCheckBox( tr("Save"), bg ); 404 save = new QCheckBox( tr("Save"), bg );
406 save->setChecked(config.readBoolEntry( "Save", false )); 405 save->setChecked(config.readBoolEntry( "Save", false ));
407 connect(save, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 406 connect(save, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
408 tidy = new QCheckBox( tr("Tidy"), bg ); 407 tidy = new QCheckBox( tr("Tidy"), bg );
409 tidy->setChecked(config.readBoolEntry( "Tidy", false )); 408 tidy->setChecked(config.readBoolEntry( "Tidy", false ));
410 connect(tidy, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 409 connect(tidy, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
411 startblock = new QCheckBox( tr("Mark Block"), bg ); 410 startblock = new QCheckBox( tr("Mark Block"), bg );
412 startblock->setChecked(config.readBoolEntry( "Start Block", false )); 411 startblock->setChecked(config.readBoolEntry( "Start Block", false ));
413 connect(startblock, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 412 connect(startblock, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
414 copyblock = new QCheckBox( tr("Copy Block"), bg ); 413 copyblock = new QCheckBox( tr("Copy Block"), bg );
415 copyblock->setChecked(config.readBoolEntry( "Copy Block", false )); 414 copyblock->setChecked(config.readBoolEntry( "Copy Block", false ));
416 connect(copyblock, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 415 connect(copyblock, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
417 m_isChanged = false; 416 m_isChanged = false;
418} 417}
419 418
420void CMarkBarPrefs::saveall() 419void CMarkBarPrefs::saveall()
421{ 420{
422 config.setGroup( "Toolbar" ); 421 config.setGroup( "Toolbar" );
423 config.writeEntry( "Mark", mark->isChecked()); 422 config.writeEntry( "Mark", mark->isChecked());
424 config.writeEntry( "Annotate", annotate->isChecked()); 423 config.writeEntry( "Annotate", annotate->isChecked());
425 config.writeEntry( "Goto", go_to->isChecked()); 424 config.writeEntry( "Goto", go_to->isChecked());
426 config.writeEntry( "Delete", Delete->isChecked()); 425 config.writeEntry( "Delete", Delete->isChecked());
427 config.writeEntry( "Autogen", autogen->isChecked()); 426 config.writeEntry( "Autogen", autogen->isChecked());
428 config.writeEntry( "Clear", clear->isChecked()); 427 config.writeEntry( "Clear", clear->isChecked());
429 config.writeEntry( "Save", save->isChecked()); 428 config.writeEntry( "Save", save->isChecked());
430 config.writeEntry( "Tidy", tidy->isChecked()); 429 config.writeEntry( "Tidy", tidy->isChecked());
431 config.writeEntry( "Start Block", startblock->isChecked()); 430 config.writeEntry( "Start Block", startblock->isChecked());
432 config.writeEntry( "Copy Block", copyblock->isChecked()); 431 config.writeEntry( "Copy Block", copyblock->isChecked());
433} 432}
434 433
435CMarkBarPrefs::~CMarkBarPrefs() 434CMarkBarPrefs::~CMarkBarPrefs()
436{ 435{
437} 436}
438 437
439CMiscBarPrefs::CMiscBarPrefs( QWidget* parent, const char* name, WFlags fl ) 438CMiscBarPrefs::CMiscBarPrefs( QWidget* parent, const char* name, WFlags fl )
440 : QWidget( parent, name, fl ) 439 : QWidget( parent, name, fl )
441{ 440{
442 441
443 QGridLayout* hl = new QGridLayout(this,2,2); 442 QGridLayout* hl = new QGridLayout(this,2,2);
444 443
445 hl->setMargin( 0 ); 444 hl->setMargin( 0 );
446 445
447 QGroupBox* gb = new QGroupBox(1, Qt::Horizontal, "Dialogs", this); 446 QGroupBox* gb = new QGroupBox(1, Qt::Horizontal, "Dialogs", this);
448 floating = new QCheckBox(gb); 447 floating = new QCheckBox(gb);
449 floating->setText(tr("Floating")); 448 floating->setText(tr("Floating"));
450 hl->addWidget( gb, 0, 0 ); 449 hl->addWidget( gb, 0, 0 );
451 450
452 451
453 gb = new QGroupBox(1, Qt::Horizontal, "Bars (Restart)", this); 452 gb = new QGroupBox(1, Qt::Horizontal, "Bars (Restart)", this);
454 453
455// QLabel* ql = new QLabel("Restart to apply changes", gb); 454// QLabel* ql = new QLabel("Restart to apply changes", gb);
456// TextLabel = new QLabel( gb ); 455// TextLabel = new QLabel( gb );
457// TextLabel->setText( tr( "Policy" ) ); 456// TextLabel->setText( tr( "Policy" ) );
458 457
459#ifdef USECOMBO 458#ifdef USECOMBO
460 tbpolicy = new QComboBox(gb); 459 tbpolicy = new QComboBox(gb);
461#else 460#else
462 tbpolicy = new MenuButton(gb); 461 tbpolicy = new MenuButton(gb);
463#endif 462#endif
464 tbpolicy->setSizePolicy(QSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed)); 463 tbpolicy->setSizePolicy(QSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed));
465#ifdef USEQPE 464#ifdef USEQPE
466 tbpolicy->insertItem(tr("Single bar")); 465 tbpolicy->insertItem(tr("Single bar"));
467 tbpolicy->insertItem(tr("Menu/tool bar")); 466 tbpolicy->insertItem(tr("Menu/tool bar"));
468 tbpolicy->insertItem(tr("Multiple bars")); 467 tbpolicy->insertItem(tr("Multiple bars"));
469#else 468#else
470 tbpolicy->insertItem(tr("Single bar")); 469 tbpolicy->insertItem(tr("Single bar"));
471 tbpolicy->insertItem(tr("Multiple bars")); 470 tbpolicy->insertItem(tr("Multiple bars"));
472#endif 471#endif
473 472
474#ifdef USECOMBO 473#ifdef USECOMBO
475 tbposition = new QComboBox(gb); 474 tbposition = new QComboBox(gb);
476#else 475#else
477 tbposition = new MenuButton(gb); 476 tbposition = new MenuButton(gb);
478#endif 477#endif
479 tbposition->insertItem(tr("Top")); 478 tbposition->insertItem(tr("Top"));
480 tbposition->insertItem(tr("Bottom")); 479 tbposition->insertItem(tr("Bottom"));
481 tbposition->insertItem(tr("Right")); 480 tbposition->insertItem(tr("Right"));
482 tbposition->insertItem(tr("Left")); 481 tbposition->insertItem(tr("Left"));
483 tbposition->insertItem(tr("Minimised")); 482 tbposition->insertItem(tr("Minimised"));
484 483
485 tbmovable = new QCheckBox( tr("Movable"), gb ); 484 tbmovable = new QCheckBox( tr("Movable"), gb );
486 485
487 hl->addWidget(gb, 0, 1); 486 hl->addWidget(gb, 0, 1);
488 487
489 gb = new QGroupBox(1, Qt::Horizontal, "QT Scroll Bar", this); 488 gb = new QGroupBox(1, Qt::Horizontal, "QT Scroll Bar", this);
490 489
491#ifdef USECOMBO 490#ifdef USECOMBO
492 qtscroll = new QComboBox(gb); 491 qtscroll = new QComboBox(gb);
493#else 492#else
494 qtscroll = new MenuButton(gb); 493 qtscroll = new MenuButton(gb);
495#endif 494#endif
496 qtscroll->insertItem(tr("None")); 495 qtscroll->insertItem(tr("None"));
497 qtscroll->insertItem(tr("Right")); 496 qtscroll->insertItem(tr("Right"));
498 qtscroll->insertItem(tr("Left")); 497 qtscroll->insertItem(tr("Left"));
499 498
500 hl->addWidget(gb, 1, 0); 499 hl->addWidget(gb, 1, 0);
501 gb = new QGroupBox(1, Qt::Horizontal, "Miniscroll", this); 500 gb = new QGroupBox(1, Qt::Horizontal, "Miniscroll", this);
502 501
503#ifdef USECOMBO 502#ifdef USECOMBO
504 localscroll = new QComboBox(gb); 503 localscroll = new QComboBox(gb);
505#else 504#else
506 localscroll = new MenuButton(gb); 505 localscroll = new MenuButton(gb);
507#endif 506#endif
508 localscroll->insertItem(tr("None")); 507 localscroll->insertItem(tr("None"));
509 localscroll->insertItem(tr("Bottom")); 508 localscroll->insertItem(tr("Bottom"));
510 localscroll->insertItem(tr("Right")); 509 localscroll->insertItem(tr("Right"));
511 localscroll->insertItem(tr("Left")); 510 localscroll->insertItem(tr("Left"));
512 511
513 //scrollonleft = new QCheckBox( tr("... on Left"), gb ); 512 //scrollonleft = new QCheckBox( tr("... on Left"), gb );
514 // ch->setChecked(config.readBoolEntry( "Movable", false )); 513 // ch->setChecked(config.readBoolEntry( "Movable", false ));
515 514
516 hl->addWidget(gb, 1, 1); 515 hl->addWidget(gb, 1, 1);
517 516
518} 517}
519 518
520CMiscBarPrefs::~CMiscBarPrefs() 519CMiscBarPrefs::~CMiscBarPrefs()
521{ 520{
522 // no need to delete child widgets, Qt does it all for us 521 // no need to delete child widgets, Qt does it all for us
523} 522}
524 523
525 524
526CIndBarPrefs::CIndBarPrefs( Config& _config, QWidget* parent, const char* name, WFlags fl ) 525CIndBarPrefs::CIndBarPrefs( Config& _config, QWidget* parent, const char* name, WFlags fl )
527 : QWidget( parent, name, fl ), config(_config) 526 : QWidget( parent, name, fl ), config(_config)
528{ 527{
529 QVBoxLayout* vb = new QVBoxLayout(this); 528 QVBoxLayout* vb = new QVBoxLayout(this);
530 529
531 QGroupBox* bg = new QGroupBox(1, Qt::Horizontal, "Indicators", this); 530 QGroupBox* bg = new QGroupBox(1, Qt::Horizontal, "Indicators", this);
532 vb->addWidget(bg); 531 vb->addWidget(bg);
533 indannotate = new QCheckBox( tr("Annotation"), bg ); 532 indannotate = new QCheckBox( tr("Annotation"), bg );
534 indannotate->setChecked(config.readBoolEntry( "Annotation indicator", false )); 533 indannotate->setChecked(config.readBoolEntry( "Annotation indicator", false ));
535 connect(indannotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) ); 534 connect(indannotate, SIGNAL(stateChanged(int)), this, SLOT( isChanged(int) ) );
536 m_isChanged = false; 535 m_isChanged = false;
537} 536}
538 537
539void CIndBarPrefs::saveall() 538void CIndBarPrefs::saveall()
540{ 539{
541 config.setGroup( "Toolbar" ); 540 config.setGroup( "Toolbar" );
542 config.writeEntry( "Annotation indicator", indannotate->isChecked()); 541 config.writeEntry( "Annotation indicator", indannotate->isChecked());
543} 542}
544 543
545CIndBarPrefs::~CIndBarPrefs() 544CIndBarPrefs::~CIndBarPrefs()
546{ 545{
547} 546}
diff --git a/noncore/apps/opie-reader/ToolbarPrefs.h b/noncore/apps/opie-reader/ToolbarPrefs.h
index a2686e5..0bdae6b 100644
--- a/noncore/apps/opie-reader/ToolbarPrefs.h
+++ b/noncore/apps/opie-reader/ToolbarPrefs.h
@@ -1,269 +1,267 @@
1/**************************************************************************** 1/****************************************************************************
2 ** Form interface generated from reading ui file 'Prefs.ui' 2 ** Form interface generated from reading ui file 'Prefs.ui'
3 ** 3 **
4 ** Created: Tue Feb 11 23:53:32 2003 4 ** Created: Tue Feb 11 23:53:32 2003
5 ** by: The User Interface Compiler (uic) 5 ** by: The User Interface Compiler (uic)
6 ** 6 **
7 ** WARNING! All changes made in this file will be lost! 7 ** WARNING! All changes made in this file will be lost!
8 ****************************************************************************/ 8 ****************************************************************************/
9#ifndef CTOOLBARPREFS_H 9#ifndef CTOOLBARPREFS_H
10#define CTOOLBARPREFS_H 10#define CTOOLBARPREFS_H
11#include "useqpe.h"
12#include <qvariant.h> 11#include <qvariant.h>
13#include <qwidget.h> 12#include <qwidget.h>
14#include <qtabdialog.h> 13#include <qtabdialog.h>
15#include <qtabwidget.h> 14#include <qtabwidget.h>
16#include <qspinbox.h> 15#include <qspinbox.h>
17#include <qcheckbox.h> 16#include <qcheckbox.h>
18#include <qcombobox.h> 17#include <qcombobox.h>
19#include <qlineedit.h> 18#include <qlineedit.h>
20#ifdef USEQPE 19#ifdef USEQPE
21#include <qpe/menubutton.h> 20#include <qpe/menubutton.h>
22#include <qpe/config.h> 21#include <qpe/config.h>
23#else 22#else
24#include "preferences.h" 23#include "preferences.h"
25#endif 24#endif
26//#include "opie.h"
27//#ifdef OPIE 25//#ifdef OPIE
28#define USECOMBO 26#define USECOMBO
29//#endif 27//#endif
30 28
31class QVBoxLayout; 29class QVBoxLayout;
32class QHBoxLayout; 30class QHBoxLayout;
33class QGridLayout; 31class QGridLayout;
34//class QCheckBox; 32//class QCheckBox;
35class QLabel; 33class QLabel;
36//class QSpinBox; 34//class QSpinBox;
37/* 35/*
38class CBarPrefs1 : public QWidget 36class CBarPrefs1 : public QWidget
39{ 37{
40 Q_OBJECT 38 Q_OBJECT
41 39
42 Config& config; 40 Config& config;
43 QCheckBox *open, *close, *info, *twotouch,*find,*scroll,*navigation,*page,*startend,*jump,*pageline; 41 QCheckBox *open, *close, *info, *twotouch,*find,*scroll,*navigation,*page,*startend,*jump,*pageline;
44 42
45 bool m_isChanged; 43 bool m_isChanged;
46 44
47 private slots: 45 private slots:
48 void isChanged(int _v) { m_isChanged = true; } 46 void isChanged(int _v) { m_isChanged = true; }
49 47
50 public: 48 public:
51 CBarPrefs1( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); 49 CBarPrefs1( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
52 ~CBarPrefs1(); 50 ~CBarPrefs1();
53 void saveall(); 51 void saveall();
54 bool isChanged() { return m_isChanged; } 52 bool isChanged() { return m_isChanged; }
55}; 53};
56*/ 54*/
57class CFileBarPrefs : public QWidget 55class CFileBarPrefs : public QWidget
58{ 56{
59 Q_OBJECT 57 Q_OBJECT
60 58
61 Config& config; 59 Config& config;
62 QCheckBox *open, *close, *info, *twotouch, *find, *scroll; 60 QCheckBox *open, *close, *info, *twotouch, *find, *scroll;
63 61
64 bool m_isChanged; 62 bool m_isChanged;
65 63
66 private slots: 64 private slots:
67 void isChanged(int _v) { m_isChanged = true; } 65 void isChanged(int _v) { m_isChanged = true; }
68 66
69 public: 67 public:
70 CFileBarPrefs( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); 68 CFileBarPrefs( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
71 ~CFileBarPrefs(); 69 ~CFileBarPrefs();
72 void saveall(); 70 void saveall();
73 bool isChanged() { return m_isChanged; } 71 bool isChanged() { return m_isChanged; }
74}; 72};
75 73
76class CNavBarPrefs : public QWidget 74class CNavBarPrefs : public QWidget
77{ 75{
78 Q_OBJECT 76 Q_OBJECT
79 77
80 Config& config; 78 Config& config;
81 QCheckBox *scroll, *navback, *navhome, *navforward; 79 QCheckBox *scroll, *navback, *navhome, *navforward;
82 QCheckBox *pageup, *pagedown, *gotostart, *gotoend, *jump, *pageline; 80 QCheckBox *pageup, *pagedown, *gotostart, *gotoend, *jump, *pageline;
83 81
84 bool m_isChanged; 82 bool m_isChanged;
85 83
86 private slots: 84 private slots:
87 void isChanged(int _v) { m_isChanged = true; } 85 void isChanged(int _v) { m_isChanged = true; }
88 86
89 public: 87 public:
90 CNavBarPrefs( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); 88 CNavBarPrefs( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
91 ~CNavBarPrefs(); 89 ~CNavBarPrefs();
92 void saveall(); 90 void saveall();
93 bool isChanged() { return m_isChanged; } 91 bool isChanged() { return m_isChanged; }
94}; 92};
95/* 93/*
96class CBarPrefs2 : public QWidget 94class CBarPrefs2 : public QWidget
97{ 95{
98 Q_OBJECT 96 Q_OBJECT
99 Config& config; 97 Config& config;
100 QCheckBox *fullscreen, *zoom, *setfont, *mark, *annotate, *go_to, *Delete, *autogen, *clear, *save, *tidy, *block, *indannotate, *encoding, *ideogram; 98 QCheckBox *fullscreen, *zoom, *setfont, *mark, *annotate, *go_to, *Delete, *autogen, *clear, *save, *tidy, *block, *indannotate, *encoding, *ideogram;
101 99
102 bool m_isChanged; 100 bool m_isChanged;
103 101
104 private slots: 102 private slots:
105 void isChanged(int _v) { m_isChanged = true; } 103 void isChanged(int _v) { m_isChanged = true; }
106 104
107 public: 105 public:
108 CBarPrefs2( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); 106 CBarPrefs2( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
109 ~CBarPrefs2(); 107 ~CBarPrefs2();
110 void saveall(); 108 void saveall();
111 bool isChanged() { return m_isChanged; } 109 bool isChanged() { return m_isChanged; }
112 110
113}; 111};
114*/ 112*/
115class CViewBarPrefs : public QWidget 113class CViewBarPrefs : public QWidget
116{ 114{
117 Q_OBJECT 115 Q_OBJECT
118 Config& config; 116 Config& config;
119 QCheckBox *fullscreen, *rotate, *zoomin, *zoomout, *setfont, *encoding, *ideogram, *invert; 117 QCheckBox *fullscreen, *rotate, *zoomin, *zoomout, *setfont, *encoding, *ideogram, *invert;
120 118
121 bool m_isChanged; 119 bool m_isChanged;
122 120
123 private slots: 121 private slots:
124 void isChanged(int _v) { m_isChanged = true; } 122 void isChanged(int _v) { m_isChanged = true; }
125 123
126 public: 124 public:
127 CViewBarPrefs( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); 125 CViewBarPrefs( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
128 ~CViewBarPrefs(); 126 ~CViewBarPrefs();
129 void saveall(); 127 void saveall();
130 bool isChanged() { return m_isChanged; } 128 bool isChanged() { return m_isChanged; }
131 129
132}; 130};
133 131
134class CMarkBarPrefs : public QWidget 132class CMarkBarPrefs : public QWidget
135{ 133{
136 Q_OBJECT 134 Q_OBJECT
137 Config& config; 135 Config& config;
138 QCheckBox *mark, *annotate, *go_to, *Delete, *autogen, *clear, *save, *tidy, *startblock, *copyblock; 136 QCheckBox *mark, *annotate, *go_to, *Delete, *autogen, *clear, *save, *tidy, *startblock, *copyblock;
139 137
140 bool m_isChanged; 138 bool m_isChanged;
141 139
142 private slots: 140 private slots:
143 void isChanged(int _v) { m_isChanged = true; } 141 void isChanged(int _v) { m_isChanged = true; }
144 142
145 public: 143 public:
146 CMarkBarPrefs( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); 144 CMarkBarPrefs( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
147 ~CMarkBarPrefs(); 145 ~CMarkBarPrefs();
148 void saveall(); 146 void saveall();
149 bool isChanged() { return m_isChanged; } 147 bool isChanged() { return m_isChanged; }
150 148
151}; 149};
152 150
153class CIndBarPrefs : public QWidget 151class CIndBarPrefs : public QWidget
154{ 152{
155 Q_OBJECT 153 Q_OBJECT
156 Config& config; 154 Config& config;
157 QCheckBox *indannotate; 155 QCheckBox *indannotate;
158 156
159 bool m_isChanged; 157 bool m_isChanged;
160 158
161 private slots: 159 private slots:
162 void isChanged(int _v) { m_isChanged = true; } 160 void isChanged(int _v) { m_isChanged = true; }
163 161
164 public: 162 public:
165 CIndBarPrefs( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); 163 CIndBarPrefs( Config&, QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
166 ~CIndBarPrefs(); 164 ~CIndBarPrefs();
167 void saveall(); 165 void saveall();
168 bool isChanged() { return m_isChanged; } 166 bool isChanged() { return m_isChanged; }
169 167
170}; 168};
171 169
172class CMiscBarPrefs : public QWidget 170class CMiscBarPrefs : public QWidget
173{ 171{
174 172
175public: 173public:
176 174
177 CMiscBarPrefs( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); 175 CMiscBarPrefs( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
178 ~CMiscBarPrefs(); 176 ~CMiscBarPrefs();
179 177
180#ifdef USECOMBO 178#ifdef USECOMBO
181 QComboBox *tbpolicy, *tbposition, *qtscroll, *localscroll; 179 QComboBox *tbpolicy, *tbposition, *qtscroll, *localscroll;
182#else 180#else
183 MenuButton *tbpolicy, *tbposition, *qtscroll, *localscroll; 181 MenuButton *tbpolicy, *tbposition, *qtscroll, *localscroll;
184#endif 182#endif
185 QCheckBox *tbmovable, *floating; 183 QCheckBox *tbmovable, *floating;
186}; 184};
187 185
188class CBarPrefs : public QDialog 186class CBarPrefs : public QDialog
189{ 187{
190 Q_OBJECT 188 Q_OBJECT
191 ; 189 ;
192 CMiscBarPrefs* misc; 190 CMiscBarPrefs* misc;
193 CFileBarPrefs* filebar; 191 CFileBarPrefs* filebar;
194 CNavBarPrefs* navbar; 192 CNavBarPrefs* navbar;
195 CViewBarPrefs* viewbar; 193 CViewBarPrefs* viewbar;
196 CMarkBarPrefs* markbar; 194 CMarkBarPrefs* markbar;
197 CIndBarPrefs* indbar; 195 CIndBarPrefs* indbar;
198 Config config; 196 Config config;
199 197
200 void keyPressEvent(QKeyEvent* e) 198 void keyPressEvent(QKeyEvent* e)
201 { 199 {
202 switch (e->key()) 200 switch (e->key())
203 { 201 {
204 case Key_Escape: 202 case Key_Escape:
205 e->accept(); 203 e->accept();
206 reject(); 204 reject();
207 break; 205 break;
208 case Key_Space: 206 case Key_Space:
209 case Key_Return: 207 case Key_Return:
210 e->accept(); 208 e->accept();
211 accept(); 209 accept();
212 break; 210 break;
213 default: 211 default:
214 QWidget::keyPressEvent(e); 212 QWidget::keyPressEvent(e);
215 } 213 }
216 } 214 }
217 public: 215 public:
218 CBarPrefs(const QString& appdir, bool fs = true, QWidget* parent = 0, const char* name = 0); 216 CBarPrefs(const QString& appdir, bool fs = true, QWidget* parent = 0, const char* name = 0);
219 ~CBarPrefs() 217 ~CBarPrefs()
220 { 218 {
221 if (result()) 219 if (result())
222 { 220 {
223 if (navbar->isChanged()) navbar->saveall(); 221 if (navbar->isChanged()) navbar->saveall();
224 if (filebar->isChanged()) filebar->saveall(); 222 if (filebar->isChanged()) filebar->saveall();
225 if (viewbar->isChanged()) viewbar->saveall(); 223 if (viewbar->isChanged()) viewbar->saveall();
226 if (markbar->isChanged()) markbar->saveall(); 224 if (markbar->isChanged()) markbar->saveall();
227 if (indbar->isChanged()) indbar->saveall(); 225 if (indbar->isChanged()) indbar->saveall();
228 } 226 }
229 } 227 }
230 bool isChanged() 228 bool isChanged()
231 { 229 {
232 return 230 return
233 ( 231 (
234 filebar->isChanged() 232 filebar->isChanged()
235 || 233 ||
236 navbar->isChanged() 234 navbar->isChanged()
237 || 235 ||
238 viewbar->isChanged() 236 viewbar->isChanged()
239 || 237 ||
240 markbar->isChanged() 238 markbar->isChanged()
241 || 239 ||
242 indbar->isChanged() 240 indbar->isChanged()
243 ); 241 );
244 } 242 }
245 bool floating() { return misc->floating->isChecked(); } 243 bool floating() { return misc->floating->isChecked(); }
246 void floating(bool v) { misc->floating->setChecked(v); } 244 void floating(bool v) { misc->floating->setChecked(v); }
247 int tbpolicy() { return misc->tbpolicy->currentItem(); } 245 int tbpolicy() { return misc->tbpolicy->currentItem(); }
248 int qtscroll() { return misc->qtscroll->currentItem(); } 246 int qtscroll() { return misc->qtscroll->currentItem(); }
249 int localscroll() { return misc->localscroll->currentItem(); } 247 int localscroll() { return misc->localscroll->currentItem(); }
250#ifdef USECOMBO 248#ifdef USECOMBO
251 void tbpolicy(int v) { misc->tbpolicy->setCurrentItem(v); } 249 void tbpolicy(int v) { misc->tbpolicy->setCurrentItem(v); }
252 void qtscroll(int v) { misc->qtscroll->setCurrentItem(v); } 250 void qtscroll(int v) { misc->qtscroll->setCurrentItem(v); }
253 void localscroll(int v) { misc->localscroll->setCurrentItem(v); } 251 void localscroll(int v) { misc->localscroll->setCurrentItem(v); }
254#else 252#else
255 void tbpolicy(int v) { misc->tbpolicy->select(v); } 253 void tbpolicy(int v) { misc->tbpolicy->select(v); }
256 void qtscroll(int v) { misc->qtscroll->select(v); } 254 void qtscroll(int v) { misc->qtscroll->select(v); }
257 void localscroll(int v) { misc->localscroll->select(v); } 255 void localscroll(int v) { misc->localscroll->select(v); }
258#endif 256#endif
259 bool tbmovable() { return misc->tbmovable->isChecked(); } 257 bool tbmovable() { return misc->tbmovable->isChecked(); }
260 void tbmovable(bool v) { misc->tbmovable->setChecked(v); } 258 void tbmovable(bool v) { misc->tbmovable->setChecked(v); }
261 int tbposition() { return misc->tbposition->currentItem(); } 259 int tbposition() { return misc->tbposition->currentItem(); }
262#ifdef USECOMBO 260#ifdef USECOMBO
263 void tbposition(int v) { misc->tbposition->setCurrentItem(v); } 261 void tbposition(int v) { misc->tbposition->setCurrentItem(v); }
264#else 262#else
265 void tbposition(int v) { misc->tbposition->select(v); } 263 void tbposition(int v) { misc->tbposition->select(v); }
266#endif 264#endif
267 265
268}; 266};
269#endif // CPREFS_H 267#endif // CPREFS_H
diff --git a/noncore/apps/opie-reader/URLDialog.h b/noncore/apps/opie-reader/URLDialog.h
index 1bcc4bd..792d13a 100644
--- a/noncore/apps/opie-reader/URLDialog.h
+++ b/noncore/apps/opie-reader/URLDialog.h
@@ -1,65 +1,64 @@
1/**************************************************************************** 1/****************************************************************************
2** Form interface generated from reading ui file 'Prefs.ui' 2** Form interface generated from reading ui file 'Prefs.ui'
3** 3**
4** Created: Tue Feb 11 23:53:32 2003 4** Created: Tue Feb 11 23:53:32 2003
5** by: The User Interface Compiler (uic) 5** by: The User Interface Compiler (uic)
6** 6**
7** WARNING! All changes made in this file will be lost! 7** WARNING! All changes made in this file will be lost!
8****************************************************************************/ 8****************************************************************************/
9#ifndef __URLDIALOG_H 9#ifndef __URLDIALOG_H
10#define __URLDIALOG_H 10#define __URLDIALOG_H
11 11
12#include "useqpe.h"
13#include <qvariant.h> 12#include <qvariant.h>
14#include <qwidget.h> 13#include <qwidget.h>
15#include <qtabdialog.h> 14#include <qtabdialog.h>
16#include <qtabwidget.h> 15#include <qtabwidget.h>
17#include <qspinbox.h> 16#include <qspinbox.h>
18#include <qcheckbox.h> 17#include <qcheckbox.h>
19#include <qcombobox.h> 18#include <qcombobox.h>
20#include <qlineedit.h> 19#include <qlineedit.h>
21//#include <qpe/menubutton.h> 20//#include <qpe/menubutton.h>
22#include <qvbuttongroup.h> 21#include <qvbuttongroup.h>
23 22
24class QVBoxLayout; 23class QVBoxLayout;
25class QHBoxLayout; 24class QHBoxLayout;
26class QGridLayout; 25class QGridLayout;
27//class QCheckBox; 26//class QCheckBox;
28class QLabel; 27class QLabel;
29//class QSpinBox; 28//class QSpinBox;
30 29
31class CURLDialog : public QDialog 30class CURLDialog : public QDialog
32{ 31{
33Q_OBJECT 32Q_OBJECT
34 QCheckBox *m_localfile, *m_globalfile, *m_clipboard; 33 QCheckBox *m_localfile, *m_globalfile, *m_clipboard;
35#ifndef USEQPE 34#ifndef USEQPE
36 void keyPressEvent(QKeyEvent* e) 35 void keyPressEvent(QKeyEvent* e)
37 { 36 {
38 switch (e->key()) 37 switch (e->key())
39 { 38 {
40 case Key_Escape: 39 case Key_Escape:
41 e->accept(); 40 e->accept();
42 reject(); 41 reject();
43 break; 42 break;
44 case Key_Space: 43 case Key_Space:
45 case Key_Return: 44 case Key_Return:
46 e->accept(); 45 e->accept();
47 accept(); 46 accept();
48 break; 47 break;
49 default: 48 default:
50 QWidget::keyPressEvent(e); 49 QWidget::keyPressEvent(e);
51 } 50 }
52 } 51 }
53#endif 52#endif
54 public: 53 public:
55 CURLDialog(const QString&, bool fs = true, QWidget* parent = 0, const char* name = 0); 54 CURLDialog(const QString&, bool fs = true, QWidget* parent = 0, const char* name = 0);
56 ~CURLDialog() {} 55 ~CURLDialog() {}
57 bool clipboard() { return m_clipboard->isChecked(); } 56 bool clipboard() { return m_clipboard->isChecked(); }
58 bool localfile() { return m_localfile->isChecked(); } 57 bool localfile() { return m_localfile->isChecked(); }
59 bool globalfile() { return m_globalfile->isChecked(); } 58 bool globalfile() { return m_globalfile->isChecked(); }
60 void clipboard(bool _b) { m_clipboard->setChecked(_b); } 59 void clipboard(bool _b) { m_clipboard->setChecked(_b); }
61 void localfile(bool _b) { m_localfile->setChecked(_b); } 60 void localfile(bool _b) { m_localfile->setChecked(_b); }
62 void globalfile(bool _b) { m_globalfile->setChecked(_b); } 61 void globalfile(bool _b) { m_globalfile->setChecked(_b); }
63 62
64}; 63};
65#endif // CPREFS_H 64#endif // CPREFS_H
diff --git a/noncore/apps/opie-reader/WeaselCodec/WeaselCodec.pro b/noncore/apps/opie-reader/WeaselCodec/WeaselCodec.pro
index 61e7dc9..f20bdc6 100644
--- a/noncore/apps/opie-reader/WeaselCodec/WeaselCodec.pro
+++ b/noncore/apps/opie-reader/WeaselCodec/WeaselCodec.pro
@@ -1,17 +1,17 @@
1DEFINES += OPIE USEQPE 1DEFINES += OPIE USEQPE
2VPATH = .. 2VPATH = ..
3 TEMPLATE= lib 3 TEMPLATE= lib
4 CONFIG = qt warn_on release dll 4 CONFIG = qt warn_on release dll
5 HEADERS = ztxt.h 5 HEADERS = ztxt.h
6 6
7 SOURCES = ztxt.cpp 7 SOURCES = ztxt.cpp
8 8
9 INTERFACES= 9 INTERFACES=
10 DESTDIR = $(OPIEDIR)/plugins/reader/codecs 10 DESTDIR = $(OPIEDIR)/plugins/reader/codecs
11 TARGET = Weasel 11 TARGET = Weasel
12LIBS += -lreader_pdb -lreader_codec 12LIBS += -lreader_pdb -lreader_codec
13 13
14 INCLUDEPATH+= ../OREADERINC $(OPIEDIR)/include 14 INCLUDEPATH+= $(OPIEDIR)/include
15 DEPENDPATH+= ../OREADERINC $(OPIEDIR)/include 15 DEPENDPATH+= $(OPIEDIR)/include
16 16
17include ( $(OPIEDIR)/include.pro ) 17include ( $(OPIEDIR)/include.pro )
diff --git a/noncore/apps/opie-reader/ZText.h b/noncore/apps/opie-reader/ZText.h
index 06e3bf8..199c7da 100644
--- a/noncore/apps/opie-reader/ZText.h
+++ b/noncore/apps/opie-reader/ZText.h
@@ -1,116 +1,115 @@
1#ifndef __Text_h 1#ifndef __Text_h
2#define __Text_h 2#define __Text_h
3#include <stdio.h> 3#include <stdio.h>
4#include <zlib.h> 4#include <zlib.h>
5#include <sys/stat.h> 5#include <sys/stat.h>
6#include "useqpe.h"
7#include "CExpander.h" 6#include "CExpander.h"
8 7
9class Text: public CExpander { 8class Text: public CExpander {
10 gzFile file; 9 gzFile file;
11 unsigned long fsize; 10 unsigned long fsize;
12public: 11public:
13 void suspend() 12 void suspend()
14 { 13 {
15#ifdef USEQPE 14#ifdef USEQPE
16 if (!bSuspended) 15 if (!bSuspended)
17 { 16 {
18 bSuspended = true; 17 bSuspended = true;
19 suspos = gztell(file); 18 suspos = gztell(file);
20 gzclose(file); 19 gzclose(file);
21 file = NULL; 20 file = NULL;
22 sustime = time(NULL); 21 sustime = time(NULL);
23 } 22 }
24#endif 23#endif
25 } 24 }
26 void unsuspend() 25 void unsuspend()
27 { 26 {
28#ifdef USEQPE 27#ifdef USEQPE
29 if (bSuspended) 28 if (bSuspended)
30 { 29 {
31 bSuspended = false; 30 bSuspended = false;
32 if (sustime != ((time_t)-1)) 31 if (sustime != ((time_t)-1))
33 { 32 {
34 int delay = time(NULL) - sustime; 33 int delay = time(NULL) - sustime;
35 if (delay < 10) sleep(10-delay); 34 if (delay < 10) sleep(10-delay);
36 } 35 }
37 file = gzopen(fname, "rb"); 36 file = gzopen(fname, "rb");
38 for (int i = 0; file == NULL && i < 5; i++) 37 for (int i = 0; file == NULL && i < 5; i++)
39 { 38 {
40 sleep(5); 39 sleep(5);
41 file = gzopen(fname, "rb"); 40 file = gzopen(fname, "rb");
42 } 41 }
43 if (file == NULL) 42 if (file == NULL)
44 { 43 {
45 QMessageBox::warning(NULL, PROGNAME, "Couldn't reopen file"); 44 QMessageBox::warning(NULL, PROGNAME, "Couldn't reopen file");
46 exit(0); 45 exit(0);
47 } 46 }
48 suspos = gzseek(file, suspos, SEEK_SET); 47 suspos = gzseek(file, suspos, SEEK_SET);
49 } 48 }
50#endif 49#endif
51 } 50 }
52 Text() : file(NULL) {}; 51 Text() : file(NULL) {};
53 virtual ~Text() 52 virtual ~Text()
54 { 53 {
55 if (file != NULL) 54 if (file != NULL)
56 { 55 {
57#ifdef USEQPE 56#ifdef USEQPE
58 unsuspend(); 57 unsuspend();
59#endif 58#endif
60 gzclose(file); 59 gzclose(file);
61 } 60 }
62 } 61 }
63 int OpenFile(const char *src) 62 int OpenFile(const char *src)
64 { 63 {
65 if (file != NULL) gzclose(file); 64 if (file != NULL) gzclose(file);
66 struct stat _stat; 65 struct stat _stat;
67 stat(src,&_stat); 66 stat(src,&_stat);
68 fsize = _stat.st_size; 67 fsize = _stat.st_size;
69 return ((file = gzopen(src,"rb")) == NULL); 68 return ((file = gzopen(src,"rb")) == NULL);
70 } 69 }
71 int getch() 70 int getch()
72 { 71 {
73#ifdef USEQPE 72#ifdef USEQPE
74 unsuspend(); 73 unsuspend();
75#endif 74#endif
76 return gzgetc(file); 75 return gzgetc(file);
77 } 76 }
78 unsigned int locate() 77 unsigned int locate()
79 { 78 {
80#ifdef USEQPE 79#ifdef USEQPE
81 unsuspend(); 80 unsuspend();
82#endif 81#endif
83 return gztell(file); 82 return gztell(file);
84 } 83 }
85 void locate(unsigned int n) 84 void locate(unsigned int n)
86 { 85 {
87#ifdef USEQPE 86#ifdef USEQPE
88 unsuspend(); 87 unsuspend();
89#endif 88#endif
90 gzseek(file,n,SEEK_SET); 89 gzseek(file,n,SEEK_SET);
91 } 90 }
92 bool hasrandomaccess() { return true; } 91 bool hasrandomaccess() { return true; }
93 void sizes(unsigned long& _file, unsigned long& _text) 92 void sizes(unsigned long& _file, unsigned long& _text)
94 { 93 {
95 _text = _file = fsize; 94 _text = _file = fsize;
96 FILE* f = fopen(fname, "rb"); 95 FILE* f = fopen(fname, "rb");
97 if (f != NULL) 96 if (f != NULL)
98 { 97 {
99 unsigned char mn[2]; 98 unsigned char mn[2];
100 fread(mn, 1, 2, f); 99 fread(mn, 1, 2, f);
101 if ((mn[0] == 31) && (mn[1] == 139)) 100 if ((mn[0] == 31) && (mn[1] == 139))
102 { 101 {
103 int tmp = sizeof(_text); 102 int tmp = sizeof(_text);
104 fseek(f,-tmp,SEEK_END); 103 fseek(f,-tmp,SEEK_END);
105 fread(&_text, sizeof(_text), 1, f); 104 fread(&_text, sizeof(_text), 1, f);
106 } 105 }
107 fclose(f); 106 fclose(f);
108 } 107 }
109 } 108 }
110 MarkupType PreferredMarkup() 109 MarkupType PreferredMarkup()
111 { 110 {
112 return cTEXT; 111 return cTEXT;
113 } 112 }
114 QString about() { return QString("Text/gzipped text codec (c) Tim Wentford"); } 113 QString about() { return QString("Text/gzipped text codec (c) Tim Wentford"); }
115}; 114};
116#endif 115#endif
diff --git a/noncore/apps/opie-reader/codeclib/codeclib.pro b/noncore/apps/opie-reader/codeclib/codeclib.pro
index 6adcda8..c24767b 100644
--- a/noncore/apps/opie-reader/codeclib/codeclib.pro
+++ b/noncore/apps/opie-reader/codeclib/codeclib.pro
@@ -1,17 +1,17 @@
1DEFINES += OPIE USEQPE 1DEFINES += OPIE USEQPE
2VPATH = .. 2VPATH = ..
3 TEMPLATE= lib 3 TEMPLATE= lib
4 CONFIG = qt warn_on release dll 4 CONFIG = qt warn_on release dll
5 HEADERS = pdb.h 5 HEADERS = pdb.h
6 6
7 SOURCES = CExpander.cpp CBuffer.cpp StyleConsts.cpp \ 7 SOURCES = CExpander.cpp CBuffer.cpp StyleConsts.cpp \
8 hrule.cpp Navigation.cpp Bkmks.cpp 8 hrule.cpp Navigation.cpp Bkmks.cpp
9 9
10 INTERFACES= 10 INTERFACES=
11 DESTDIR = $(OPIEDIR)/lib 11 DESTDIR = $(OPIEDIR)/lib
12 TARGET = reader_codec 12 TARGET = reader_codec
13 13
14 INCLUDEPATH+= ../OREADERINC $(OPIEDIR)/include 14 INCLUDEPATH+= $(OPIEDIR)/include
15 DEPENDPATH+= ../OREADERINC $(OPIEDIR)/include 15 DEPENDPATH+= $(OPIEDIR)/include
16 16
17include ( $(OPIEDIR)/include.pro ) 17include ( $(OPIEDIR)/include.pro )
diff --git a/noncore/apps/opie-reader/ebookcodec.h b/noncore/apps/opie-reader/ebookcodec.h
index b341e55..f6e2daf 100644
--- a/noncore/apps/opie-reader/ebookcodec.h
+++ b/noncore/apps/opie-reader/ebookcodec.h
@@ -1,120 +1,118 @@
1#include "CExpander.h" 1#include "CExpander.h"
2 2
3#include <qfileinfo.h> 3#include <qfileinfo.h>
4#include <qdir.h> 4#include <qdir.h>
5 5
6#include "useqpe.h"
7#ifdef USEQPE 6#ifdef USEQPE
8#include <qpe/global.h> 7#include <qpe/global.h>
9#endif 8#endif
10 9
11#include "util.h" 10#include "util.h"
12 11
13#include "static.h"
14#ifndef __STATIC 12#ifndef __STATIC
15#include <dlfcn.h> 13#include <dlfcn.h>
16class ebookcodec : public CExpander_Interface 14class ebookcodec : public CExpander_Interface
17{ 15{
18 CExpander *codec; 16 CExpander *codec;
19 void *handle; 17 void *handle;
20 int status; 18 int status;
21 public: 19 public:
22 QString about() 20 QString about()
23 { 21 {
24 return QString("Plug-in ebook codec interface (c) Tim Wentford\n")+codec->about(); 22 return QString("Plug-in ebook codec interface (c) Tim Wentford\n")+codec->about();
25 } 23 }
26 ebookcodec(const QString& _s) : codec(NULL), handle(NULL), status(0) 24 ebookcodec(const QString& _s) : codec(NULL), handle(NULL), status(0)
27 { 25 {
28 QString codecpath(QTReaderUtil::getPluginPath()); 26 QString codecpath(QTReaderUtil::getPluginPath());
29 codecpath += _s; 27 codecpath += _s;
30 if (QFile::exists(codecpath)) 28 if (QFile::exists(codecpath))
31 { 29 {
32 qDebug("Codec:%s", (const char*)codecpath); 30 qDebug("Codec:%s", (const char*)codecpath);
33 handle = dlopen(codecpath, RTLD_LAZY); 31 handle = dlopen(codecpath, RTLD_LAZY);
34 if (handle == 0) 32 if (handle == 0)
35 { 33 {
36 /* 34 /*
37 QString wrn(dlerror()); 35 QString wrn(dlerror());
38 QString fmt; 36 QString fmt;
39 while (wrn.length() > 10) 37 while (wrn.length() > 10)
40 { 38 {
41 fmt += wrn.left(10); 39 fmt += wrn.left(10);
42 fmt += '\n'; 40 fmt += '\n';
43 wrn = wrn.right(wrn.length()-10); 41 wrn = wrn.right(wrn.length()-10);
44 } 42 }
45 fmt += wrn; 43 fmt += wrn;
46 QMessageBox::warning(NULL, PROGNAME, fmt); 44 QMessageBox::warning(NULL, PROGNAME, fmt);
47 */ 45 */
48 qDebug("Can't find codec:%s", dlerror()); 46 qDebug("Can't find codec:%s", dlerror());
49 status = -10; 47 status = -10;
50 return; 48 return;
51 } 49 }
52 CExpander* (*newcodec)(); 50 CExpander* (*newcodec)();
53 newcodec = (CExpander* (*)())dlsym(handle, "newcodec"); 51 newcodec = (CExpander* (*)())dlsym(handle, "newcodec");
54 if (newcodec == NULL) 52 if (newcodec == NULL)
55 { 53 {
56 qDebug("Can't find newcodec"); 54 qDebug("Can't find newcodec");
57 status = -20; 55 status = -20;
58 return; 56 return;
59 } 57 }
60 codec = (*newcodec)(); 58 codec = (*newcodec)();
61 } 59 }
62 else 60 else
63 { 61 {
64 qDebug("Can't find codec"); 62 qDebug("Can't find codec");
65 } 63 }
66 if (codec == NULL) 64 if (codec == NULL)
67 { 65 {
68 qDebug("Can't do newcodec"); 66 qDebug("Can't do newcodec");
69 status = -30; 67 status = -30;
70 return; 68 return;
71 } 69 }
72 } 70 }
73 virtual ~ebookcodec() 71 virtual ~ebookcodec()
74 { 72 {
75 if (codec != NULL) delete codec; 73 if (codec != NULL) delete codec;
76 if (handle != NULL) dlclose(handle); 74 if (handle != NULL) dlclose(handle);
77 } 75 }
78 size_t getHome() { return codec->getHome(); } 76 size_t getHome() { return codec->getHome(); }
79#ifdef USEQPE 77#ifdef USEQPE
80 void suspend() { codec->suspend(); } 78 void suspend() { codec->suspend(); }
81 void unsuspend() { codec->unsuspend(); } 79 void unsuspend() { codec->unsuspend(); }
82 void suspend(FILE*& fin) { codec->suspend(fin); } 80 void suspend(FILE*& fin) { codec->suspend(fin); }
83 void unsuspend(FILE*& fin) { codec->unsuspend(fin); } 81 void unsuspend(FILE*& fin) { codec->unsuspend(fin); }
84#endif 82#endif
85 unsigned int locate() { return codec->locate(); } 83 unsigned int locate() { return codec->locate(); }
86 void locate(unsigned int n) { codec->locate(n); } 84 void locate(unsigned int n) { codec->locate(n); }
87 bool hasrandomaccess() { return codec->hasrandomaccess(); } 85 bool hasrandomaccess() { return codec->hasrandomaccess(); }
88 void sizes(unsigned long& file, unsigned long& text) 86 void sizes(unsigned long& file, unsigned long& text)
89 { 87 {
90 codec->sizes(file, text); 88 codec->sizes(file, text);
91 //qDebug("Codec sizes:(%u, %u)", file, text); 89 //qDebug("Codec sizes:(%u, %u)", file, text);
92 } 90 }
93 CList<Bkmk>* getbkmklist() { return codec->getbkmklist(); } 91 CList<Bkmk>* getbkmklist() { return codec->getbkmklist(); }
94 void getch(tchar& ch, CStyle& sty, unsigned long& pos) { codec->getch(ch, sty, pos); } 92 void getch(tchar& ch, CStyle& sty, unsigned long& pos) { codec->getch(ch, sty, pos); }
95 int getch() { return codec->getch(); } 93 int getch() { return codec->getch(); }
96 linkType hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm) { return codec->hyperlink(n, noff, wrd, nm); } 94 linkType hyperlink(unsigned int n, unsigned int noff, QString& wrd, QString& nm) { return codec->hyperlink(n, noff, wrd, nm); }
97 MarkupType PreferredMarkup() { return codec->PreferredMarkup(); } 95 MarkupType PreferredMarkup() { return codec->PreferredMarkup(); }
98 void saveposn(size_t posn) { codec->saveposn(posn); } 96 void saveposn(size_t posn) { codec->saveposn(posn); }
99 void writeposn(size_t posn) { codec->writeposn(posn); } 97 void writeposn(size_t posn) { codec->writeposn(posn); }
100 linkType forward(size_t& loc) { return codec->forward(loc); } 98 linkType forward(size_t& loc) { return codec->forward(loc); }
101 linkType back(size_t& loc) { return codec->back(loc); } 99 linkType back(size_t& loc) { return codec->back(loc); }
102 bool hasnavigation() { return codec->hasnavigation(); } 100 bool hasnavigation() { return codec->hasnavigation(); }
103 void start2endSection() { codec->start2endSection(); } 101 void start2endSection() { codec->start2endSection(); }
104 QImage* getPicture(unsigned long tgt) { return codec->getPicture(tgt); } 102 QImage* getPicture(unsigned long tgt) { return codec->getPicture(tgt); }
105 void setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen) { return codec->setSaveData(data, len, src, srclen); } 103 void setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen) { return codec->setSaveData(data, len, src, srclen); }
106 void putSaveData(unsigned char*& src, unsigned short& srclen) { codec->putSaveData(src, srclen); } 104 void putSaveData(unsigned char*& src, unsigned short& srclen) { codec->putSaveData(src, srclen); }
107 void setContinuous(bool _b) { codec->setContinuous(_b); } 105 void setContinuous(bool _b) { codec->setContinuous(_b); }
108 void setwidth(int w) { codec->setwidth(w); } 106 void setwidth(int w) { codec->setwidth(w); }
109 unsigned long startSection() { return codec->startSection(); } 107 unsigned long startSection() { return codec->startSection(); }
110 unsigned long endSection() { return codec->endSection(); } 108 unsigned long endSection() { return codec->endSection(); }
111 int openfile(const char *src) 109 int openfile(const char *src)
112 { 110 {
113 //qDebug("ebook openfile:%s", src); 111 //qDebug("ebook openfile:%s", src);
114 return (status != 0) ? status : codec->openfile(src); 112 return (status != 0) ? status : codec->openfile(src);
115 } 113 }
116 int getwidth() { return codec->getwidth(); } 114 int getwidth() { return codec->getwidth(); }
117 QImage* getPicture(const QString& href) { return codec->getPicture(href); } 115 QImage* getPicture(const QString& href) { return codec->getPicture(href); }
118 bool getFile(const QString& href) { return codec->getFile(href); } 116 bool getFile(const QString& href) { return codec->getFile(href); }
119}; 117};
120#endif 118#endif
diff --git a/noncore/apps/opie-reader/iSiloCodec/iSiloCodec.pro b/noncore/apps/opie-reader/iSiloCodec/iSiloCodec.pro
index 78d5a49..5cf075e 100644
--- a/noncore/apps/opie-reader/iSiloCodec/iSiloCodec.pro
+++ b/noncore/apps/opie-reader/iSiloCodec/iSiloCodec.pro
@@ -1,19 +1,19 @@
1DEFINES += OPIE USEQPE 1DEFINES += OPIE USEQPE
2VPATH = .. 2VPATH = ..
3 TEMPLATE= lib 3 TEMPLATE= lib
4 CONFIG = qt warn_on release dll 4 CONFIG = qt warn_on release dll
5 #HEADERS = Aportis.h 5 #HEADERS = Aportis.h
6 6
7 SOURCES = iSilo.cpp 7 SOURCES = iSilo.cpp
8 8
9 9
10 INTERFACES= 10 INTERFACES=
11 DESTDIR = $(OPIEDIR)/plugins/reader/codecs 11 DESTDIR = $(OPIEDIR)/plugins/reader/codecs
12 TARGET = iSilo 12 TARGET = iSilo
13LIBS += -lreader_pdb -lreader_codec 13LIBS += -lreader_pdb -lreader_codec
14 14
15 INCLUDEPATH+= ../OREADERINC $(OPIEDIR)/include 15 INCLUDEPATH+= $(OPIEDIR)/include
16 DEPENDPATH+= ../OREADERINC $(OPIEDIR)/include 16 DEPENDPATH+= $(OPIEDIR)/include
17 17
18include ( $(OPIEDIR)/include.pro ) 18include ( $(OPIEDIR)/include.pro )
19 19
diff --git a/noncore/apps/opie-reader/main.cpp b/noncore/apps/opie-reader/main.cpp
index 3e1f5e7..af276da 100644
--- a/noncore/apps/opie-reader/main.cpp
+++ b/noncore/apps/opie-reader/main.cpp
@@ -1,50 +1,49 @@
1#include "useqpe.h"
2#ifdef USEQPE 1#ifdef USEQPE
3#include <qpe/qpeapplication.h> 2#include <qpe/qpeapplication.h>
4#else 3#else
5#include <qapplication.h> 4#include <qapplication.h>
6#endif 5#endif
7#include "QTReaderApp.h" 6#include "QTReaderApp.h"
8 7
9#include "signal.h" 8#include "signal.h"
10#include "stdio.h" 9#include "stdio.h"
11#include "time.h" 10#include "time.h"
12 11
13 12
14#ifdef USEQPE 13#ifdef USEQPE
15QTReaderApp* app = NULL; 14QTReaderApp* app = NULL;
16 15
17void handler(int signum) 16void handler(int signum)
18{ 17{
19 if (app != NULL) 18 if (app != NULL)
20 { 19 {
21 app->suspend(); 20 app->suspend();
22 app->saveprefs(); 21 app->saveprefs();
23 } 22 }
24 signal(signum, handler); 23 signal(signum, handler);
25} 24}
26#endif 25#endif
27 26
28int main( int argc, char ** argv ) 27int main( int argc, char ** argv )
29{ 28{
30 29
31#ifdef USEQPE 30#ifdef USEQPE
32 signal(SIGCONT, handler); 31 signal(SIGCONT, handler);
33 QPEApplication a( argc, argv ); 32 QPEApplication a( argc, argv );
34 QTReaderApp m; 33 QTReaderApp m;
35 a.showMainDocumentWidget( &m ); 34 a.showMainDocumentWidget( &m );
36 app = &m; 35 app = &m;
37#else 36#else
38 QApplication a( argc, argv ); 37 QApplication a( argc, argv );
39 QTReaderApp m; 38 QTReaderApp m;
40 a.setMainWidget( &m ); 39 a.setMainWidget( &m );
41 if (argc > 1) 40 if (argc > 1)
42 { 41 {
43 m.setDocument(argv[1]); 42 m.setDocument(argv[1]);
44 } 43 }
45#endif 44#endif
46 45
47 46
48 return a.exec(); 47 return a.exec();
49} 48}
50 49
diff --git a/noncore/apps/opie-reader/pdb.cpp b/noncore/apps/opie-reader/pdb.cpp
index 39551cc..6719af4 100644
--- a/noncore/apps/opie-reader/pdb.cpp
+++ b/noncore/apps/opie-reader/pdb.cpp
@@ -1,90 +1,89 @@
1#include "pdb.h" 1#include "pdb.h"
2#ifdef _WINDOWS 2#ifdef _WINDOWS
3#include <winsock2.h> 3#include <winsock2.h>
4#endif 4#endif
5 5
6#include "useqpe.h"
7 6
8#ifdef USEQPE 7#ifdef USEQPE
9void Cpdb::suspend() 8void Cpdb::suspend()
10{ 9{
11 CExpander::suspend(fin); 10 CExpander::suspend(fin);
12} 11}
13void Cpdb::unsuspend() 12void Cpdb::unsuspend()
14{ 13{
15 CExpander::unsuspend(fin); 14 CExpander::unsuspend(fin);
16} 15}
17#endif 16#endif
18 17
19Cpdb::~Cpdb() 18Cpdb::~Cpdb()
20{ 19{
21 if (fin != NULL) 20 if (fin != NULL)
22 { 21 {
23#ifdef USEQPE 22#ifdef USEQPE
24 unsuspend(); 23 unsuspend();
25#endif 24#endif
26 fclose(fin); 25 fclose(fin);
27 } 26 }
28} 27}
29 28
30size_t Cpdb::recordpos(int n) 29size_t Cpdb::recordpos(int n)
31{ 30{
32 UInt16 mxn = ntohs(head.recordList.numRecords); 31 UInt16 mxn = ntohs(head.recordList.numRecords);
33 if (n >= mxn) 32 if (n >= mxn)
34 { 33 {
35 return file_length; 34 return file_length;
36 } 35 }
37 else 36 else
38 { 37 {
39 size_t dataoffset = sizeof(DatabaseHdrType) - sizeof(UInt16); 38 size_t dataoffset = sizeof(DatabaseHdrType) - sizeof(UInt16);
40 dataoffset += /*dataoffset%4 + */ sizeof(RecordListType) * n; 39 dataoffset += /*dataoffset%4 + */ sizeof(RecordListType) * n;
41 fseek(fin, dataoffset, SEEK_SET); 40 fseek(fin, dataoffset, SEEK_SET);
42 RecordListType hdr; 41 RecordListType hdr;
43 fread(&hdr, 1, sizeof(hdr), fin); 42 fread(&hdr, 1, sizeof(hdr), fin);
44 return ntohl(hdr.nextRecordListID); 43 return ntohl(hdr.nextRecordListID);
45 } 44 }
46 45
47} 46}
48 47
49size_t Cpdb::recordlength(int n) 48size_t Cpdb::recordlength(int n)
50{ 49{
51 return recordpos(n+1)-recordpos(n); 50 return recordpos(n+1)-recordpos(n);
52} 51}
53 52
54void Cpdb::gotorecordnumber(int n) 53void Cpdb::gotorecordnumber(int n)
55{ 54{
56 fseek(fin, recordpos(n), SEEK_SET); 55 fseek(fin, recordpos(n), SEEK_SET);
57} 56}
58 57
59bool Cpdb::openpdbfile(const char *src) 58bool Cpdb::openpdbfile(const char *src)
60{ 59{
61 //qDebug("cpdb openfile:%s", src); 60 //qDebug("cpdb openfile:%s", src);
62 61
63 // printf("In openfile\n"); 62 // printf("In openfile\n");
64 // printf("closing fin:%x\n",fin); 63 // printf("closing fin:%x\n",fin);
65 if (fin != NULL) fclose(fin); 64 if (fin != NULL) fclose(fin);
66 // printf("opening fin\n"); 65 // printf("opening fin\n");
67 fin = fopen(src,"rb"); 66 fin = fopen(src,"rb");
68 67
69 if (fin==0) 68 if (fin==0)
70 { 69 {
71 return false; 70 return false;
72 } 71 }
73 72
74 // just holds the first few chars of the file 73 // just holds the first few chars of the file
75 //char buf[0x100]; 74 //char buf[0x100];
76 struct stat _stat; 75 struct stat _stat;
77 stat(src,&_stat); 76 stat(src,&_stat);
78 file_length = _stat.st_size; 77 file_length = _stat.st_size;
79 // fseek(fin,0,SEEK_END); 78 // fseek(fin,0,SEEK_END);
80 // file_length = ftell(fin); 79 // file_length = ftell(fin);
81 80
82 fseek(fin,0,SEEK_SET); 81 fseek(fin,0,SEEK_SET);
83 82
84 fread(&head, 1, sizeof(head), fin); 83 fread(&head, 1, sizeof(head), fin);
85 84
86 qDebug("Database name:%s", head.name); 85 qDebug("Database name:%s", head.name);
87 qDebug("Total number of records:%u", ntohs(head.recordList.numRecords)); 86 qDebug("Total number of records:%u", ntohs(head.recordList.numRecords));
88 87
89 return true; 88 return true;
90} 89}
diff --git a/noncore/apps/opie-reader/pdb.h b/noncore/apps/opie-reader/pdb.h
index 7a6580d..7458919 100644
--- a/noncore/apps/opie-reader/pdb.h
+++ b/noncore/apps/opie-reader/pdb.h
@@ -1,101 +1,100 @@
1 1
2/* 2/*
3 * This header file defines some structures and types normally found in the 3 * This header file defines some structures and types normally found in the
4 * Palm SDK. However, I don't want to require the presense of the SDK for a 4 * Palm SDK. However, I don't want to require the presense of the SDK for a
5 * small utility since most Palm owners won't have it. 5 * small utility since most Palm owners won't have it.
6 * 6 *
7 * $Id$ 7 * $Id$
8 * 8 *
9 */ 9 */
10 10
11#ifndef __PDB_H__ 11#ifndef __PDB_H__
12#define __PDB_H__ 12#define __PDB_H__
13 13
14#ifndef _WINDOWS 14#ifndef _WINDOWS
15#include <netinet/in.h> 15#include <netinet/in.h>
16#endif 16#endif
17#include <stdio.h> 17#include <stdio.h>
18#include "useqpe.h"
19#include "CExpander.h" 18#include "CExpander.h"
20 19
21/* Normal Palm typedefs */ 20/* Normal Palm typedefs */
22typedef unsigned char UInt8; 21typedef unsigned char UInt8;
23typedef unsigned short UInt16; 22typedef unsigned short UInt16;
24typedef signed short Int16; 23typedef signed short Int16;
25typedef unsigned long UInt32; 24typedef unsigned long UInt32;
26typedef UInt32 LocalID; 25typedef UInt32 LocalID;
27 26
28/* Max length of DB name */ 27/* Max length of DB name */
29#define dmDBNameLength 0x20 28#define dmDBNameLength 0x20
30 29
31 30
32/************************************************************ 31/************************************************************
33 * Structure of a Record entry 32 * Structure of a Record entry
34 *************************************************************/ 33 *************************************************************/
35typedef struct { 34typedef struct {
36 LocalID localChunkID; // local chunkID of a record 35 LocalID localChunkID; // local chunkID of a record
37 UInt8 attributes; // record attributes; 36 UInt8 attributes; // record attributes;
38 UInt8 uniqueID[3]; // unique ID of record; should 37 UInt8 uniqueID[3]; // unique ID of record; should
39 // not be 0 for a legal record. 38 // not be 0 for a legal record.
40} RecordEntryType; 39} RecordEntryType;
41 40
42 41
43/************************************************************ 42/************************************************************
44 * Structure of a record list extension. This is used if all 43 * Structure of a record list extension. This is used if all
45 * the database record/resource entries of a database can't fit into 44 * the database record/resource entries of a database can't fit into
46 * the database header. 45 * the database header.
47 *************************************************************/ 46 *************************************************************/
48typedef struct { 47typedef struct {
49 LocalID nextRecordListID; // local chunkID of next list 48 LocalID nextRecordListID; // local chunkID of next list
50 UInt16 numRecords; // number of records in this list 49 UInt16 numRecords; // number of records in this list
51 UInt16 firstEntry; // array of Record/Rsrc entries 50 UInt16 firstEntry; // array of Record/Rsrc entries
52 // starts here 51 // starts here
53} RecordListType; 52} RecordListType;
54 53
55 54
56/************************************************************ 55/************************************************************
57 * Structure of a Database Header 56 * Structure of a Database Header
58 *************************************************************/ 57 *************************************************************/
59typedef struct { 58typedef struct {
60 UInt8 name[dmDBNameLength]; // name of database 59 UInt8 name[dmDBNameLength]; // name of database
61 UInt16 attributes; // database attributes 60 UInt16 attributes; // database attributes
62 UInt16 version; // version of database 61 UInt16 version; // version of database
63 UInt32 creationDate; // creation date of database 62 UInt32 creationDate; // creation date of database
64 UInt32 modificationDate; // latest modification date 63 UInt32 modificationDate; // latest modification date
65 UInt32 lastBackupDate; // latest backup date 64 UInt32 lastBackupDate; // latest backup date
66 UInt32 modificationNumber; // modification number of database 65 UInt32 modificationNumber; // modification number of database
67 LocalID appInfoID; // application specific info 66 LocalID appInfoID; // application specific info
68 LocalID sortInfoID; // app specific sorting info 67 LocalID sortInfoID; // app specific sorting info
69 UInt32 type; // database type 68 UInt32 type; // database type
70 UInt32 creator; // database creator 69 UInt32 creator; // database creator
71 UInt32 uniqueIDSeed; // used to generate unique IDs. 70 UInt32 uniqueIDSeed; // used to generate unique IDs.
72 // Note that only the low order 71 // Note that only the low order
73 // 3 bytes of this is used (in 72 // 3 bytes of this is used (in
74 // RecordEntryType.uniqueID). 73 // RecordEntryType.uniqueID).
75 // We are keeping 4 bytes for 74 // We are keeping 4 bytes for
76 // alignment purposes. 75 // alignment purposes.
77 RecordListType recordList; // first record list 76 RecordListType recordList; // first record list
78} DatabaseHdrType; 77} DatabaseHdrType;
79 78
80 79
81class Cpdb : public CExpander 80class Cpdb : public CExpander
82{ 81{
83 protected: 82 protected:
84 size_t file_length; 83 size_t file_length;
85 FILE* fin; 84 FILE* fin;
86 size_t recordpos(int); 85 size_t recordpos(int);
87 size_t recordlength(int); 86 size_t recordlength(int);
88 void gotorecordnumber(int); 87 void gotorecordnumber(int);
89 DatabaseHdrType head; 88 DatabaseHdrType head;
90 bool openpdbfile(const char* src); 89 bool openpdbfile(const char* src);
91 Cpdb() : fin(NULL) {} 90 Cpdb() : fin(NULL) {}
92 ~Cpdb(); 91 ~Cpdb();
93#ifdef USEQPE 92#ifdef USEQPE
94 void suspend(); 93 void suspend();
95 void unsuspend(); 94 void unsuspend();
96#endif 95#endif
97 public: 96 public:
98 virtual void sizes(unsigned long& _file, unsigned long& _text) = 0; 97 virtual void sizes(unsigned long& _file, unsigned long& _text) = 0;
99}; 98};
100#endif 99#endif
101 100
diff --git a/noncore/apps/opie-reader/pdblib/pdblib.pro b/noncore/apps/opie-reader/pdblib/pdblib.pro
index cb861a8..830d988 100644
--- a/noncore/apps/opie-reader/pdblib/pdblib.pro
+++ b/noncore/apps/opie-reader/pdblib/pdblib.pro
@@ -1,16 +1,16 @@
1DEFINES += OPIE USEQPE 1DEFINES += OPIE USEQPE
2VPATH = .. 2VPATH = ..
3 TEMPLATE= lib 3 TEMPLATE= lib
4 CONFIG = qt warn_on release dll 4 CONFIG = qt warn_on release dll
5 HEADERS = pdb.h 5 HEADERS = pdb.h
6 6
7 SOURCES = pdb.cpp 7 SOURCES = pdb.cpp
8 8
9 INTERFACES= 9 INTERFACES=
10 DESTDIR = $(OPIEDIR)/lib 10 DESTDIR = $(OPIEDIR)/lib
11 TARGET = reader_pdb 11 TARGET = reader_pdb
12 12
13 INCLUDEPATH+= ../OREADERINC $(OPIEDIR)/include 13 INCLUDEPATH+= $(OPIEDIR)/include
14 DEPENDPATH+= ../OREADERINC $(OPIEDIR)/include 14 DEPENDPATH+= $(OPIEDIR)/include
15 15
16include ( $(OPIEDIR)/include.pro ) 16include ( $(OPIEDIR)/include.pro )
diff --git a/noncore/apps/opie-reader/plucker.cpp b/noncore/apps/opie-reader/plucker.cpp
index d1ccd6f..4ea807a 100644
--- a/noncore/apps/opie-reader/plucker.cpp
+++ b/noncore/apps/opie-reader/plucker.cpp
@@ -1,231 +1,229 @@
1#include "useqpe.h"
2#include <stdio.h> 1#include <stdio.h>
3#include <string.h> 2#include <string.h>
4#include <qmessagebox.h> 3#include <qmessagebox.h>
5#include <qpixmap.h> 4#include <qpixmap.h>
6#ifdef USEQPE 5#ifdef USEQPE
7#include <qpe/qcopenvelope_qws.h> 6#include <qpe/qcopenvelope_qws.h>
8#endif 7#endif
9#ifdef LOCALPICTURES 8#ifdef LOCALPICTURES
10#include <qscrollview.h> 9#include <qscrollview.h>
11#endif 10#endif
12#ifdef USEQPE 11#ifdef USEQPE
13#include <qpe/global.h> 12#include <qpe/global.h>
14#include <qpe/qpeapplication.h> 13#include <qpe/qpeapplication.h>
15#else 14#else
16#include <qapplication.h> 15#include <qapplication.h>
17#endif 16#endif
18#include <qclipboard.h> 17#include <qclipboard.h>
19 18
20#include "plucker.h" 19#include "plucker.h"
21#include "Aportis.h" 20#include "Aportis.h"
22#include "Palm2QImage.h" 21#include "Palm2QImage.h"
23#include "static.h"
24 22
25 23
26struct CPlucker_dataRecord 24struct CPlucker_dataRecord
27{ 25{
28 UInt16 uid; 26 UInt16 uid;
29 UInt16 nParagraphs; 27 UInt16 nParagraphs;
30 UInt16 size; 28 UInt16 size;
31 UInt8 type; 29 UInt8 type;
32 UInt8 reserved; 30 UInt8 reserved;
33}; 31};
34 32
35int CPlucker::HeaderSize() 33int CPlucker::HeaderSize()
36{ 34{
37 return sizeof(CPlucker_dataRecord); 35 return sizeof(CPlucker_dataRecord);
38} 36}
39 37
40void CPlucker::GetHeader(UInt16& uid, UInt16& nParagraphs, UInt32& size, UInt8& type, UInt8& reserved) 38void CPlucker::GetHeader(UInt16& uid, UInt16& nParagraphs, UInt32& size, UInt8& type, UInt8& reserved)
41{ 39{
42 CPlucker_dataRecord thishdr; 40 CPlucker_dataRecord thishdr;
43 fread(&thishdr, 1, HeaderSize(), fin); 41 fread(&thishdr, 1, HeaderSize(), fin);
44 uid = ntohs(thishdr.uid); 42 uid = ntohs(thishdr.uid);
45 nParagraphs = ntohs(thishdr.nParagraphs); 43 nParagraphs = ntohs(thishdr.nParagraphs);
46 size = ntohs(thishdr.size); 44 size = ntohs(thishdr.size);
47 type = thishdr.type; 45 type = thishdr.type;
48 reserved = thishdr.reserved; 46 reserved = thishdr.reserved;
49} 47}
50 48
51CPlucker::CPlucker() 49CPlucker::CPlucker()
52 { /*printf("constructing:%x\n",fin);*/ 50 { /*printf("constructing:%x\n",fin);*/
53 EOPPhase = 0; 51 EOPPhase = 0;
54 } 52 }
55 53
56bool CPlucker::CorrectDecoder() 54bool CPlucker::CorrectDecoder()
57{ 55{
58 return (memcmp(&head.type, "DataPlkr", 8) == 0); 56 return (memcmp(&head.type, "DataPlkr", 8) == 0);
59} 57}
60 58
61int CPlucker::bgetch() 59int CPlucker::bgetch()
62{ 60{
63 int ch = EOF; 61 int ch = EOF;
64 if (bufferpos >= buffercontent) 62 if (bufferpos >= buffercontent)
65 { 63 {
66 if (isEndOfSection(bufferrec)) 64 if (isEndOfSection(bufferrec))
67 { 65 {
68 if (!m_continuous) return EOF; 66 if (!m_continuous) return EOF;
69 } 67 }
70 if (bufferrec >= ntohs(head.recordList.numRecords) - 1) 68 if (bufferrec >= ntohs(head.recordList.numRecords) - 1)
71 { 69 {
72 return EOF; 70 return EOF;
73 } 71 }
74 if (!expand(bufferrec+1)) 72 if (!expand(bufferrec+1))
75 { 73 {
76 return EOF; 74 return EOF;
77 } 75 }
78 mystyle.unset(); 76 mystyle.unset();
79 if (m_ParaOffsets[m_nextParaIndex] == 0) 77 if (m_ParaOffsets[m_nextParaIndex] == 0)
80 { 78 {
81 while (m_ParaOffsets[m_nextParaIndex+1] == 0) 79 while (m_ParaOffsets[m_nextParaIndex+1] == 0)
82 { 80 {
83 // qDebug("Skipping extraspace:%d", m_ParaAttrs[m_nextParaIndex]&7); 81 // qDebug("Skipping extraspace:%d", m_ParaAttrs[m_nextParaIndex]&7);
84 m_nextParaIndex++; 82 m_nextParaIndex++;
85 } 83 }
86 } 84 }
87 mystyle.setExtraSpace((m_ParaAttrs[m_nextParaIndex]&7)*2); 85 mystyle.setExtraSpace((m_ParaAttrs[m_nextParaIndex]&7)*2);
88 //qDebug("Using extraspace:%d", m_ParaAttrs[m_nextParaIndex]&7); 86 //qDebug("Using extraspace:%d", m_ParaAttrs[m_nextParaIndex]&7);
89 ch = 10; 87 ch = 10;
90 if (m_continuous) EOPPhase = 4; 88 if (m_continuous) EOPPhase = 4;
91 } 89 }
92 else if (bufferpos == m_nextPara) 90 else if (bufferpos == m_nextPara)
93 { 91 {
94 while (bufferpos == m_nextPara) 92 while (bufferpos == m_nextPara)
95 { 93 {
96 UInt16 attr = m_ParaAttrs[m_nextParaIndex]; 94 UInt16 attr = m_ParaAttrs[m_nextParaIndex];
97 m_nextParaIndex++; 95 m_nextParaIndex++;
98 // qDebug("Skipping extraspace:%d", m_ParaAttrs[m_nextParaIndex]&7); 96 // qDebug("Skipping extraspace:%d", m_ParaAttrs[m_nextParaIndex]&7);
99 if (m_nextParaIndex == m_nParas) 97 if (m_nextParaIndex == m_nParas)
100 { 98 {
101 m_nextPara = -1; 99 m_nextPara = -1;
102 } 100 }
103 else 101 else
104 { 102 {
105 m_nextPara += m_ParaOffsets[m_nextParaIndex]; 103 m_nextPara += m_ParaOffsets[m_nextParaIndex];
106 } 104 }
107 } 105 }
108 mystyle.unset(); 106 mystyle.unset();
109 mystyle.setExtraSpace((m_ParaAttrs[m_nextParaIndex]&7)*2); 107 mystyle.setExtraSpace((m_ParaAttrs[m_nextParaIndex]&7)*2);
110 //qDebug("Using extraspace:%d", m_ParaAttrs[m_nextParaIndex]&7); 108 //qDebug("Using extraspace:%d", m_ParaAttrs[m_nextParaIndex]&7);
111 if (m_lastBreak == locate()) 109 if (m_lastBreak == locate())
112 { 110 {
113 currentpos++; 111 currentpos++;
114 ch = expandedtextbuffer[bufferpos++]; 112 ch = expandedtextbuffer[bufferpos++];
115 } 113 }
116 else 114 else
117 { 115 {
118 ch = 10; 116 ch = 10;
119 } 117 }
120 } 118 }
121 else 119 else
122 { 120 {
123 currentpos++; 121 currentpos++;
124 ch = expandedtextbuffer[bufferpos++]; 122 ch = expandedtextbuffer[bufferpos++];
125 } 123 }
126 return ch; 124 return ch;
127} 125}
128 126
129tchar CPlucker::getch(bool fast) 127tchar CPlucker::getch(bool fast)
130{ 128{
131 mystyle.clearPicture(); 129 mystyle.clearPicture();
132 130
133 if (EOPPhase > 0) 131 if (EOPPhase > 0)
134 { 132 {
135 int ch = 10; 133 int ch = 10;
136 switch (EOPPhase) 134 switch (EOPPhase)
137 { 135 {
138 case 4: 136 case 4:
139 if (!fast) mystyle.setPicture(false, hRule(100,5)); 137 if (!fast) mystyle.setPicture(false, hRule(100,5));
140 mystyle.setCentreJustify(); 138 mystyle.setCentreJustify();
141 ch = '#'; 139 ch = '#';
142 break; 140 break;
143 case 3: 141 case 3:
144 mystyle.setFontSize(3); 142 mystyle.setFontSize(3);
145 ch = 10; 143 ch = 10;
146 break; 144 break;
147 case 2: 145 case 2:
148 ch = 10; 146 ch = 10;
149 break; 147 break;
150 case 1: 148 case 1:
151 mystyle.unset(); 149 mystyle.unset();
152 default: 150 default:
153 ch = 10; 151 ch = 10;
154 } 152 }
155 EOPPhase--; 153 EOPPhase--;
156 return ch; 154 return ch;
157 } 155 }
158 156
159 return getch_base(fast); 157 return getch_base(fast);
160} 158}
161 159
162QImage* CPlucker::imagefromdata(UInt8* imgbuffer, UInt32 imgsize) 160QImage* CPlucker::imagefromdata(UInt8* imgbuffer, UInt32 imgsize)
163{ 161{
164 QImage* qimage = Palm2QImage(imgbuffer, imgsize); 162 QImage* qimage = Palm2QImage(imgbuffer, imgsize);
165 delete [] imgbuffer; 163 delete [] imgbuffer;
166 return qimage; 164 return qimage;
167} 165}
168 166
169void CPlucker::start2endSection() // to plucker base 167void CPlucker::start2endSection() // to plucker base
170{ 168{
171 m_currentstart = NEFstartSection(); 169 m_currentstart = NEFstartSection();
172 m_currentend = NEFendSection(); 170 m_currentend = NEFendSection();
173} 171}
174 172
175unsigned long CPlucker::NEFstartSection() // virtual in plucker base - differs only in obsoleted nef so move implementation 173unsigned long CPlucker::NEFstartSection() // virtual in plucker base - differs only in obsoleted nef so move implementation
176{ 174{
177//inefficient - Should calc start/end of section on entry to section? 175//inefficient - Should calc start/end of section on entry to section?
178 UInt16 thishdr_uid, thishdr_nParagraphs; 176 UInt16 thishdr_uid, thishdr_nParagraphs;
179 UInt32 thishdr_size; 177 UInt32 thishdr_size;
180 UInt8 thishdr_type, thishdr_reserved; 178 UInt8 thishdr_type, thishdr_reserved;
181 unsigned long textlength = currentpos-bufferpos; 179 unsigned long textlength = currentpos-bufferpos;
182 for (UInt16 recptr = bufferrec-1; recptr >= 1; recptr--) 180 for (UInt16 recptr = bufferrec-1; recptr >= 1; recptr--)
183 { 181 {
184 gotorecordnumber(recptr); 182 gotorecordnumber(recptr);
185 //qDebug("recptr:%u", recptr); 183 //qDebug("recptr:%u", recptr);
186 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 184 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
187 if (thishdr_type < 2) 185 if (thishdr_type < 2)
188 { 186 {
189 if ((thishdr_reserved && continuation_bit) == 0) break; 187 if ((thishdr_reserved && continuation_bit) == 0) break;
190 textlength -= thishdr_size; 188 textlength -= thishdr_size;
191 //qDebug("Textlength:%u, reserved:%u, recptr:%u", textlength, thishdr_reserved, recptr); 189 //qDebug("Textlength:%u, reserved:%u, recptr:%u", textlength, thishdr_reserved, recptr);
192 } 190 }
193 } 191 }
194 return textlength; 192 return textlength;
195} 193}
196 194
197unsigned long CPlucker::NEFendSection() // virtual in plucker base - differs only in obsoleted nef so move implementation 195unsigned long CPlucker::NEFendSection() // virtual in plucker base - differs only in obsoleted nef so move implementation
198{ 196{
199//inefficient - Should calc start/end of section on entry to section? 197//inefficient - Should calc start/end of section on entry to section?
200 unsigned long textlength = currentpos-bufferpos+buffercontent; 198 unsigned long textlength = currentpos-bufferpos+buffercontent;
201 gotorecordnumber(bufferrec); 199 gotorecordnumber(bufferrec);
202 UInt16 thishdr_uid, thishdr_nParagraphs; 200 UInt16 thishdr_uid, thishdr_nParagraphs;
203 UInt32 thishdr_size; 201 UInt32 thishdr_size;
204 UInt8 thishdr_type, thishdr_reserved; 202 UInt8 thishdr_type, thishdr_reserved;
205 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 203 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
206 if ((thishdr_reserved && continuation_bit) != 0) 204 if ((thishdr_reserved && continuation_bit) != 0)
207 { 205 {
208 for (UInt16 recptr = bufferrec+1; recptr < ntohs(head.recordList.numRecords); recptr++) 206 for (UInt16 recptr = bufferrec+1; recptr < ntohs(head.recordList.numRecords); recptr++)
209 { 207 {
210 gotorecordnumber(recptr); 208 gotorecordnumber(recptr);
211 UInt16 thishdr_uid, thishdr_nParagraphs; 209 UInt16 thishdr_uid, thishdr_nParagraphs;
212 UInt32 thishdr_size; 210 UInt32 thishdr_size;
213 UInt8 thishdr_type, thishdr_reserved; 211 UInt8 thishdr_type, thishdr_reserved;
214 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 212 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
215 //qDebug("recptr %u bufferrec %u type %u m_reserved %u", recptr, bufferrec, typ 213 //qDebug("recptr %u bufferrec %u type %u m_reserved %u", recptr, bufferrec, typ
216 if (thishdr_type < 2) 214 if (thishdr_type < 2)
217 { 215 {
218 textlength += thishdr_size; 216 textlength += thishdr_size;
219 if ((thishdr_reserved && continuation_bit) == 0) break; 217 if ((thishdr_reserved && continuation_bit) == 0) break;
220 } 218 }
221 } 219 }
222 } 220 }
223 return textlength; 221 return textlength;
224} 222}
225 223
226#ifndef __STATIC 224#ifndef __STATIC
227extern "C" 225extern "C"
228{ 226{
229 CExpander* newcodec() { return new CPlucker; } 227 CExpander* newcodec() { return new CPlucker; }
230} 228}
231#endif 229#endif
diff --git a/noncore/apps/opie-reader/plucker_base.cpp b/noncore/apps/opie-reader/plucker_base.cpp
index 0b7fae8..d7d538f 100644
--- a/noncore/apps/opie-reader/plucker_base.cpp
+++ b/noncore/apps/opie-reader/plucker_base.cpp
@@ -1,1411 +1,1408 @@
1#include "useqpe.h"
2#include "usenef.h" 1#include "usenef.h"
3#include <stdio.h> 2#include <stdio.h>
4#include <string.h> 3#include <string.h>
5#include <qmessagebox.h> 4#include <qmessagebox.h>
6#include <qpixmap.h> 5#include <qpixmap.h>
7#ifdef USEQPE 6#ifdef USEQPE
8#include <qpe/qcopenvelope_qws.h> 7#include <qpe/qcopenvelope_qws.h>
9#endif /* USEQPE */ 8#endif /* USEQPE */
10#ifdef LOCALPICTURES 9#ifdef LOCALPICTURES
11#include <qscrollview.h> 10#include <qscrollview.h>
12#endif 11#endif
13#ifdef USEQPE 12#ifdef USEQPE
14#include <qpe/global.h> 13#include <qpe/global.h>
15#endif /* USEQPE */ 14#endif /* USEQPE */
16#include <qclipboard.h> 15#include <qclipboard.h>
17#ifndef USEQPE 16#ifndef USEQPE
18#include <qapplication.h> 17#include <qapplication.h>
19#else /* USEQPE */ 18#else /* USEQPE */
20#include <qpe/qpeapplication.h> 19#include <qpe/qpeapplication.h>
21#endif /* USEQPE */ 20#endif /* USEQPE */
22#include <qimage.h> 21#include <qimage.h>
23 22
24#include "static.h"
25#include "plucker_base.h" 23#include "plucker_base.h"
26#include "Aportis.h" 24#include "Aportis.h"
27#include "hrule.h" 25#include "hrule.h"
28#include "util.h" 26#include "util.h"
29 27
30const UInt8 CPlucker_base::continuation_bit = 1; 28const UInt8 CPlucker_base::continuation_bit = 1;
31 29
32CPlucker_base::CPlucker_base() : 30CPlucker_base::CPlucker_base() :
33#ifdef LOCALPICTURES 31#ifdef LOCALPICTURES
34 m_viewer(NULL), 32 m_viewer(NULL),
35 m_picture(NULL), 33 m_picture(NULL),
36#endif 34#endif
37 expandedtextbuffer(NULL), 35 expandedtextbuffer(NULL),
38 compressedtextbuffer(NULL), 36 compressedtextbuffer(NULL),
39 bufferrec(-1), 37 bufferrec(-1),
40 m_offset(0) 38 m_offset(0)
41 //, urls(NULL) 39 //, urls(NULL)
42{ /*printf("constructing:%x\n",fin);*/ } 40{ /*printf("constructing:%x\n",fin);*/ }
43 41
44 42
45void CPlucker_base::Expand(UInt32 reclen, UInt8 type, UInt8* buffer, UInt32 buffersize) 43void CPlucker_base::Expand(UInt32 reclen, UInt8 type, UInt8* buffer, UInt32 buffersize)
46{ 44{
47 if (type%2 == 0) 45 if (type%2 == 0)
48 { 46 {
49 fread(buffer, reclen, sizeof(char), fin); 47 fread(buffer, reclen, sizeof(char), fin);
50 } 48 }
51 else 49 else
52 { 50 {
53 UInt8* readbuffer = NULL; 51 UInt8* readbuffer = NULL;
54 if (reclen > compressedbuffersize) 52 if (reclen > compressedbuffersize)
55 { 53 {
56 readbuffer = new UInt8[reclen]; 54 readbuffer = new UInt8[reclen];
57 } 55 }
58 else 56 else
59 { 57 {
60 readbuffer = compressedtextbuffer; 58 readbuffer = compressedtextbuffer;
61 } 59 }
62 if (readbuffer != NULL) 60 if (readbuffer != NULL)
63 { 61 {
64 fread(readbuffer, reclen, sizeof(char), fin); 62 fread(readbuffer, reclen, sizeof(char), fin);
65 (*m_decompress)(readbuffer, reclen, buffer, buffersize); 63 (*m_decompress)(readbuffer, reclen, buffer, buffersize);
66 if (reclen > compressedbuffersize) 64 if (reclen > compressedbuffersize)
67 { 65 {
68 delete [] readbuffer; 66 delete [] readbuffer;
69 } 67 }
70 } 68 }
71 } 69 }
72} 70}
73 71
74void CPlucker_base::sizes(unsigned long& _file, unsigned long& _text) 72void CPlucker_base::sizes(unsigned long& _file, unsigned long& _text)
75{ 73{
76 _file = file_length; 74 _file = file_length;
77 if (textlength == 0) 75 if (textlength == 0)
78 { 76 {
79 for (int recptr = 1; recptr < ntohs(head.recordList.numRecords); recptr++) 77 for (int recptr = 1; recptr < ntohs(head.recordList.numRecords); recptr++)
80 { 78 {
81 gotorecordnumber(recptr); 79 gotorecordnumber(recptr);
82 UInt16 thishdr_uid, thishdr_nParagraphs; 80 UInt16 thishdr_uid, thishdr_nParagraphs;
83 UInt32 thishdr_size; 81 UInt32 thishdr_size;
84 UInt8 thishdr_type, thishdr_reserved; 82 UInt8 thishdr_type, thishdr_reserved;
85 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 83 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
86 if (thishdr_type < 2) textlength += thishdr_size; 84 if (thishdr_type < 2) textlength += thishdr_size;
87 } 85 }
88 } 86 }
89 _text = textlength; 87 _text = textlength;
90 //ntohl(hdr0.size); 88 //ntohl(hdr0.size);
91} 89}
92 90
93char* CPlucker_base::geturl(UInt16 tgt) 91char* CPlucker_base::geturl(UInt16 tgt)
94{ 92{
95 char * pRet = NULL; 93 char * pRet = NULL;
96 gotorecordnumber(0); 94 gotorecordnumber(0);
97 fread(&hdr0, 1, 6, fin); 95 fread(&hdr0, 1, 6, fin);
98 unsigned int nrecs = ntohs(hdr0.nRecords); 96 unsigned int nrecs = ntohs(hdr0.nRecords);
99 //qDebug("Version %u, no. recs %u", ntohs(hdr0.version), nrecs); 97 //qDebug("Version %u, no. recs %u", ntohs(hdr0.version), nrecs);
100 UInt16 urlid = 0; 98 UInt16 urlid = 0;
101 bool urlsfound = false; 99 bool urlsfound = false;
102 char* urls = NULL; 100 char* urls = NULL;
103 size_t urlsize = 0; 101 size_t urlsize = 0;
104 for (unsigned int i = 0; i < nrecs; i++) 102 for (unsigned int i = 0; i < nrecs; i++)
105 { 103 {
106 UInt16 id, name; 104 UInt16 id, name;
107 fread(&name, 1, sizeof(name), fin); 105 fread(&name, 1, sizeof(name), fin);
108 fread(&id, 1, sizeof(id), fin); 106 fread(&id, 1, sizeof(id), fin);
109 //qDebug("N:%d, I:%d", ntohs(name), ntohs(id)); 107 //qDebug("N:%d, I:%d", ntohs(name), ntohs(id));
110 if (ntohs(name) == 2) 108 if (ntohs(name) == 2)
111 { 109 {
112 urlsfound = true; 110 urlsfound = true;
113 urlid = id; 111 urlid = id;
114 //qDebug("Found url index:%d", ntohs(urlid)); 112 //qDebug("Found url index:%d", ntohs(urlid));
115 } 113 }
116 ////qDebug("%x", id); 114 ////qDebug("%x", id);
117 } 115 }
118 if (urlsfound) 116 if (urlsfound)
119 { 117 {
120 unsigned short recptr = finduid(ntohs(urlid)); 118 unsigned short recptr = finduid(ntohs(urlid));
121 if (recptr != 0) 119 if (recptr != 0)
122 { 120 {
123 gotorecordnumber(recptr); 121 gotorecordnumber(recptr);
124 UInt16 thishdr_uid, thishdr_nParagraphs; 122 UInt16 thishdr_uid, thishdr_nParagraphs;
125 UInt32 thishdr_size; 123 UInt32 thishdr_size;
126 UInt8 thishdr_type, thishdr_reserved; 124 UInt8 thishdr_type, thishdr_reserved;
127 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 125 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
128 UInt16 urlctr = 0; 126 UInt16 urlctr = 0;
129 while (1) 127 while (1)
130 { 128 {
131 UInt16 tctr; 129 UInt16 tctr;
132 fread(&tctr, 1, sizeof(tctr), fin); 130 fread(&tctr, 1, sizeof(tctr), fin);
133 fread(&urlid, 1, sizeof(urlid), fin); 131 fread(&urlid, 1, sizeof(urlid), fin);
134 tctr = ntohs(tctr); 132 tctr = ntohs(tctr);
135 //qDebug("tgt:%u urlctr:%u tctr:%u", tgt, urlctr, tctr); 133 //qDebug("tgt:%u urlctr:%u tctr:%u", tgt, urlctr, tctr);
136 if (tctr >= tgt) 134 if (tctr >= tgt)
137 { 135 {
138 break; 136 break;
139 } 137 }
140 urlctr = tctr; 138 urlctr = tctr;
141 } 139 }
142 //qDebug("urls are in %d", ntohs(urlid)); 140 //qDebug("urls are in %d", ntohs(urlid));
143 recptr = finduid(ntohs(urlid)); 141 recptr = finduid(ntohs(urlid));
144 if (recptr != 0) 142 if (recptr != 0)
145 { 143 {
146 UInt32 reclen = recordlength(recptr) - HeaderSize(); 144 UInt32 reclen = recordlength(recptr) - HeaderSize();
147 gotorecordnumber(recptr); 145 gotorecordnumber(recptr);
148 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 146 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
149 //qDebug("Found urls:%x",thishdr_type); 147 //qDebug("Found urls:%x",thishdr_type);
150 urlsize = thishdr_size; 148 urlsize = thishdr_size;
151 urls = new char[urlsize]; 149 urls = new char[urlsize];
152 Expand(reclen, thishdr_type, (UInt8*)urls, urlsize); 150 Expand(reclen, thishdr_type, (UInt8*)urls, urlsize);
153 char* ptr = urls; 151 char* ptr = urls;
154 int rn = urlctr+1; 152 int rn = urlctr+1;
155 while (ptr - urls < urlsize) 153 while (ptr - urls < urlsize)
156 { 154 {
157 if (rn == tgt) 155 if (rn == tgt)
158 { 156 {
159 //qDebug("URL:%s", ptr); 157 //qDebug("URL:%s", ptr);
160 int len = strlen(ptr)+1; 158 int len = strlen(ptr)+1;
161 pRet = new char[len]; 159 pRet = new char[len];
162 memcpy(pRet, ptr, len); 160 memcpy(pRet, ptr, len);
163 break; 161 break;
164 } 162 }
165 ptr += strlen(ptr)+1; 163 ptr += strlen(ptr)+1;
166 rn++; 164 rn++;
167 } 165 }
168 delete [] urls; 166 delete [] urls;
169 } 167 }
170 } 168 }
171 } 169 }
172 else 170 else
173 { 171 {
174 pRet = NULL; 172 pRet = NULL;
175 } 173 }
176 return pRet; 174 return pRet;
177} 175}
178 176
179CPlucker_base::~CPlucker_base() 177CPlucker_base::~CPlucker_base()
180{ 178{
181 if (expandedtextbuffer != NULL) delete [] expandedtextbuffer; 179 if (expandedtextbuffer != NULL) delete [] expandedtextbuffer;
182 if (compressedtextbuffer != NULL) delete [] compressedtextbuffer; 180 if (compressedtextbuffer != NULL) delete [] compressedtextbuffer;
183#ifdef LOCALPICTURES 181#ifdef LOCALPICTURES
184 if (m_viewer != NULL) delete m_viewer; 182 if (m_viewer != NULL) delete m_viewer;
185#endif 183#endif
186} 184}
187 185
188int CPlucker_base::getch() { return getch(false); } 186int CPlucker_base::getch() { return getch(false); }
189 187
190void CPlucker_base::getch(tchar& ch, CStyle& sty, unsigned long& pos) 188void CPlucker_base::getch(tchar& ch, CStyle& sty, unsigned long& pos)
191{ 189{
192 pos = locate(); 190 pos = locate();
193 ch = getch(false); 191 ch = getch(false);
194 sty = mystyle; 192 sty = mystyle;
195} 193}
196 194
197unsigned int CPlucker_base::locate() 195unsigned int CPlucker_base::locate()
198{ 196{
199 return currentpos; 197 return currentpos;
200 /* 198 /*
201 UInt16 thisrec = 1; 199 UInt16 thisrec = 1;
202 unsigned long locpos = 0; 200 unsigned long locpos = 0;
203 gotorecordnumber(thisrec); 201 gotorecordnumber(thisrec);
204 UInt16 thishdr_uid, thishdr_nParagraphs; 202 UInt16 thishdr_uid, thishdr_nParagraphs;
205 UInt32 thishdr_size; 203 UInt32 thishdr_size;
206 UInt8 thishdr_type, thishdr_reserved; 204 UInt8 thishdr_type, thishdr_reserved;
207 while (thisrec < bufferrec) 205 while (thisrec < bufferrec)
208 { 206 {
209 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 207 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
210 if (thishdr_type < 2) locpos += thishdr_size; 208 if (thishdr_type < 2) locpos += thishdr_size;
211 thisrec++; 209 thisrec++;
212 gotorecordnumber(thisrec); 210 gotorecordnumber(thisrec);
213 } 211 }
214 return locpos+bufferpos; 212 return locpos+bufferpos;
215 */ 213 */
216} 214}
217 215
218void CPlucker_base::locate(unsigned int n) 216void CPlucker_base::locate(unsigned int n)
219{ 217{
220 218
221 // clock_t start = clock(); 219 // clock_t start = clock();
222 if (n >= currentpos-bufferpos && n < currentpos - bufferpos + buffercontent) 220 if (n >= currentpos-bufferpos && n < currentpos - bufferpos + buffercontent)
223 { 221 {
224 currentpos -= bufferpos; 222 currentpos -= bufferpos;
225 expand(bufferrec); 223 expand(bufferrec);
226 while (currentpos < n && bufferpos < buffercontent) getch_base(true); 224 while (currentpos < n && bufferpos < buffercontent) getch_base(true);
227 return; 225 return;
228 } 226 }
229 /* 227 /*
230 228
231 UInt32 textlength = currentpos - bufferpos; 229 UInt32 textlength = currentpos - bufferpos;
232 UInt16 recptr = bufferrec; 230 UInt16 recptr = bufferrec;
233 if (n < textlength/2) 231 if (n < textlength/2)
234 { 232 {
235 textlength = 0; 233 textlength = 0;
236 UInt16 thishdr_uid, thishdr_nParagraphs; 234 UInt16 thishdr_uid, thishdr_nParagraphs;
237 UInt32 thishdr_size = buffercontent; 235 UInt32 thishdr_size = buffercontent;
238 UInt8 thishdr_type, thishdr_reserved; 236 UInt8 thishdr_type, thishdr_reserved;
239 for (recptr = 1; recptr < ntohs(head.recordList.numRecords); recptr++) 237 for (recptr = 1; recptr < ntohs(head.recordList.numRecords); recptr++)
240 { 238 {
241 gotorecordnumber(recptr); 239 gotorecordnumber(recptr);
242 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 240 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
243 if (thishdr_type < 2) 241 if (thishdr_type < 2)
244 { 242 {
245 textlength += thishdr_size; 243 textlength += thishdr_size;
246 if (textlength > n) 244 if (textlength > n)
247 { 245 {
248 textlength -= thishdr_size; 246 textlength -= thishdr_size;
249 break; 247 break;
250 } 248 }
251 } 249 }
252 } 250 }
253 } 251 }
254 else if (n < textlength) 252 else if (n < textlength)
255 { 253 {
256 UInt16 thishdr_uid, thishdr_nParagraphs; 254 UInt16 thishdr_uid, thishdr_nParagraphs;
257 UInt32 thishdr_size; 255 UInt32 thishdr_size;
258 UInt8 thishdr_type, thishdr_reserved; 256 UInt8 thishdr_type, thishdr_reserved;
259 while (n < textlength && recptr > 1) 257 while (n < textlength && recptr > 1)
260 { 258 {
261 recptr--; 259 recptr--;
262 gotorecordnumber(recptr); 260 gotorecordnumber(recptr);
263 //qDebug("recptr:%u", recptr); 261 //qDebug("recptr:%u", recptr);
264 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 262 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
265 if (thishdr_type < 2) 263 if (thishdr_type < 2)
266 { 264 {
267 textlength -= thishdr_size; 265 textlength -= thishdr_size;
268 } 266 }
269 } 267 }
270 } 268 }
271 else 269 else
272 { 270 {
273 UInt16 thishdr_uid, thishdr_nParagraphs; 271 UInt16 thishdr_uid, thishdr_nParagraphs;
274 UInt32 thishdr_size = buffercontent; 272 UInt32 thishdr_size = buffercontent;
275 UInt8 thishdr_type, thishdr_reserved; 273 UInt8 thishdr_type, thishdr_reserved;
276 while (n > textlength + thishdr_size && recptr < ntohs(head.recordList.numRecords)-1) 274 while (n > textlength + thishdr_size && recptr < ntohs(head.recordList.numRecords)-1)
277 { 275 {
278 textlength += thishdr_size; 276 textlength += thishdr_size;
279 recptr++; 277 recptr++;
280 gotorecordnumber(recptr); 278 gotorecordnumber(recptr);
281 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 279 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
282 if (!(thishdr_type < 2)) 280 if (!(thishdr_type < 2))
283 { 281 {
284 thishdr_size = 0; 282 thishdr_size = 0;
285 } 283 }
286 } 284 }
287 } 285 }
288 286
289 */ 287 */
290 UInt16 thisrec = 0; 288 UInt16 thisrec = 0;
291 unsigned long locpos = 0; 289 unsigned long locpos = 0;
292 unsigned long bs = 0; 290 unsigned long bs = 0;
293 UInt16 thishdr_uid, thishdr_nParagraphs; 291 UInt16 thishdr_uid, thishdr_nParagraphs;
294 UInt32 thishdr_size; 292 UInt32 thishdr_size;
295 UInt8 thishdr_type, thishdr_reserved; 293 UInt8 thishdr_type, thishdr_reserved;
296 do 294 do
297 { 295 {
298 thisrec++; 296 thisrec++;
299 locpos += bs; 297 locpos += bs;
300 gotorecordnumber(thisrec); 298 gotorecordnumber(thisrec);
301 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 299 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
302 if (thishdr_type < 2) 300 if (thishdr_type < 2)
303 { 301 {
304 bs = thishdr_size; 302 bs = thishdr_size;
305 } 303 }
306 else 304 else
307 { 305 {
308 bs = 0; 306 bs = 0;
309 } 307 }
310 } while (locpos + bs <= n); 308 } while (locpos + bs <= n);
311 309
312 // qDebug("Time(2): %u", clock()-start); 310 // qDebug("Time(2): %u", clock()-start);
313 /* 311 /*
314 if (recptr != thisrec) 312 if (recptr != thisrec)
315 { 313 {
316 qDebug("Disaster:recptr:%u thisrec:%u", recptr, thisrec); 314 qDebug("Disaster:recptr:%u thisrec:%u", recptr, thisrec);
317 UInt16 thishdr_uid, thishdr_nParagraphs; 315 UInt16 thishdr_uid, thishdr_nParagraphs;
318 UInt32 thishdr_size = buffercontent; 316 UInt32 thishdr_size = buffercontent;
319 UInt8 thishdr_type, thishdr_reserved; 317 UInt8 thishdr_type, thishdr_reserved;
320 for (recptr = 1; recptr < ntohs(head.recordList.numRecords); recptr++) 318 for (recptr = 1; recptr < ntohs(head.recordList.numRecords); recptr++)
321 { 319 {
322 gotorecordnumber(recptr); 320 gotorecordnumber(recptr);
323 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 321 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
324 // qDebug("UID:%u Paras:%u Size:%u Type:%u Reserved:%u", thishdr_uid, thishdr_nParagraphs, thishdr_size, (unsigned int)thishdr_type, (unsigned int)thishdr_reserved); 322 // qDebug("UID:%u Paras:%u Size:%u Type:%u Reserved:%u", thishdr_uid, thishdr_nParagraphs, thishdr_size, (unsigned int)thishdr_type, (unsigned int)thishdr_reserved);
325 } 323 }
326 //QApplication::exit ( 100 ); 324 //QApplication::exit ( 100 );
327 } 325 }
328 */ 326 */
329 currentpos = locpos; 327 currentpos = locpos;
330 expand(thisrec); 328 expand(thisrec);
331 while (currentpos < n && bufferpos < buffercontent) getch_base(true); 329 while (currentpos < n && bufferpos < buffercontent) getch_base(true);
332 330
333 /* // This is faster but the alignment attribute doesn't get set 8^( 331 /* // This is faster but the alignment attribute doesn't get set 8^(
334 bufferpos = n-locpos; 332 bufferpos = n-locpos;
335 currentpos = n; 333 currentpos = n;
336 while (bufferpos >= m_nextPara && m_nextPara >= 0) 334 while (bufferpos >= m_nextPara && m_nextPara >= 0)
337 { 335 {
338 UInt16 attr = m_ParaAttrs[m_nextParaIndex]; 336 UInt16 attr = m_ParaAttrs[m_nextParaIndex];
339 m_nextParaIndex++; 337 m_nextParaIndex++;
340 if (m_nextParaIndex == m_nParas) 338 if (m_nextParaIndex == m_nParas)
341 { 339 {
342 m_nextPara = -1; 340 m_nextPara = -1;
343 } 341 }
344 else 342 else
345 { 343 {
346 m_nextPara += m_ParaOffsets[m_nextParaIndex]; 344 m_nextPara += m_ParaOffsets[m_nextParaIndex];
347 } 345 }
348 } 346 }
349 */ 347 */
350} 348}
351 349
352bool CPlucker_base::expand(int thisrec) 350bool CPlucker_base::expand(int thisrec)
353{ 351{
354 mystyle.unset(); 352 mystyle.unset();
355 if (bufferrec != thisrec) 353 if (bufferrec != thisrec)
356 { 354 {
357 size_t reclen = recordlength(thisrec); 355 size_t reclen = recordlength(thisrec);
358 gotorecordnumber(thisrec); 356 gotorecordnumber(thisrec);
359 UInt16 thishdr_uid, thishdr_nParagraphs; 357 UInt16 thishdr_uid, thishdr_nParagraphs;
360 UInt32 thishdr_size; 358 UInt32 thishdr_size;
361 UInt8 thishdr_type, thishdr_reserved; 359 UInt8 thishdr_type, thishdr_reserved;
362 while (1) 360 while (1)
363 { 361 {
364 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 362 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
365 //qDebug("This (%d) type is %d, uid is %u", thisrec, thishdr_type, thishdr_uid); 363 //qDebug("This (%d) type is %d, uid is %u", thisrec, thishdr_type, thishdr_uid);
366 if (thishdr_type < 2) break; 364 if (thishdr_type < 2) break;
367 //qDebug("Skipping paragraph of type %d", thishdr_type); 365 //qDebug("Skipping paragraph of type %d", thishdr_type);
368 if (++thisrec >= ntohs(head.recordList.numRecords) - 1) return false; 366 if (++thisrec >= ntohs(head.recordList.numRecords) - 1) return false;
369 reclen = recordlength(thisrec); 367 reclen = recordlength(thisrec);
370 gotorecordnumber(thisrec); 368 gotorecordnumber(thisrec);
371 } 369 }
372 m_nParas = thishdr_nParagraphs; 370 m_nParas = thishdr_nParagraphs;
373 m_bufferisreserved = (thishdr_reserved != 0); 371 m_bufferisreserved = (thishdr_reserved != 0);
374 //qDebug("It has %u paragraphs and is %u bytes", thishdr_nParagraphs, thishdr_size); 372 //qDebug("It has %u paragraphs and is %u bytes", thishdr_nParagraphs, thishdr_size);
375 uid = thishdr_uid; 373 uid = thishdr_uid;
376 // gotorecordnumber(thisrec); 374 // gotorecordnumber(thisrec);
377 // fread(expandedtextbuffer,1,10,fin); 375 // fread(expandedtextbuffer,1,10,fin);
378 for (int i = 0; i < m_nParas; i++) 376 for (int i = 0; i < m_nParas; i++)
379 { 377 {
380 UInt16 ubytes, attrs; 378 UInt16 ubytes, attrs;
381 fread(&ubytes, 1, sizeof(ubytes), fin); 379 fread(&ubytes, 1, sizeof(ubytes), fin);
382 fread(&attrs, 1, sizeof(attrs), fin); 380 fread(&attrs, 1, sizeof(attrs), fin);
383 m_ParaOffsets[i] = ntohs(ubytes); 381 m_ParaOffsets[i] = ntohs(ubytes);
384 m_ParaAttrs[i] = ntohs(attrs); 382 m_ParaAttrs[i] = ntohs(attrs);
385 ////qDebug("Bytes %u, Attr %x", ntohs(ubytes), ntohs(attrs)); 383 ////qDebug("Bytes %u, Attr %x", ntohs(ubytes), ntohs(attrs));
386 } 384 }
387 385
388 reclen -= HeaderSize()+4*m_nParas; 386 reclen -= HeaderSize()+4*m_nParas;
389 387
390 buffercontent = thishdr_size; 388 buffercontent = thishdr_size;
391 389
392 if (thishdr_size > buffersize) 390 if (thishdr_size > buffersize)
393 { 391 {
394 delete [] expandedtextbuffer; 392 delete [] expandedtextbuffer;
395 buffersize = thishdr_size; 393 buffersize = thishdr_size;
396 expandedtextbuffer = new UInt8[buffersize]; 394 expandedtextbuffer = new UInt8[buffersize];
397 } 395 }
398 Expand(reclen, thishdr_type, expandedtextbuffer, buffercontent); 396 Expand(reclen, thishdr_type, expandedtextbuffer, buffercontent);
399 bufferrec = thisrec; 397 bufferrec = thisrec;
400 } 398 }
401 399
402 400
403 if (m_nParas > 0) 401 if (m_nParas > 0)
404 { 402 {
405 m_nextPara = m_ParaOffsets[0]; 403 m_nextPara = m_ParaOffsets[0];
406 //qDebug("First offset = %u", m_nextPara); 404 //qDebug("First offset = %u", m_nextPara);
407 m_nextParaIndex = 0; 405 m_nextParaIndex = 0;
408 } 406 }
409 else 407 else
410 { 408 {
411 m_nextPara = -1; 409 m_nextPara = -1;
412 } 410 }
413 bufferpos = 0; 411 bufferpos = 0;
414 //qDebug("BC:%u, HS:%u", buffercontent, thishdr_size); 412 //qDebug("BC:%u, HS:%u", buffercontent, thishdr_size);
415 return true; 413 return true;
416} 414}
417 415
418void CPlucker_base::UnZip(UInt8* compressedbuffer, size_t reclen, UInt8* tgtbuffer, size_t bsize) 416void CPlucker_base::UnZip(UInt8* compressedbuffer, size_t reclen, UInt8* tgtbuffer, size_t bsize)
419{ 417{
420 z_stream zstream; 418 z_stream zstream;
421 memset(&zstream,sizeof(zstream),0); 419 memset(&zstream,sizeof(zstream),0);
422 zstream.next_in = compressedbuffer; 420 zstream.next_in = compressedbuffer;
423 zstream.next_out = tgtbuffer; 421 zstream.next_out = tgtbuffer;
424 zstream.avail_out = bsize; 422 zstream.avail_out = bsize;
425 zstream.avail_in = reclen; 423 zstream.avail_in = reclen;
426 424
427 int keylen = 0; 425 int keylen = 0;
428 426
429 zstream.zalloc = Z_NULL; 427 zstream.zalloc = Z_NULL;
430 zstream.zfree = Z_NULL; 428 zstream.zfree = Z_NULL;
431 zstream.opaque = Z_NULL; 429 zstream.opaque = Z_NULL;
432 430
433 // printf("Initialising\n"); 431 // printf("Initialising\n");
434 432
435 inflateInit(&zstream); 433 inflateInit(&zstream);
436 int err = 0; 434 int err = 0;
437 do { 435 do {
438 if ( zstream.avail_in == 0 && 0 < keylen ) { 436 if ( zstream.avail_in == 0 && 0 < keylen ) {
439 zstream.next_in = compressedbuffer + keylen; 437 zstream.next_in = compressedbuffer + keylen;
440 zstream.avail_in = reclen - keylen; 438 zstream.avail_in = reclen - keylen;
441 keylen = 0; 439 keylen = 0;
442 } 440 }
443 zstream.next_out = tgtbuffer; 441 zstream.next_out = tgtbuffer;
444 zstream.avail_out = bsize; 442 zstream.avail_out = bsize;
445 443
446 err = inflate( &zstream, Z_SYNC_FLUSH ); 444 err = inflate( &zstream, Z_SYNC_FLUSH );
447 445
448 ////qDebug("err:%d - %u", err, zstream.avail_in); 446 ////qDebug("err:%d - %u", err, zstream.avail_in);
449 447
450 } while ( err == Z_OK ); 448 } while ( err == Z_OK );
451 449
452 inflateEnd(&zstream); 450 inflateEnd(&zstream);
453} 451}
454 452
455void CPlucker_base::UnDoc(UInt8* compressedbuffer, size_t reclen, UInt8* tgtbuffer, size_t bsize) 453void CPlucker_base::UnDoc(UInt8* compressedbuffer, size_t reclen, UInt8* tgtbuffer, size_t bsize)
456{ 454{
457 // UInt16 headerSize; 455 // UInt16 headerSize;
458 UInt16 docSize; 456 UInt16 docSize;
459 UInt16 i; 457 UInt16 i;
460 UInt16 j; 458 UInt16 j;
461 UInt16 k; 459 UInt16 k;
462 460
463 UInt8 *inBuf = compressedbuffer; 461 UInt8 *inBuf = compressedbuffer;
464 UInt8 *outBuf = tgtbuffer; 462 UInt8 *outBuf = tgtbuffer;
465 463
466 // headerSize = sizeof( Header ) + record->paragraphs * sizeof( Paragraph ); 464 // headerSize = sizeof( Header ) + record->paragraphs * sizeof( Paragraph );
467 docSize = reclen; 465 docSize = reclen;
468 466
469 j = 0; 467 j = 0;
470 k = 0; 468 k = 0;
471 while ( j < docSize ) { 469 while ( j < docSize ) {
472 i = 0; 470 i = 0;
473 while ( i < bsize && j < docSize ) { 471 while ( i < bsize && j < docSize ) {
474 UInt16 c; 472 UInt16 c;
475 473
476 c = (UInt16) inBuf[ j++ ]; 474 c = (UInt16) inBuf[ j++ ];
477 if ( 0 < c && c < 9 ) { 475 if ( 0 < c && c < 9 ) {
478 while ( 0 < c-- ) 476 while ( 0 < c-- )
479 outBuf[ i++ ] = inBuf[ j++ ]; 477 outBuf[ i++ ] = inBuf[ j++ ];
480 } 478 }
481 else if ( c < 0x80 ) 479 else if ( c < 0x80 )
482 outBuf[ i++ ] = c; 480 outBuf[ i++ ] = c;
483 else if ( 0xc0 <= c ) { 481 else if ( 0xc0 <= c ) {
484 outBuf[ i++ ] = ' '; 482 outBuf[ i++ ] = ' ';
485 outBuf[ i++ ] = c ^ 0x80; 483 outBuf[ i++ ] = c ^ 0x80;
486 } 484 }
487 else { 485 else {
488 Int16 m; 486 Int16 m;
489 Int16 n; 487 Int16 n;
490 488
491 c <<= 8; 489 c <<= 8;
492 c += inBuf[ j++ ]; 490 c += inBuf[ j++ ];
493 491
494 m = ( c & 0x3fff ) >> COUNT_BITS; 492 m = ( c & 0x3fff ) >> COUNT_BITS;
495 n = c & ( ( 1 << COUNT_BITS ) - 1 ); 493 n = c & ( ( 1 << COUNT_BITS ) - 1 );
496 n += 2; 494 n += 2;
497 495
498 do { 496 do {
499 outBuf[ i ] = outBuf[ i - m ]; 497 outBuf[ i ] = outBuf[ i - m ];
500 i++; 498 i++;
501 } while ( 0 < n-- ); 499 } while ( 0 < n-- );
502 } 500 }
503 } 501 }
504 k += bsize; 502 k += bsize;
505 } 503 }
506} 504}
507 505
508void CPlucker_base::home() 506void CPlucker_base::home()
509{ 507{
510 currentpos = 0; 508 currentpos = 0;
511 expand(1); 509 expand(1);
512} 510}
513 511
514CList<Bkmk>* CPlucker_base::getbkmklist() 512CList<Bkmk>* CPlucker_base::getbkmklist()
515{ 513{
516 /* 514 /*
517 UInt16 thishdr_uid, thishdr_nParagraphs; 515 UInt16 thishdr_uid, thishdr_nParagraphs;
518 UInt32 thishdr_size; 516 UInt32 thishdr_size;
519 UInt8 thishdr_type, thishdr_reserved; 517 UInt8 thishdr_type, thishdr_reserved;
520 518
521 for (int i = 1; i < ntohs(head.recordList.numRecords); i++) 519 for (int i = 1; i < ntohs(head.recordList.numRecords); i++)
522 { 520 {
523 gotorecordnumber(i); 521 gotorecordnumber(i);
524 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 522 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
525 if (thishdr_type == 8) 523 if (thishdr_type == 8)
526 { 524 {
527 UInt16 n; 525 UInt16 n;
528 fread(&n, 1, sizeof(n), fin); 526 fread(&n, 1, sizeof(n), fin);
529 n = ntohs(n); 527 n = ntohs(n);
530 //qDebug("Found %u bookmarks", n); 528 //qDebug("Found %u bookmarks", n);
531 } 529 }
532 //qDebug("Found:%d, %u", i , thishdr_type); 530 //qDebug("Found:%d, %u", i , thishdr_type);
533 } 531 }
534 */ 532 */
535 return NULL; 533 return NULL;
536} 534}
537 535
538#include <qnamespace.h> 536#include <qnamespace.h>
539 537
540QImage* CPlucker_base::expandimg(UInt16 tgt, bool border) 538QImage* CPlucker_base::expandimg(UInt16 tgt, bool border)
541{ 539{
542 QImage* qimage = getimg(tgt); 540 QImage* qimage = getimg(tgt);
543 QImage* ret; 541 QImage* ret;
544 if (qimage == NULL) return NULL; 542 if (qimage == NULL) return NULL;
545 if (border) 543 if (border)
546 { 544 {
547 QPixmap* image = new QPixmap(0,0); 545 QPixmap* image = new QPixmap(0,0);
548 image->convertFromImage(*qimage); 546 image->convertFromImage(*qimage);
549 delete qimage; 547 delete qimage;
550 QPixmap* pret = new QPixmap(image->width()+4, image->height()+4); 548 QPixmap* pret = new QPixmap(image->width()+4, image->height()+4);
551 pret->fill(Qt::red); 549 pret->fill(Qt::red);
552 bitBlt(pret, 2, 2, image, 0, 0, -1, -1);//, Qt::RasterOp::CopyROP); 550 bitBlt(pret, 2, 2, image, 0, 0, -1, -1);//, Qt::RasterOp::CopyROP);
553 delete image; 551 delete image;
554 ret = new QImage(pret->convertToImage()); 552 ret = new QImage(pret->convertToImage());
555 } 553 }
556 else 554 else
557 { 555 {
558 ret = qimage; 556 ret = qimage;
559 } 557 }
560 return ret; 558 return ret;
561} 559}
562 560
563#ifdef _BUFFERPICS 561#ifdef _BUFFERPICS
564#include <qmap.h> 562#include <qmap.h>
565#endif 563#endif
566 564
567QImage* CPlucker_base::getPicture(unsigned long tgt) 565QImage* CPlucker_base::getPicture(unsigned long tgt)
568{ 566{
569#ifdef _BUFFERPICS 567#ifdef _BUFFERPICS
570 static QMap<unsigned long, QPixmap> pix; 568 static QMap<unsigned long, QPixmap> pix;
571 QMap<unsigned long, QPixmap>::Iterator t = pix.find(tgt); 569 QMap<unsigned long, QPixmap>::Iterator t = pix.find(tgt);
572 if (t == pix.end()) 570 if (t == pix.end())
573 { 571 {
574 pix[tgt] = *expandimg(tgt); 572 pix[tgt] = *expandimg(tgt);
575 return &pix[tgt]; 573 return &pix[tgt];
576 } 574 }
577 else 575 else
578 return &(t.data()); 576 return &(t.data());
579#else 577#else
580 return expandimg(tgt >> 16); 578 return expandimg(tgt >> 16);
581#endif 579#endif
582} 580}
583 581
584#ifdef LOCALPICTURES 582#ifdef LOCALPICTURES
585#include <unistd.h> 583#include <unistd.h>
586#include <qpe/global.h> 584#include <qpe/global.h>
587void CPlucker_base::showimg(UInt16 tgt) 585void CPlucker_base::showimg(UInt16 tgt)
588{ 586{
589 //qDebug("Crassssssh!"); 587 //qDebug("Crassssssh!");
590 QPixmap* qimage = expandimg(tgt); 588 QPixmap* qimage = expandimg(tgt);
591 m_picture->setFixedSize(qimage->size()); 589 m_picture->setFixedSize(qimage->size());
592 m_picture->setBackgroundPixmap(*qimage); 590 m_picture->setBackgroundPixmap(*qimage);
593 delete qimage; 591 delete qimage;
594 m_viewer->show(); 592 m_viewer->show();
595 593
596 /* 594 /*
597 char tmp[] = "uqtreader.XXXXXX"; 595 char tmp[] = "uqtreader.XXXXXX";
598 QImage* qimage = getimg(tgt); 596 QImage* qimage = getimg(tgt);
599 QPixmap* image = new QPixmap(0,0); 597 QPixmap* image = new QPixmap(0,0);
600 // //qDebug("New image"); 598 // //qDebug("New image");
601 image->convertFromImage(*qimage); 599 image->convertFromImage(*qimage);
602 delete qimage; 600 delete qimage;
603 char tmpfile[sizeof(tmp)+1]; 601 char tmpfile[sizeof(tmp)+1];
604 strcpy(tmpfile,tmp); 602 strcpy(tmpfile,tmp);
605 int f = mkstemp(tmpfile); 603 int f = mkstemp(tmpfile);
606 close(f); 604 close(f);
607 //qDebug("TMPFILE:%s", tmpfile); 605 //qDebug("TMPFILE:%s", tmpfile);
608 if (image->save(tmpfile,"PNG")) 606 if (image->save(tmpfile,"PNG"))
609 { 607 {
610 QCopEnvelope e("QPE/Application/showimg", "setDocument(QString)"); 608 QCopEnvelope e("QPE/Application/showimg", "setDocument(QString)");
611 e << QString(tmpfile); 609 e << QString(tmpfile);
612 } 610 }
613 Global::statusMessage("Opening image"); 611 Global::statusMessage("Opening image");
614 sleep(5); 612 sleep(5);
615 delete image; 613 delete image;
616 unlink(tmpfile); 614 unlink(tmpfile);
617 */ 615 */
618} 616}
619 617
620#endif 618#endif
621 619
622unsigned short CPlucker_base::finduid(unsigned short urlid) 620unsigned short CPlucker_base::finduid(unsigned short urlid)
623{ 621{
624 // //qDebug("Finding %u", urlid); 622 // //qDebug("Finding %u", urlid);
625 unsigned short jmin = 1, jmax = ntohs(head.recordList.numRecords); 623 unsigned short jmin = 1, jmax = ntohs(head.recordList.numRecords);
626 unsigned short jmid = (jmin+jmax) >> 1; 624 unsigned short jmid = (jmin+jmax) >> 1;
627 while (jmax - jmin > 1) 625 while (jmax - jmin > 1)
628 { 626 {
629 gotorecordnumber(jmid); 627 gotorecordnumber(jmid);
630 UInt16 thishdr_uid, thishdr_nParagraphs; 628 UInt16 thishdr_uid, thishdr_nParagraphs;
631 UInt32 thishdr_size; 629 UInt32 thishdr_size;
632 UInt8 thishdr_type, thishdr_reserved; 630 UInt8 thishdr_type, thishdr_reserved;
633 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 631 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
634 unsigned short luid = thishdr_uid; 632 unsigned short luid = thishdr_uid;
635 ////qDebug("%u %u %u : %u", jmin, jmid, jmax, urlid); 633 ////qDebug("%u %u %u : %u", jmin, jmid, jmax, urlid);
636 if (luid == urlid) 634 if (luid == urlid)
637 { 635 {
638 return jmid; 636 return jmid;
639 } 637 }
640 if (luid < urlid) 638 if (luid < urlid)
641 { 639 {
642 jmin = jmid; 640 jmin = jmid;
643 } 641 }
644 else 642 else
645 { 643 {
646 jmax = jmid; 644 jmax = jmid;
647 } 645 }
648 jmid = (jmin+jmax) >> 1; 646 jmid = (jmin+jmax) >> 1;
649 } 647 }
650 gotorecordnumber(jmin); 648 gotorecordnumber(jmin);
651 UInt16 thishdr_uid, thishdr_nParagraphs; 649 UInt16 thishdr_uid, thishdr_nParagraphs;
652 UInt32 thishdr_size; 650 UInt32 thishdr_size;
653 UInt8 thishdr_type, thishdr_reserved; 651 UInt8 thishdr_type, thishdr_reserved;
654 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 652 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
655 unsigned short luid = thishdr_uid; 653 unsigned short luid = thishdr_uid;
656 //qDebug("jmin at end:%u,%u", jmin, luid); 654 //qDebug("jmin at end:%u,%u", jmin, luid);
657 if (luid == urlid) 655 if (luid == urlid)
658 { 656 {
659 return jmin; 657 return jmin;
660 } 658 }
661 gotorecordnumber(jmax); 659 gotorecordnumber(jmax);
662 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 660 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
663 luid = thishdr_uid; 661 luid = thishdr_uid;
664 //qDebug("jmax at end:%u,%u", jmax, luid); 662 //qDebug("jmax at end:%u,%u", jmax, luid);
665 if (luid == urlid) 663 if (luid == urlid)
666 { 664 {
667 return jmax; 665 return jmax;
668 } 666 }
669 //qDebug("Couldn't find %u", urlid); 667 //qDebug("Couldn't find %u", urlid);
670 return 0; // Not found! 668 return 0; // Not found!
671} 669}
672 670
673#include <qnamespace.h> 671#include <qnamespace.h>
674 672
675void CPlucker_base::setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen) 673void CPlucker_base::setSaveData(unsigned char*& data, unsigned short& len, unsigned char* src, unsigned short srclen)
676{ 674{
677 unsigned short sz = 0; 675 unsigned short sz = 0;
678 for (CList<unsigned long>::iterator it = visited.begin(); it != visited.end(); it++) 676 for (CList<unsigned long>::iterator it = visited.begin(); it != visited.end(); it++)
679 { 677 {
680 sz++; 678 sz++;
681 } 679 }
682 size_t newlen = srclen+sizeof(sz)+sz*sizeof(unsigned long); 680 size_t newlen = srclen+sizeof(sz)+sz*sizeof(unsigned long);
683 unsigned char* newdata = new unsigned char[newlen]; 681 unsigned char* newdata = new unsigned char[newlen];
684 unsigned char* pdata = newdata; 682 unsigned char* pdata = newdata;
685 memcpy(newdata, src, srclen); 683 memcpy(newdata, src, srclen);
686 newdata += srclen; 684 newdata += srclen;
687 memcpy(newdata, &sz, sizeof(sz)); 685 memcpy(newdata, &sz, sizeof(sz));
688 newdata += sizeof(sz); 686 newdata += sizeof(sz);
689#ifdef _WINDOWS 687#ifdef _WINDOWS
690 for (it = visited.begin(); it != visited.end(); it++) 688 for (it = visited.begin(); it != visited.end(); it++)
691#else 689#else
692 for (CList<unsigned long>::iterator it = visited.begin(); it != visited.end(); it++) 690 for (CList<unsigned long>::iterator it = visited.begin(); it != visited.end(); it++)
693#endif 691#endif
694 { 692 {
695 unsigned long t = *it; 693 unsigned long t = *it;
696 //qDebug("[%u]", t); 694 //qDebug("[%u]", t);
697 memcpy(newdata, &t, sizeof(t)); 695 memcpy(newdata, &t, sizeof(t));
698 newdata += sizeof(t); 696 newdata += sizeof(t);
699 } 697 }
700 m_nav.setSaveData(data, len, pdata, newlen); 698 m_nav.setSaveData(data, len, pdata, newlen);
701 delete [] pdata; 699 delete [] pdata;
702} 700}
703 701
704void CPlucker_base::putSaveData(unsigned char*& src, unsigned short& srclen) 702void CPlucker_base::putSaveData(unsigned char*& src, unsigned short& srclen)
705{ 703{
706 unsigned short sz; 704 unsigned short sz;
707 if (srclen >= sizeof(sz)) 705 if (srclen >= sizeof(sz))
708 { 706 {
709 memcpy(&sz, src, sizeof(sz)); 707 memcpy(&sz, src, sizeof(sz));
710 src += sizeof(sz); 708 src += sizeof(sz);
711 srclen -= sizeof(sz); 709 srclen -= sizeof(sz);
712 } 710 }
713 for (int i = 0; i < sz; i++) 711 for (int i = 0; i < sz; i++)
714 { 712 {
715 unsigned long t; 713 unsigned long t;
716 if (srclen >= sizeof(t)) 714 if (srclen >= sizeof(t))
717 { 715 {
718 memcpy(&t, src, sizeof(t)); 716 memcpy(&t, src, sizeof(t));
719 // qDebug("[%u]", t); 717 // qDebug("[%u]", t);
720 visited.push_front(t); 718 visited.push_front(t);
721 src += sizeof(t); 719 src += sizeof(t);
722 srclen -= sizeof(t); 720 srclen -= sizeof(t);
723 } 721 }
724 else 722 else
725 { 723 {
726 QMessageBox::warning(NULL, PROGNAME, "File data mismatch\nMight fix itself"); 724 QMessageBox::warning(NULL, PROGNAME, "File data mismatch\nMight fix itself");
727 break; 725 break;
728 } 726 }
729 } 727 }
730 m_nav.putSaveData(src, srclen); 728 m_nav.putSaveData(src, srclen);
731} 729}
732 730
733int CPlucker_base::OpenFile(const char *src) 731int CPlucker_base::OpenFile(const char *src)
734{ 732{
735 qDebug("plucker openfile:%s", src); 733 qDebug("plucker openfile:%s", src);
736 m_lastBreak = 0; 734 m_lastBreak = 0;
737 if (!Cpdb::openpdbfile(src)) 735 if (!Cpdb::openpdbfile(src))
738 { 736 {
739 return -1; 737 return -1;
740 } 738 }
741 739
742 if (!CorrectDecoder()) return -1; 740 if (!CorrectDecoder()) return -1;
743 741
744 gotorecordnumber(0); 742 gotorecordnumber(0);
745 fread(&hdr0, 1, 6, fin); 743 fread(&hdr0, 1, 6, fin);
746 qDebug("Compression type:%u", ntohs(hdr0.version)); 744 qDebug("Compression type:%u", ntohs(hdr0.version));
747 745
748 746
749 switch (ntohs(hdr0.version)) 747 switch (ntohs(hdr0.version))
750 { 748 {
751 case 2: 749 case 2:
752 m_decompress = UnZip; 750 m_decompress = UnZip;
753 break; 751 break;
754 case 1: 752 case 1:
755 m_decompress = UnDoc; 753 m_decompress = UnDoc;
756 break; 754 break;
757#ifdef USENEF 755#ifdef USENEF
758 case 3: 756 case 3:
759 m_decompress = getdecompressor("PluckerDecompress3"); 757 m_decompress = getdecompressor("PluckerDecompress3");
760 break; 758 break;
761 case 4: 759 case 4:
762 m_decompress = getdecompressor("PluckerDecompress4"); 760 m_decompress = getdecompressor("PluckerDecompress4");
763 break; 761 break;
764#endif 762#endif
765 default: 763 default:
766 m_decompress = NULL; 764 m_decompress = NULL;
767 } 765 }
768 if (m_decompress == NULL) return -1; 766 if (m_decompress == NULL) return -1;
769 767
770 setbuffersize(); 768 setbuffersize();
771 compressedtextbuffer = new UInt8[compressedbuffersize]; 769 compressedtextbuffer = new UInt8[compressedbuffersize];
772 expandedtextbuffer = new UInt8[buffersize]; 770 expandedtextbuffer = new UInt8[buffersize];
773 771
774 unsigned int nrecs = ntohs(hdr0.nRecords); 772 unsigned int nrecs = ntohs(hdr0.nRecords);
775 qDebug("Version %u, no. reserved recs %u", ntohs(hdr0.version), nrecs); 773 qDebug("Version %u, no. reserved recs %u", ntohs(hdr0.version), nrecs);
776 textlength = ntohl(head.sortInfoID); 774 textlength = ntohl(head.sortInfoID);
777 qDebug("Textlength at startup:%u", textlength); 775 qDebug("Textlength at startup:%u", textlength);
778 UInt16 homerecid = 1; 776 UInt16 homerecid = 1;
779 for (unsigned int i = 0; i < nrecs; i++) 777 for (unsigned int i = 0; i < nrecs; i++)
780 { 778 {
781 UInt16 id, name; 779 UInt16 id, name;
782 fread(&name, 1, sizeof(name), fin); 780 fread(&name, 1, sizeof(name), fin);
783 fread(&id, 1, sizeof(id), fin); 781 fread(&id, 1, sizeof(id), fin);
784 //qDebug("N:%d, I:%d", ntohs(name), ntohs(id)); 782 //qDebug("N:%d, I:%d", ntohs(name), ntohs(id));
785 if (ntohs(name) == 0) homerecid = ntohs(id); 783 if (ntohs(name) == 0) homerecid = ntohs(id);
786 } 784 }
787 785
788 textlength = 0; 786 textlength = 0;
789 for (int recptr = 1; recptr < ntohs(head.recordList.numRecords); recptr++) 787 for (int recptr = 1; recptr < ntohs(head.recordList.numRecords); recptr++)
790 { 788 {
791 gotorecordnumber(recptr); 789 gotorecordnumber(recptr);
792 UInt16 thishdr_uid, thishdr_nParagraphs; 790 UInt16 thishdr_uid, thishdr_nParagraphs;
793 UInt32 thishdr_size; 791 UInt32 thishdr_size;
794 UInt8 thishdr_type, thishdr_reserved; 792 UInt8 thishdr_type, thishdr_reserved;
795 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 793 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
796 if (thishdr_uid == homerecid) 794 if (thishdr_uid == homerecid)
797 { 795 {
798 m_homepos = textlength; 796 m_homepos = textlength;
799 break; 797 break;
800 } 798 }
801 if (thishdr_type < 2) textlength += thishdr_size; 799 if (thishdr_type < 2) textlength += thishdr_size;
802 } 800 }
803 qDebug("Found home"); 801 qDebug("Found home");
804 textlength = 0; 802 textlength = 0;
805 home(); 803 home();
806 qDebug("Gone home"); 804 qDebug("Gone home");
807#ifdef LOCALPICTURES 805#ifdef LOCALPICTURES
808 if (m_viewer == NULL) 806 if (m_viewer == NULL)
809 { 807 {
810 m_viewer = new QScrollView(NULL); 808 m_viewer = new QScrollView(NULL);
811 m_picture = new QWidget(m_viewer->viewport()); 809 m_picture = new QWidget(m_viewer->viewport());
812 m_viewer->addChild(m_picture); 810 m_viewer->addChild(m_picture);
813 } 811 }
814#endif 812#endif
815 return 0; 813 return 0;
816 814
817} 815}
818 816
819QImage* CPlucker_base::getimg(UInt16 tgt) 817QImage* CPlucker_base::getimg(UInt16 tgt)
820{ 818{
821 size_t reclen; 819 size_t reclen;
822 UInt16 thisrec = finduid(tgt); 820 UInt16 thisrec = finduid(tgt);
823 qDebug("getimg:Found %u from uid:%u", thisrec, tgt); 821 qDebug("getimg:Found %u from uid:%u", thisrec, tgt);
824 reclen = recordlength(thisrec); 822 reclen = recordlength(thisrec);
825 gotorecordnumber(thisrec); 823 gotorecordnumber(thisrec);
826 UInt16 thishdr_uid, thishdr_nParagraphs; 824 UInt16 thishdr_uid, thishdr_nParagraphs;
827 UInt32 thishdr_size; 825 UInt32 thishdr_size;
828 UInt8 thishdr_type, thishdr_reserved; 826 UInt8 thishdr_type, thishdr_reserved;
829 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 827 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
830 if (thishdr_type == 15) 828 if (thishdr_type == 15)
831 { 829 {
832 char *buffer = new char[thishdr_size]; 830 char *buffer = new char[thishdr_size];
833 fread(buffer, thishdr_size, sizeof(char), fin); 831 fread(buffer, thishdr_size, sizeof(char), fin);
834 unsigned short tmp; 832 unsigned short tmp;
835 memcpy(&tmp, buffer, sizeof(tmp)); 833 memcpy(&tmp, buffer, sizeof(tmp));
836 unsigned short cols = ntohs(tmp); 834 unsigned short cols = ntohs(tmp);
837 memcpy(&tmp, buffer+sizeof(tmp), sizeof(tmp)); 835 memcpy(&tmp, buffer+sizeof(tmp), sizeof(tmp));
838 unsigned short rows = ntohs(tmp); 836 unsigned short rows = ntohs(tmp);
839 qDebug("Found a picture of type:%u [%u,%u]", thishdr_type, rows, cols); 837 qDebug("Found a picture of type:%u [%u,%u]", thishdr_type, rows, cols);
840 QImage*** images; 838 QImage*** images;
841 images = new QImage**[rows]; 839 images = new QImage**[rows];
842#ifdef _WINDOWS 840#ifdef _WINDOWS
843 int i; 841 int i;
844 for (i = 0; i < rows; i++) 842 for (i = 0; i < rows; i++)
845#else 843#else
846 for (int i = 0; i < rows; i++) 844 for (int i = 0; i < rows; i++)
847#endif 845#endif
848 { 846 {
849 images[i] = new QImage*[cols]; 847 images[i] = new QImage*[cols];
850 } 848 }
851 int height = 0; 849 int height = 0;
852 int width = 0; 850 int width = 0;
853#ifdef _WINDOWS 851#ifdef _WINDOWS
854 for (i = 0; i < rows; i++) 852 for (i = 0; i < rows; i++)
855#else 853#else
856 for (int i = 0; i < rows; i++) 854 for (int i = 0; i < rows; i++)
857#endif 855#endif
858 { 856 {
859 width = 0; 857 width = 0;
860 for (int j = 0; j < cols; j++) 858 for (int j = 0; j < cols; j++)
861 { 859 {
862 memcpy(&tmp, buffer+(i*cols+j+2)*sizeof(tmp), sizeof(tmp)); 860 memcpy(&tmp, buffer+(i*cols+j+2)*sizeof(tmp), sizeof(tmp));
863 unsigned short uid = ntohs(tmp); 861 unsigned short uid = ntohs(tmp);
864 images[i][j] = getimg(uid); 862 images[i][j] = getimg(uid);
865 width += images[i][j]->width(); 863 width += images[i][j]->width();
866 } 864 }
867 height += images[i][0]->height(); 865 height += images[i][0]->height();
868 } 866 }
869 delete [] buffer; 867 delete [] buffer;
870 QPixmap pm(width, height); 868 QPixmap pm(width, height);
871 int hoffset = 0; 869 int hoffset = 0;
872#ifdef _WINDOWS 870#ifdef _WINDOWS
873 for (i = 0; i < rows; i++) 871 for (i = 0; i < rows; i++)
874#else 872#else
875 for (int i = 0; i < rows; i++) 873 for (int i = 0; i < rows; i++)
876#endif 874#endif
877 { 875 {
878 int woffset = 0; 876 int woffset = 0;
879 int delht = images[i][0]->height(); 877 int delht = images[i][0]->height();
880 for (int j = 0; j < cols; j++) 878 for (int j = 0; j < cols; j++)
881 { 879 {
882 QPixmap pm2; 880 QPixmap pm2;
883 pm2.convertFromImage(*(images[i][j])); 881 pm2.convertFromImage(*(images[i][j]));
884 delete images[i][j]; 882 delete images[i][j];
885 bitBlt(&pm, woffset, hoffset, &pm2, 0, 0, pm2.width(), pm2.height()); 883 bitBlt(&pm, woffset, hoffset, &pm2, 0, 0, pm2.width(), pm2.height());
886 woffset += pm2.width(); 884 woffset += pm2.width();
887 } 885 }
888 hoffset += delht; 886 hoffset += delht;
889 } 887 }
890#ifdef _WINDOWS 888#ifdef _WINDOWS
891 for (i = 0; i < rows; i++) 889 for (i = 0; i < rows; i++)
892#else 890#else
893 for (int i = 0; i < rows; i++) 891 for (int i = 0; i < rows; i++)
894#endif 892#endif
895 { 893 {
896 delete [] images[i]; 894 delete [] images[i];
897 } 895 }
898 delete [] images; 896 delete [] images;
899 return new QImage(pm.convertToImage()); 897 return new QImage(pm.convertToImage());
900 } 898 }
901 else 899 else
902 { 900 {
903 qDebug("Found a picture of type:%u", thishdr_type); 901 qDebug("Found a picture of type:%u", thishdr_type);
904 reclen -= HeaderSize(); 902 reclen -= HeaderSize();
905 903
906 UInt32 imgsize = thishdr_size; 904 UInt32 imgsize = thishdr_size;
907 UInt8* imgbuffer = new UInt8[imgsize]; 905 UInt8* imgbuffer = new UInt8[imgsize];
908 906
909 Expand(reclen, thishdr_type, imgbuffer, imgsize); 907 Expand(reclen, thishdr_type, imgbuffer, imgsize);
910 908
911 return imagefromdata(imgbuffer, imgsize); 909 return imagefromdata(imgbuffer, imgsize);
912 } 910 }
913} 911}
914 912
915linkType CPlucker_base::hyperlink(unsigned int n, unsigned int offset, QString& wrd, QString&) 913linkType CPlucker_base::hyperlink(unsigned int n, unsigned int offset, QString& wrd, QString&)
916{ 914{
917 visited.push_front(n); 915 visited.push_front(n);
918 UInt16 tuid = (n >> 16); 916 UInt16 tuid = (n >> 16);
919 n &= 0xffff; 917 n &= 0xffff;
920 char *turl = geturl(tuid); 918 char *turl = geturl(tuid);
921 if (turl != NULL) 919 if (turl != NULL)
922 { 920 {
923 qDebug("URL in PB:%s", turl); 921 qDebug("URL in PB:%s", turl);
924 wrd = turl; 922 wrd = turl;
925 delete [] turl; 923 delete [] turl;
926 } 924 }
927 else 925 else
928 { 926 {
929 wrd.truncate(0); 927 wrd.truncate(0);
930 } 928 }
931 qDebug("Hyper: UID:%u, Para:%u, Offset:%u", tuid, n, offset); 929 qDebug("Hyper: UID:%u, Para:%u, Offset:%u", tuid, n, offset);
932 UInt16 thisrec = 1; 930 UInt16 thisrec = 1;
933 currentpos = 0; 931 currentpos = 0;
934 gotorecordnumber(thisrec); 932 gotorecordnumber(thisrec);
935 UInt16 thishdr_uid, thishdr_nParagraphs; 933 UInt16 thishdr_uid, thishdr_nParagraphs;
936 UInt32 thishdr_size; 934 UInt32 thishdr_size;
937 UInt8 thishdr_type, thishdr_reserved; 935 UInt8 thishdr_type, thishdr_reserved;
938 while (1) 936 while (1)
939 { 937 {
940 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved); 938 GetHeader(thishdr_uid, thishdr_nParagraphs, thishdr_size, thishdr_type, thishdr_reserved);
941 if (tuid == thishdr_uid) break; 939 if (tuid == thishdr_uid) break;
942 if (thishdr_type < 2) currentpos += thishdr_size; 940 if (thishdr_type < 2) currentpos += thishdr_size;
943 ////qDebug("hyper-cp:%u", currentpos); 941 ////qDebug("hyper-cp:%u", currentpos);
944 thisrec++; 942 thisrec++;
945 if (thisrec >= ntohs(head.recordList.numRecords)) 943 if (thisrec >= ntohs(head.recordList.numRecords))
946 { 944 {
947 if (wrd.isEmpty()) 945 if (wrd.isEmpty())
948 { 946 {
949 QMessageBox::information(NULL, 947 QMessageBox::information(NULL,
950 QString(PROGNAME), 948 QString(PROGNAME),
951 QString("Couldn't find link") 949 QString("Couldn't find link")
952 ); 950 );
953 } 951 }
954 else 952 else
955 { 953 {
956#ifdef USEQPE 954#ifdef USEQPE
957 if (wrd.length() > 10) 955 if (wrd.length() > 10)
958 { 956 {
959 Global::statusMessage(wrd.left(8) + ".."); 957 Global::statusMessage(wrd.left(8) + "..");
960 } 958 }
961 else 959 else
962 { 960 {
963 Global::statusMessage(wrd); 961 Global::statusMessage(wrd);
964 } 962 }
965#else 963#else
966#endif /* USEQPE */ 964#endif /* USEQPE */
967 //qDebug("Link:%s", (const char*)wrd); 965 //qDebug("Link:%s", (const char*)wrd);
968 // setlink(fn, wrd); 966 // setlink(fn, wrd);
969 } 967 }
970 return eNone; 968 return eNone;
971 } 969 }
972 gotorecordnumber(thisrec); 970 gotorecordnumber(thisrec);
973 } 971 }
974 if (thishdr_type > 1) 972 if (thishdr_type > 1)
975 { 973 {
976 if (thishdr_type == 4) 974 if (thishdr_type == 4)
977 { 975 {
978 QMessageBox::information(NULL, 976 QMessageBox::information(NULL,
979 QString(PROGNAME), 977 QString(PROGNAME),
980 QString("Mailto links\nnot yet supported (2)")); 978 QString("Mailto links\nnot yet supported (2)"));
981 } 979 }
982 else 980 else
983 { 981 {
984 if (thishdr_type > 3 && thishdr_type != 15) 982 if (thishdr_type > 3 && thishdr_type != 15)
985 { 983 {
986 QMessageBox::information(NULL, 984 QMessageBox::information(NULL,
987 QString(PROGNAME), 985 QString(PROGNAME),
988 QString("External links\nnot yet supported (2)") 986 QString("External links\nnot yet supported (2)")
989 ); 987 );
990 return eNone; 988 return eNone;
991 } 989 }
992 else 990 else
993 { 991 {
994#ifdef LOCALPICTURES 992#ifdef LOCALPICTURES
995 showimg(tuid); 993 showimg(tuid);
996#else 994#else
997 return ePicture; 995 return ePicture;
998#endif 996#endif
999 } 997 }
1000 } 998 }
1001 return eNone; 999 return eNone;
1002 } 1000 }
1003 /* 1001 /*
1004 if (thishdr_type == 2 || thishdr_type == 3) 1002 if (thishdr_type == 2 || thishdr_type == 3)
1005 { 1003 {
1006 expandimg(thisrec); 1004 expandimg(thisrec);
1007 1005
1008 } 1006 }
1009 */ 1007 */
1010 else 1008 else
1011 { 1009 {
1012 expand(thisrec); 1010 expand(thisrec);
1013 unsigned int paraoffset = offset; 1011 unsigned int paraoffset = offset;
1014 // unsigned int noff = 0; 1012 // unsigned int noff = 0;
1015 if (n != 0) 1013 if (n != 0)
1016 { 1014 {
1017 if (n >= m_nParas) 1015 if (n >= m_nParas)
1018 { 1016 {
1019 QMessageBox::information(NULL, 1017 QMessageBox::information(NULL,
1020 QString(PROGNAME), 1018 QString(PROGNAME),
1021 QString("Error in link\nPara # too big") 1019 QString("Error in link\nPara # too big")
1022 ); 1020 );
1023 return eNone; 1021 return eNone;
1024 } 1022 }
1025 unsigned int noff = 0; 1023 unsigned int noff = 0;
1026 for (unsigned int i = 0; i < n; i++) noff += m_ParaOffsets[i]; 1024 for (unsigned int i = 0; i < n; i++) noff += m_ParaOffsets[i];
1027 1025
1028 paraoffset += noff; 1026 paraoffset += noff;
1029 } 1027 }
1030 if (paraoffset > thishdr_size) 1028 if (paraoffset > thishdr_size)
1031 { 1029 {
1032 QMessageBox::information(NULL, 1030 QMessageBox::information(NULL,
1033 QString(PROGNAME), 1031 QString(PROGNAME),
1034 QString("Error in link\nOffset too big") 1032 QString("Error in link\nOffset too big")
1035 ); 1033 );
1036 return eNone; 1034 return eNone;
1037 } 1035 }
1038 while (bufferpos < paraoffset && bufferpos < buffercontent) getch_base(true); 1036 while (bufferpos < paraoffset && bufferpos < buffercontent) getch_base(true);
1039 //qDebug("Hyper:<%u,%u,%u>", paraoffset, bufferpos, currentpos); 1037 //qDebug("Hyper:<%u,%u,%u>", paraoffset, bufferpos, currentpos);
1040 /* // This is faster but the alignment doesn't get set 1038 /* // This is faster but the alignment doesn't get set
1041 mystyle.unset(); 1039 mystyle.unset();
1042 bufferpos = n; 1040 bufferpos = n;
1043 currentpos += n; 1041 currentpos += n;
1044 while (bufferpos >= m_nextPara && m_nextPara >= 0) 1042 while (bufferpos >= m_nextPara && m_nextPara >= 0)
1045 { 1043 {
1046 UInt16 attr = m_ParaAttrs[m_nextParaIndex]; 1044 UInt16 attr = m_ParaAttrs[m_nextParaIndex];
1047 m_nextParaIndex++; 1045 m_nextParaIndex++;
1048 if (m_nextParaIndex == m_nParas) 1046 if (m_nextParaIndex == m_nParas)
1049 { 1047 {
1050 m_nextPara = -1; 1048 m_nextPara = -1;
1051 } 1049 }
1052 else 1050 else
1053 { 1051 {
1054 m_nextPara += m_ParaOffsets[m_nextParaIndex]; 1052 m_nextPara += m_ParaOffsets[m_nextParaIndex];
1055 } 1053 }
1056 } 1054 }
1057 */ 1055 */
1058 } 1056 }
1059 return eLink; 1057 return eLink;
1060} 1058}
1061 1059
1062tchar CPlucker_base::getch_base(bool fast) 1060tchar CPlucker_base::getch_base(bool fast)
1063{ 1061{
1064 int ch = bgetch(); 1062 int ch = bgetch();
1065 while (ch == 0) 1063 while (ch == 0)
1066 { 1064 {
1067 ch = bgetch(); 1065 ch = bgetch();
1068 ////qDebug("Function:%x", ch); 1066 ////qDebug("Function:%x", ch);
1069 switch (ch) 1067 switch (ch)
1070 { 1068 {
1071 case 0x38: 1069 case 0x38:
1072 // //qDebug("Break:%u", locate()); 1070 // //qDebug("Break:%u", locate());
1073 if (m_lastBreak == locate()) 1071 if (m_lastBreak == locate())
1074 { 1072 {
1075 ch = bgetch(); 1073 ch = bgetch();
1076 } 1074 }
1077 else 1075 else
1078 { 1076 {
1079 ch = 10; 1077 ch = 10;
1080 } 1078 }
1081 m_lastBreak = locate(); 1079 m_lastBreak = locate();
1082 break; 1080 break;
1083 case 0x0a: 1081 case 0x0a:
1084 case 0x0c: 1082 case 0x0c:
1085 { 1083 {
1086 unsigned long ln = 0; 1084 unsigned long ln = 0;
1087 int skip = ch & 7; 1085 int skip = ch & 7;
1088 for (int i = 0; i < 2; i++) 1086 for (int i = 0; i < 2; i++)
1089 { 1087 {
1090 int ch = bgetch(); 1088 int ch = bgetch();
1091 ln = (ln << 8) + ch; 1089 ln = (ln << 8) + ch;
1092 // //qDebug("ch:%d, ln:%u", ch, ln); 1090 // //qDebug("ch:%d, ln:%u", ch, ln);
1093 } 1091 }
1094 if (skip == 2) 1092 if (skip == 2)
1095 { 1093 {
1096 ln <<= 16; 1094 ln <<= 16;
1097 } 1095 }
1098 else 1096 else
1099 { 1097 {
1100 for (int i = 0; i < 2; i++) 1098 for (int i = 0; i < 2; i++)
1101 { 1099 {
1102 int ch = bgetch(); 1100 int ch = bgetch();
1103 ln = (ln << 8) + ch; 1101 ln = (ln << 8) + ch;
1104 // //qDebug("ch:%d, ln:%u", ch, ln); 1102 // //qDebug("ch:%d, ln:%u", ch, ln);
1105 } 1103 }
1106 } 1104 }
1107 // //qDebug("ln:%u", ln); 1105 // //qDebug("ln:%u", ln);
1108 mystyle.setLink(true); 1106 mystyle.setLink(true);
1109 mystyle.setData(ln); 1107 mystyle.setData(ln);
1110 // mystyle.setColour(255, 0, 0); 1108 // mystyle.setColour(255, 0, 0);
1111 bool hasseen = false; 1109 bool hasseen = false;
1112 for (CList<unsigned long>::iterator it = visited.begin(); it != visited.end(); it++) 1110 for (CList<unsigned long>::iterator it = visited.begin(); it != visited.end(); it++)
1113 { 1111 {
1114 if (*it == ln) 1112 if (*it == ln)
1115 { 1113 {
1116 hasseen = true; 1114 hasseen = true;
1117 break; 1115 break;
1118 } 1116 }
1119 } 1117 }
1120 if (hasseen) 1118 if (hasseen)
1121 { 1119 {
1122 mystyle.setStrikethru(); 1120 mystyle.setStrikethru();
1123 } 1121 }
1124 else 1122 else
1125 { 1123 {
1126 mystyle.setUnderline(); 1124 mystyle.setUnderline();
1127 } 1125 }
1128 mystyle.setOffset(m_offset); 1126 mystyle.setOffset(m_offset);
1129 m_offset = 0; 1127 m_offset = 0;
1130 ch = bgetch(); 1128 ch = bgetch();
1131 } 1129 }
1132 break; 1130 break;
1133 case 0x08: 1131 case 0x08:
1134 ch = bgetch(); 1132 ch = bgetch();
1135 // mystyle.setColour(0, 0, 0); 1133 // mystyle.setColour(0, 0, 0);
1136 mystyle.unsetUnderline(); 1134 mystyle.unsetUnderline();
1137 mystyle.unsetStrikethru(); 1135 mystyle.unsetStrikethru();
1138 mystyle.setLink(false); 1136 mystyle.setLink(false);
1139 mystyle.setData(0); 1137 mystyle.setData(0);
1140 break; 1138 break;
1141 case 0x40: 1139 case 0x40:
1142 mystyle.setItalic(); 1140 mystyle.setItalic();
1143 ch = bgetch(); 1141 ch = bgetch();
1144 break; 1142 break;
1145 case 0x48: 1143 case 0x48:
1146 mystyle.unsetItalic(); 1144 mystyle.unsetItalic();
1147 ch = bgetch(); 1145 ch = bgetch();
1148 break; 1146 break;
1149 case 0x11: 1147 case 0x11:
1150 { 1148 {
1151 ch = bgetch(); 1149 ch = bgetch();
1152 // //qDebug("Font:%d",ch); 1150 // //qDebug("Font:%d",ch);
1153 mystyle.setVOffset(0); 1151 mystyle.setVOffset(0);
1154 mystyle.unsetMono(); 1152 mystyle.unsetMono();
1155 mystyle.unsetBold(); 1153 mystyle.unsetBold();
1156 switch (ch) 1154 switch (ch)
1157 { 1155 {
1158 case 0: 1156 case 0:
1159 mystyle.setFontSize(0); 1157 mystyle.setFontSize(0);
1160 break; 1158 break;
1161 case 1: 1159 case 1:
1162 mystyle.setFontSize(3); 1160 mystyle.setFontSize(3);
1163 mystyle.setBold(); 1161 mystyle.setBold();
1164 break; 1162 break;
1165 case 2: 1163 case 2:
1166 mystyle.setFontSize(2); 1164 mystyle.setFontSize(2);
1167 mystyle.setBold(); 1165 mystyle.setBold();
1168 break; 1166 break;
1169 case 3: 1167 case 3:
1170 mystyle.setFontSize(1); 1168 mystyle.setFontSize(1);
1171 mystyle.setBold(); 1169 mystyle.setBold();
1172 break; 1170 break;
1173 case 4: 1171 case 4:
1174 mystyle.setFontSize(0); 1172 mystyle.setFontSize(0);
1175 mystyle.setBold(); 1173 mystyle.setBold();
1176 break; 1174 break;
1177 case 5: 1175 case 5:
1178 mystyle.setFontSize(0); 1176 mystyle.setFontSize(0);
1179 mystyle.setBold(); 1177 mystyle.setBold();
1180 break; 1178 break;
1181 case 6: 1179 case 6:
1182 mystyle.setFontSize(0); 1180 mystyle.setFontSize(0);
1183 mystyle.setBold(); 1181 mystyle.setBold();
1184 break; 1182 break;
1185 case 7: 1183 case 7:
1186 mystyle.setFontSize(0); 1184 mystyle.setFontSize(0);
1187 mystyle.setBold(); 1185 mystyle.setBold();
1188 break; 1186 break;
1189 case 8: // should be fixed width 1187 case 8: // should be fixed width
1190 //qDebug("Trying fixed width"); 1188 //qDebug("Trying fixed width");
1191 mystyle.setFontSize(0); 1189 mystyle.setFontSize(0);
1192 mystyle.setMono(); 1190 mystyle.setMono();
1193 break; 1191 break;
1194 case 9: 1192 case 9:
1195 // mystyle.setFontSize(mystyle.getFontSize()); 1193 // mystyle.setFontSize(mystyle.getFontSize());
1196 mystyle.setFontSize(-1); 1194 mystyle.setFontSize(-1);
1197 break; 1195 break;
1198 case 10: 1196 case 10:
1199 mystyle.setFontSize(-2); 1197 mystyle.setFontSize(-2);
1200 mystyle.setVOffset(1); 1198 mystyle.setVOffset(1);
1201 break; 1199 break;
1202 case 11: 1200 case 11:
1203 mystyle.setFontSize(-2); 1201 mystyle.setFontSize(-2);
1204 mystyle.setVOffset(-1); 1202 mystyle.setVOffset(-1);
1205 break; 1203 break;
1206 default: 1204 default:
1207 qDebug("Unrecognised font"); 1205 qDebug("Unrecognised font");
1208 break; 1206 break;
1209 } 1207 }
1210 ch = bgetch(); 1208 ch = bgetch();
1211 } 1209 }
1212 break; 1210 break;
1213 case 0x29: 1211 case 0x29:
1214 ch = bgetch(); 1212 ch = bgetch();
1215 switch (ch) 1213 switch (ch)
1216 { 1214 {
1217 case 0: 1215 case 0:
1218 mystyle.setLeftJustify(); 1216 mystyle.setLeftJustify();
1219 // //qDebug("left"); 1217 // //qDebug("left");
1220 break; 1218 break;
1221 case 1: 1219 case 1:
1222 mystyle.setRightJustify(); 1220 mystyle.setRightJustify();
1223 // //qDebug("right"); 1221 // //qDebug("right");
1224 break; 1222 break;
1225 case 2: 1223 case 2:
1226 mystyle.setCentreJustify(); 1224 mystyle.setCentreJustify();
1227 // //qDebug("centre"); 1225 // //qDebug("centre");
1228 break; 1226 break;
1229 case 3: 1227 case 3:
1230 mystyle.setFullJustify(); 1228 mystyle.setFullJustify();
1231 // //qDebug("full"); 1229 // //qDebug("full");
1232 break; 1230 break;
1233 1231
1234 } 1232 }
1235 ch = bgetch(); 1233 ch = bgetch();
1236 break; 1234 break;
1237 case 0x53: 1235 case 0x53:
1238 { 1236 {
1239 int r = bgetch(); 1237 int r = bgetch();
1240 int g = bgetch(); 1238 int g = bgetch();
1241 int b = bgetch(); 1239 int b = bgetch();
1242 mystyle.setColour(r,g,b); 1240 mystyle.setColour(r,g,b);
1243 ch = bgetch(); 1241 ch = bgetch();
1244 } 1242 }
1245 break; 1243 break;
1246 case 0x1a: 1244 case 0x1a:
1247 case 0x5c: 1245 case 0x5c:
1248 { 1246 {
1249 bool hasalternate = (ch == 0x5c); 1247 bool hasalternate = (ch == 0x5c);
1250 UInt16 ir = bgetch(); 1248 UInt16 ir = bgetch();
1251 ir = (ir << 8) + bgetch(); 1249 ir = (ir << 8) + bgetch();
1252 if (hasalternate) 1250 if (hasalternate)
1253 { 1251 {
1254 //qDebug("Alternate image:%x", ir); 1252 //qDebug("Alternate image:%x", ir);
1255 UInt16 ir2 = bgetch(); 1253 UInt16 ir2 = bgetch();
1256 ir2 = (ir2 << 8) + bgetch(); 1254 ir2 = (ir2 << 8) + bgetch();
1257 if (!fast) mystyle.setPicture(true, expandimg(ir2, true), true, ir << 16); 1255 if (!fast) mystyle.setPicture(true, expandimg(ir2, true), true, ir << 16);
1258#ifdef LOCALPICTURES 1256#ifdef LOCALPICTURES
1259 UInt32 ln = ir; 1257 UInt32 ln = ir;
1260 ln <<= 16; 1258 ln <<= 16;
1261 mystyle.setLink(true); 1259 mystyle.setLink(true);
1262 mystyle.setData(ln); 1260 mystyle.setData(ln);
1263#endif 1261#endif
1264 } 1262 }
1265 else 1263 else
1266 { 1264 {
1267 if (!fast) mystyle.setPicture(true, expandimg(ir)); 1265 if (!fast) mystyle.setPicture(true, expandimg(ir));
1268 } 1266 }
1269 // if (mystyle.getLink()) qDebug("Picture link!"); 1267 // if (mystyle.getLink()) qDebug("Picture link!");
1270 ch = '#'; 1268 ch = '#';
1271 } 1269 }
1272 // ch = bgetch(); 1270 // ch = bgetch();
1273 break; 1271 break;
1274 case 0x33: 1272 case 0x33:
1275 { 1273 {
1276 UInt8 h = bgetch(); 1274 UInt8 h = bgetch();
1277 UInt8 wc = bgetch(); 1275 UInt8 wc = bgetch();
1278 UInt8 pc = bgetch(); 1276 UInt8 pc = bgetch();
1279 UInt16 w = wc; 1277 UInt16 w = wc;
1280 // //qDebug("h,w,pc [%u, %u, %u]", h, w, pc); 1278 // //qDebug("h,w,pc [%u, %u, %u]", h, w, pc);
1281 if (w == 0) 1279 if (w == 0)
1282 { 1280 {
1283 w = (m_scrWidth*(unsigned long)pc)/100; 1281 w = (m_scrWidth*(unsigned long)pc)/100;
1284 } 1282 }
1285 if (w == 0) w = m_scrWidth; 1283 if (w == 0) w = m_scrWidth;
1286 mystyle.setPicture(false, hRule(w,h,mystyle.Red(),mystyle.Green(),mystyle.Blue())); 1284 mystyle.setPicture(false, hRule(w,h,mystyle.Red(),mystyle.Green(),mystyle.Blue()));
1287 // if (mystyle.getLink()) //qDebug("hRule link!"); 1285 // if (mystyle.getLink()) //qDebug("hRule link!");
1288 ch = '#'; 1286 ch = '#';
1289 } 1287 }
1290 break; 1288 break;
1291 case 0x60: 1289 case 0x60:
1292 mystyle.setUnderline(); 1290 mystyle.setUnderline();
1293 ch = bgetch(); 1291 ch = bgetch();
1294 break; 1292 break;
1295 case 0x68: 1293 case 0x68:
1296 mystyle.unsetUnderline(); 1294 mystyle.unsetUnderline();
1297 ch = bgetch(); 1295 ch = bgetch();
1298 break; 1296 break;
1299 case 0x22: 1297 case 0x22:
1300 ch = bgetch(); 1298 ch = bgetch();
1301 mystyle.setLeftMargin(ch); 1299 mystyle.setLeftMargin(ch);
1302 // //qDebug("Left margin:%d", ch); 1300 // //qDebug("Left margin:%d", ch);
1303 ch = bgetch(); 1301 ch = bgetch();
1304 mystyle.setRightMargin(ch); 1302 mystyle.setRightMargin(ch);
1305 // //qDebug("Right margin:%d", ch); 1303 // //qDebug("Right margin:%d", ch);
1306 ch = bgetch(); 1304 ch = bgetch();
1307 break; 1305 break;
1308 case 0x70: 1306 case 0x70:
1309 mystyle.setStrikethru(); 1307 mystyle.setStrikethru();
1310 ch = bgetch(); 1308 ch = bgetch();
1311 break; 1309 break;
1312 case 0x78: 1310 case 0x78:
1313 mystyle.unsetStrikethru(); 1311 mystyle.unsetStrikethru();
1314 ch = bgetch(); 1312 ch = bgetch();
1315 break; 1313 break;
1316 case 0x83: 1314 case 0x83:
1317 { 1315 {
1318 int tlen = bgetch(); 1316 int tlen = bgetch();
1319 ch = bgetch(); 1317 ch = bgetch();
1320 ch <<= 8; 1318 ch <<= 8;
1321 ch |= (tchar)bgetch(); 1319 ch |= (tchar)bgetch();
1322 for (int i = 0; i < tlen; i++) bgetch(); 1320 for (int i = 0; i < tlen; i++) bgetch();
1323 //qDebug("Function 83"); 1321 //qDebug("Function 83");
1324 } 1322 }
1325 break; 1323 break;
1326 case 0x9a: 1324 case 0x9a:
1327 { 1325 {
1328 m_offset = 255*bgetch(); 1326 m_offset = 255*bgetch();
1329 m_offset += bgetch(); 1327 m_offset += bgetch();
1330 qDebug("Found offset:%u", m_offset); 1328 qDebug("Found offset:%u", m_offset);
1331 ch = bgetch(); 1329 ch = bgetch();
1332 } 1330 }
1333 break; 1331 break;
1334 case 0x85: 1332 case 0x85:
1335 default: 1333 default:
1336 qDebug("Function:%x NOT IMPLEMENTED", ch); 1334 qDebug("Function:%x NOT IMPLEMENTED", ch);
1337 { 1335 {
1338 int skip = ch & 7; 1336 int skip = ch & 7;
1339 for (int i = 0; i < skip; i++) 1337 for (int i = 0; i < skip; i++)
1340 { 1338 {
1341 ch = bgetch(); 1339 ch = bgetch();
1342 //qDebug("Arg %d, %d", i, ch); 1340 //qDebug("Arg %d, %d", i, ch);
1343 } 1341 }
1344 ch = bgetch(); 1342 ch = bgetch();
1345 } 1343 }
1346 } 1344 }
1347 } 1345 }
1348 1346
1349 if (m_lastIsBreak && !mystyle.isMono()) 1347 if (m_lastIsBreak && !mystyle.isMono())
1350 { 1348 {
1351 while (ch == ' ') 1349 while (ch == ' ')
1352 { 1350 {
1353 ch = getch(false); 1351 ch = getch(false);
1354 } 1352 }
1355 } 1353 }
1356 1354
1357 m_lastIsBreak = (ch == 10); 1355 m_lastIsBreak = (ch == 10);
1358 1356
1359 return (ch == EOF) ? UEOF : ch; 1357 return (ch == EOF) ? UEOF : ch;
1360} 1358}
1361 1359
1362#include "static.h"
1363#if defined(__STATIC) && defined(USENEF) 1360#if defined(__STATIC) && defined(USENEF)
1364#include "Model.h" 1361#include "Model.h"
1365void (*CPlucker_base::getdecompressor(const QString& _s))(UInt8*, size_t, UInt8*, size_t) 1362void (*CPlucker_base::getdecompressor(const QString& _s))(UInt8*, size_t, UInt8*, size_t)
1366{ 1363{
1367 if (_s == "PluckerDecompress3") 1364 if (_s == "PluckerDecompress3")
1368 { 1365 {
1369 return PluckerDecompress3; 1366 return PluckerDecompress3;
1370 } 1367 }
1371 if (_s == "PluckerDecompress4") 1368 if (_s == "PluckerDecompress4")
1372 { 1369 {
1373 return PluckerDecompress4; 1370 return PluckerDecompress4;
1374 } 1371 }
1375 return NULL; 1372 return NULL;
1376} 1373}
1377#else 1374#else
1378 1375
1379#include "qfileinfo.h" 1376#include "qfileinfo.h"
1380 1377
1381#include <dlfcn.h> 1378#include <dlfcn.h>
1382 1379
1383void (*CPlucker_base::getdecompressor(const QString& _s))(UInt8*, size_t, UInt8*, size_t) 1380void (*CPlucker_base::getdecompressor(const QString& _s))(UInt8*, size_t, UInt8*, size_t)
1384{ 1381{
1385 QString codecpath(QTReaderUtil::getPluginPath("support")); 1382 QString codecpath(QTReaderUtil::getPluginPath("support"));
1386 codecpath += "/libpluckerdecompress.so"; 1383 codecpath += "/libpluckerdecompress.so";
1387 qDebug("Codec:%s", (const char*)codecpath); 1384 qDebug("Codec:%s", (const char*)codecpath);
1388 if (QFile::exists(codecpath)) 1385 if (QFile::exists(codecpath))
1389 { 1386 {
1390 qDebug("Codec:%s", (const char*)codecpath); 1387 qDebug("Codec:%s", (const char*)codecpath);
1391 void* handle = dlopen(codecpath, RTLD_LAZY); 1388 void* handle = dlopen(codecpath, RTLD_LAZY);
1392 if (handle == 0) 1389 if (handle == 0)
1393 { 1390 {
1394 qDebug("Can't find codec:%s", dlerror()); 1391 qDebug("Can't find codec:%s", dlerror());
1395 return NULL; 1392 return NULL;
1396 } 1393 }
1397 return (void (*)(UInt8*, size_t, UInt8*, size_t))dlsym(handle, _s); 1394 return (void (*)(UInt8*, size_t, UInt8*, size_t))dlsym(handle, _s);
1398 } 1395 }
1399 return NULL; 1396 return NULL;
1400} 1397}
1401#endif 1398#endif
1402 1399
1403QString CPlucker_base::about() 1400QString CPlucker_base::about()
1404{ 1401{
1405 QString abt = "Plucker base codec (c) Tim Wentford"; 1402 QString abt = "Plucker base codec (c) Tim Wentford";
1406 if (m_decompress != UnDoc && m_decompress != UnZip) 1403 if (m_decompress != UnDoc && m_decompress != UnZip)
1407 { 1404 {
1408 abt += "\nSpecial decompression (c) Tim Wentford"; 1405 abt += "\nSpecial decompression (c) Tim Wentford";
1409 } 1406 }
1410 return abt; 1407 return abt;
1411} 1408}
diff --git a/noncore/apps/opie-reader/pluckerbaselib/pluckerbaselib.pro b/noncore/apps/opie-reader/pluckerbaselib/pluckerbaselib.pro
index bee1a2d..7c2f31e 100644
--- a/noncore/apps/opie-reader/pluckerbaselib/pluckerbaselib.pro
+++ b/noncore/apps/opie-reader/pluckerbaselib/pluckerbaselib.pro
@@ -1,18 +1,18 @@
1DEFINES += OPIE USEQPE 1DEFINES += OPIE USEQPE
2VPATH = .. 2VPATH = ..
3 TEMPLATE= lib 3 TEMPLATE= lib
4 CONFIG = qt warn_on release dll 4 CONFIG = qt warn_on release dll
5 HEADERS = pdb.h \ 5 HEADERS = pdb.h \
6 util.h 6 util.h
7 7
8 SOURCES = plucker_base.cpp 8 SOURCES = plucker_base.cpp
9 9
10 INTERFACES= 10 INTERFACES=
11 DESTDIR = $(OPIEDIR)/lib 11 DESTDIR = $(OPIEDIR)/lib
12 TARGET = reader_pluckerbase 12 TARGET = reader_pluckerbase
13 LIBS += -ldl 13 LIBS += -ldl
14 14
15 INCLUDEPATH+= ../OREADERINC $(OPIEDIR)/include 15 INCLUDEPATH+= $(OPIEDIR)/include
16 DEPENDPATH+= ../OREADERINC $(OPIEDIR)/include 16 DEPENDPATH+= $(OPIEDIR)/include
17 17
18include ( $(OPIEDIR)/include.pro ) 18include ( $(OPIEDIR)/include.pro )
diff --git a/noncore/apps/opie-reader/ppm_expander.cpp b/noncore/apps/opie-reader/ppm_expander.cpp
index ea5b955..2a4318b 100644
--- a/noncore/apps/opie-reader/ppm_expander.cpp
+++ b/noncore/apps/opie-reader/ppm_expander.cpp
@@ -1,116 +1,115 @@
1/* 1/*
2 * Interface pour le programme de compression 2 * Interface pour le programme de compression
3 * (c) 1995 Fabrice Bellard 3 * (c) 1995 Fabrice Bellard
4 */ 4 */
5 5
6#include <stdlib.h> 6#include <stdlib.h>
7//#include <unistd.h> 7//#include <unistd.h>
8#include <stdio.h> 8#include <stdio.h>
9#include <string.h> 9#include <string.h>
10#include <time.h> 10#include <time.h>
11#include "static.h"
12 11
13/*************************************************************************** 12/***************************************************************************
14 * Interface avec les routines de compression 13 * Interface avec les routines de compression
15 */ 14 */
16 15
17#define METHOD_NB 2 /* nombre total de méthodes de compression */ 16#define METHOD_NB 2 /* nombre total de méthodes de compression */
18 17
19#define METHOD_STORE 0 18#define METHOD_STORE 0
20#define METHOD_PPM 1 19#define METHOD_PPM 1
21 20
22 21
23#define DEFAULT_SUFFIX ".st" /* extension par défault */ 22#define DEFAULT_SUFFIX ".st" /* extension par défault */
24/* signature en début de fichier */ 23/* signature en début de fichier */
25#define STAT_MAGIC_SIZE 4 24#define STAT_MAGIC_SIZE 4
26char stat_magic[STAT_MAGIC_SIZE]={'P','P','M','S'}; 25char stat_magic[STAT_MAGIC_SIZE]={'P','P','M','S'};
27 26
28#include "ppm_expander.h" 27#include "ppm_expander.h"
29 28
30ppm_expander::~ppm_expander() { 29ppm_expander::~ppm_expander() {
31 if (needppmend) ppm.PPM_End(); 30 if (needppmend) ppm.PPM_End();
32 ppm.arith.Arith_DecodeEnd(); 31 ppm.arith.Arith_DecodeEnd();
33 if (buf_in!=NULL) delete [] buf_in; 32 if (buf_in!=NULL) delete [] buf_in;
34 if (buf_out!=NULL) delete [] buf_out; 33 if (buf_out!=NULL) delete [] buf_out;
35 if (my_read_buf != NULL) delete my_read_buf; 34 if (my_read_buf != NULL) delete my_read_buf;
36 if (my_file_in != NULL) fclose(my_file_in); 35 if (my_file_in != NULL) fclose(my_file_in);
37} 36}
38 37
39int ppm_expander::OpenFile(const char* infile) 38int ppm_expander::OpenFile(const char* infile)
40{ 39{
41 my_file_in=fopen(infile,"rb"); 40 my_file_in=fopen(infile,"rb");
42 my_read_buf = new PPM_ReadBuf(my_file_in); 41 my_read_buf = new PPM_ReadBuf(my_file_in);
43 return home(); 42 return home();
44} 43}
45 44
46void ppm_expander::sizes(unsigned long& file, unsigned long& text) 45void ppm_expander::sizes(unsigned long& file, unsigned long& text)
47{ 46{
48 struct stat _stat; 47 struct stat _stat;
49 fstat(fileno(my_file_in),&_stat); 48 fstat(fileno(my_file_in),&_stat);
50 file = _stat.st_size; 49 file = _stat.st_size;
51 text = numblocks*blocksize; 50 text = numblocks*blocksize;
52} 51}
53 52
54int ppm_expander::home() 53int ppm_expander::home()
55{ 54{
56 fseek(my_file_in,0, SEEK_SET); 55 fseek(my_file_in,0, SEEK_SET);
57 unsigned char header[STAT_MAGIC_SIZE]; 56 unsigned char header[STAT_MAGIC_SIZE];
58 size_t len=fread(header,1,STAT_MAGIC_SIZE,my_file_in); 57 size_t len=fread(header,1,STAT_MAGIC_SIZE,my_file_in);
59 if (strncmp((char*)header,stat_magic,STAT_MAGIC_SIZE)!=0) { 58 if (strncmp((char*)header,stat_magic,STAT_MAGIC_SIZE)!=0) {
60 return 1; 59 return 1;
61 } 60 }
62 if (len!=(STAT_MAGIC_SIZE)) { 61 if (len!=(STAT_MAGIC_SIZE)) {
63 return 1; 62 return 1;
64 } 63 }
65 if (fread(&maxnode,sizeof(maxnode),1,my_file_in) != 1) return 1; 64 if (fread(&maxnode,sizeof(maxnode),1,my_file_in) != 1) return 1;
66 if (fread(&blocksize,sizeof(blocksize),1,my_file_in) != 1) return 1; 65 if (fread(&blocksize,sizeof(blocksize),1,my_file_in) != 1) return 1;
67 if (fread(&numblocks,sizeof(numblocks),1,my_file_in) != 1) return 1; 66 if (fread(&numblocks,sizeof(numblocks),1,my_file_in) != 1) return 1;
68 //fprintf(stderr,"<%u,%u,%u>\n",maxnode,blocksize,numblocks); 67 //fprintf(stderr,"<%u,%u,%u>\n",maxnode,blocksize,numblocks);
69 locate(0,0); 68 locate(0,0);
70 outbytes = 0; 69 outbytes = 0;
71 return 0; 70 return 0;
72} 71}
73 72
74void ppm_expander::locate(unsigned int n) { 73void ppm_expander::locate(unsigned int n) {
75 locate(n/blocksize, n%blocksize); 74 locate(n/blocksize, n%blocksize);
76 outbytes = n; 75 outbytes = n;
77} 76}
78 77
79void ppm_expander::locate(unsigned short block, unsigned int n) 78void ppm_expander::locate(unsigned short block, unsigned int n)
80{ 79{
81 if (needppmend) 80 if (needppmend)
82 { 81 {
83 ppm.PPM_End(); 82 ppm.PPM_End();
84 needppmend = false; 83 needppmend = false;
85 } 84 }
86 size_t fpos; 85 size_t fpos;
87 fseek(my_file_in,STAT_MAGIC_SIZE+sizeof(maxnode)+sizeof(blocksize)+sizeof(numblocks)+block*sizeof(fpos),SEEK_SET); 86 fseek(my_file_in,STAT_MAGIC_SIZE+sizeof(maxnode)+sizeof(blocksize)+sizeof(numblocks)+block*sizeof(fpos),SEEK_SET);
88 fread(&fpos,sizeof(fpos),1,my_file_in); 87 fread(&fpos,sizeof(fpos),1,my_file_in);
89 fseek(my_file_in,fpos,SEEK_SET); 88 fseek(my_file_in,fpos,SEEK_SET);
90 89
91 ppm.arith.Arith_DecodeInit(my_read_buf,buf_in,bufsize); 90 ppm.arith.Arith_DecodeInit(my_read_buf,buf_in,bufsize);
92 int err=ppm.PPM_Init(maxnode); 91 int err=ppm.PPM_Init(maxnode);
93 needppmend = true; 92 needppmend = true;
94 curblock = block; 93 curblock = block;
95 for (int i = 0; i < n; i++) getch(); 94 for (int i = 0; i < n; i++) getch();
96} 95}
97 96
98int ppm_expander::getch() { 97int ppm_expander::getch() {
99 if (curblock >= numblocks) return EOF; 98 if (curblock >= numblocks) return EOF;
100 int c=ppm.PPM_Decode(); 99 int c=ppm.PPM_Decode();
101 if (c == SYM_EOF) 100 if (c == SYM_EOF)
102 { 101 {
103 if (++curblock >= numblocks) return EOF; 102 if (++curblock >= numblocks) return EOF;
104 locate(curblock,0); 103 locate(curblock,0);
105 c = ppm.PPM_Decode(); 104 c = ppm.PPM_Decode();
106 } 105 }
107 outbytes++; 106 outbytes++;
108 return (c==SYM_EOF) ? EOF : c; 107 return (c==SYM_EOF) ? EOF : c;
109} 108}
110 109
111#ifndef __STATIC 110#ifndef __STATIC
112extern "C" 111extern "C"
113{ 112{
114 CExpander* newcodec() { return new ppm_expander; } 113 CExpander* newcodec() { return new ppm_expander; }
115} 114}
116#endif 115#endif
diff --git a/noncore/apps/opie-reader/ppm_expander.h b/noncore/apps/opie-reader/ppm_expander.h
index a1a3b60..ccc89c2 100644
--- a/noncore/apps/opie-reader/ppm_expander.h
+++ b/noncore/apps/opie-reader/ppm_expander.h
@@ -1,62 +1,61 @@
1#ifndef __ppm_expander_h 1#ifndef __ppm_expander_h
2#define __ppm_expander_h 2#define __ppm_expander_h
3 3
4#include "useqpe.h"
5#include "CExpander.h" 4#include "CExpander.h"
6#include <sys/stat.h> 5#include <sys/stat.h>
7 6
8 7
9#include "utypes.h" 8#include "utypes.h"
10#include "ppm.h" 9#include "ppm.h"
11#include "arith.h" 10#include "arith.h"
12 11
13 12
14#define SYM_EOF 256 13#define SYM_EOF 256
15 14
16class ppm_expander : public CExpander { 15class ppm_expander : public CExpander {
17 UCHAR *buf_in,*buf_out; 16 UCHAR *buf_in,*buf_out;
18 unsigned int bufsize; 17 unsigned int bufsize;
19 unsigned int outbytes; 18 unsigned int outbytes;
20 unsigned long blocksize; 19 unsigned long blocksize;
21 unsigned short numblocks; 20 unsigned short numblocks;
22 unsigned short curblock; 21 unsigned short curblock;
23 unsigned short maxnode; 22 unsigned short maxnode;
24 bool needppmend; 23 bool needppmend;
25 int home(); 24 int home();
26 FILE* my_file_in; 25 FILE* my_file_in;
27 PPM_ReadBuf* my_read_buf; 26 PPM_ReadBuf* my_read_buf;
28 ppm_worker ppm; 27 ppm_worker ppm;
29public: 28public:
30 QString about() { return QString("ppms Codec (c) Tim Wentford\nCompression code (c) Fabrice Bellard"); } 29 QString about() { return QString("ppms Codec (c) Tim Wentford\nCompression code (c) Fabrice Bellard"); }
31#ifdef USEQPE 30#ifdef USEQPE
32 void suspend() 31 void suspend()
33 { 32 {
34 CExpander::suspend(my_file_in); 33 CExpander::suspend(my_file_in);
35 } 34 }
36 void unsuspend() 35 void unsuspend()
37 { 36 {
38 CExpander::unsuspend(my_file_in); 37 CExpander::unsuspend(my_file_in);
39 } 38 }
40#endif 39#endif
41 ppm_expander() : needppmend(false), my_file_in(NULL), my_read_buf(NULL) 40 ppm_expander() : needppmend(false), my_file_in(NULL), my_read_buf(NULL)
42 { 41 {
43 bufsize = 1024; 42 bufsize = 1024;
44 buf_in = new UCHAR[bufsize]; 43 buf_in = new UCHAR[bufsize];
45 buf_out = new UCHAR[bufsize]; 44 buf_out = new UCHAR[bufsize];
46 outbytes = 0; 45 outbytes = 0;
47 } 46 }
48 int OpenFile(const char* infile); 47 int OpenFile(const char* infile);
49 int getch(); 48 int getch();
50 void locate(unsigned short block, unsigned int n); 49 void locate(unsigned short block, unsigned int n);
51 virtual ~ppm_expander(); 50 virtual ~ppm_expander();
52 unsigned int locate() { return outbytes; } 51 unsigned int locate() { return outbytes; }
53 void locate(unsigned int n); 52 void locate(unsigned int n);
54 bool hasrandomaccess() { return (numblocks > 1); } 53 bool hasrandomaccess() { return (numblocks > 1); }
55 void sizes(unsigned long& file, unsigned long& text); 54 void sizes(unsigned long& file, unsigned long& text);
56 MarkupType PreferredMarkup() 55 MarkupType PreferredMarkup()
57 { 56 {
58 return cTEXT; 57 return cTEXT;
59 } 58 }
60}; 59};
61 60
62#endif 61#endif
diff --git a/noncore/apps/opie-reader/ppmsCodec/ppmsCodec.pro b/noncore/apps/opie-reader/ppmsCodec/ppmsCodec.pro
index 8699d3b..d6ec97b 100644
--- a/noncore/apps/opie-reader/ppmsCodec/ppmsCodec.pro
+++ b/noncore/apps/opie-reader/ppmsCodec/ppmsCodec.pro
@@ -1,19 +1,19 @@
1DEFINES += OPIE USEQPE 1DEFINES += OPIE USEQPE
2VPATH = .. 2VPATH = ..
3 TEMPLATE= lib 3 TEMPLATE= lib
4 CONFIG = qt warn_on release dll 4 CONFIG = qt warn_on release dll
5 HEADERS = Aportis.h 5 HEADERS = Aportis.h
6 6
7 SOURCES = ppm_expander.cpp \ 7 SOURCES = ppm_expander.cpp \
8 ppm.cpp \ 8 ppm.cpp \
9 arith_d.cpp 9 arith_d.cpp
10 10
11 INTERFACES= 11 INTERFACES=
12 DESTDIR = $(OPIEDIR)/plugins/reader/codecs 12 DESTDIR = $(OPIEDIR)/plugins/reader/codecs
13 TARGET = ppms 13 TARGET = ppms
14LIBS += -lreader_codec 14LIBS += -lreader_codec
15 15
16 INCLUDEPATH+= ../OREADERINC $(OPIEDIR)/include 16 INCLUDEPATH+= $(OPIEDIR)/include
17 DEPENDPATH+= ../OREADERINC $(OPIEDIR)/include 17 DEPENDPATH+= $(OPIEDIR)/include
18 18
19include ( $(OPIEDIR)/include.pro ) 19include ( $(OPIEDIR)/include.pro )
diff --git a/noncore/apps/opie-reader/preferences.cpp b/noncore/apps/opie-reader/preferences.cpp
index b9397cf..0f59a22 100755
--- a/noncore/apps/opie-reader/preferences.cpp
+++ b/noncore/apps/opie-reader/preferences.cpp
@@ -1,105 +1,104 @@
1#include "useqpe.h"
2#ifndef USEQPE 1#ifndef USEQPE
3 2
4#include "preferences.h" 3#include "preferences.h"
5 4
6#include <qfile.h> 5#include <qfile.h>
7#include <qtextstream.h> 6#include <qtextstream.h>
8 7
9Config::Config(const QString& _fn) : fname(_fn) 8Config::Config(const QString& _fn) : fname(_fn)
10{ 9{
11// qDebug("Config::Config:%s", (const char*)fname); 10// qDebug("Config::Config:%s", (const char*)fname);
12 QFile fl(fname); 11 QFile fl(fname);
13 if (fl.open(IO_ReadOnly)) 12 if (fl.open(IO_ReadOnly))
14 { 13 {
15 QTextStream t(&fl); 14 QTextStream t(&fl);
16 QString key, value; 15 QString key, value;
17 while (!t.eof()) 16 while (!t.eof())
18 { 17 {
19 QString data = t.readLine(); 18 QString data = t.readLine();
20 int colon = data.find(':'); 19 int colon = data.find(':');
21 if (colon > 0) 20 if (colon > 0)
22 { 21 {
23 QString key = data.left(colon); 22 QString key = data.left(colon);
24 QString value = data.right(data.length()-colon-1); 23 QString value = data.right(data.length()-colon-1);
25 values[key] = value; 24 values[key] = value;
26 } 25 }
27 } 26 }
28 fl.close(); 27 fl.close();
29 } 28 }
30// read entries into values 29// read entries into values
31} 30}
32Config::~Config() 31Config::~Config()
33{ 32{
34// qDebug("Config::~Config:%s", (const char*)fname); 33// qDebug("Config::~Config:%s", (const char*)fname);
35 QFile fl(fname); 34 QFile fl(fname);
36 if (fl.open(IO_WriteOnly)) 35 if (fl.open(IO_WriteOnly))
37 { 36 {
38 QTextStream t(&fl); 37 QTextStream t(&fl);
39 for (QMap<QString,QString>::Iterator iter = values.begin(); 38 for (QMap<QString,QString>::Iterator iter = values.begin();
40 iter != values.end(); 39 iter != values.end();
41 iter++) 40 iter++)
42 { 41 {
43 t << iter.key() << ':' << iter.data() << '\n'; 42 t << iter.key() << ':' << iter.data() << '\n';
44 } 43 }
45 fl.close(); 44 fl.close();
46 } 45 }
47} 46}
48QString Config::readEntry(const QString& key, const QString& deflt) 47QString Config::readEntry(const QString& key, const QString& deflt)
49{ 48{
50 QMap<QString,QString>::Iterator iter = values.find(key); 49 QMap<QString,QString>::Iterator iter = values.find(key);
51 if (iter != values.end()) 50 if (iter != values.end())
52 { 51 {
53 return iter.data(); 52 return iter.data();
54 } 53 }
55 else 54 else
56 { 55 {
57 return deflt; 56 return deflt;
58 } 57 }
59} 58}
60bool Config::readBoolEntry(const QString& key, const bool deflt) 59bool Config::readBoolEntry(const QString& key, const bool deflt)
61{ 60{
62 bool ok; 61 bool ok;
63 QMap<QString,QString>::Iterator iter = values.find(key); 62 QMap<QString,QString>::Iterator iter = values.find(key);
64 if (iter != values.end()) 63 if (iter != values.end())
65 { 64 {
66 int ret = iter.data().toInt(&ok); 65 int ret = iter.data().toInt(&ok);
67 return ((ok) ? !!ret : deflt); 66 return ((ok) ? !!ret : deflt);
68 } 67 }
69 else 68 else
70 { 69 {
71 return deflt; 70 return deflt;
72 } 71 }
73} 72}
74int Config::readNumEntry(const QString& key, const int deflt) 73int Config::readNumEntry(const QString& key, const int deflt)
75{ 74{
76 bool ok; 75 bool ok;
77 QMap<QString,QString>::Iterator iter = values.find(key); 76 QMap<QString,QString>::Iterator iter = values.find(key);
78 if (iter != values.end()) 77 if (iter != values.end())
79 { 78 {
80 int ret = iter.data().toInt(&ok); 79 int ret = iter.data().toInt(&ok);
81 return ((ok) ? ret : deflt); 80 return ((ok) ? ret : deflt);
82 } 81 }
83 else 82 else
84 { 83 {
85 return deflt; 84 return deflt;
86 } 85 }
87} 86}
88void Config::writeEntry(const QString& key, const QString& value) 87void Config::writeEntry(const QString& key, const QString& value)
89{ 88{
90 values[key] = value; 89 values[key] = value;
91} 90}
92 91
93void Config::writeEntry(const QString& key, const bool value) 92void Config::writeEntry(const QString& key, const bool value)
94{ 93{
95 values[key] = (value) ? "1" : "0"; 94 values[key] = (value) ? "1" : "0";
96} 95}
97 96
98void Config::writeEntry(const QString& key, const int value) 97void Config::writeEntry(const QString& key, const int value)
99{ 98{
100 QString rhs; 99 QString rhs;
101 rhs.setNum(value); 100 rhs.setNum(value);
102 values[key] = rhs; 101 values[key] = rhs;
103} 102}
104 103
105#endif 104#endif
diff --git a/noncore/apps/opie-reader/preferences.h b/noncore/apps/opie-reader/preferences.h
index 69d1774..aeb2a84 100644
--- a/noncore/apps/opie-reader/preferences.h
+++ b/noncore/apps/opie-reader/preferences.h
@@ -1,27 +1,26 @@
1#include "useqpe.h"
2#ifndef USEQPE 1#ifndef USEQPE
3#ifndef __PREFERENCES_H 2#ifndef __PREFERENCES_H
4#define __PREFERENCES_H 3#define __PREFERENCES_H
5 4
6#include <qstring.h> 5#include <qstring.h>
7#include <qmap.h> 6#include <qmap.h>
8 7
9class Config 8class Config
10{ 9{
11 QMap<QString, QString> values; 10 QMap<QString, QString> values;
12 QString fname; 11 QString fname;
13 public: 12 public:
14 Config(const QString& fname); 13 Config(const QString& fname);
15 ~Config(); 14 ~Config();
16 void setGroup(const QString& s) { } 15 void setGroup(const QString& s) { }
17 QString readEntry(const QString&, const QString&); 16 QString readEntry(const QString&, const QString&);
18 bool readBoolEntry(const QString&, const bool); 17 bool readBoolEntry(const QString&, const bool);
19 int readNumEntry(const QString&, const int); 18 int readNumEntry(const QString&, const int);
20 19
21 void writeEntry(const QString&, const QString&); 20 void writeEntry(const QString&, const QString&);
22 void writeEntry(const QString&, const bool); 21 void writeEntry(const QString&, const bool);
23 void writeEntry(const QString&, const int); 22 void writeEntry(const QString&, const int);
24}; 23};
25 24
26#endif // PREFERENCES 25#endif // PREFERENCES
27#endif 26#endif
diff --git a/noncore/apps/opie-reader/static.h b/noncore/apps/opie-reader/static.h
deleted file mode 100644
index e69de29..0000000
--- a/noncore/apps/opie-reader/static.h
+++ b/dev/null
diff --git a/noncore/apps/opie-reader/striphtml.cpp b/noncore/apps/opie-reader/striphtml.cpp
index 9cd6a0d..e86402b 100644
--- a/noncore/apps/opie-reader/striphtml.cpp
+++ b/noncore/apps/opie-reader/striphtml.cpp
@@ -1,1249 +1,1248 @@
1#include <qmap.h> 1#include <qmap.h>
2#include <qfileinfo.h> 2#include <qfileinfo.h>
3#include <qtextstream.h> 3#include <qtextstream.h>
4#include <qdir.h> 4#include <qdir.h>
5#include "useqpe.h"
6#ifdef USEQPE 5#ifdef USEQPE
7#include <qpe/global.h> 6#include <qpe/global.h>
8#endif 7#endif
9#include "CDrawBuffer.h" 8#include "CDrawBuffer.h"
10#include "striphtml.h" 9#include "striphtml.h"
11#include "hrule.h" 10#include "hrule.h"
12#include "util.h" 11#include "util.h"
13 12
14#include <qregexp.h> 13#include <qregexp.h>
15#include <qimage.h> 14#include <qimage.h>
16#include <qpixmap.h> 15#include <qpixmap.h>
17//#include <qprogressdialog.h> 16//#include <qprogressdialog.h>
18//#include <qapplication.h> 17//#include <qapplication.h>
19 18
20static unsigned char h2i(unsigned char c) 19static unsigned char h2i(unsigned char c)
21{ 20{
22 unsigned char ret = 0; 21 unsigned char ret = 0;
23 if ('0' <= c && c <= '9') 22 if ('0' <= c && c <= '9')
24 { 23 {
25 ret = c - '0'; 24 ret = c - '0';
26 } 25 }
27 else if ('a' <= c && c <= 'f') 26 else if ('a' <= c && c <= 'f')
28 { 27 {
29 ret = c - 'a' + 10; 28 ret = c - 'a' + 10;
30 } 29 }
31 return ret; 30 return ret;
32} 31}
33 32
34static void parse_color(const QString& attr, unsigned char& r, unsigned char& g, unsigned char& b) 33static void parse_color(const QString& attr, unsigned char& r, unsigned char& g, unsigned char& b)
35{ 34{
36 r = g = b = 0; 35 r = g = b = 0;
37 if (attr.length() >= 7 && attr[0] == '#') 36 if (attr.length() >= 7 && attr[0] == '#')
38 { 37 {
39 r = h2i(attr[1].unicode()); 38 r = h2i(attr[1].unicode());
40 r = 16*r + h2i(attr[2].unicode()); 39 r = 16*r + h2i(attr[2].unicode());
41 g = h2i(attr[3].unicode()); 40 g = h2i(attr[3].unicode());
42 g = 16*g + h2i(attr[4].unicode()); 41 g = 16*g + h2i(attr[4].unicode());
43 b = h2i(attr[5].unicode()); 42 b = h2i(attr[5].unicode());
44 b = 16*b + h2i(attr[6].unicode()); 43 b = 16*b + h2i(attr[6].unicode());
45 } 44 }
46 else if (attr == "red") 45 else if (attr == "red")
47 { 46 {
48 r = 255; 47 r = 255;
49 } 48 }
50 else if (attr == "green") 49 else if (attr == "green")
51 { 50 {
52 g = 255; 51 g = 255;
53 } 52 }
54 else if (attr == "blue") 53 else if (attr == "blue")
55 { 54 {
56 b = 255; 55 b = 255;
57 } 56 }
58 else if (attr == "white") 57 else if (attr == "white")
59 { 58 {
60 r = g = b = 255; 59 r = g = b = 255;
61 } 60 }
62 else if (attr == "black") 61 else if (attr == "black")
63 { 62 {
64 r = g = b = 0; 63 r = g = b = 0;
65 } 64 }
66 else 65 else
67 { 66 {
68 qDebug("Don't understand colour \"%s\"", (const char*)attr); 67 qDebug("Don't understand colour \"%s\"", (const char*)attr);
69 } 68 }
70} 69}
71 70
72CNavigation_base<htmlmark> striphtml::m_nav; 71CNavigation_base<htmlmark> striphtml::m_nav;
73 72
74void striphtml::skipblock(const QString& _ent) 73void striphtml::skipblock(const QString& _ent)
75{ 74{
76 tchar ch = '>'; 75 tchar ch = '>';
77 CStyle dummy; 76 CStyle dummy;
78 QString ent; 77 QString ent;
79 unsigned long pos; 78 unsigned long pos;
80 do 79 do
81 { 80 {
82 while (ch != '<' && ch != UEOF) 81 while (ch != '<' && ch != UEOF)
83 { 82 {
84 mygetch(ch, dummy, pos); 83 mygetch(ch, dummy, pos);
85 } 84 }
86 85
87 ch = skip_ws(); 86 ch = skip_ws();
88 87
89 ent = getname(ch, " >").lower(); 88 ent = getname(ch, " >").lower();
90 qDebug("Skipblock:%s", (const char*)ent); 89 qDebug("Skipblock:%s", (const char*)ent);
91 } while (ent != _ent && ch != UEOF); 90 } while (ent != _ent && ch != UEOF);
92} 91}
93 92
94void striphtml::locate(unsigned int n) 93void striphtml::locate(unsigned int n)
95{ 94{
96 m_inblock = false; 95 m_inblock = false;
97 text_q = ""; 96 text_q = "";
98 forcecentre = false; 97 forcecentre = false;
99 ignorespace = false; 98 ignorespace = false;
100 while (!stylestack.isEmpty()) stylestack.pop(); 99 while (!stylestack.isEmpty()) stylestack.pop();
101 currentstyle.unset(); 100 currentstyle.unset();
102 qDebug("striphtml:locating:%u", n); 101 qDebug("striphtml:locating:%u", n);
103 parent->locate(n); 102 parent->locate(n);
104} 103}
105 104
106int striphtml::getpara(CBuffer& buff, unsigned long& startpos) 105int striphtml::getpara(CBuffer& buff, unsigned long& startpos)
107{ 106{
108 tchar ch; 107 tchar ch;
109 CStyle sty; 108 CStyle sty;
110 unsigned long pos; 109 unsigned long pos;
111 int i = 0; 110 int i = 0;
112 parent->getch(ch, sty, startpos); 111 parent->getch(ch, sty, startpos);
113 pos = startpos; 112 pos = startpos;
114 while (1) 113 while (1)
115 { 114 {
116 if (ch == 10 && !isPre) 115 if (ch == 10 && !isPre)
117 { 116 {
118 ch = ' '; 117 ch = ' ';
119 } 118 }
120 if (ch == UEOF) 119 if (ch == UEOF)
121 { 120 {
122 // qDebug("EOF:%d:%u", i, pos); 121 // qDebug("EOF:%d:%u", i, pos);
123 buff[i] = 0; 122 buff[i] = 0;
124 if (i == 0) 123 if (i == 0)
125 { 124 {
126 i = -1; 125 i = -1;
127 } 126 }
128 return i; 127 return i;
129 } 128 }
130 else if (ch == '<') 129 else if (ch == '<')
131 { 130 {
132 tchar ch2 = skip_ws(); 131 tchar ch2 = skip_ws();
133 QString ent = getname(ch2, " >"); 132 QString ent = getname(ch2, " >");
134 ent = ent.lower(); 133 ent = ent.lower();
135 // qDebug("ent:%s", (const char*)ent); 134 // qDebug("ent:%s", (const char*)ent);
136 if (ent == "a") 135 if (ent == "a")
137 { 136 {
138 buff[i++] = '<'; 137 buff[i++] = '<';
139 buff[i++] = 'a'; 138 buff[i++] = 'a';
140 buff[i++] = ch2; 139 buff[i++] = ch2;
141 // buff[i] = 0; qDebug("ANCHOR:%s", (const char*)toQString(buff.data())); 140 // buff[i] = 0; qDebug("ANCHOR:%s", (const char*)toQString(buff.data()));
142 } 141 }
143 else if (ent == "/a") 142 else if (ent == "/a")
144 { 143 {
145 buff[i++] = '<'; 144 buff[i++] = '<';
146 buff[i++] = '/'; 145 buff[i++] = '/';
147 buff[i++] = 'a'; 146 buff[i++] = 'a';
148 buff[i++] = ch2; 147 buff[i++] = ch2;
149 // buff[i] = 0; qDebug("/ANCHOR:%s", (const char*)toQString(buff.data())); 148 // buff[i] = 0; qDebug("/ANCHOR:%s", (const char*)toQString(buff.data()));
150 } 149 }
151 else if (ent == "div") 150 else if (ent == "div")
152 { 151 {
153 // buff[i] = 0; qDebug("DIV:%s", (const char*)toQString(buff.data())); 152 // buff[i] = 0; qDebug("DIV:%s", (const char*)toQString(buff.data()));
154 if (i == 0) 153 if (i == 0)
155 { 154 {
156 buff[i++] = '<'; 155 buff[i++] = '<';
157 buff[i++] = 'd'; 156 buff[i++] = 'd';
158 buff[i++] = 'i'; 157 buff[i++] = 'i';
159 buff[i++] = 'v'; 158 buff[i++] = 'v';
160 buff[i++] = ' '; 159 buff[i++] = ' ';
161 buff[i++] = ch2; 160 buff[i++] = ch2;
162 while (ch2 != '>' && ch2 != UEOF && i < 2048) 161 while (ch2 != '>' && ch2 != UEOF && i < 2048)
163 { 162 {
164 parent->getch(ch2, sty, pos); 163 parent->getch(ch2, sty, pos);
165 buff[i++] = ch2; 164 buff[i++] = ch2;
166 } 165 }
167 } 166 }
168 else 167 else
169 { 168 {
170 locate(pos); 169 locate(pos);
171 } 170 }
172 buff[i++] = 0; 171 buff[i++] = 0;
173 // qDebug("DIV:%s", (const char*)toQString(buff.data())); 172 // qDebug("DIV:%s", (const char*)toQString(buff.data()));
174 return i; 173 return i;
175 } 174 }
176 else if (ent == "p" || (ent[0] == 'h' && ent.length() == 2 && QString("123456789").find(ent[1]) != -1)) 175 else if (ent == "p" || (ent[0] == 'h' && ent.length() == 2 && QString("123456789").find(ent[1]) != -1))
177 { 176 {
178 buff[i++] = 0; 177 buff[i++] = 0;
179 while (ch2 != '>' && ch2 != UEOF) 178 while (ch2 != '>' && ch2 != UEOF)
180 { 179 {
181 parent->getch(ch2, sty, pos); 180 parent->getch(ch2, sty, pos);
182 } 181 }
183 return i; 182 return i;
184 } 183 }
185 else 184 else
186 { 185 {
187 while (ch2 != '>' && ch2 != UEOF) 186 while (ch2 != '>' && ch2 != UEOF)
188 { 187 {
189 parent->getch(ch2, sty, pos); 188 parent->getch(ch2, sty, pos);
190 } 189 }
191 } 190 }
192 } 191 }
193 else 192 else
194 { 193 {
195 buff[i++] = ch; 194 buff[i++] = ch;
196 } 195 }
197 parent->getch(ch, sty, pos); 196 parent->getch(ch, sty, pos);
198 } 197 }
199} 198}
200 199
201QString striphtml::dehtml(const QString& _info) 200QString striphtml::dehtml(const QString& _info)
202{ 201{
203 QString info; 202 QString info;
204 for (int i = 0; i < _info.length(); i++) 203 for (int i = 0; i < _info.length(); i++)
205 { 204 {
206 tchar ch = _info[i]; 205 tchar ch = _info[i];
207 if (ch == '%') 206 if (ch == '%')
208 { 207 {
209 ch = 0; 208 ch = 0;
210 for (int j = 0; j < 2; j++) 209 for (int j = 0; j < 2; j++)
211 { 210 {
212 ch <<= 4; 211 ch <<= 4;
213 tchar ch1 = _info[++i]; 212 tchar ch1 = _info[++i];
214 if ('0' <= ch1 && ch1 <= '9') 213 if ('0' <= ch1 && ch1 <= '9')
215 { 214 {
216 ch += ch1 - '0'; 215 ch += ch1 - '0';
217 } 216 }
218 else if ('a' <= ch1 && ch1 <= 'f') 217 else if ('a' <= ch1 && ch1 <= 'f')
219 { 218 {
220 ch += ch1 - 'a' + 10; 219 ch += ch1 - 'a' + 10;
221 } 220 }
222 else if ('A' <= ch1 && ch1 <= 'F') 221 else if ('A' <= ch1 && ch1 <= 'F')
223 { 222 {
224 ch += ch1 - 'A' + 10; 223 ch += ch1 - 'A' + 10;
225 } 224 }
226 } 225 }
227 } 226 }
228 info += ch; 227 info += ch;
229 } 228 }
230 return info; 229 return info;
231} 230}
232 231
233bool striphtml::findanchor(const QString& _info) 232bool striphtml::findanchor(const QString& _info)
234{ 233{
235 // QProgressDialog dlg("Finding link...", QString::null, 0, NULL, "progress", true); 234 // QProgressDialog dlg("Finding link...", QString::null, 0, NULL, "progress", true);
236 // QProgressBar dlg(0); 235 // QProgressBar dlg(0);
237#if defined(USEQPE) || defined(_WINDOWS) 236#if defined(USEQPE) || defined(_WINDOWS)
238 QString info; 237 QString info;
239 for (int i = 0; i < _info.length(); i++) 238 for (int i = 0; i < _info.length(); i++)
240 { 239 {
241 tchar ch = _info[i]; 240 tchar ch = _info[i];
242 if (QString(".^$[]*+?").find(ch) != -1) 241 if (QString(".^$[]*+?").find(ch) != -1)
243 { 242 {
244 info += '\\'; 243 info += '\\';
245 } 244 }
246 info += ch; 245 info += ch;
247 } 246 }
248#else 247#else
249 QString info = QRegExp::escape(_info); 248 QString info = QRegExp::escape(_info);
250#endif 249#endif
251 qDebug("Adjusted searchstring:%s", (const char*)info); 250 qDebug("Adjusted searchstring:%s", (const char*)info);
252 QString sname("<[Aa][^>]*[ \t]+[Nn][Aa][Mm][Ee][ \t]*=[ \t]*\"?"); 251 QString sname("<[Aa][^>]*[ \t]+[Nn][Aa][Mm][Ee][ \t]*=[ \t]*\"?");
253 sname += info + "\"?[ \t>]"; 252 sname += info + "\"?[ \t>]";
254 QString sid("<[A-Za-z][^>]*[ \t]+[Ii][Dd][ \t]*=[ \t]*\"?"); 253 QString sid("<[A-Za-z][^>]*[ \t]+[Ii][Dd][ \t]*=[ \t]*\"?");
255 sid += info+"\"?[ \t>]"; 254 sid += info+"\"?[ \t>]";
256#ifdef USEQPE 255#ifdef USEQPE
257 QRegExp name(sname); 256 QRegExp name(sname);
258 QRegExp id(sid); 257 QRegExp id(sid);
259#else 258#else
260 QRegExp name(sname+"|"+sid); 259 QRegExp name(sname+"|"+sid);
261#endif 260#endif
262 bool ret = true; 261 bool ret = true;
263 locate(0); 262 locate(0);
264 unsigned long pos = 0; 263 unsigned long pos = 0;
265 unsigned long startpos = 0; 264 unsigned long startpos = 0;
266 int offset; 265 int offset;
267 CBuffer test; 266 CBuffer test;
268 qDebug("striphtml::findanchor"); 267 qDebug("striphtml::findanchor");
269 // dlg.show(); 268 // dlg.show();
270 if (getpara(test, pos) >= 0) 269 if (getpara(test, pos) >= 0)
271 { 270 {
272 while (1) 271 while (1)
273 { 272 {
274 // qApp->processEvents(); 273 // qApp->processEvents();
275 if ((offset = name.match(toQString(test.data()))) != -1) break; 274 if ((offset = name.match(toQString(test.data()))) != -1) break;
276#ifdef USEQPE 275#ifdef USEQPE
277 if ((offset = id.match(toQString(test.data()))) != -1) break; 276 if ((offset = id.match(toQString(test.data()))) != -1) break;
278#endif 277#endif
279 if (getpara(test, pos) < 0) 278 if (getpara(test, pos) < 0)
280 { 279 {
281 locate(startpos); 280 locate(startpos);
282 qDebug("Not found"); 281 qDebug("Not found");
283 return false; 282 return false;
284 } 283 }
285 } 284 }
286 locate(pos); 285 locate(pos);
287 qDebug("Found"); 286 qDebug("Found");
288 ret = true; 287 ret = true;
289 } 288 }
290 else 289 else
291 { 290 {
292 locate(startpos); 291 locate(startpos);
293 qDebug("Not found"); 292 qDebug("Not found");
294 ret = false; 293 ret = false;
295 } 294 }
296 return ret; 295 return ret;
297} 296}
298 297
299striphtml::striphtml(const QString& _s) : entmap(NULL), isPre(false), currentid(0), lastch(0), currentfile(_s), indent(0), forcecentre(false), m_inblock(false), m_bchm(false), ignorespace(false) 298striphtml::striphtml(const QString& _s) : entmap(NULL), isPre(false), currentid(0), lastch(0), currentfile(_s), indent(0), forcecentre(false), m_inblock(false), m_bchm(false), ignorespace(false)
300{ 299{
301 href2filepos = new QMap<QString, unsigned long>; 300 href2filepos = new QMap<QString, unsigned long>;
302 id2href = new QMap<unsigned long, QString>; 301 id2href = new QMap<unsigned long, QString>;
303} 302}
304 303
305striphtml::~striphtml() 304striphtml::~striphtml()
306{ 305{
307 if (entmap != NULL) delete entmap; 306 if (entmap != NULL) delete entmap;
308 delete href2filepos; 307 delete href2filepos;
309 delete id2href; 308 delete id2href;
310} 309}
311 310
312void striphtml::initentmap() 311void striphtml::initentmap()
313{ 312{
314 entmap = new QMap<QString, tchar>; 313 entmap = new QMap<QString, tchar>;
315 QString fname(QTReaderUtil::getPluginPath("data")); 314 QString fname(QTReaderUtil::getPluginPath("data"));
316 QFileInfo fi; 315 QFileInfo fi;
317 fi.setFile(fname, "HTMLentities"); 316 fi.setFile(fname, "HTMLentities");
318 if (fi.exists()) 317 if (fi.exists())
319 { 318 {
320 fname = fi.absFilePath(); 319 fname = fi.absFilePath();
321 320
322 QFile fl(fname); 321 QFile fl(fname);
323 if (fl.open(IO_ReadOnly)) 322 if (fl.open(IO_ReadOnly))
324 { 323 {
325 QTextStream t(&fl); 324 QTextStream t(&fl);
326 QString key, value; 325 QString key, value;
327 while (!t.eof()) 326 while (!t.eof())
328 { 327 {
329 QString data = t.readLine(); 328 QString data = t.readLine();
330 int colon = data.find(':'); 329 int colon = data.find(':');
331 if (colon > 0) 330 if (colon > 0)
332 { 331 {
333 QString key = data.left(colon); 332 QString key = data.left(colon);
334 QString value = data.right(data.length()-colon-1); 333 QString value = data.right(data.length()-colon-1);
335 bool ok; 334 bool ok;
336 int ret = value.toInt(&ok); 335 int ret = value.toInt(&ok);
337 if (ok) 336 if (ok)
338 { 337 {
339 (*entmap)[key] = ret; 338 (*entmap)[key] = ret;
340 } 339 }
341 } 340 }
342 } 341 }
343 fl.close(); 342 fl.close();
344 } 343 }
345 } 344 }
346} 345}
347 346
348unsigned short striphtml::skip_ws() 347unsigned short striphtml::skip_ws()
349{ 348{
350 tchar ch; 349 tchar ch;
351 CStyle sty; 350 CStyle sty;
352 unsigned long dummy; 351 unsigned long dummy;
353 do 352 do
354 { 353 {
355 mygetch(ch, sty, dummy); 354 mygetch(ch, sty, dummy);
356 } 355 }
357 while (ch < 33 && ch != UEOF); 356 while (ch < 33 && ch != UEOF);
358 return ch; 357 return ch;
359} 358}
360 359
361unsigned short striphtml::skip_ws_end() 360unsigned short striphtml::skip_ws_end()
362{ 361{
363 unsigned long dummy; 362 unsigned long dummy;
364 return skip_ws_end(dummy); 363 return skip_ws_end(dummy);
365} 364}
366 365
367unsigned short striphtml::skip_ws_end(unsigned long& pos) 366unsigned short striphtml::skip_ws_end(unsigned long& pos)
368{ 367{
369 tchar ch; 368 tchar ch;
370 CStyle sty; 369 CStyle sty;
371 do 370 do
372 { 371 {
373 mygetch(ch, sty, pos); 372 mygetch(ch, sty, pos);
374 } 373 }
375 while (ch != '>' && ch != UEOF); 374 while (ch != '>' && ch != UEOF);
376 return ch; 375 return ch;
377} 376}
378 377
379QString striphtml::getname(tchar& ch, const QString& nd) 378QString striphtml::getname(tchar& ch, const QString& nd)
380{ 379{
381 QString nm = ""; 380 QString nm = "";
382 // nm += ch; 381 // nm += ch;
383 CStyle sty; 382 CStyle sty;
384 unsigned long dummy; 383 unsigned long dummy;
385 while (1) 384 while (1)
386 { 385 {
387 // if ( QChar(ch).isLetterOrNumber() ) 386 // if ( QChar(ch).isLetterOrNumber() )
388 if (ch != UEOF && nd.find(ch, 0, false) == -1 && nm.length() < 2048) 387 if (ch != UEOF && nd.find(ch, 0, false) == -1 && nm.length() < 2048)
389 { 388 {
390 nm += ch; 389 nm += ch;
391 } 390 }
392 else 391 else
393 { 392 {
394 break; 393 break;
395 } 394 }
396 mygetch(ch, sty, dummy); 395 mygetch(ch, sty, dummy);
397 } 396 }
398 return nm; 397 return nm;
399} 398}
400 399
401QString striphtml::getattr(tchar& ch) 400QString striphtml::getattr(tchar& ch)
402{ 401{
403 QString ref; 402 QString ref;
404 CStyle sty; 403 CStyle sty;
405 unsigned long pos; 404 unsigned long pos;
406 if (ch == ' ') ch = skip_ws(); 405 if (ch == ' ') ch = skip_ws();
407 if (ch == '=') 406 if (ch == '=')
408 { 407 {
409 ch = skip_ws(); 408 ch = skip_ws();
410 if (ch == '"') 409 if (ch == '"')
411 { 410 {
412 mygetch(ch, sty, pos); 411 mygetch(ch, sty, pos);
413 ref = getname(ch, "\""); 412 ref = getname(ch, "\"");
414 ch = skip_ws(); 413 ch = skip_ws();
415 } 414 }
416 else 415 else
417 { 416 {
418 ref = getname(ch, " >"); 417 ref = getname(ch, " >");
419 if (ch == ' ') ch = skip_ws(); 418 if (ch == ' ') ch = skip_ws();
420 } 419 }
421 } 420 }
422 return ref; 421 return ref;
423} 422}
424 423
425linkType striphtml::hyperlink(unsigned int n, unsigned int, QString& w, QString& nm) 424linkType striphtml::hyperlink(unsigned int n, unsigned int, QString& w, QString& nm)
426{ 425{
427#if defined(USEQPE) || defined(_WINDOWS) 426#if defined(USEQPE) || defined(_WINDOWS)
428 QMap<unsigned long, QString>::Iterator hrefit = id2href->find(n); 427 QMap<unsigned long, QString>::Iterator hrefit = id2href->find(n);
429#else 428#else
430 QMap<unsigned long, QString>::iterator hrefit = id2href->find(n); 429 QMap<unsigned long, QString>::iterator hrefit = id2href->find(n);
431#endif 430#endif
432 if (hrefit == id2href->end()) 431 if (hrefit == id2href->end())
433 { 432 {
434 return eNone; 433 return eNone;
435 } 434 }
436 QString href = *hrefit; 435 QString href = *hrefit;
437#if defined(USEQPE) || defined(_WINDOWS) 436#if defined(USEQPE) || defined(_WINDOWS)
438 QMap<QString, unsigned long>::Iterator fpit = href2filepos->find(href); 437 QMap<QString, unsigned long>::Iterator fpit = href2filepos->find(href);
439#else 438#else
440 QMap<QString, unsigned long>::iterator fpit = href2filepos->find(href); 439 QMap<QString, unsigned long>::iterator fpit = href2filepos->find(href);
441#endif 440#endif
442 if (fpit == href2filepos->end()) 441 if (fpit == href2filepos->end())
443 { 442 {
444 if (href == "history.back()") 443 if (href == "history.back()")
445 { 444 {
446 QString fc = currentfile; 445 QString fc = currentfile;
447 unsigned long loc; 446 unsigned long loc;
448 htmlmark m(fc, loc); 447 htmlmark m(fc, loc);
449 linkType ret = (m_nav.back(m)) ? eFile : eNone; 448 linkType ret = (m_nav.back(m)) ? eFile : eNone;
450 if (fc == m.filename()) 449 if (fc == m.filename())
451 { 450 {
452 if ((ret & eFile) != 0) 451 if ((ret & eFile) != 0)
453 { 452 {
454 locate(m.posn()); 453 locate(m.posn());
455 return eLink; 454 return eLink;
456 } 455 }
457 } 456 }
458 return eNone; 457 return eNone;
459 } 458 }
460 qDebug("Searching for %s", (const char*)href); 459 qDebug("Searching for %s", (const char*)href);
461 460
462 461
463 QString file, name; 462 QString file, name;
464 463
465 int colon = href.find('#'); 464 int colon = href.find('#');
466 if (colon >= 0) 465 if (colon >= 0)
467 { 466 {
468 file = dehtml(href.left(colon)); 467 file = dehtml(href.left(colon));
469 name = dehtml(href.right(href.length()-colon-1)); 468 name = dehtml(href.right(href.length()-colon-1));
470 } 469 }
471 else 470 else
472 { 471 {
473 file = dehtml(href); 472 file = dehtml(href);
474 } 473 }
475 474
476 qDebug("File:%s", (const char*)file); 475 qDebug("File:%s", (const char*)file);
477 qDebug("Name:%s", (const char*)name); 476 qDebug("Name:%s", (const char*)name);
478 477
479 478
480 if (file.isEmpty()) 479 if (file.isEmpty())
481 { 480 {
482 fpit = href2filepos->find(name); 481 fpit = href2filepos->find(name);
483 if (fpit != href2filepos->end()) 482 if (fpit != href2filepos->end())
484 { 483 {
485 locate(*fpit); 484 locate(*fpit);
486 return eLink; 485 return eLink;
487 } 486 }
488 else 487 else
489 { 488 {
490 // nm = QString("<a[^>]*name[ \t]*=[ \t]*\"") + name + "\""; 489 // nm = QString("<a[^>]*name[ \t]*=[ \t]*\"") + name + "\"";
491 qDebug("Do a search for:%s", (const char*)name); 490 qDebug("Do a search for:%s", (const char*)name);
492 parent->locate(0); 491 parent->locate(0);
493 findanchor(name); 492 findanchor(name);
494 return eLink; 493 return eLink;
495 } 494 }
496 } 495 }
497 else 496 else
498 // if (href.find('#') == -1) 497 // if (href.find('#') == -1)
499 { 498 {
500 if (m_bchm) 499 if (m_bchm)
501 { 500 {
502 w = "/"+file; 501 w = "/"+file;
503 nm = name; 502 nm = name;
504 return eFile; 503 return eFile;
505 } 504 }
506 else 505 else
507 { 506 {
508 QFileInfo f(currentfile); 507 QFileInfo f(currentfile);
509 QFileInfo f1(f.dir(true), file); 508 QFileInfo f1(f.dir(true), file);
510 if (f1.exists()) 509 if (f1.exists())
511 { 510 {
512 w = f1.absFilePath(); 511 w = f1.absFilePath();
513 nm = name; 512 nm = name;
514 } 513 }
515 else 514 else
516 { 515 {
517 w = file; 516 w = file;
518 } 517 }
519 return (f1.exists() ? eFile : eNone); 518 return (f1.exists() ? eFile : eNone);
520 } 519 }
521 } 520 }
522 return eNone; 521 return eNone;
523 } 522 }
524 locate(*fpit); 523 locate(*fpit);
525 // parent->locate((*href2filepos)[(*id2href)[n]]); 524 // parent->locate((*href2filepos)[(*id2href)[n]]);
526 return eLink; 525 return eLink;
527} 526}
528/* 527/*
529unsigned short striphtml::parse_m() 528unsigned short striphtml::parse_m()
530{ 529{
531 tchar ch; 530 tchar ch;
532 CStyle sty; 531 CStyle sty;
533 unsigned long dummy; 532 unsigned long dummy;
534 mygetch(ch, sty, dummy); 533 mygetch(ch, sty, dummy);
535 if (ch == 'm' || ch == 'M') 534 if (ch == 'm' || ch == 'M')
536 { 535 {
537 ch = skip_ws_end(); 536 ch = skip_ws_end();
538 if (ch == '>') 537 if (ch == '>')
539 { 538 {
540 return 0; 539 return 0;
541 } 540 }
542 } 541 }
543 return ch; 542 return ch;
544} 543}
545*/ 544*/
546 545
547void striphtml::mygetch(tchar& ch, CStyle& sty, unsigned long& pos) 546void striphtml::mygetch(tchar& ch, CStyle& sty, unsigned long& pos)
548{ 547{
549 if (!text_q.isEmpty() && !m_inblock) 548 if (!text_q.isEmpty() && !m_inblock)
550 { 549 {
551 ch = text_q[0].unicode(); 550 ch = text_q[0].unicode();
552 text_q = text_q.right(text_q.length()-1); 551 text_q = text_q.right(text_q.length()-1);
553 } 552 }
554 else 553 else
555 { 554 {
556 parent->getch(ch, sty, pos); 555 parent->getch(ch, sty, pos);
557 if (ch == '<') 556 if (ch == '<')
558 { 557 {
559 m_inblock = true; 558 m_inblock = true;
560 } 559 }
561 if (ch == '>') 560 if (ch == '>')
562 { 561 {
563 m_inblock = false; 562 m_inblock = false;
564 } 563 }
565 } 564 }
566 if (ch == 10 && !isPre) 565 if (ch == 10 && !isPre)
567 { 566 {
568 ch = ' '; 567 ch = ' ';
569 } 568 }
570} 569}
571 570
572void striphtml::parse_paragraph(CStyle& currentstyle, tchar& ch, unsigned long pos) 571void striphtml::parse_paragraph(CStyle& currentstyle, tchar& ch, unsigned long pos)
573{ 572{
574/* 573/*
575 int count = 0; 574 int count = 0;
576 for (CList<CStyle>::iterator iter = stylestack.begin(); iter != stylestack.end(); ++iter) 575 for (CList<CStyle>::iterator iter = stylestack.begin(); iter != stylestack.end(); ++iter)
577 { 576 {
578 count++; 577 count++;
579 } 578 }
580 qDebug("Currently have %u styles", count); 579 qDebug("Currently have %u styles", count);
581*/ 580*/
582 if (stylestack.isEmpty()) 581 if (stylestack.isEmpty())
583 { 582 {
584 currentstyle.unset(); 583 currentstyle.unset();
585 } 584 }
586 else 585 else
587 { 586 {
588 qDebug("Using stack style"); 587 qDebug("Using stack style");
589 currentstyle = stylestack.first(); 588 currentstyle = stylestack.first();
590 } 589 }
591 if (forcecentre) 590 if (forcecentre)
592 { 591 {
593 currentstyle.setCentreJustify(); 592 currentstyle.setCentreJustify();
594 } 593 }
595 if (ch == ' ') ch = skip_ws(); 594 if (ch == ' ') ch = skip_ws();
596 while (ch != '>' && ch != UEOF) 595 while (ch != '>' && ch != UEOF)
597 { 596 {
598 QString ent = getname(ch, " =>").lower(); 597 QString ent = getname(ch, " =>").lower();
599 QString attr = getattr(ch).lower(); 598 QString attr = getattr(ch).lower();
600 //qDebug("(Paragraph)Entity:%s Attr:%s", (const char*)ent, (const char*)attr); 599 //qDebug("(Paragraph)Entity:%s Attr:%s", (const char*)ent, (const char*)attr);
601 if (ent == "align") 600 if (ent == "align")
602 { 601 {
603 if (attr == "center") 602 if (attr == "center")
604 { 603 {
605 currentstyle.setCentreJustify(); 604 currentstyle.setCentreJustify();
606 } 605 }
607 if (attr == "right") 606 if (attr == "right")
608 { 607 {
609 currentstyle.setRightJustify(); 608 currentstyle.setRightJustify();
610 } 609 }
611 } 610 }
612 if (ent == "id") 611 if (ent == "id")
613 { 612 {
614 (*href2filepos)[attr] = pos; 613 (*href2filepos)[attr] = pos;
615 } 614 }
616 if (ent == "bgcolor") 615 if (ent == "bgcolor")
617 { 616 {
618 qDebug("Got paper colour:%s", (const char*)attr); 617 qDebug("Got paper colour:%s", (const char*)attr);
619 unsigned char r,g,b; 618 unsigned char r,g,b;
620 parse_color(attr, r, g, b); 619 parse_color(attr, r, g, b);
621 currentstyle.setPaper(r, g, b); 620 currentstyle.setPaper(r, g, b);
622 } 621 }
623 if (ent == "color") 622 if (ent == "color")
624 { 623 {
625 qDebug("Got foreground colour:%s", (const char*)attr); 624 qDebug("Got foreground colour:%s", (const char*)attr);
626 unsigned char r,g,b; 625 unsigned char r,g,b;
627 parse_color(attr, r, g, b); 626 parse_color(attr, r, g, b);
628 currentstyle.setColour(r, g, b); 627 currentstyle.setColour(r, g, b);
629 } 628 }
630 if (ch == ' ') ch = skip_ws(); 629 if (ch == ' ') ch = skip_ws();
631 } 630 }
632 ch = 10; 631 ch = 10;
633} 632}
634 633
635void striphtml::getch(tchar& ch, CStyle& sty, unsigned long& pos) 634void striphtml::getch(tchar& ch, CStyle& sty, unsigned long& pos)
636{ 635{
637 currentstyle.clearPicture(); 636 currentstyle.clearPicture();
638 if (!q.isEmpty()) 637 if (!q.isEmpty())
639 { 638 {
640 ch = q[0].unicode(); 639 ch = q[0].unicode();
641 if (ch == '-') 640 if (ch == '-')
642 { 641 {
643 tchar w = q[1].unicode(); 642 tchar w = q[1].unicode();
644 tchar h = q[2].unicode(); 643 tchar h = q[2].unicode();
645 unsigned char r = q[3].unicode(); 644 unsigned char r = q[3].unicode();
646 unsigned char g = q[4].unicode(); 645 unsigned char g = q[4].unicode();
647 unsigned char b = q[5].unicode(); 646 unsigned char b = q[5].unicode();
648 ch = '#'; 647 ch = '#';
649 //qDebug("html:hrule<%u, %u>", w, h); 648 //qDebug("html:hrule<%u, %u>", w, h);
650 currentstyle.setPicture(false, hRule(w,h,r,g,b)); 649 currentstyle.setPicture(false, hRule(w,h,r,g,b));
651 q = q.right(q.length()-6); 650 q = q.right(q.length()-6);
652 } 651 }
653 else 652 else
654 { 653 {
655 q = q.right(q.length()-1); 654 q = q.right(q.length()-1);
656 } 655 }
657 sty = currentstyle; 656 sty = currentstyle;
658 return; 657 return;
659 } 658 }
660 do 659 do
661 { 660 {
662 unsigned long npos; 661 unsigned long npos;
663 CStyle dummy; 662 CStyle dummy;
664 mygetch(ch, dummy, pos); 663 mygetch(ch, dummy, pos);
665 // if (ch == 10 && !isPre) ch = ' '; 664 // if (ch == 10 && !isPre) ch = ' ';
666 while (ch == '<' && ch != UEOF) 665 while (ch == '<' && ch != UEOF)
667 { 666 {
668 ch = skip_ws(); 667 ch = skip_ws();
669 668
670 QString ent = getname(ch, " >").lower(); 669 QString ent = getname(ch, " >").lower();
671 670
672 // qDebug("Entity:%s", (const char*)ent); 671 // qDebug("Entity:%s", (const char*)ent);
673 672
674 if (ent == "a"/* || ent == "reference"*/) 673 if (ent == "a"/* || ent == "reference"*/)
675 { 674 {
676 if (ch == ' ') ch = skip_ws(); 675 if (ch == ' ') ch = skip_ws();
677 bool fileposfound = false; 676 bool fileposfound = false;
678 bool ishref = false; 677 bool ishref = false;
679 unsigned int filepos = 0; 678 unsigned int filepos = 0;
680 QString ref, name; 679 QString ref, name;
681 while (ch != '>' && ch != UEOF) 680 while (ch != '>' && ch != UEOF)
682 { 681 {
683 QString ent = getname(ch, " =>").lower(); 682 QString ent = getname(ch, " =>").lower();
684 QString attr = getattr(ch); 683 QString attr = getattr(ch);
685 qDebug("<A>Entity:%s Attr:%s", (const char*)ent, (const char*)attr); 684 qDebug("<A>Entity:%s Attr:%s", (const char*)ent, (const char*)attr);
686 if (ent == "name") 685 if (ent == "name")
687 { 686 {
688 name = attr; 687 name = attr;
689 } 688 }
690 if (ent == "onclick") 689 if (ent == "onclick")
691 { 690 {
692 int st = attr.find('\''); 691 int st = attr.find('\'');
693 int nd = attr.findRev('\''); 692 int nd = attr.findRev('\'');
694 ref = attr.mid(st+1, nd-st-1); 693 ref = attr.mid(st+1, nd-st-1);
695 ishref = true; 694 ishref = true;
696 qDebug("Onclick:%s", (const char*)ref); 695 qDebug("Onclick:%s", (const char*)ref);
697 } 696 }
698 if (ent == "href") 697 if (ent == "href")
699 { 698 {
700 ishref = true; 699 ishref = true;
701 ref = attr; 700 ref = attr;
702 } 701 }
703 if (ent == "filepos") 702 if (ent == "filepos")
704 { 703 {
705 filepos = attr.toUInt(&fileposfound); 704 filepos = attr.toUInt(&fileposfound);
706 if (ref.isEmpty()) 705 if (ref.isEmpty())
707 { 706 {
708 ishref = true; 707 ishref = true;
709 ref = attr; 708 ref = attr;
710 } 709 }
711 } 710 }
712 if (ent == "title") 711 if (ent == "title")
713 { 712 {
714 text_q = attr + "</a><p>"; 713 text_q = attr + "</a><p>";
715 } 714 }
716 qDebug("<a %s=%s>", (const char*)ent, (const char*)ref); 715 qDebug("<a %s=%s>", (const char*)ent, (const char*)ref);
717 } 716 }
718 if (ishref) 717 if (ishref)
719 { 718 {
720 currentstyle.setColour(0,0,255); 719 currentstyle.setColour(0,0,255);
721 currentstyle.setLink(true); 720 currentstyle.setLink(true);
722 currentstyle.setData(currentid); 721 currentstyle.setData(currentid);
723 if (!text_q.isEmpty()) 722 if (!text_q.isEmpty())
724 { 723 {
725 currentstyle.setBold(); 724 currentstyle.setBold();
726 currentstyle.setCentreJustify(); 725 currentstyle.setCentreJustify();
727 } 726 }
728 (*id2href)[currentid] = ref; 727 (*id2href)[currentid] = ref;
729 currentid++; 728 currentid++;
730 729
731 730
732 if (fileposfound) 731 if (fileposfound)
733 { 732 {
734 (*href2filepos)[ref] = filepos; 733 (*href2filepos)[ref] = filepos;
735 } 734 }
736 } 735 }
737 if (!name.isEmpty()) 736 if (!name.isEmpty())
738 { 737 {
739 (*href2filepos)[name] = pos; 738 (*href2filepos)[name] = pos;
740 } 739 }
741 } 740 }
742 else if (ent == "p") 741 else if (ent == "p")
743 { 742 {
744 parse_paragraph(currentstyle, ch, pos); 743 parse_paragraph(currentstyle, ch, pos);
745 currentstyle.setExtraSpace(3); 744 currentstyle.setExtraSpace(3);
746 continue; 745 continue;
747 } 746 }
748 else if (ent == "div") 747 else if (ent == "div")
749 { 748 {
750 parse_paragraph(currentstyle, ch, pos); 749 parse_paragraph(currentstyle, ch, pos);
751 stylestack.push_front(currentstyle); 750 stylestack.push_front(currentstyle);
752 //indent = 0; 751 //indent = 0;
753 continue; 752 continue;
754 } 753 }
755 else if (ent == "sup") 754 else if (ent == "sup")
756 { 755 {
757 currentstyle.setVOffset(-1); 756 currentstyle.setVOffset(-1);
758 } 757 }
759 else if (ent == "sup") 758 else if (ent == "sup")
760 { 759 {
761 currentstyle.setVOffset(1); 760 currentstyle.setVOffset(1);
762 } 761 }
763 else if (ent == "/sup" || ent == "/sub") 762 else if (ent == "/sup" || ent == "/sub")
764 { 763 {
765 currentstyle.setVOffset(0); 764 currentstyle.setVOffset(0);
766 } 765 }
767 else if (ent == "span") 766 else if (ent == "span")
768 { 767 {
769 if (ch == ' ') ch = skip_ws(); 768 if (ch == ' ') ch = skip_ws();
770 while (ch != '>' && ch != UEOF) 769 while (ch != '>' && ch != UEOF)
771 { 770 {
772 QString ent = getname(ch, " =>").lower(); 771 QString ent = getname(ch, " =>").lower();
773 QString attr = getattr(ch).lower(); 772 QString attr = getattr(ch).lower();
774 if (ent == "bgcolor") 773 if (ent == "bgcolor")
775 { 774 {
776 qDebug("Got background colour:%s", (const char*)attr); 775 qDebug("Got background colour:%s", (const char*)attr);
777 unsigned char r,g,b; 776 unsigned char r,g,b;
778 parse_color(attr, r, g, b); 777 parse_color(attr, r, g, b);
779 currentstyle.setBackground(r, g, b); 778 currentstyle.setBackground(r, g, b);
780 } 779 }
781 if (ent == "color") 780 if (ent == "color")
782 { 781 {
783 qDebug("Got foreground colour:%s", (const char*)attr); 782 qDebug("Got foreground colour:%s", (const char*)attr);
784 unsigned char r,g,b; 783 unsigned char r,g,b;
785 parse_color(attr, r, g, b); 784 parse_color(attr, r, g, b);
786 currentstyle.setColour(r, g, b); 785 currentstyle.setColour(r, g, b);
787 } 786 }
788 } 787 }
789 stylestack.push_front(currentstyle); 788 stylestack.push_front(currentstyle);
790 } 789 }
791 else if (ent == "/span") 790 else if (ent == "/span")
792 { 791 {
793 if (ch != '>') ch = skip_ws_end(); 792 if (ch != '>') ch = skip_ws_end();
794 currentstyle.setBackground(255, 255, 255); 793 currentstyle.setBackground(255, 255, 255);
795 currentstyle.setColour(0, 0, 0); 794 currentstyle.setColour(0, 0, 0);
796 if (!stylestack.isEmpty()) 795 if (!stylestack.isEmpty())
797 { 796 {
798 stylestack.pop(); 797 stylestack.pop();
799 } 798 }
800 } 799 }
801 else if (ent == "pre") 800 else if (ent == "pre")
802 { 801 {
803 isPre = true; 802 isPre = true;
804 currentstyle.setMono(); 803 currentstyle.setMono();
805 } 804 }
806 else if (ent == "tt") 805 else if (ent == "tt")
807 { 806 {
808 currentstyle.setMono(); 807 currentstyle.setMono();
809 } 808 }
810 else if (ent == "b" || ent == "strong") 809 else if (ent == "b" || ent == "strong")
811 { 810 {
812 currentstyle.setBold(); 811 currentstyle.setBold();
813 } 812 }
814 else if (ent == "u") 813 else if (ent == "u")
815 { 814 {
816 currentstyle.setUnderline(); 815 currentstyle.setUnderline();
817 } 816 }
818 else if (ent == "/u") 817 else if (ent == "/u")
819 { 818 {
820 currentstyle.unsetUnderline(); 819 currentstyle.unsetUnderline();
821 } 820 }
822 else if (ent == "blockquote") 821 else if (ent == "blockquote")
823 { 822 {
824 if (ch != '>') ch = skip_ws_end(); 823 if (ch != '>') ch = skip_ws_end();
825 ch = 10; 824 ch = 10;
826 currentstyle.setLeftMargin(30); 825 currentstyle.setLeftMargin(30);
827 currentstyle.setRightMargin(30); 826 currentstyle.setRightMargin(30);
828 continue; 827 continue;
829 } 828 }
830 else if (ent == "br" || ent == "br/") 829 else if (ent == "br" || ent == "br/")
831 { 830 {
832 if (ch != '>') ch = skip_ws_end(); 831 if (ch != '>') ch = skip_ws_end();
833 ch = 10; 832 ch = 10;
834 continue; 833 continue;
835 } 834 }
836 else if (ent == "mbp:pagebreak") 835 else if (ent == "mbp:pagebreak")
837 { 836 {
838 /* 837 /*
839 if (ch != '>') ch = skip_ws_end(pos); 838 if (ch != '>') ch = skip_ws_end(pos);
840 q += 10; 839 q += 10;
841 q += QChar(UEOF); 840 q += QChar(UEOF);
842 ch = 10; 841 ch = 10;
843 continue; 842 continue;
844 */ 843 */
845 ch = 6; 844 ch = 6;
846 // currentstyle.setTop(); 845 // currentstyle.setTop();
847 continue; 846 continue;
848 } 847 }
849 else if (ent == "center") 848 else if (ent == "center")
850 { 849 {
851 //forcecentre = true; 850 //forcecentre = true;
852 qDebug("setting centre"); 851 qDebug("setting centre");
853 currentstyle.setCentreJustify(); 852 currentstyle.setCentreJustify();
854 ch = 10; 853 ch = 10;
855 continue; 854 continue;
856 } 855 }
857 else if (ent == "/center") 856 else if (ent == "/center")
858 { 857 {
859 qDebug("unsetting centre"); 858 qDebug("unsetting centre");
860 forcecentre = false; 859 forcecentre = false;
861 } 860 }
862 else if (ent == "li") 861 else if (ent == "li")
863 { 862 {
864 if (ch != '>') ch = skip_ws_end(); 863 if (ch != '>') ch = skip_ws_end();
865 ch = 10; 864 ch = 10;
866 if (m_listtype[indent % m_cmaxdepth] == 1) 865 if (m_listtype[indent % m_cmaxdepth] == 1)
867 { 866 {
868 q.setNum(m_ctr[indent % m_cmaxdepth]++); 867 q.setNum(m_ctr[indent % m_cmaxdepth]++);
869 } 868 }
870 else 869 else
871 { 870 {
872 q += QChar(8226); 871 q += QChar(8226);
873 } 872 }
874 q += ' '; 873 q += ' ';
875 currentstyle.setLeftMargin(6*indent); 874 currentstyle.setLeftMargin(6*indent);
876 qDebug("Setting indent:%d", indent); 875 qDebug("Setting indent:%d", indent);
877 continue; 876 continue;
878 } 877 }
879 else if (ent == "ul") 878 else if (ent == "ul")
880 { 879 {
881 indent++; 880 indent++;
882 m_listtype[indent % m_cmaxdepth] = 0; 881 m_listtype[indent % m_cmaxdepth] = 0;
883 } 882 }
884 else if (ent == "/ul") 883 else if (ent == "/ul")
885 { 884 {
886 indent--; 885 indent--;
887 } 886 }
888 else if (ent == "ol") 887 else if (ent == "ol")
889 { 888 {
890 indent++; 889 indent++;
891 m_listtype[indent % m_cmaxdepth] = 1; 890 m_listtype[indent % m_cmaxdepth] = 1;
892 m_ctr[indent % m_cmaxdepth] = 1; 891 m_ctr[indent % m_cmaxdepth] = 1;
893 } 892 }
894 else if (ent == "/ol") 893 else if (ent == "/ol")
895 { 894 {
896 indent--; 895 indent--;
897 } 896 }
898 else if (ent == "i") 897 else if (ent == "i")
899 { 898 {
900 currentstyle.setItalic(); 899 currentstyle.setItalic();
901 } 900 }
902 else if (ent == "em") 901 else if (ent == "em")
903 { 902 {
904 currentstyle.setItalic(); 903 currentstyle.setItalic();
905 } 904 }
906 else if (ent == "small") 905 else if (ent == "small")
907 { 906 {
908 currentstyle.setFontSize(-2); 907 currentstyle.setFontSize(-2);
909 } 908 }
910 else if (ent == "/small") 909 else if (ent == "/small")
911 { 910 {
912 currentstyle.setFontSize(0); 911 currentstyle.setFontSize(0);
913 } 912 }
914 else if (ent == "big") 913 else if (ent == "big")
915 { 914 {
916 currentstyle.setFontSize(2); 915 currentstyle.setFontSize(2);
917 } 916 }
918 else if (ent == "/big") 917 else if (ent == "/big")
919 { 918 {
920 currentstyle.setFontSize(0); 919 currentstyle.setFontSize(0);
921 } 920 }
922 else if (ent[0] == 'h' && ent.length() == 2 && QString("123456789").find(ent[1]) != -1) 921 else if (ent[0] == 'h' && ent.length() == 2 && QString("123456789").find(ent[1]) != -1)
923 { 922 {
924 indent = 0; 923 indent = 0;
925 if (ent[1] == '1') 924 if (ent[1] == '1')
926 { 925 {
927 parse_paragraph(currentstyle, ch, pos); 926 parse_paragraph(currentstyle, ch, pos);
928 currentstyle.setFontSize(3); 927 currentstyle.setFontSize(3);
929 currentstyle.setExtraSpace(8); 928 currentstyle.setExtraSpace(8);
930 currentstyle.setBold(); 929 currentstyle.setBold();
931 // currentstyle.setExtraSpace(10); 930 // currentstyle.setExtraSpace(10);
932 continue; 931 continue;
933 } 932 }
934 else if (ent[1] == '2') 933 else if (ent[1] == '2')
935 { 934 {
936 parse_paragraph(currentstyle, ch, pos); 935 parse_paragraph(currentstyle, ch, pos);
937 currentstyle.setFontSize(2); 936 currentstyle.setFontSize(2);
938 currentstyle.setExtraSpace(6); 937 currentstyle.setExtraSpace(6);
939 currentstyle.setBold(); 938 currentstyle.setBold();
940 // currentstyle.setExtraSpace(10); 939 // currentstyle.setExtraSpace(10);
941 continue; 940 continue;
942 } 941 }
943 else if (ent[1] == '3') 942 else if (ent[1] == '3')
944 { 943 {
945 parse_paragraph(currentstyle, ch, pos); 944 parse_paragraph(currentstyle, ch, pos);
946 currentstyle.setFontSize(1); 945 currentstyle.setFontSize(1);
947 currentstyle.setExtraSpace(4); 946 currentstyle.setExtraSpace(4);
948 currentstyle.setBold(); 947 currentstyle.setBold();
949 // currentstyle.setExtraSpace(10); 948 // currentstyle.setExtraSpace(10);
950 continue; 949 continue;
951 } 950 }
952 else 951 else
953 { 952 {
954 parse_paragraph(currentstyle, ch, pos); 953 parse_paragraph(currentstyle, ch, pos);
955 currentstyle.setExtraSpace(4); 954 currentstyle.setExtraSpace(4);
956 currentstyle.setBold(); 955 currentstyle.setBold();
957 // currentstyle.setExtraSpace(10); 956 // currentstyle.setExtraSpace(10);
958 continue; 957 continue;
959 } 958 }
960 } 959 }
961 960
962 961
963 else if (ent == "/a") 962 else if (ent == "/a")
964 { 963 {
965 currentstyle.setColour(0,0,0); 964 currentstyle.setColour(0,0,0);
966 currentstyle.setLink(false); 965 currentstyle.setLink(false);
967 } 966 }
968 else if (ent == "/pre") 967 else if (ent == "/pre")
969 { 968 {
970 currentstyle.unsetMono(); 969 currentstyle.unsetMono();
971 isPre = false; 970 isPre = false;
972 } 971 }
973 else if (ent == "/tt") 972 else if (ent == "/tt")
974 { 973 {
975 currentstyle.unsetMono(); 974 currentstyle.unsetMono();
976 } 975 }
977 else if (ent == "/b" || ent == "/strong") 976 else if (ent == "/b" || ent == "/strong")
978 { 977 {
979 currentstyle.unsetBold(); 978 currentstyle.unsetBold();
980 } 979 }
981 else if (ent == "/i") 980 else if (ent == "/i")
982 { 981 {
983 currentstyle.unsetItalic(); 982 currentstyle.unsetItalic();
984 } 983 }
985 else if (ent == "/em") 984 else if (ent == "/em")
986 { 985 {
987 currentstyle.unsetItalic(); 986 currentstyle.unsetItalic();
988 } 987 }
989 else if (ent == "/div") 988 else if (ent == "/div")
990 { 989 {
991 currentstyle.unset(); 990 currentstyle.unset();
992 if (ch != '>') ch = skip_ws_end(); 991 if (ch != '>') ch = skip_ws_end();
993 ch = 10; 992 ch = 10;
994 if (!stylestack.isEmpty()) 993 if (!stylestack.isEmpty())
995 { 994 {
996 stylestack.pop(); 995 stylestack.pop();
997 } 996 }
998 continue; 997 continue;
999 } 998 }
1000 else if (ent == "tr") 999 else if (ent == "tr")
1001 { 1000 {
1002 if (ch != '>') ch = skip_ws_end(); 1001 if (ch != '>') ch = skip_ws_end();
1003 ch = 10; 1002 ch = 10;
1004 q += '-'; 1003 q += '-';
1005 q += QChar(parent->getwidth()); 1004 q += QChar(parent->getwidth());
1006 q += 2; 1005 q += 2;
1007 q += '\0'; 1006 q += '\0';
1008 q += '\0'; 1007 q += '\0';
1009 q += '\0'; 1008 q += '\0';
1010 continue; 1009 continue;
1011 } 1010 }
1012 else if (ent == "td") 1011 else if (ent == "td")
1013 { 1012 {
1014 if (ch != '>') ch = skip_ws_end(); 1013 if (ch != '>') ch = skip_ws_end();
1015 ignorespace = false; 1014 ignorespace = false;
1016 } 1015 }
1017 else if (ent == "/td") 1016 else if (ent == "/td")
1018 { 1017 {
1019 ignorespace = true; 1018 ignorespace = true;
1020 // parse_paragraph(currentstyle, ch, pos); 1019 // parse_paragraph(currentstyle, ch, pos);
1021 //stylestack.push_front(currentstyle); 1020 //stylestack.push_front(currentstyle);
1022 if (ch != '>') ch = skip_ws_end(); 1021 if (ch != '>') ch = skip_ws_end();
1023 // ch = '|'; 1022 // ch = '|';
1024 //continue; 1023 //continue;
1025 ch = 10; 1024 ch = 10;
1026 q += '-'; 1025 q += '-';
1027 q += QChar(parent->getwidth()); 1026 q += QChar(parent->getwidth());
1028 q += 1; 1027 q += 1;
1029 q += '\0'; 1028 q += '\0';
1030 q += '\0'; 1029 q += '\0';
1031 q += '\0'; 1030 q += '\0';
1032 continue; 1031 continue;
1033 } 1032 }
1034 /* 1033 /*
1035 else if (ent == "/td") 1034 else if (ent == "/td")
1036 { 1035 {
1037 currentstyle.unset(); 1036 currentstyle.unset();
1038 if (ch != '>') ch = skip_ws_end(); 1037 if (ch != '>') ch = skip_ws_end();
1039 if (!stylestack.isEmpty()) 1038 if (!stylestack.isEmpty())
1040 { 1039 {
1041 stylestack.pop(); 1040 stylestack.pop();
1042 } 1041 }
1043 // ch = 10; 1042 // ch = 10;
1044 continue; 1043 continue;
1045 } 1044 }
1046 */ 1045 */
1047 else if (ent[0] == '/' && ent.length() == 3 && ent[1] == 'h' && QString("123456789").find(ent[2]) != -1) 1046 else if (ent[0] == '/' && ent.length() == 3 && ent[1] == 'h' && QString("123456789").find(ent[2]) != -1)
1048 { 1047 {
1049 currentstyle.unset(); 1048 currentstyle.unset();
1050 if (ch != '>') ch = skip_ws_end(); 1049 if (ch != '>') ch = skip_ws_end();
1051 ch = 10; 1050 ch = 10;
1052 continue; 1051 continue;
1053 } 1052 }
1054 1053
1055 1054
1056 1055
1057 else if (ent == "table" || ent == "/table") 1056 else if (ent == "table" || ent == "/table")
1058 { 1057 {
1059 currentstyle.unset(); 1058 currentstyle.unset();
1060 ignorespace = (ent == "table"); 1059 ignorespace = (ent == "table");
1061 if (ch == ' ') ch = skip_ws(); 1060 if (ch == ' ') ch = skip_ws();
1062 while (ch != '>' && ch != UEOF) 1061 while (ch != '>' && ch != UEOF)
1063 { 1062 {
1064 QString ent = getname(ch, " =>").lower(); 1063 QString ent = getname(ch, " =>").lower();
1065 QString attr = getattr(ch); 1064 QString attr = getattr(ch);
1066 qDebug("<table>Entity:%s Attr:%s", (const char*)ent, (const char*)attr); 1065 qDebug("<table>Entity:%s Attr:%s", (const char*)ent, (const char*)attr);
1067 } 1066 }
1068 if (ch != '>') ch = skip_ws_end(); 1067 if (ch != '>') ch = skip_ws_end();
1069 1068
1070 ch = 10; 1069 ch = 10;
1071 q += '-'; 1070 q += '-';
1072 q += QChar(parent->getwidth()); 1071 q += QChar(parent->getwidth());
1073 q += 2; 1072 q += 2;
1074 q += '\0'; 1073 q += '\0';
1075 q += '\0'; 1074 q += '\0';
1076 q += '\0'; 1075 q += '\0';
1077 continue; 1076 continue;
1078 } 1077 }
1079 else if (ent == "hr") 1078 else if (ent == "hr")
1080 { 1079 {
1081 if (ch == ' ') ch = skip_ws(); 1080 if (ch == ' ') ch = skip_ws();
1082 // if (stylestack.isEmpty()) 1081 // if (stylestack.isEmpty())
1083 // { 1082 // {
1084 currentstyle.unset(); 1083 currentstyle.unset();
1085 // } 1084 // }
1086 /* 1085 /*
1087 else 1086 else
1088 { 1087 {
1089 qDebug("Using stack style"); 1088 qDebug("Using stack style");
1090 currentstyle = stylestack.first(); 1089 currentstyle = stylestack.first();
1091 } 1090 }
1092 */ 1091 */
1093 unsigned char red = 0, green = 0, blue = 0; 1092 unsigned char red = 0, green = 0, blue = 0;
1094 while (ch != '>' && ch != UEOF) 1093 while (ch != '>' && ch != UEOF)
1095 { 1094 {
1096 QString ent = getname(ch, " =>").lower(); 1095 QString ent = getname(ch, " =>").lower();
1097 QString attr = getattr(ch); 1096 QString attr = getattr(ch);
1098 if (ent == "color") 1097 if (ent == "color")
1099 { 1098 {
1100 parse_color(attr, red, green, blue); 1099 parse_color(attr, red, green, blue);
1101 } 1100 }
1102 qDebug("<hr>Entity:%s Attr:%s", (const char*)ent, (const char*)attr); 1101 qDebug("<hr>Entity:%s Attr:%s", (const char*)ent, (const char*)attr);
1103 } 1102 }
1104 if (ch != '>') ch = skip_ws_end(); 1103 if (ch != '>') ch = skip_ws_end();
1105 ch = 10; 1104 ch = 10;
1106 q += '-'; 1105 q += '-';
1107 q += QChar(parent->getwidth()); 1106 q += QChar(parent->getwidth());
1108 q += 3; 1107 q += 3;
1109 q += red; 1108 q += red;
1110 q += green; 1109 q += green;
1111 q += blue; 1110 q += blue;
1112 continue; 1111 continue;
1113 } 1112 }
1114 1113
1115 1114
1116 1115
1117 else if (ent == "img") 1116 else if (ent == "img")
1118 { 1117 {
1119 if (ch == ' ') ch = skip_ws(); 1118 if (ch == ' ') ch = skip_ws();
1120 while (ch != '>' && ch != UEOF) 1119 while (ch != '>' && ch != UEOF)
1121 { 1120 {
1122 QString ent = getname(ch, " =>").lower(); 1121 QString ent = getname(ch, " =>").lower();
1123 QString attr = getattr(ch); 1122 QString attr = getattr(ch);
1124 qDebug("<img>Entity:%s Attr:%s", (const char*)ent, (const char*)attr); 1123 qDebug("<img>Entity:%s Attr:%s", (const char*)ent, (const char*)attr);
1125 if (ent == "src") 1124 if (ent == "src")
1126 { 1125 {
1127 if (m_bchm) 1126 if (m_bchm)
1128 { 1127 {
1129 QImage* img = parent->getPicture(attr); 1128 QImage* img = parent->getPicture(attr);
1130 if (img != NULL) 1129 if (img != NULL)
1131 { 1130 {
1132 currentstyle.setPicture(true, img); 1131 currentstyle.setPicture(true, img);
1133 } 1132 }
1134 } 1133 }
1135 else 1134 else
1136 { 1135 {
1137 QFileInfo f(currentfile); 1136 QFileInfo f(currentfile);
1138 QFileInfo f1(f.dir(true), attr); 1137 QFileInfo f1(f.dir(true), attr);
1139 QPixmap pm; 1138 QPixmap pm;
1140 if (pm.load(f1.absFilePath())) 1139 if (pm.load(f1.absFilePath()))
1141 { 1140 {
1142 QImage* img = new QImage(pm.convertToImage()); 1141 QImage* img = new QImage(pm.convertToImage());
1143 currentstyle.setPicture(true, img); 1142 currentstyle.setPicture(true, img);
1144 } 1143 }
1145 } 1144 }
1146 } 1145 }
1147 if (ent == "recindex") 1146 if (ent == "recindex")
1148 { 1147 {
1149 bool ok; 1148 bool ok;
1150 unsigned int picindex = attr.toUInt(&ok); 1149 unsigned int picindex = attr.toUInt(&ok);
1151 qDebug("Looking for image at %u", picindex); 1150 qDebug("Looking for image at %u", picindex);
1152 QImage* img = parent->getPicture(picindex); 1151 QImage* img = parent->getPicture(picindex);
1153 if (img != NULL) 1152 if (img != NULL)
1154 { 1153 {
1155 currentstyle.setPicture(true, img); 1154 currentstyle.setPicture(true, img);
1156 } 1155 }
1157 else 1156 else
1158 { 1157 {
1159 qDebug("No image found"); 1158 qDebug("No image found");
1160 } 1159 }
1161 } 1160 }
1162 } 1161 }
1163 if (ch != '>') ch = skip_ws_end(); 1162 if (ch != '>') ch = skip_ws_end();
1164 ch = '#'; 1163 ch = '#';
1165 break; 1164 break;
1166 } 1165 }
1167 else if (ent.left(2) == "dc") 1166 else if (ent.left(2) == "dc")
1168 { 1167 {
1169 QString nd("/"); 1168 QString nd("/");
1170 skipblock(nd+ent); 1169 skipblock(nd+ent);
1171 } 1170 }
1172 else if (ent == "metadata") 1171 else if (ent == "metadata")
1173 { 1172 {
1174 // skipblock("/metadata"); 1173 // skipblock("/metadata");
1175 } 1174 }
1176 /* 1175 /*
1177 else if (ent == "metadata") 1176 else if (ent == "metadata")
1178 { 1177 {
1179 currentstyle.setFontSize(-2); 1178 currentstyle.setFontSize(-2);
1180 } 1179 }
1181 else if (ent == "/metadata") 1180 else if (ent == "/metadata")
1182 { 1181 {
1183 currentstyle.unset(); 1182 currentstyle.unset();
1184 ch = 10; 1183 ch = 10;
1185 continue; 1184 continue;
1186 } 1185 }
1187 */ 1186 */
1188 else 1187 else
1189 { 1188 {
1190 if (ent[0] != '/') 1189 if (ent[0] != '/')
1191 qDebug("Not handling:%s", (const char*)ent); 1190 qDebug("Not handling:%s", (const char*)ent);
1192 } 1191 }
1193 1192
1194 if (ch != '>') ch = skip_ws_end(); 1193 if (ch != '>') ch = skip_ws_end();
1195 mygetch(ch, dummy, npos); 1194 mygetch(ch, dummy, npos);
1196 } 1195 }
1197 if (ch == '&') 1196 if (ch == '&')
1198 { 1197 {
1199 mygetch(ch, dummy, npos); 1198 mygetch(ch, dummy, npos);
1200 if (ch == '#') 1199 if (ch == '#')
1201 { 1200 {
1202 int id = 0; 1201 int id = 0;
1203 mygetch(ch, dummy, npos); 1202 mygetch(ch, dummy, npos);
1204 while (ch != ';' && ch != UEOF) 1203 while (ch != ';' && ch != UEOF)
1205 { 1204 {
1206 id = 10*id+ch-'0'; 1205 id = 10*id+ch-'0';
1207 mygetch(ch, dummy, npos); 1206 mygetch(ch, dummy, npos);
1208 } 1207 }
1209 ch = id; 1208 ch = id;
1210 } 1209 }
1211 else 1210 else
1212 { 1211 {
1213 QString en; 1212 QString en;
1214 en += ch; 1213 en += ch;
1215 mygetch(ch, dummy, npos); 1214 mygetch(ch, dummy, npos);
1216 while (ch != ';' && ch != UEOF) 1215 while (ch != ';' && ch != UEOF)
1217 { 1216 {
1218 en += ch; 1217 en += ch;
1219 mygetch(ch, dummy, npos); 1218 mygetch(ch, dummy, npos);
1220 } 1219 }
1221 if (entmap == NULL) initentmap(); 1220 if (entmap == NULL) initentmap();
1222#if defined(USEQPE) || defined(_WINDOWS) 1221#if defined(USEQPE) || defined(_WINDOWS)
1223 QMap<QString, tchar>::Iterator it = entmap->find(en); 1222 QMap<QString, tchar>::Iterator it = entmap->find(en);
1224#else 1223#else
1225 QMap<QString, tchar>::iterator it = entmap->find(en); 1224 QMap<QString, tchar>::iterator it = entmap->find(en);
1226#endif 1225#endif
1227 if (it != entmap->end()) 1226 if (it != entmap->end())
1228 { 1227 {
1229 ch = *it; 1228 ch = *it;
1230 } 1229 }
1231 else 1230 else
1232 { 1231 {
1233 ch = '.'; 1232 ch = '.';
1234 } 1233 }
1235 } 1234 }
1236 } 1235 }
1237 // sty = (dummy == ucFontBase) ? currentstyle : dummy; 1236 // sty = (dummy == ucFontBase) ? currentstyle : dummy;
1238 sty = currentstyle; 1237 sty = currentstyle;
1239 } 1238 }
1240 while (!isPre && (lastch == ' ' || lastch == 10 || ignorespace) && ch == ' '); 1239 while (!isPre && (lastch == ' ' || lastch == 10 || ignorespace) && ch == ' ');
1241 // lastch = ch; 1240 // lastch = ch;
1242 lastch = ch; 1241 lastch = ch;
1243 return; 1242 return;
1244} 1243}
1245 1244
1246extern "C" 1245extern "C"
1247{ 1246{
1248 CFilter* newfilter(const QString& s) { return new striphtml(s); } 1247 CFilter* newfilter(const QString& s) { return new striphtml(s); }
1249} 1248}
diff --git a/noncore/apps/opie-reader/useqpe.h b/noncore/apps/opie-reader/useqpe.h
deleted file mode 100644
index e69de29..0000000
--- a/noncore/apps/opie-reader/useqpe.h
+++ b/dev/null
diff --git a/noncore/apps/opie-reader/ztxt.cpp b/noncore/apps/opie-reader/ztxt.cpp
index 79c5fa4..35db05e 100644
--- a/noncore/apps/opie-reader/ztxt.cpp
+++ b/noncore/apps/opie-reader/ztxt.cpp
@@ -1,174 +1,173 @@
1#include <stdio.h> 1#include <stdio.h>
2#include <string.h> 2#include <string.h>
3#include "ztxt.h" 3#include "ztxt.h"
4#include "my_list.h" 4#include "my_list.h"
5#include "Bkmks.h" 5#include "Bkmks.h"
6#include "static.h"
7 6
8ztxt::ztxt() : bInit(false), expandedtextbuffer(NULL), compressedtextbuffer(NULL) { /*printf("constructing:%x\n",fin);*/ } 7ztxt::ztxt() : bInit(false), expandedtextbuffer(NULL), compressedtextbuffer(NULL) { /*printf("constructing:%x\n",fin);*/ }
9 8
10 9
11int ztxt::OpenFile(const char *src) 10int ztxt::OpenFile(const char *src)
12{ 11{
13 if (!Cpdb::openpdbfile(src)) 12 if (!Cpdb::openpdbfile(src))
14 { 13 {
15 return -1; 14 return -1;
16 } 15 }
17 16
18//printf("Okay %u\n", 4); 17//printf("Okay %u\n", 4);
19 18
20 if (head.type != ZTXT_ID) return -1; 19 if (head.type != ZTXT_ID) return -1;
21 20
22 gotorecordnumber(0); 21 gotorecordnumber(0);
23 fread(&hdr0, 1, sizeof(hdr0), fin); 22 fread(&hdr0, 1, sizeof(hdr0), fin);
24//printf("Okay %u\n", 5); 23//printf("Okay %u\n", 5);
25 buffersize = ntohl(hdr0.size); 24 buffersize = ntohl(hdr0.size);
26 compressedtextbuffer = new UInt8[buffersize]; 25 compressedtextbuffer = new UInt8[buffersize];
27 expandedtextbuffer = new UInt8[buffersize]; 26 expandedtextbuffer = new UInt8[buffersize];
28//printf("Okay %u\n", 6); 27//printf("Okay %u\n", 6);
29 28
30 home(); 29 home();
31//printf("Okay %u\n", 7); 30//printf("Okay %u\n", 7);
32 31
33// printf("Returning 0\n"); 32// printf("Returning 0\n");
34 33
35 return 0; 34 return 0;
36} 35}
37 36
38int ztxt::getch() 37int ztxt::getch()
39{ 38{
40 if (bufferpos >= buffercontent) 39 if (bufferpos >= buffercontent)
41 { 40 {
42 size_t reclen = recordlength(++bufferrec); 41 size_t reclen = recordlength(++bufferrec);
43 if (reclen == 0) return -1; 42 if (reclen == 0) return -1;
44 gotorecordnumber(bufferrec); 43 gotorecordnumber(bufferrec);
45 fread(compressedtextbuffer, reclen, sizeof(char), fin); 44 fread(compressedtextbuffer, reclen, sizeof(char), fin);
46 45
47 zstream.next_in = compressedtextbuffer; 46 zstream.next_in = compressedtextbuffer;
48 zstream.next_out = expandedtextbuffer; 47 zstream.next_out = expandedtextbuffer;
49 zstream.avail_out = buffersize; 48 zstream.avail_out = buffersize;
50 zstream.avail_in = reclen; 49 zstream.avail_in = reclen;
51 50
52 int ret = inflate(&zstream, Z_SYNC_FLUSH); 51 int ret = inflate(&zstream, Z_SYNC_FLUSH);
53 buffercontent = buffersize - zstream.avail_out; 52 buffercontent = buffersize - zstream.avail_out;
54 bufferpos = 0; 53 bufferpos = 0;
55 54
56 } 55 }
57 currentpos++; 56 currentpos++;
58 return expandedtextbuffer[bufferpos++]; 57 return expandedtextbuffer[bufferpos++];
59} 58}
60 59
61unsigned int ztxt::locate() 60unsigned int ztxt::locate()
62{ 61{
63 return currentpos; 62 return currentpos;
64} 63}
65 64
66void ztxt::locate(unsigned int n) 65void ztxt::locate(unsigned int n)
67{ 66{
68 67
69 if (hasrandomaccess()) 68 if (hasrandomaccess())
70 { 69 {
71 bufferrec = n / ntohs(hdr0.recordSize) + 1; 70 bufferrec = n / ntohs(hdr0.recordSize) + 1;
72 if (bufferrec == 1) 71 if (bufferrec == 1)
73 { 72 {
74 inflateEnd(&zstream); 73 inflateEnd(&zstream);
75 } 74 }
76 size_t reclen = recordlength(bufferrec); 75 size_t reclen = recordlength(bufferrec);
77 if (reclen == 0) return; 76 if (reclen == 0) return;
78 gotorecordnumber(bufferrec); 77 gotorecordnumber(bufferrec);
79 fread(compressedtextbuffer, reclen, sizeof(char), fin); 78 fread(compressedtextbuffer, reclen, sizeof(char), fin);
80 79
81 zstream.next_in = compressedtextbuffer; 80 zstream.next_in = compressedtextbuffer;
82 zstream.next_out = expandedtextbuffer; 81 zstream.next_out = expandedtextbuffer;
83 zstream.avail_out = buffersize; 82 zstream.avail_out = buffersize;
84 zstream.avail_in = reclen; 83 zstream.avail_in = reclen;
85 84
86 if (bufferrec == 1) 85 if (bufferrec == 1)
87 { 86 {
88 zstream.zalloc = Z_NULL; 87 zstream.zalloc = Z_NULL;
89 zstream.zfree = Z_NULL; 88 zstream.zfree = Z_NULL;
90 zstream.opaque = Z_NULL; 89 zstream.opaque = Z_NULL;
91 90
92 inflateInit(&zstream); 91 inflateInit(&zstream);
93 } 92 }
94 93
95 94
96 int ret = inflate(&zstream, Z_SYNC_FLUSH); 95 int ret = inflate(&zstream, Z_SYNC_FLUSH);
97 buffercontent = buffersize - zstream.avail_out; 96 buffercontent = buffersize - zstream.avail_out;
98 bufferpos = 0; 97 bufferpos = 0;
99 currentpos = n - n % ntohs(hdr0.recordSize); 98 currentpos = n - n % ntohs(hdr0.recordSize);
100 while (currentpos < n) getch(); 99 while (currentpos < n) getch();
101 } 100 }
102 else 101 else
103 { 102 {
104 home(); 103 home();
105 while (currentpos < n && getch() != EOF); 104 while (currentpos < n && getch() != EOF);
106 } 105 }
107} 106}
108 107
109void ztxt::home() 108void ztxt::home()
110{ 109{
111 if (bInit) 110 if (bInit)
112 { 111 {
113 inflateEnd(&zstream); 112 inflateEnd(&zstream);
114 } 113 }
115 bInit = true; 114 bInit = true;
116 size_t reclen = recordlength(1); 115 size_t reclen = recordlength(1);
117 gotorecordnumber(1); 116 gotorecordnumber(1);
118 fread(compressedtextbuffer, reclen, sizeof(char), fin); 117 fread(compressedtextbuffer, reclen, sizeof(char), fin);
119 118
120 zstream.next_in = compressedtextbuffer; 119 zstream.next_in = compressedtextbuffer;
121 zstream.next_out = expandedtextbuffer; 120 zstream.next_out = expandedtextbuffer;
122 zstream.avail_out = buffersize; 121 zstream.avail_out = buffersize;
123 zstream.avail_in = reclen; 122 zstream.avail_in = reclen;
124 123
125 zstream.zalloc = Z_NULL; 124 zstream.zalloc = Z_NULL;
126 zstream.zfree = Z_NULL; 125 zstream.zfree = Z_NULL;
127 zstream.opaque = Z_NULL; 126 zstream.opaque = Z_NULL;
128 127
129// printf("Initialising\n"); 128// printf("Initialising\n");
130 129
131 inflateInit(&zstream); 130 inflateInit(&zstream);
132 131
133 int ret = inflate(&zstream, Z_SYNC_FLUSH); 132 int ret = inflate(&zstream, Z_SYNC_FLUSH);
134// printf("Inflate : %d\n", ret); 133// printf("Inflate : %d\n", ret);
135 bufferpos = 0; 134 bufferpos = 0;
136 bufferrec = 1; 135 bufferrec = 1;
137 currentpos = 0; 136 currentpos = 0;
138 buffercontent = buffersize - zstream.avail_out; 137 buffercontent = buffersize - zstream.avail_out;
139 //printf("buffercontent:%u\n", buffercontent); 138 //printf("buffercontent:%u\n", buffercontent);
140} 139}
141 140
142CList<Bkmk>* ztxt::getbkmklist() 141CList<Bkmk>* ztxt::getbkmklist()
143{ 142{
144 UInt16 recno = ntohs(hdr0.bookmarkRecord); 143 UInt16 recno = ntohs(hdr0.bookmarkRecord);
145 144
146// printf("Bookmarks - record %d contains %d\n", recno, ntohs(hdr0.numBookmarks)); 145// printf("Bookmarks - record %d contains %d\n", recno, ntohs(hdr0.numBookmarks));
147 146
148 if (recno == 0) return NULL; 147 if (recno == 0) return NULL;
149 148
150 CList<Bkmk>* t = new CList<Bkmk>; 149 CList<Bkmk>* t = new CList<Bkmk>;
151 size_t cur = ftell(fin); 150 size_t cur = ftell(fin);
152 gotorecordnumber(recno); 151 gotorecordnumber(recno);
153 for (int i = 0; i < ntohs(hdr0.numBookmarks); i++) 152 for (int i = 0; i < ntohs(hdr0.numBookmarks); i++)
154 { 153 {
155 zTXTbkmk bkmk; 154 zTXTbkmk bkmk;
156 if (fread(&bkmk, sizeof(bkmk), 1, fin) != 1) break; 155 if (fread(&bkmk, sizeof(bkmk), 1, fin) != 1) break;
157// printf("Bookmark number:%d:%.20s\n", i, bkmk.title); 156// printf("Bookmark number:%d:%.20s\n", i, bkmk.title);
158 tchar title[MAX_BMRK_LENGTH]; 157 tchar title[MAX_BMRK_LENGTH];
159 for (int j = 0; j < MAX_BMRK_LENGTH; j++) 158 for (int j = 0; j < MAX_BMRK_LENGTH; j++)
160 { 159 {
161 title[j] = bkmk.title[j]; 160 title[j] = bkmk.title[j];
162 } 161 }
163 t->push_back(Bkmk(title, NULL, ntohl(bkmk.offset))); 162 t->push_back(Bkmk(title, NULL, ntohl(bkmk.offset)));
164 } 163 }
165 fseek(fin, cur, SEEK_SET); 164 fseek(fin, cur, SEEK_SET);
166 return t; 165 return t;
167} 166}
168 167
169#ifndef __STATIC 168#ifndef __STATIC
170extern "C" 169extern "C"
171{ 170{
172 CExpander* newcodec() { return new ztxt; } 171 CExpander* newcodec() { return new ztxt; }
173} 172}
174#endif 173#endif