summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/opie-console/TEScreen.cpp17
-rw-r--r--noncore/apps/opie-console/TEScreen.h2
-rw-r--r--noncore/apps/opie-console/TEmulation.cpp4
-rw-r--r--noncore/apps/opie-console/TEmulation.h7
-rw-r--r--noncore/apps/opie-console/emulation_handler.cpp3
-rw-r--r--noncore/apps/opie-console/emulation_handler.h1
-rw-r--r--noncore/apps/opie-console/mainwindow.cpp35
-rw-r--r--noncore/apps/opie-console/mainwindow.h1
-rw-r--r--noncore/apps/opie-console/metafactory.cpp25
-rw-r--r--noncore/apps/opie-console/metafactory.h11
10 files changed, 64 insertions, 42 deletions
diff --git a/noncore/apps/opie-console/TEScreen.cpp b/noncore/apps/opie-console/TEScreen.cpp
index a3d115d..2675d31 100644
--- a/noncore/apps/opie-console/TEScreen.cpp
+++ b/noncore/apps/opie-console/TEScreen.cpp
@@ -1,1197 +1,1208 @@
1/* -------------------------------------------------------------------------- */ 1/* -------------------------------------------------------------------------- */
2/* */ 2/* */
3/* [TEScreen.C] Screen Data Type */ 3/* [TEScreen.C] Screen Data Type */
4/* */ 4/* */
5/* -------------------------------------------------------------------------- */ 5/* -------------------------------------------------------------------------- */
6/* */ 6/* */
7/* Copyright (c) 1997,1998 by Lars Doelle <lars.doelle@on-line.de> */ 7/* Copyright (c) 1997,1998 by Lars Doelle <lars.doelle@on-line.de> */
8/* */ 8/* */
9/* This file is part of Konsole - an X terminal for KDE */ 9/* This file is part of Konsole - an X terminal for KDE */
10/* */ 10/* */
11/* -------------------------------------------------------------------------- */ 11/* -------------------------------------------------------------------------- */
12 /* */ 12 /* */
13/* Ported Konsole to Qt/Embedded */ 13/* Ported Konsole to Qt/Embedded */
14 /* */ 14 /* */
15/* Copyright (C) 2000 by John Ryland <jryland@trolltech.com> */ 15/* Copyright (C) 2000 by John Ryland <jryland@trolltech.com> */
16 /* */ 16 /* */
17/* -------------------------------------------------------------------------- */ 17/* -------------------------------------------------------------------------- */
18 18
19/*! \file 19/*! \file
20*/ 20*/
21 21
22/*! \class TEScreen 22/*! \class TEScreen
23 23
24 \brief The image manipulated by the emulation. 24 \brief The image manipulated by the emulation.
25 25
26 This class implements the operations of the terminal emulation framework. 26 This class implements the operations of the terminal emulation framework.
27 It is a complete passive device, driven by the emulation decoder 27 It is a complete passive device, driven by the emulation decoder
28 (TEmuVT102). By this it forms in fact an ADT, that defines operations 28 (TEmuVT102). By this it forms in fact an ADT, that defines operations
29 on a rectangular image. 29 on a rectangular image.
30 30
31 It does neither know how to display its image nor about escape sequences. 31 It does neither know how to display its image nor about escape sequences.
32 It is further independent of the underlying toolkit. By this, one can even 32 It is further independent of the underlying toolkit. By this, one can even
33 use this module for an ordinary text surface. 33 use this module for an ordinary text surface.
34 34
35 Since the operations are called by a specific emulation decoder, one may 35 Since the operations are called by a specific emulation decoder, one may
36 collect their different operations here. 36 collect their different operations here.
37 37
38 The state manipulated by the operations is mainly kept in `image', though 38 The state manipulated by the operations is mainly kept in `image', though
39 it is a little more complex bejond this. See the header file of the class. 39 it is a little more complex bejond this. See the header file of the class.
40 40
41 \sa TEWidget \sa VT102Emulation 41 \sa TEWidget \sa VT102Emulation
42*/ 42*/
43 43
44#include <stdio.h> 44#include <stdio.h>
45#include <stdlib.h> 45#include <stdlib.h>
46#include <unistd.h> 46#include <unistd.h>
47// #include <kdebug.h> 47// #include <kdebug.h>
48 48
49#include <assert.h> 49#include <assert.h>
50#include <string.h> 50#include <string.h>
51#include <ctype.h> 51#include <ctype.h>
52 52
53#include "TEScreen.h" 53#include "TEScreen.h"
54 54
55#define HERE printf("%s(%d): here\n",__FILE__,__LINE__) 55#define HERE printf("%s(%d): here\n",__FILE__,__LINE__)
56 56
57//FIXME: this is emulation specific. Use FALSE for xterm, TRUE for ANSI. 57//FIXME: this is emulation specific. Use FALSE for xterm, TRUE for ANSI.
58//FIXME: see if we can get this from terminfo. 58//FIXME: see if we can get this from terminfo.
59#define BS_CLEARS FALSE 59#define BS_CLEARS FALSE
60 60
61#define loc(X,Y) ((Y)*columns+(X)) 61#define loc(X,Y) ((Y)*columns+(X))
62 62
63/*! creates a `TEScreen' of `lines' lines and `columns' columns. 63/*! creates a `TEScreen' of `lines' lines and `columns' columns.
64*/ 64*/
65 65
66TEScreen::TEScreen(int lines, int columns) 66TEScreen::TEScreen(int lines, int columns)
67{ 67{
68 this->lines = lines; 68 this->lines = lines;
69 this->columns = columns; 69 this->columns = columns;
70 70
71 image = (ca*) malloc(lines*columns*sizeof(ca)); 71 image = (ca*) malloc(lines*columns*sizeof(ca));
72 tabstops = NULL; initTabStops(); 72 tabstops = NULL; initTabStops();
73 73
74 histCursor = 0; 74 histCursor = 0;
75 75
76 clearSelection(); 76 clearSelection();
77 reset(); 77 reset();
78} 78}
79 79
80/*! Destructor 80/*! Destructor
81*/ 81*/
82 82
83TEScreen::~TEScreen() 83TEScreen::~TEScreen()
84{ 84{
85 free(image); 85 free(image);
86 if (tabstops) free(tabstops); 86 if (tabstops) free(tabstops);
87} 87}
88 88
89/* ------------------------------------------------------------------------- */ 89/* ------------------------------------------------------------------------- */
90/* */ 90/* */
91/* Normalized Screen Operations */ 91/* Normalized Screen Operations */
92/* */ 92/* */
93/* ------------------------------------------------------------------------- */ 93/* ------------------------------------------------------------------------- */
94 94
95// Cursor Setting -------------------------------------------------------------- 95// Cursor Setting --------------------------------------------------------------
96 96
97/*! \section Cursor 97/*! \section Cursor
98 98
99 The `cursor' is a location within the screen that is implicitely used in 99 The `cursor' is a location within the screen that is implicitely used in
100 many operations. The operations within this section allow to manipulate 100 many operations. The operations within this section allow to manipulate
101 the cursor explicitly and to obtain it's value. 101 the cursor explicitly and to obtain it's value.
102 102
103 The position of the cursor is guarantied to be between (including) 0 and 103 The position of the cursor is guarantied to be between (including) 0 and
104 `columns-1' and `lines-1'. 104 `columns-1' and `lines-1'.
105*/ 105*/
106 106
107/*! 107/*!
108 Move the cursor up. 108 Move the cursor up.
109 109
110 The cursor will not be moved beyond the top margin. 110 The cursor will not be moved beyond the top margin.
111*/ 111*/
112 112
113void TEScreen::cursorUp(int n) 113void TEScreen::cursorUp(int n)
114//=CUU 114//=CUU
115{ 115{
116 if (n == 0) n = 1; // Default 116 if (n == 0) n = 1; // Default
117 int stop = cuY < tmargin ? 0 : tmargin; 117 int stop = cuY < tmargin ? 0 : tmargin;
118 cuX = QMIN(columns-1,cuX); // nowrap! 118 cuX = QMIN(columns-1,cuX); // nowrap!
119 cuY = QMAX(stop,cuY-n); 119 cuY = QMAX(stop,cuY-n);
120} 120}
121 121
122/*! 122/*!
123 Move the cursor down. 123 Move the cursor down.
124 124
125 The cursor will not be moved beyond the bottom margin. 125 The cursor will not be moved beyond the bottom margin.
126*/ 126*/
127 127
128void TEScreen::cursorDown(int n) 128void TEScreen::cursorDown(int n)
129//=CUD 129//=CUD
130{ 130{
131 if (n == 0) n = 1; // Default 131 if (n == 0) n = 1; // Default
132 int stop = cuY > bmargin ? lines-1 : bmargin; 132 int stop = cuY > bmargin ? lines-1 : bmargin;
133 cuX = QMIN(columns-1,cuX); // nowrap! 133 cuX = QMIN(columns-1,cuX); // nowrap!
134 cuY = QMIN(stop,cuY+n); 134 cuY = QMIN(stop,cuY+n);
135} 135}
136 136
137/*! 137/*!
138 Move the cursor left. 138 Move the cursor left.
139 139
140 The cursor will not move beyond the first column. 140 The cursor will not move beyond the first column.
141*/ 141*/
142 142
143void TEScreen::cursorLeft(int n) 143void TEScreen::cursorLeft(int n)
144//=CUB 144//=CUB
145{ 145{
146 if (n == 0) n = 1; // Default 146 if (n == 0) n = 1; // Default
147 cuX = QMIN(columns-1,cuX); // nowrap! 147 cuX = QMIN(columns-1,cuX); // nowrap!
148 cuX = QMAX(0,cuX-n); 148 cuX = QMAX(0,cuX-n);
149} 149}
150 150
151/*! 151/*!
152 Move the cursor left. 152 Move the cursor left.
153 153
154 The cursor will not move beyond the rightmost column. 154 The cursor will not move beyond the rightmost column.
155*/ 155*/
156 156
157void TEScreen::cursorRight(int n) 157void TEScreen::cursorRight(int n)
158//=CUF 158//=CUF
159{ 159{
160 if (n == 0) n = 1; // Default 160 if (n == 0) n = 1; // Default
161 cuX = QMIN(columns-1,cuX+n); 161 cuX = QMIN(columns-1,cuX+n);
162} 162}
163 163
164/*! 164/*!
165 Set top and bottom margin. 165 Set top and bottom margin.
166*/ 166*/
167 167
168void TEScreen::setMargins(int top, int bot) 168void TEScreen::setMargins(int top, int bot)
169//=STBM 169//=STBM
170{ 170{
171 if (top == 0) top = 1; // Default 171 if (top == 0) top = 1; // Default
172 if (bot == 0) bot = lines; // Default 172 if (bot == 0) bot = lines; // Default
173 top = top - 1; // Adjust to internal lineno 173 top = top - 1; // Adjust to internal lineno
174 bot = bot - 1; // Adjust to internal lineno 174 bot = bot - 1; // Adjust to internal lineno
175 if ( !( 0 <= top && top < bot && bot < lines ) ) 175 if ( !( 0 <= top && top < bot && bot < lines ) )
176 { fprintf(stderr,"%s(%d) : setRegion(%d,%d) : bad range.\n", 176 { fprintf(stderr,"%s(%d) : setRegion(%d,%d) : bad range.\n",
177 __FILE__,__LINE__,top,bot); 177 __FILE__,__LINE__,top,bot);
178 return; // Default error action: ignore 178 return; // Default error action: ignore
179 } 179 }
180 tmargin = top; 180 tmargin = top;
181 bmargin = bot; 181 bmargin = bot;
182 cuX = 0; 182 cuX = 0;
183 cuY = getMode(MODE_Origin) ? top : 0; 183 cuY = getMode(MODE_Origin) ? top : 0;
184} 184}
185 185
186/*! 186/*!
187 Move the cursor down one line. 187 Move the cursor down one line.
188 188
189 If cursor is on bottom margin, the region between the 189 If cursor is on bottom margin, the region between the
190 actual top and bottom margin is scrolled up instead. 190 actual top and bottom margin is scrolled up instead.
191*/ 191*/
192 192
193void TEScreen::index() 193void TEScreen::index()
194//=IND 194//=IND
195{ 195{
196 if (cuY == bmargin) 196 if (cuY == bmargin)
197 { 197 {
198 if (tmargin == 0 && bmargin == lines-1) addHistLine(); // hist.history 198 if (tmargin == 0 && bmargin == lines-1) addHistLine(); // hist.history
199 scrollUp(tmargin,1); 199 scrollUp(tmargin,1);
200 } 200 }
201 else if (cuY < lines-1) 201 else if (cuY < lines-1)
202 cuY += 1; 202 cuY += 1;
203} 203}
204 204
205/*! 205/*!
206 Move the cursor up one line. 206 Move the cursor up one line.
207 207
208 If cursor is on the top margin, the region between the 208 If cursor is on the top margin, the region between the
209 actual top and bottom margin is scrolled down instead. 209 actual top and bottom margin is scrolled down instead.
210*/ 210*/
211 211
212void TEScreen::reverseIndex() 212void TEScreen::reverseIndex()
213//=RI 213//=RI
214{ 214{
215 if (cuY == tmargin) 215 if (cuY == tmargin)
216 scrollDown(tmargin,1); 216 scrollDown(tmargin,1);
217 else if (cuY > 0) 217 else if (cuY > 0)
218 cuY -= 1; 218 cuY -= 1;
219} 219}
220 220
221/*! 221/*!
222 Move the cursor to the begin of the next line. 222 Move the cursor to the begin of the next line.
223 223
224 If cursor is on bottom margin, the region between the 224 If cursor is on bottom margin, the region between the
225 actual top and bottom margin is scrolled up. 225 actual top and bottom margin is scrolled up.
226*/ 226*/
227 227
228void TEScreen::NextLine() 228void TEScreen::NextLine()
229//=NEL 229//=NEL
230{ 230{
231 Return(); index(); 231 Return(); index();
232} 232}
233 233
234// Line Editing ---------------------------------------------------------------- 234// Line Editing ----------------------------------------------------------------
235 235
236/*! \section inserting / deleting characters 236/*! \section inserting / deleting characters
237*/ 237*/
238 238
239/*! erase `n' characters starting from (including) the cursor position. 239/*! erase `n' characters starting from (including) the cursor position.
240 240
241 The line is filled in from the right with spaces. 241 The line is filled in from the right with spaces.
242*/ 242*/
243 243
244void TEScreen::eraseChars(int n) 244void TEScreen::eraseChars(int n)
245{ 245{
246 if (n == 0) n = 1; // Default 246 if (n == 0) n = 1; // Default
247 int p = QMAX(0,QMIN(cuX+n-1,columns-1)); 247 int p = QMAX(0,QMIN(cuX+n-1,columns-1));
248 clearImage(loc(cuX,cuY),loc(p,cuY),' '); 248 clearImage(loc(cuX,cuY),loc(p,cuY),' ');
249} 249}
250 250
251/*! delete `n' characters starting from (including) the cursor position. 251/*! delete `n' characters starting from (including) the cursor position.
252 252
253 The line is filled in from the right with spaces. 253 The line is filled in from the right with spaces.
254*/ 254*/
255 255
256void TEScreen::deleteChars(int n) 256void TEScreen::deleteChars(int n)
257{ 257{
258 if (n == 0) n = 1; // Default 258 if (n == 0) n = 1; // Default
259 int p = QMAX(0,QMIN(cuX+n,columns-1)); 259 int p = QMAX(0,QMIN(cuX+n,columns-1));
260 moveImage(loc(cuX,cuY),loc(p,cuY),loc(columns-1,cuY)); 260 moveImage(loc(cuX,cuY),loc(p,cuY),loc(columns-1,cuY));
261 clearImage(loc(columns-n,cuY),loc(columns-1,cuY),' '); 261 clearImage(loc(columns-n,cuY),loc(columns-1,cuY),' ');
262} 262}
263 263
264/*! insert `n' spaces at the cursor position. 264/*! insert `n' spaces at the cursor position.
265 265
266 The cursor is not moved by the operation. 266 The cursor is not moved by the operation.
267*/ 267*/
268 268
269void TEScreen::insertChars(int n) 269void TEScreen::insertChars(int n)
270{ 270{
271 if (n == 0) n = 1; // Default 271 if (n == 0) n = 1; // Default
272 int p = QMAX(0,QMIN(columns-1-n,columns-1)); 272 int p = QMAX(0,QMIN(columns-1-n,columns-1));
273 int q = QMAX(0,QMIN(cuX+n,columns-1)); 273 int q = QMAX(0,QMIN(cuX+n,columns-1));
274 moveImage(loc(q,cuY),loc(cuX,cuY),loc(p,cuY)); 274 moveImage(loc(q,cuY),loc(cuX,cuY),loc(p,cuY));
275 clearImage(loc(cuX,cuY),loc(q-1,cuY),' '); 275 clearImage(loc(cuX,cuY),loc(q-1,cuY),' ');
276} 276}
277 277
278/*! delete `n' lines starting from (including) the cursor position. 278/*! delete `n' lines starting from (including) the cursor position.
279 279
280 The cursor is not moved by the operation. 280 The cursor is not moved by the operation.
281*/ 281*/
282 282
283void TEScreen::deleteLines(int n) 283void TEScreen::deleteLines(int n)
284{ 284{
285 if (n == 0) n = 1; // Default 285 if (n == 0) n = 1; // Default
286 scrollUp(cuY,n); 286 scrollUp(cuY,n);
287} 287}
288 288
289/*! insert `n' lines at the cursor position. 289/*! insert `n' lines at the cursor position.
290 290
291 The cursor is not moved by the operation. 291 The cursor is not moved by the operation.
292*/ 292*/
293 293
294void TEScreen::insertLines(int n) 294void TEScreen::insertLines(int n)
295{ 295{
296 if (n == 0) n = 1; // Default 296 if (n == 0) n = 1; // Default
297 scrollDown(cuY,n); 297 scrollDown(cuY,n);
298} 298}
299 299
300// Mode Operations ----------------------------------------------------------- 300// Mode Operations -----------------------------------------------------------
301 301
302/*! Set a specific mode. */ 302/*! Set a specific mode. */
303 303
304void TEScreen::setMode(int m) 304void TEScreen::setMode(int m)
305{ 305{
306 currParm.mode[m] = TRUE; 306 currParm.mode[m] = TRUE;
307 switch(m) 307 switch(m)
308 { 308 {
309 case MODE_Origin : cuX = 0; cuY = tmargin; break; //FIXME: home 309 case MODE_Origin : cuX = 0; cuY = tmargin; break; //FIXME: home
310 } 310 }
311} 311}
312 312
313/*! Reset a specific mode. */ 313/*! Reset a specific mode. */
314 314
315void TEScreen::resetMode(int m) 315void TEScreen::resetMode(int m)
316{ 316{
317 currParm.mode[m] = FALSE; 317 currParm.mode[m] = FALSE;
318 switch(m) 318 switch(m)
319 { 319 {
320 case MODE_Origin : cuX = 0; cuY = 0; break; //FIXME: home 320 case MODE_Origin : cuX = 0; cuY = 0; break; //FIXME: home
321 } 321 }
322} 322}
323 323
324/*! Save a specific mode. */ 324/*! Save a specific mode. */
325 325
326void TEScreen::saveMode(int m) 326void TEScreen::saveMode(int m)
327{ 327{
328 saveParm.mode[m] = currParm.mode[m]; 328 saveParm.mode[m] = currParm.mode[m];
329} 329}
330 330
331/*! Restore a specific mode. */ 331/*! Restore a specific mode. */
332 332
333void TEScreen::restoreMode(int m) 333void TEScreen::restoreMode(int m)
334{ 334{
335 currParm.mode[m] = saveParm.mode[m]; 335 currParm.mode[m] = saveParm.mode[m];
336} 336}
337 337
338//NOTE: this is a helper function 338//NOTE: this is a helper function
339/*! Return the setting a specific mode. */ 339/*! Return the setting a specific mode. */
340BOOL TEScreen::getMode(int m) 340BOOL TEScreen::getMode(int m)
341{ 341{
342 return currParm.mode[m]; 342 return currParm.mode[m];
343} 343}
344 344
345/*! Save the cursor position and the rendition attribute settings. */ 345/*! Save the cursor position and the rendition attribute settings. */
346 346
347void TEScreen::saveCursor() 347void TEScreen::saveCursor()
348{ 348{
349 sa_cuX = cuX; 349 sa_cuX = cuX;
350 sa_cuY = cuY; 350 sa_cuY = cuY;
351 sa_cu_re = cu_re; 351 sa_cu_re = cu_re;
352 sa_cu_fg = cu_fg; 352 sa_cu_fg = cu_fg;
353 sa_cu_bg = cu_bg; 353 sa_cu_bg = cu_bg;
354} 354}
355 355
356/*! Restore the cursor position and the rendition attribute settings. */ 356/*! Restore the cursor position and the rendition attribute settings. */
357 357
358void TEScreen::restoreCursor() 358void TEScreen::restoreCursor()
359{ 359{
360 cuX = QMIN(sa_cuX,columns-1); 360 cuX = QMIN(sa_cuX,columns-1);
361 cuY = QMIN(sa_cuY,lines-1); 361 cuY = QMIN(sa_cuY,lines-1);
362 cu_re = sa_cu_re; 362 cu_re = sa_cu_re;
363 cu_fg = sa_cu_fg; 363 cu_fg = sa_cu_fg;
364 cu_bg = sa_cu_bg; 364 cu_bg = sa_cu_bg;
365 effectiveRendition(); 365 effectiveRendition();
366} 366}
367 367
368/* ------------------------------------------------------------------------- */ 368/* ------------------------------------------------------------------------- */
369/* */ 369/* */
370/* Screen Operations */ 370/* Screen Operations */
371/* */ 371/* */
372/* ------------------------------------------------------------------------- */ 372/* ------------------------------------------------------------------------- */
373 373
374/*! Assing a new size to the screen. 374/*! Assing a new size to the screen.
375 375
376 The topmost left position is maintained, while lower lines 376 The topmost left position is maintained, while lower lines
377 or right hand side columns might be removed or filled with 377 or right hand side columns might be removed or filled with
378 spaces to fit the new size. 378 spaces to fit the new size.
379 379
380 The region setting is reset to the whole screen and the 380 The region setting is reset to the whole screen and the
381 tab positions reinitialized. 381 tab positions reinitialized.
382*/ 382*/
383 383
384void TEScreen::resizeImage(int new_lines, int new_columns) 384void TEScreen::resizeImage(int new_lines, int new_columns)
385{ 385{
386 386
387 if (cuY > new_lines-1) 387 if (cuY > new_lines-1)
388 { // attempt to preserve focus and lines 388 { // attempt to preserve focus and lines
389 bmargin = lines-1; //FIXME: margin lost 389 bmargin = lines-1; //FIXME: margin lost
390 for (int i = 0; i < cuY-(new_lines-1); i++) 390 for (int i = 0; i < cuY-(new_lines-1); i++)
391 { 391 {
392 addHistLine(); scrollUp(0,1); 392 addHistLine(); scrollUp(0,1);
393 } 393 }
394 } 394 }
395 395
396 // make new image 396 // make new image
397 ca* newimg = (ca*)malloc(new_lines*new_columns*sizeof(ca)); 397 ca* newimg = (ca*)malloc(new_lines*new_columns*sizeof(ca));
398 398
399 clearSelection(); 399 clearSelection();
400 400
401 // clear new image 401 // clear new image
402 for (int y = 0; y < new_lines; y++) 402 for (int y = 0; y < new_lines; y++)
403 for (int x = 0; x < new_columns; x++) 403 for (int x = 0; x < new_columns; x++)
404 { 404 {
405 newimg[y*new_columns+x].c = ' '; 405 newimg[y*new_columns+x].c = ' ';
406 newimg[y*new_columns+x].f = DEFAULT_FORE_COLOR; 406 newimg[y*new_columns+x].f = DEFAULT_FORE_COLOR;
407 newimg[y*new_columns+x].b = DEFAULT_BACK_COLOR; 407 newimg[y*new_columns+x].b = DEFAULT_BACK_COLOR;
408 newimg[y*new_columns+x].r = DEFAULT_RENDITION; 408 newimg[y*new_columns+x].r = DEFAULT_RENDITION;
409 } 409 }
410 int cpy_lines = QMIN(new_lines, lines); 410 int cpy_lines = QMIN(new_lines, lines);
411 int cpy_columns = QMIN(new_columns,columns); 411 int cpy_columns = QMIN(new_columns,columns);
412 // copy to new image 412 // copy to new image
413 for (int y = 0; y < cpy_lines; y++) 413 for (int y = 0; y < cpy_lines; y++)
414 for (int x = 0; x < cpy_columns; x++) 414 for (int x = 0; x < cpy_columns; x++)
415 { 415 {
416 newimg[y*new_columns+x].c = image[loc(x,y)].c; 416 newimg[y*new_columns+x].c = image[loc(x,y)].c;
417 newimg[y*new_columns+x].f = image[loc(x,y)].f; 417 newimg[y*new_columns+x].f = image[loc(x,y)].f;
418 newimg[y*new_columns+x].b = image[loc(x,y)].b; 418 newimg[y*new_columns+x].b = image[loc(x,y)].b;
419 newimg[y*new_columns+x].r = image[loc(x,y)].r; 419 newimg[y*new_columns+x].r = image[loc(x,y)].r;
420 } 420 }
421 free(image); 421 free(image);
422 image = newimg; 422 image = newimg;
423 lines = new_lines; 423 lines = new_lines;
424 columns = new_columns; 424 columns = new_columns;
425 cuX = QMIN(cuX,columns-1); 425 cuX = QMIN(cuX,columns-1);
426 cuY = QMIN(cuY,lines-1); 426 cuY = QMIN(cuY,lines-1);
427 427
428 // FIXME: try to keep values, evtl. 428 // FIXME: try to keep values, evtl.
429 tmargin=0; 429 tmargin=0;
430 bmargin=lines-1; 430 bmargin=lines-1;
431 initTabStops(); 431 initTabStops();
432 clearSelection(); 432 clearSelection();
433} 433}
434 434
435/* 435/*
436 Clarifying rendition here and in TEWidget. 436 Clarifying rendition here and in TEWidget.
437 437
438 currently, TEWidget's color table is 438 currently, TEWidget's color table is
439 0 1 2 .. 9 10 .. 17 439 0 1 2 .. 9 10 .. 17
440 dft_fg, dft_bg, dim 0..7, intensive 0..7 440 dft_fg, dft_bg, dim 0..7, intensive 0..7
441 441
442 cu_fg, cu_bg contain values 0..8; 442 cu_fg, cu_bg contain values 0..8;
443 - 0 = default color 443 - 0 = default color
444 - 1..8 = ansi specified color 444 - 1..8 = ansi specified color
445 445
446 re_fg, re_bg contain values 0..17 446 re_fg, re_bg contain values 0..17
447 due to the TEWidget's color table 447 due to the TEWidget's color table
448 448
449 rendition attributes are 449 rendition attributes are
450 450
451 attr widget screen 451 attr widget screen
452 -------------- ------ ------ 452 -------------- ------ ------
453 RE_UNDERLINE XX XX affects foreground only 453 RE_UNDERLINE XX XX affects foreground only
454 RE_BLINK XX XX affects foreground only 454 RE_BLINK XX XX affects foreground only
455 RE_BOLD XX XX affects foreground only 455 RE_BOLD XX XX affects foreground only
456 RE_REVERSE -- XX 456 RE_REVERSE -- XX
457 RE_TRANSPARENT XX -- affects background only 457 RE_TRANSPARENT XX -- affects background only
458 RE_INTENSIVE XX -- affects foreground only 458 RE_INTENSIVE XX -- affects foreground only
459 459
460 Note that RE_BOLD is used in both widget 460 Note that RE_BOLD is used in both widget
461 and screen rendition. Since xterm/vt102 461 and screen rendition. Since xterm/vt102
462 is to poor to distinguish between bold 462 is to poor to distinguish between bold
463 (which is a font attribute) and intensive 463 (which is a font attribute) and intensive
464 (which is a color attribute), we translate 464 (which is a color attribute), we translate
465 this and RE_BOLD in falls eventually appart 465 this and RE_BOLD in falls eventually appart
466 into RE_BOLD and RE_INTENSIVE. 466 into RE_BOLD and RE_INTENSIVE.
467*/ 467*/
468 468
469void TEScreen::reverseRendition(ca* p) 469void TEScreen::reverseRendition(ca* p)
470{ UINT8 f = p->f; UINT8 b = p->b; 470{ UINT8 f = p->f; UINT8 b = p->b;
471 p->f = b; p->b = f; //p->r &= ~RE_TRANSPARENT; 471 p->f = b; p->b = f; //p->r &= ~RE_TRANSPARENT;
472} 472}
473 473
474void TEScreen::effectiveRendition() 474void TEScreen::effectiveRendition()
475// calculate rendition 475// calculate rendition
476{ 476{
477 ef_re = cu_re & (RE_UNDERLINE | RE_BLINK); 477 ef_re = cu_re & (RE_UNDERLINE | RE_BLINK);
478 if (cu_re & RE_REVERSE) 478 if (cu_re & RE_REVERSE)
479 { 479 {
480 ef_fg = cu_bg; 480 ef_fg = cu_bg;
481 ef_bg = cu_fg; 481 ef_bg = cu_fg;
482 } 482 }
483 else 483 else
484 { 484 {
485 ef_fg = cu_fg; 485 ef_fg = cu_fg;
486 ef_bg = cu_bg; 486 ef_bg = cu_bg;
487 } 487 }
488 if (cu_re & RE_BOLD) 488 if (cu_re & RE_BOLD)
489 { 489 {
490 if (ef_fg < BASE_COLORS) 490 if (ef_fg < BASE_COLORS)
491 ef_fg += BASE_COLORS; 491 ef_fg += BASE_COLORS;
492 else 492 else
493 ef_fg -= BASE_COLORS; 493 ef_fg -= BASE_COLORS;
494 } 494 }
495} 495}
496 496
497/*! 497/*!
498 returns the image. 498 returns the image.
499 499
500 Get the size of the image by \sa getLines and \sa getColumns. 500 Get the size of the image by \sa getLines and \sa getColumns.
501 501
502 NOTE that the image returned by this function must later be 502 NOTE that the image returned by this function must later be
503 freed. 503 freed.
504 504
505*/ 505*/
506 506
507ca* TEScreen::getCookedImage() 507ca* TEScreen::getCookedImage()
508{ int x,y; 508{ int x,y;
509 ca* merged = (ca*)malloc(lines*columns*sizeof(ca)); 509 ca* merged = (ca*)malloc(lines*columns*sizeof(ca));
510 ca dft(' ',DEFAULT_FORE_COLOR,DEFAULT_BACK_COLOR,DEFAULT_RENDITION); 510 ca dft(' ',DEFAULT_FORE_COLOR,DEFAULT_BACK_COLOR,DEFAULT_RENDITION);
511 511
512 for (y = 0; (y < lines) && (y < (hist.getLines()-histCursor)); y++) 512 for (y = 0; (y < lines) && (y < (hist.getLines()-histCursor)); y++)
513 { 513 {
514 int len = QMIN(columns,hist.getLineLen(y+histCursor)); 514 int len = QMIN(columns,hist.getLineLen(y+histCursor));
515 int yp = y*columns; 515 int yp = y*columns;
516 int yq = (y+histCursor)*columns; 516 int yq = (y+histCursor)*columns;
517 517
518 hist.getCells(y+histCursor,0,len,merged+yp); 518 hist.getCells(y+histCursor,0,len,merged+yp);
519 for (x = len; x < columns; x++) merged[yp+x] = dft; 519 for (x = len; x < columns; x++) merged[yp+x] = dft;
520 for (x = 0; x < columns; x++) 520 for (x = 0; x < columns; x++)
521 { int p=x + yp; int q=x + yq; 521 { int p=x + yp; int q=x + yq;
522 if ( ( q >= sel_TL ) && ( q <= sel_BR ) ) 522 if ( ( q >= sel_TL ) && ( q <= sel_BR ) )
523 reverseRendition(&merged[p]); // for selection 523 reverseRendition(&merged[p]); // for selection
524 } 524 }
525 } 525 }
526 if (lines >= hist.getLines()-histCursor) 526 if (lines >= hist.getLines()-histCursor)
527 { 527 {
528 for (y = (hist.getLines()-histCursor); y < lines ; y++) 528 for (y = (hist.getLines()-histCursor); y < lines ; y++)
529 { 529 {
530 int yp = y*columns; 530 int yp = y*columns;
531 int yq = (y+histCursor)*columns; 531 int yq = (y+histCursor)*columns;
532 int yr = (y-hist.getLines()+histCursor)*columns; 532 int yr = (y-hist.getLines()+histCursor)*columns;
533 for (x = 0; x < columns; x++) 533 for (x = 0; x < columns; x++)
534 { int p = x + yp; int q = x + yq; int r = x + yr; 534 { int p = x + yp; int q = x + yq; int r = x + yr;
535 merged[p] = image[r]; 535 merged[p] = image[r];
536 if ( q >= sel_TL && q <= sel_BR ) 536 if ( q >= sel_TL && q <= sel_BR )
537 reverseRendition(&merged[p]); // for selection 537 reverseRendition(&merged[p]); // for selection
538 } 538 }
539 539
540 } 540 }
541 } 541 }
542 // evtl. inverse display 542 // evtl. inverse display
543 if (getMode(MODE_Screen)) 543 if (getMode(MODE_Screen))
544 { int i,n = lines*columns; 544 { int i,n = lines*columns;
545 for (i = 0; i < n; i++) 545 for (i = 0; i < n; i++)
546 reverseRendition(&merged[i]); // for reverse display 546 reverseRendition(&merged[i]); // for reverse display
547 } 547 }
548 if (getMode(MODE_Cursor) && (cuY+(hist.getLines()-histCursor) < lines)) // cursor visible 548 if (getMode(MODE_Cursor) && (cuY+(hist.getLines()-histCursor) < lines)) // cursor visible
549 reverseRendition(&merged[loc(cuX,cuY+(hist.getLines()-histCursor))]); 549 reverseRendition(&merged[loc(cuX,cuY+(hist.getLines()-histCursor))]);
550 return merged; 550 return merged;
551} 551}
552 552
553 553
554/*! 554/*!
555*/ 555*/
556 556
557void TEScreen::reset() 557void TEScreen::reset()
558{ 558{
559 setMode(MODE_Wrap ); saveMode(MODE_Wrap ); // wrap at end of margin 559 setMode(MODE_Wrap ); saveMode(MODE_Wrap ); // wrap at end of margin
560 resetMode(MODE_Origin); saveMode(MODE_Origin); // position refere to [1,1] 560 resetMode(MODE_Origin); saveMode(MODE_Origin); // position refere to [1,1]
561 resetMode(MODE_Insert); saveMode(MODE_Insert); // overstroke 561 resetMode(MODE_Insert); saveMode(MODE_Insert); // overstroke
562 setMode(MODE_Cursor); // cursor visible 562 setMode(MODE_Cursor); // cursor visible
563 resetMode(MODE_Screen); // screen not inverse 563 resetMode(MODE_Screen); // screen not inverse
564 resetMode(MODE_NewLine); 564 resetMode(MODE_NewLine);
565 565
566 tmargin=0; 566 tmargin=0;
567 bmargin=lines-1; 567 bmargin=lines-1;
568 568
569 setDefaultRendition(); 569 setDefaultRendition();
570 saveCursor(); 570 saveCursor();
571 571
572 clear(); 572 clear();
573} 573}
574 574
575/*! Clear the entire screen and home the cursor. 575/*! Clear the entire screen and home the cursor.
576*/ 576*/
577 577
578void TEScreen::clear() 578void TEScreen::clear()
579{ 579{
580 clearEntireScreen(); 580 clearEntireScreen();
581 home(); 581 home();
582} 582}
583 583
584/*! Moves the cursor left one column. 584/*! Moves the cursor left one column.
585*/ 585*/
586 586
587void TEScreen::BackSpace() 587void TEScreen::BackSpace()
588{ 588{
589 cuX = QMAX(0,cuX-1); 589 cuX = QMAX(0,cuX-1);
590 if (BS_CLEARS) image[loc(cuX,cuY)].c = ' '; 590 if (BS_CLEARS) image[loc(cuX,cuY)].c = ' ';
591} 591}
592 592
593/*! 593/*!
594*/ 594*/
595 595
596void TEScreen::Tabulate() 596void TEScreen::Tabulate()
597{ 597{
598 // note that TAB is a format effector (does not write ' '); 598 // note that TAB is a format effector (does not write ' ');
599 cursorRight(1); while(cuX < columns-1 && !tabstops[cuX]) cursorRight(1); 599 cursorRight(1); while(cuX < columns-1 && !tabstops[cuX]) cursorRight(1);
600} 600}
601 601
602void TEScreen::clearTabStops() 602void TEScreen::clearTabStops()
603{ 603{
604 for (int i = 0; i < columns; i++) tabstops[i-1] = FALSE; 604 for (int i = 0; i < columns; i++) tabstops[i-1] = FALSE;
605} 605}
606 606
607void TEScreen::changeTabStop(bool set) 607void TEScreen::changeTabStop(bool set)
608{ 608{
609 if (cuX >= columns) return; 609 if (cuX >= columns) return;
610 tabstops[cuX] = set; 610 tabstops[cuX] = set;
611} 611}
612 612
613void TEScreen::initTabStops() 613void TEScreen::initTabStops()
614{ 614{
615 if (tabstops) free(tabstops); 615 if (tabstops) free(tabstops);
616 tabstops = (bool*)malloc(columns*sizeof(bool)); 616 tabstops = (bool*)malloc(columns*sizeof(bool));
617 // Arrg! The 1st tabstop has to be one longer than the other. 617 // Arrg! The 1st tabstop has to be one longer than the other.
618 // i.e. the kids start counting from 0 instead of 1. 618 // i.e. the kids start counting from 0 instead of 1.
619 // Other programs might behave correctly. Be aware. 619 // Other programs might behave correctly. Be aware.
620 for (int i = 0; i < columns; i++) tabstops[i] = (i%8 == 0 && i != 0); 620 for (int i = 0; i < columns; i++) tabstops[i] = (i%8 == 0 && i != 0);
621} 621}
622 622
623/*! 623/*!
624 This behaves either as IND (Screen::Index) or as NEL (Screen::NextLine) 624 This behaves either as IND (Screen::Index) or as NEL (Screen::NextLine)
625 depending on the NewLine Mode (LNM). This mode also 625 depending on the NewLine Mode (LNM). This mode also
626 affects the key sequence returned for newline ([CR]LF). 626 affects the key sequence returned for newline ([CR]LF).
627*/ 627*/
628 628
629void TEScreen::NewLine() 629void TEScreen::NewLine()
630{ 630{
631 if (getMode(MODE_NewLine)) Return(); 631 if (getMode(MODE_NewLine)) Return();
632 index(); 632 index();
633} 633}
634 634
635/*! put `c' literally onto the screen at the current cursor position. 635/*! put `c' literally onto the screen at the current cursor position.
636 636
637 VT100 uses the convention to produce an automatic newline (am) 637 VT100 uses the convention to produce an automatic newline (am)
638 with the *first* character that would fall onto the next line (xenl). 638 with the *first* character that would fall onto the next line (xenl).
639*/ 639*/
640 640
641void TEScreen::checkSelection(int from, int to) 641void TEScreen::checkSelection(int from, int to)
642{ 642{
643 if (sel_begin == -1) return; 643 if (sel_begin == -1) return;
644 int scr_TL = loc(0, hist.getLines()); 644 int scr_TL = loc(0, hist.getLines());
645 //Clear entire selection if it overlaps region [from, to] 645 //Clear entire selection if it overlaps region [from, to]
646 if ( (sel_BR > (from+scr_TL) )&&(sel_TL < (to+scr_TL)) ) 646 if ( (sel_BR > (from+scr_TL) )&&(sel_TL < (to+scr_TL)) )
647 { 647 {
648 clearSelection(); 648 clearSelection();
649 } 649 }
650} 650}
651 651
652void TEScreen::ShowCharacter(unsigned short c) 652void TEScreen::ShowCharacter(unsigned short c)
653{ 653{
654 // Note that VT100 does wrapping BEFORE putting the character. 654 // Note that VT100 does wrapping BEFORE putting the character.
655 // This has impact on the assumption of valid cursor positions. 655 // This has impact on the assumption of valid cursor positions.
656 // We indicate the fact that a newline has to be triggered by 656 // We indicate the fact that a newline has to be triggered by
657 // putting the cursor one right to the last column of the screen. 657 // putting the cursor one right to the last column of the screen.
658 658
659 if (cuX >= columns) 659 if (cuX >= columns)
660 { 660 {
661 if (getMode(MODE_Wrap)) NextLine(); else cuX = columns-1; 661 if (getMode(MODE_Wrap)) NextLine(); else cuX = columns-1;
662 } 662 }
663 663
664 if (getMode(MODE_Insert)) insertChars(1); 664 if (getMode(MODE_Insert)) insertChars(1);
665 665
666 int i = loc(cuX,cuY); 666 int i = loc(cuX,cuY);
667 667
668 checkSelection(i, i); // check if selection is still valid. 668 checkSelection(i, i); // check if selection is still valid.
669 669
670 image[i].c = c; 670 image[i].c = c;
671 image[i].f = ef_fg; 671 image[i].f = ef_fg;
672 image[i].b = ef_bg; 672 image[i].b = ef_bg;
673 image[i].r = ef_re; 673 image[i].r = ef_re;
674 674
675 cuX += 1; 675 cuX += 1;
676} 676}
677 677
678// Region commands ------------------------------------------------------------- 678// Region commands -------------------------------------------------------------
679 679
680 680
681/*! scroll up `n' lines within current region. 681/*! scroll up `n' lines within current region.
682 The `n' new lines are cleared. 682 The `n' new lines are cleared.
683 \sa setRegion \sa scrollDown 683 \sa setRegion \sa scrollDown
684*/ 684*/
685 685
686void TEScreen::scrollUp(int from, int n) 686void TEScreen::scrollUp(int from, int n)
687{ 687{
688 if (n <= 0 || from + n > bmargin) return; 688 if (n <= 0 || from + n > bmargin) return;
689 //FIXME: make sure `tmargin', `bmargin', `from', `n' is in bounds. 689 //FIXME: make sure `tmargin', `bmargin', `from', `n' is in bounds.
690 moveImage(loc(0,from),loc(0,from+n),loc(columns-1,bmargin)); 690 moveImage(loc(0,from),loc(0,from+n),loc(columns-1,bmargin));
691 clearImage(loc(0,bmargin-n+1),loc(columns-1,bmargin),' '); 691 clearImage(loc(0,bmargin-n+1),loc(columns-1,bmargin),' ');
692} 692}
693 693
694/*! scroll down `n' lines within current region. 694/*! scroll down `n' lines within current region.
695 The `n' new lines are cleared. 695 The `n' new lines are cleared.
696 \sa setRegion \sa scrollUp 696 \sa setRegion \sa scrollUp
697*/ 697*/
698 698
699void TEScreen::scrollDown(int from, int n) 699void TEScreen::scrollDown(int from, int n)
700{ 700{
701//FIXME: make sure `tmargin', `bmargin', `from', `n' is in bounds. 701//FIXME: make sure `tmargin', `bmargin', `from', `n' is in bounds.
702 if (n <= 0) return; 702 if (n <= 0) return;
703 if (from > bmargin) return; 703 if (from > bmargin) return;
704 if (from + n > bmargin) n = bmargin - from; 704 if (from + n > bmargin) n = bmargin - from;
705 moveImage(loc(0,from+n),loc(0,from),loc(columns-1,bmargin-n)); 705 moveImage(loc(0,from+n),loc(0,from),loc(columns-1,bmargin-n));
706 clearImage(loc(0,from),loc(columns-1,from+n-1),' '); 706 clearImage(loc(0,from),loc(columns-1,from+n-1),' ');
707} 707}
708 708
709/*! position the cursor to a specific line and column. */ 709/*! position the cursor to a specific line and column. */
710void TEScreen::setCursorYX(int y, int x) 710void TEScreen::setCursorYX(int y, int x)
711{ 711{
712 setCursorY(y); setCursorX(x); 712 setCursorY(y); setCursorX(x);
713} 713}
714 714
715/*! Set the cursor to x-th line. */ 715/*! Set the cursor to x-th line. */
716 716
717void TEScreen::setCursorX(int x) 717void TEScreen::setCursorX(int x)
718{ 718{
719 if (x == 0) x = 1; // Default 719 if (x == 0) x = 1; // Default
720 x -= 1; // Adjust 720 x -= 1; // Adjust
721 cuX = QMAX(0,QMIN(columns-1, x)); 721 cuX = QMAX(0,QMIN(columns-1, x));
722} 722}
723 723
724/*! Set the cursor to y-th line. */ 724/*! Set the cursor to y-th line. */
725 725
726void TEScreen::setCursorY(int y) 726void TEScreen::setCursorY(int y)
727{ 727{
728 if (y == 0) y = 1; // Default 728 if (y == 0) y = 1; // Default
729 y -= 1; // Adjust 729 y -= 1; // Adjust
730 cuY = QMAX(0,QMIN(lines -1, y + (getMode(MODE_Origin) ? tmargin : 0) )); 730 cuY = QMAX(0,QMIN(lines -1, y + (getMode(MODE_Origin) ? tmargin : 0) ));
731} 731}
732 732
733/*! set cursor to the `left upper' corner of the screen (1,1). 733/*! set cursor to the `left upper' corner of the screen (1,1).
734*/ 734*/
735 735
736void TEScreen::home() 736void TEScreen::home()
737{ 737{
738 cuX = 0; 738 cuX = 0;
739 cuY = 0; 739 cuY = 0;
740} 740}
741 741
742/*! set cursor to the begin of the current line. 742/*! set cursor to the begin of the current line.
743*/ 743*/
744 744
745void TEScreen::Return() 745void TEScreen::Return()
746{ 746{
747 cuX = 0; 747 cuX = 0;
748} 748}
749 749
750/*! returns the current cursor columns. 750/*! returns the current cursor columns.
751*/ 751*/
752 752
753int TEScreen::getCursorX() 753int TEScreen::getCursorX()
754{ 754{
755 return cuX; 755 return cuX;
756} 756}
757 757
758/*! returns the current cursor line. 758/*! returns the current cursor line.
759*/ 759*/
760 760
761int TEScreen::getCursorY() 761int TEScreen::getCursorY()
762{ 762{
763 return cuY; 763 return cuY;
764} 764}
765 765
766// Erasing --------------------------------------------------------------------- 766// Erasing ---------------------------------------------------------------------
767 767
768/*! \section Erasing 768/*! \section Erasing
769 769
770 This group of operations erase parts of the screen contents by filling 770 This group of operations erase parts of the screen contents by filling
771 it with spaces colored due to the current rendition settings. 771 it with spaces colored due to the current rendition settings.
772 772
773 Althought the cursor position is involved in most of these operations, 773 Althought the cursor position is involved in most of these operations,
774 it is never modified by them. 774 it is never modified by them.
775*/ 775*/
776 776
777/*! fill screen between (including) `loca' and `loce' with spaces. 777/*! fill screen between (including) `loca' and `loce' with spaces.
778 778
779 This is an internal helper functions. The parameter types are internal 779 This is an internal helper functions. The parameter types are internal
780 addresses of within the screen image and make use of the way how the 780 addresses of within the screen image and make use of the way how the
781 screen matrix is mapped to the image vector. 781 screen matrix is mapped to the image vector.
782*/ 782*/
783 783
784void TEScreen::clearImage(int loca, int loce, char c) 784void TEScreen::clearImage(int loca, int loce, char c)
785{ int i; 785{ int i;
786 int scr_TL=loc(0,hist.getLines()); 786 int scr_TL=loc(0,hist.getLines());
787 //FIXME: check positions 787 //FIXME: check positions
788 788
789 //Clear entire selection if it overlaps region to be moved... 789 //Clear entire selection if it overlaps region to be moved...
790 if ( (sel_BR > (loca+scr_TL) )&&(sel_TL < (loce+scr_TL)) ) 790 if ( (sel_BR > (loca+scr_TL) )&&(sel_TL < (loce+scr_TL)) )
791 { 791 {
792 clearSelection(); 792 clearSelection();
793 } 793 }
794 for (i = loca; i <= loce; i++) 794 for (i = loca; i <= loce; i++)
795 { 795 {
796 image[i].c = c; 796 image[i].c = c;
797 image[i].f = ef_fg; //DEFAULT_FORE_COLOR; //FIXME: xterm and linux/ansi 797 image[i].f = ef_fg; //DEFAULT_FORE_COLOR; //FIXME: xterm and linux/ansi
798 image[i].b = ef_bg; //DEFAULT_BACK_COLOR; // many have different 798 image[i].b = ef_bg; //DEFAULT_BACK_COLOR; // many have different
799 image[i].r = ef_re; //DEFAULT_RENDITION; // ideas here. 799 image[i].r = ef_re; //DEFAULT_RENDITION; // ideas here.
800 } 800 }
801} 801}
802 802
803/*! move image between (including) `loca' and `loce' to 'dst'. 803/*! move image between (including) `loca' and `loce' to 'dst'.
804 804
805 This is an internal helper functions. The parameter types are internal 805 This is an internal helper functions. The parameter types are internal
806 addresses of within the screen image and make use of the way how the 806 addresses of within the screen image and make use of the way how the
807 screen matrix is mapped to the image vector. 807 screen matrix is mapped to the image vector.
808*/ 808*/
809 809
810void TEScreen::moveImage(int dst, int loca, int loce) 810void TEScreen::moveImage(int dst, int loca, int loce)
811{ 811{
812//FIXME: check positions 812//FIXME: check positions
813 if (loce < loca) { 813 if (loce < loca) {
814 // kdDebug() << "WARNING!!! call to TEScreen:moveImage with loce < loca!" << endl; 814 // kdDebug() << "WARNING!!! call to TEScreen:moveImage with loce < loca!" << endl;
815 return; 815 return;
816 } 816 }
817 memmove(&image[dst],&image[loca],(loce-loca+1)*sizeof(ca)); 817 memmove(&image[dst],&image[loca],(loce-loca+1)*sizeof(ca));
818} 818}
819 819
820/*! clear from (including) current cursor position to end of screen. 820/*! clear from (including) current cursor position to end of screen.
821*/ 821*/
822 822
823void TEScreen::clearToEndOfScreen() 823void TEScreen::clearToEndOfScreen()
824{ 824{
825 clearImage(loc(cuX,cuY),loc(columns-1,lines-1),' '); 825 clearImage(loc(cuX,cuY),loc(columns-1,lines-1),' ');
826} 826}
827 827
828/*! clear from begin of screen to (including) current cursor position. 828/*! clear from begin of screen to (including) current cursor position.
829*/ 829*/
830 830
831void TEScreen::clearToBeginOfScreen() 831void TEScreen::clearToBeginOfScreen()
832{ 832{
833 clearImage(loc(0,0),loc(cuX,cuY),' '); 833 clearImage(loc(0,0),loc(cuX,cuY),' ');
834} 834}
835 835
836/*! clear the entire screen. 836/*! clear the entire screen.
837*/ 837*/
838 838
839void TEScreen::clearEntireScreen() 839void TEScreen::clearEntireScreen()
840{ 840{
841 clearImage(loc(0,0),loc(columns-1,lines-1),' '); 841 clearImage(loc(0,0),loc(columns-1,lines-1),' ');
842} 842}
843 843
844/*! fill screen with 'E' 844/*! fill screen with 'E'
845 This is to aid screen alignment 845 This is to aid screen alignment
846*/ 846*/
847 847
848void TEScreen::helpAlign() 848void TEScreen::helpAlign()
849{ 849{
850 clearImage(loc(0,0),loc(columns-1,lines-1),'E'); 850 clearImage(loc(0,0),loc(columns-1,lines-1),'E');
851} 851}
852 852
853/*! clear from (including) current cursor position to end of current cursor line. 853/*! clear from (including) current cursor position to end of current cursor line.
854*/ 854*/
855 855
856void TEScreen::clearToEndOfLine() 856void TEScreen::clearToEndOfLine()
857{ 857{
858 clearImage(loc(cuX,cuY),loc(columns-1,cuY),' '); 858 clearImage(loc(cuX,cuY),loc(columns-1,cuY),' ');
859} 859}
860 860
861/*! clear from begin of current cursor line to (including) current cursor position. 861/*! clear from begin of current cursor line to (including) current cursor position.
862*/ 862*/
863 863
864void TEScreen::clearToBeginOfLine() 864void TEScreen::clearToBeginOfLine()
865{ 865{
866 clearImage(loc(0,cuY),loc(cuX,cuY),' '); 866 clearImage(loc(0,cuY),loc(cuX,cuY),' ');
867} 867}
868 868
869/*! clears entire current cursor line 869/*! clears entire current cursor line
870*/ 870*/
871 871
872void TEScreen::clearEntireLine() 872void TEScreen::clearEntireLine()
873{ 873{
874 clearImage(loc(0,cuY),loc(columns-1,cuY),' '); 874 clearImage(loc(0,cuY),loc(columns-1,cuY),' ');
875} 875}
876 876
877// Rendition ------------------------------------------------------------------ 877// Rendition ------------------------------------------------------------------
878 878
879/*! 879/*!
880 set rendition mode 880 set rendition mode
881*/ 881*/
882 882
883void TEScreen::setRendition(int re) 883void TEScreen::setRendition(int re)
884{ 884{
885 cu_re |= re; 885 cu_re |= re;
886 effectiveRendition(); 886 effectiveRendition();
887} 887}
888 888
889/*! 889/*!
890 reset rendition mode 890 reset rendition mode
891*/ 891*/
892 892
893void TEScreen::resetRendition(int re) 893void TEScreen::resetRendition(int re)
894{ 894{
895 cu_re &= ~re; 895 cu_re &= ~re;
896 effectiveRendition(); 896 effectiveRendition();
897} 897}
898 898
899/*! 899/*!
900*/ 900*/
901 901
902void TEScreen::setDefaultRendition() 902void TEScreen::setDefaultRendition()
903{ 903{
904 setForeColorToDefault(); 904 setForeColorToDefault();
905 setBackColorToDefault(); 905 setBackColorToDefault();
906 cu_re = DEFAULT_RENDITION; 906 cu_re = DEFAULT_RENDITION;
907 effectiveRendition(); 907 effectiveRendition();
908} 908}
909 909
910/*! 910/*!
911*/ 911*/
912 912
913void TEScreen::setForeColor(int fgcolor) 913void TEScreen::setForeColor(int fgcolor)
914{ 914{
915 cu_fg = (fgcolor&7)+((fgcolor&8) ? 4+8 : 2); 915 cu_fg = (fgcolor&7)+((fgcolor&8) ? 4+8 : 2);
916 effectiveRendition(); 916 effectiveRendition();
917} 917}
918 918
919/*! 919/*!
920*/ 920*/
921 921
922void TEScreen::setBackColor(int bgcolor) 922void TEScreen::setBackColor(int bgcolor)
923{ 923{
924 cu_bg = (bgcolor&7)+((bgcolor&8) ? 4+8 : 2); 924 cu_bg = (bgcolor&7)+((bgcolor&8) ? 4+8 : 2);
925 effectiveRendition(); 925 effectiveRendition();
926} 926}
927 927
928/*! 928/*!
929*/ 929*/
930 930
931void TEScreen::setBackColorToDefault() 931void TEScreen::setBackColorToDefault()
932{ 932{
933 cu_bg = DEFAULT_BACK_COLOR; 933 cu_bg = DEFAULT_BACK_COLOR;
934 effectiveRendition(); 934 effectiveRendition();
935} 935}
936 936
937/*! 937/*!
938*/ 938*/
939 939
940void TEScreen::setForeColorToDefault() 940void TEScreen::setForeColorToDefault()
941{ 941{
942 cu_fg = DEFAULT_FORE_COLOR; 942 cu_fg = DEFAULT_FORE_COLOR;
943 effectiveRendition(); 943 effectiveRendition();
944} 944}
945 945
946/* ------------------------------------------------------------------------- */ 946/* ------------------------------------------------------------------------- */
947/* */ 947/* */
948/* Marking & Selection */ 948/* Marking & Selection */
949/* */ 949/* */
950/* ------------------------------------------------------------------------- */ 950/* ------------------------------------------------------------------------- */
951 951
952void TEScreen::clearSelection() 952void TEScreen::clearSelection()
953{ 953{
954 sel_BR = -1; 954 sel_BR = -1;
955 sel_TL = -1; 955 sel_TL = -1;
956 sel_begin = -1; 956 sel_begin = -1;
957} 957}
958 958
959void TEScreen::setSelBeginXY(const int x, const int y) 959void TEScreen::setSelBeginXY(const int x, const int y)
960{ 960{
961 sel_begin = loc(x,y+histCursor) ; 961 sel_begin = loc(x,y+histCursor) ;
962 sel_BR = sel_begin; 962 sel_BR = sel_begin;
963 sel_TL = sel_begin; 963 sel_TL = sel_begin;
964} 964}
965 965
966void TEScreen::setSelExtentXY(const int x, const int y) 966void TEScreen::setSelExtentXY(const int x, const int y)
967{ 967{
968 if (sel_begin == -1) return; 968 if (sel_begin == -1) return;
969 int l = loc(x,y + histCursor); 969 int l = loc(x,y + histCursor);
970 970
971 if (l < sel_begin) 971 if (l < sel_begin)
972 { 972 {
973 sel_TL = l; 973 sel_TL = l;
974 sel_BR = sel_begin; 974 sel_BR = sel_begin;
975 } 975 }
976 else 976 else
977 { 977 {
978 /* FIXME, HACK to correct for x too far to the right... */ 978 /* FIXME, HACK to correct for x too far to the right... */
979 if (( x == columns )|| (x == 0)) l--; 979 if (( x == columns )|| (x == 0)) l--;
980 980
981 sel_TL = sel_begin; 981 sel_TL = sel_begin;
982 sel_BR = l; 982 sel_BR = l;
983 } 983 }
984} 984}
985 985
986QString TEScreen::getSelText(const BOOL preserve_line_breaks) 986QString TEScreen::getSelText(const BOOL preserve_line_breaks)
987{ 987{
988 if (sel_begin == -1) 988 if (sel_begin == -1)
989 return QString::null; // Selection got clear while selecting. 989 return QString::null; // Selection got clear while selecting.
990 990
991 int *m; // buffer to fill. 991 int *m; // buffer to fill.
992 int s, d; // source index, dest. index. 992 int s, d; // source index, dest. index.
993 int hist_BR = loc(0, hist.getLines()); 993 int hist_BR = loc(0, hist.getLines());
994 int hY = sel_TL / columns; 994 int hY = sel_TL / columns;
995 int hX = sel_TL % columns; 995 int hX = sel_TL % columns;
996 int eol; // end of line 996 int eol; // end of line
997 997
998 s = sel_TL; // tracks copy in source. 998 s = sel_TL; // tracks copy in source.
999 999
1000 // allocate buffer for maximum 1000 // allocate buffer for maximum
1001 // possible size... 1001 // possible size...
1002 d = (sel_BR - sel_TL) / columns + 1; 1002 d = (sel_BR - sel_TL) / columns + 1;
1003 m = new int[d * (columns + 1) + 2]; 1003 m = new int[d * (columns + 1) + 2];
1004 d = 0; 1004 d = 0;
1005 1005
1006 while (s <= sel_BR) 1006 while (s <= sel_BR)
1007 { 1007 {
1008 if (s < hist_BR) 1008 if (s < hist_BR)
1009 { // get lines from hist.history 1009 { // get lines from hist.history
1010 // buffer. 1010 // buffer.
1011 eol = hist.getLineLen(hY); 1011 eol = hist.getLineLen(hY);
1012 1012
1013 if ((hY == (sel_BR / columns)) && 1013 if ((hY == (sel_BR / columns)) &&
1014 (eol >= (sel_BR % columns))) 1014 (eol >= (sel_BR % columns)))
1015 { 1015 {
1016 eol = sel_BR % columns + 1; 1016 eol = sel_BR % columns + 1;
1017 } 1017 }
1018 1018
1019 while (hX < eol) 1019 while (hX < eol)
1020 { 1020 {
1021 m[d++] = hist.getCell(hY, hX++).c; 1021 m[d++] = hist.getCell(hY, hX++).c;
1022 s++; 1022 s++;
1023 } 1023 }
1024 1024
1025 if (s <= sel_BR) 1025 if (s <= sel_BR)
1026 { 1026 {
1027 // The line break handling 1027 // The line break handling
1028 // It's different from the screen 1028 // It's different from the screen
1029 // image case! 1029 // image case!
1030 if (eol % columns == 0) 1030 if (eol % columns == 0)
1031 { 1031 {
1032 // That's either a completely filled 1032 // That's either a completely filled
1033 // line or an empty line 1033 // line or an empty line
1034 if (eol == 0) 1034 if (eol == 0)
1035 { 1035 {
1036 m[d++] = '\n'; 1036 m[d++] = '\n';
1037 } 1037 }
1038 else 1038 else
1039 { 1039 {
1040 // We have a full line. 1040 // We have a full line.
1041 // FIXME: How can we handle newlines 1041 // FIXME: How can we handle newlines
1042 // at this position?! 1042 // at this position?!
1043 } 1043 }
1044 } 1044 }
1045 else if ((eol + 1) % columns == 0) 1045 else if ((eol + 1) % columns == 0)
1046 { 1046 {
1047 // FIXME: We don't know if this was a 1047 // FIXME: We don't know if this was a
1048 // space at the last position or a 1048 // space at the last position or a
1049 // short line!! 1049 // short line!!
1050 m[d++] = ' '; 1050 m[d++] = ' ';
1051 } 1051 }
1052 else 1052 else
1053 { 1053 {
1054 // We have a short line here. Put a 1054 // We have a short line here. Put a
1055 // newline or a space into the 1055 // newline or a space into the
1056 // buffer. 1056 // buffer.
1057 m[d++] = preserve_line_breaks ? '\n' : ' '; 1057 m[d++] = preserve_line_breaks ? '\n' : ' ';
1058 } 1058 }
1059 } 1059 }
1060 1060
1061 hY++; 1061 hY++;
1062 hX = 0; 1062 hX = 0;
1063 s = hY * columns; 1063 s = hY * columns;
1064 } 1064 }
1065 else 1065 else
1066 { // or from screen image. 1066 { // or from screen image.
1067 eol = (s / columns + 1) * columns - 1; 1067 eol = (s / columns + 1) * columns - 1;
1068 1068
1069 if (eol < sel_BR) 1069 if (eol < sel_BR)
1070 { 1070 {
1071 while ((eol > s) && 1071 while ((eol > s) &&
1072 isspace(image[eol - hist_BR].c)) 1072 isspace(image[eol - hist_BR].c))
1073 { 1073 {
1074 eol--; 1074 eol--;
1075 } 1075 }
1076 } 1076 }
1077 else 1077 else
1078 { 1078 {
1079 eol = sel_BR; 1079 eol = sel_BR;
1080 } 1080 }
1081 1081
1082 while (s <= eol) 1082 while (s <= eol)
1083 { 1083 {
1084 m[d++] = image[s++ - hist_BR].c; 1084 m[d++] = image[s++ - hist_BR].c;
1085 } 1085 }
1086 1086
1087 if (eol < sel_BR) 1087 if (eol < sel_BR)
1088 { 1088 {
1089 // eol processing see below ... 1089 // eol processing see below ...
1090 if ((eol + 1) % columns == 0) 1090 if ((eol + 1) % columns == 0)
1091 { 1091 {
1092 if (image[eol - hist_BR].c == ' ') 1092 if (image[eol - hist_BR].c == ' ')
1093 { 1093 {
1094 m[d++] = ' '; 1094 m[d++] = ' ';
1095 } 1095 }
1096 } 1096 }
1097 else 1097 else
1098 { 1098 {
1099 m[d++] = ((preserve_line_breaks || 1099 m[d++] = ((preserve_line_breaks ||
1100 ((eol % columns) == 0)) ? 1100 ((eol % columns) == 0)) ?
1101 '\n' : ' '); 1101 '\n' : ' ');
1102 } 1102 }
1103 } 1103 }
1104 1104
1105 s = (eol / columns + 1) * columns; 1105 s = (eol / columns + 1) * columns;
1106 } 1106 }
1107 } 1107 }
1108 1108
1109 QChar* qc = new QChar[d]; 1109 QChar* qc = new QChar[d];
1110 1110
1111 for (int i = 0; i < d; i++) 1111 for (int i = 0; i < d; i++)
1112 { 1112 {
1113 qc[i] = m[i]; 1113 qc[i] = m[i];
1114 } 1114 }
1115 1115
1116 QString res(qc, d); 1116 QString res(qc, d);
1117 1117
1118 delete m; 1118 delete m;
1119 delete qc; 1119 delete qc;
1120 1120
1121 return res; 1121 return res;
1122} 1122}
1123QString TEScreen::getHistory() {
1124 sel_begin = 0;
1125 sel_BR = sel_begin;
1126 sel_TL = sel_begin;
1127 setSelExtentXY(columns-1,lines-1);
1128 QString tmp=getSelText(true);
1129 while (tmp.at(tmp.length()-2).unicode()==10 && tmp.at(tmp.length()-1).unicode()==10)
1130 tmp.truncate(tmp.length()-1);
1131
1132 return tmp;
1133}
1123/* above ... end of line processing for selection -- psilva 1134/* above ... end of line processing for selection -- psilva
1124cases: 1135cases:
1125 1136
11261) (eol+1)%columns == 0 --> the whole line is filled. 11371) (eol+1)%columns == 0 --> the whole line is filled.
1127 If the last char is a space, insert (preserve) space. otherwise 1138 If the last char is a space, insert (preserve) space. otherwise
1128 leave the text alone, so that words that are broken by linewrap 1139 leave the text alone, so that words that are broken by linewrap
1129 are preserved. 1140 are preserved.
1130 1141
1131FIXME: 1142FIXME:
1132 * this suppresses \n for command output that is 1143 * this suppresses \n for command output that is
1133 sized to the exact column width of the screen. 1144 sized to the exact column width of the screen.
1134 1145
11352) eol%columns == 0 --> blank line. 11462) eol%columns == 0 --> blank line.
1136 insert a \n unconditionally. 1147 insert a \n unconditionally.
1137 Do it either you would because you are in preserve_line_break mode, 1148 Do it either you would because you are in preserve_line_break mode,
1138 or because it's an ASCII paragraph delimiter, so even when 1149 or because it's an ASCII paragraph delimiter, so even when
1139 not preserving line_breaks, you want to preserve paragraph breaks. 1150 not preserving line_breaks, you want to preserve paragraph breaks.
1140 1151
1141 3) else --> partially filled line 1152 3) else --> partially filled line
1142 insert a \n in preserve line break mode, else a space 1153 insert a \n in preserve line break mode, else a space
1143 The space prevents concatenation of the last word of one 1154 The space prevents concatenation of the last word of one
1144 line with the first of the next. 1155 line with the first of the next.
1145 1156
1146*/ 1157*/
1147 1158
1148void TEScreen::addHistLine() 1159void TEScreen::addHistLine()
1149{ 1160{
1150 assert(hasScroll() || histCursor == 0); 1161 assert(hasScroll() || histCursor == 0);
1151 1162
1152 // add to hist buffer 1163 // add to hist buffer
1153 // we have to take care about scrolling, too... 1164 // we have to take care about scrolling, too...
1154 1165
1155 if (hasScroll()) 1166 if (hasScroll())
1156 { ca dft; 1167 { ca dft;
1157 1168
1158 int end = columns-1; 1169 int end = columns-1;
1159 while (end >= 0 && image[end] == dft) 1170 while (end >= 0 && image[end] == dft)
1160 end -= 1; 1171 end -= 1;
1161 1172
1162 hist.addCells(image,end+1); 1173 hist.addCells(image,end+1);
1163 hist.addLine(); 1174 hist.addLine();
1164 1175
1165 // adjust history cursor 1176 // adjust history cursor
1166 histCursor += (hist.getLines()-1 == histCursor); 1177 histCursor += (hist.getLines()-1 == histCursor);
1167 } 1178 }
1168 1179
1169 if (!hasScroll()) histCursor = 0; //FIXME: a poor workaround 1180 if (!hasScroll()) histCursor = 0; //FIXME: a poor workaround
1170} 1181}
1171 1182
1172void TEScreen::setHistCursor(int cursor) 1183void TEScreen::setHistCursor(int cursor)
1173{ 1184{
1174 histCursor = cursor; //FIXME:rangecheck 1185 histCursor = cursor; //FIXME:rangecheck
1175} 1186}
1176 1187
1177int TEScreen::getHistCursor() 1188int TEScreen::getHistCursor()
1178{ 1189{
1179 return histCursor; 1190 return histCursor;
1180} 1191}
1181 1192
1182int TEScreen::getHistLines() 1193int TEScreen::getHistLines()
1183{ 1194{
1184 return hist.getLines(); 1195 return hist.getLines();
1185} 1196}
1186 1197
1187void TEScreen::setScroll(bool on) 1198void TEScreen::setScroll(bool on)
1188{ 1199{
1189 histCursor = 0; 1200 histCursor = 0;
1190 clearSelection(); 1201 clearSelection();
1191 hist.setScroll(on); 1202 hist.setScroll(on);
1192} 1203}
1193 1204
1194bool TEScreen::hasScroll() 1205bool TEScreen::hasScroll()
1195{ 1206{
1196 return hist.hasScroll(); 1207 return hist.hasScroll();
1197} 1208}
diff --git a/noncore/apps/opie-console/TEScreen.h b/noncore/apps/opie-console/TEScreen.h
index 473ce79..a840b44 100644
--- a/noncore/apps/opie-console/TEScreen.h
+++ b/noncore/apps/opie-console/TEScreen.h
@@ -1,259 +1,261 @@
1/* -------------------------------------------------------------------------- */ 1/* -------------------------------------------------------------------------- */
2/* */ 2/* */
3/* [te_screen.h] Screen Data Type */ 3/* [te_screen.h] Screen Data Type */
4/* */ 4/* */
5/* -------------------------------------------------------------------------- */ 5/* -------------------------------------------------------------------------- */
6/* */ 6/* */
7/* Copyright (c) 1997,1998 by Lars Doelle <lars.doelle@on-line.de> */ 7/* Copyright (c) 1997,1998 by Lars Doelle <lars.doelle@on-line.de> */
8/* */ 8/* */
9/* This file is part of Konsole - an X terminal for KDE */ 9/* This file is part of Konsole - an X terminal for KDE */
10/* */ 10/* */
11/* -------------------------------------------------------------------------- */ 11/* -------------------------------------------------------------------------- */
12 /* */ 12 /* */
13/* Ported Konsole to Qt/Embedded */ 13/* Ported Konsole to Qt/Embedded */
14 /* */ 14 /* */
15/* Copyright (C) 2000 by John Ryland <jryland@trolltech.com> */ 15/* Copyright (C) 2000 by John Ryland <jryland@trolltech.com> */
16 /* */ 16 /* */
17/* -------------------------------------------------------------------------- */ 17/* -------------------------------------------------------------------------- */
18 18
19#ifndef TESCREEN_H 19#ifndef TESCREEN_H
20#define TESCREEN_H 20#define TESCREEN_H
21 21
22/*! \file 22/*! \file
23*/ 23*/
24 24
25#include "TECommon.h" 25#include "TECommon.h"
26#include "TEHistory.h" 26#include "TEHistory.h"
27 27
28#define MODE_Origin 0 28#define MODE_Origin 0
29#define MODE_Wrap 1 29#define MODE_Wrap 1
30#define MODE_Insert 2 30#define MODE_Insert 2
31#define MODE_Screen 3 31#define MODE_Screen 3
32#define MODE_Cursor 4 32#define MODE_Cursor 4
33#define MODE_NewLine 5 33#define MODE_NewLine 5
34#define MODES_SCREEN 6 34#define MODES_SCREEN 6
35 35
36/*! 36/*!
37*/ 37*/
38struct ScreenParm 38struct ScreenParm
39{ 39{
40 int mode[MODES_SCREEN]; 40 int mode[MODES_SCREEN];
41}; 41};
42 42
43 43
44class TEScreen 44class TEScreen
45{ 45{
46public: 46public:
47 TEScreen(int lines, int columns); 47 TEScreen(int lines, int columns);
48 ~TEScreen(); 48 ~TEScreen();
49 49
50public: // these are all `Screen' operations 50public: // these are all `Screen' operations
51 // 51 //
52 // VT100/2 Operations ------------------ 52 // VT100/2 Operations ------------------
53 // 53 //
54 // Cursor Movement 54 // Cursor Movement
55 // 55 //
56 void cursorUp (int n); 56 void cursorUp (int n);
57 void cursorDown (int n); 57 void cursorDown (int n);
58 void cursorLeft (int n); 58 void cursorLeft (int n);
59 void cursorRight (int n); 59 void cursorRight (int n);
60 void setCursorY (int y); 60 void setCursorY (int y);
61 void setCursorX (int x); 61 void setCursorX (int x);
62 void setCursorYX (int y, int x); 62 void setCursorYX (int y, int x);
63 void setMargins (int t, int b); 63 void setMargins (int t, int b);
64 // 64 //
65 // Cursor Movement with Scrolling 65 // Cursor Movement with Scrolling
66 // 66 //
67 void NewLine (); 67 void NewLine ();
68 void NextLine (); 68 void NextLine ();
69 void index (); 69 void index ();
70 void reverseIndex(); 70 void reverseIndex();
71 // 71 //
72 void Return (); 72 void Return ();
73 void BackSpace (); 73 void BackSpace ();
74 void Tabulate (); 74 void Tabulate ();
75 // 75 //
76 // Editing 76 // Editing
77 // 77 //
78 void eraseChars (int n); 78 void eraseChars (int n);
79 void deleteChars (int n); 79 void deleteChars (int n);
80 void insertChars (int n); 80 void insertChars (int n);
81 void deleteLines (int n); 81 void deleteLines (int n);
82 void insertLines (int n); 82 void insertLines (int n);
83 // 83 //
84 // ------------------------------------- 84 // -------------------------------------
85 // 85 //
86 void clearTabStops(); 86 void clearTabStops();
87 void changeTabStop(bool set); 87 void changeTabStop(bool set);
88 // 88 //
89 void resetMode (int n); 89 void resetMode (int n);
90 void setMode (int n); 90 void setMode (int n);
91 void saveMode (int n); 91 void saveMode (int n);
92 void restoreMode (int n); 92 void restoreMode (int n);
93 // 93 //
94 void saveCursor (); 94 void saveCursor ();
95 void restoreCursor(); 95 void restoreCursor();
96 // 96 //
97 // ------------------------------------- 97 // -------------------------------------
98 // 98 //
99 void clearEntireScreen(); 99 void clearEntireScreen();
100 void clearToEndOfScreen(); 100 void clearToEndOfScreen();
101 void clearToBeginOfScreen(); 101 void clearToBeginOfScreen();
102 // 102 //
103 void clearEntireLine(); 103 void clearEntireLine();
104 void clearToEndOfLine(); 104 void clearToEndOfLine();
105 void clearToBeginOfLine(); 105 void clearToBeginOfLine();
106 // 106 //
107 void helpAlign (); 107 void helpAlign ();
108 // 108 //
109 // ------------------------------------- 109 // -------------------------------------
110 // 110 //
111 void setRendition (int rendition); 111 void setRendition (int rendition);
112 void resetRendition(int rendition); 112 void resetRendition(int rendition);
113 void setForeColor (int fgcolor); 113 void setForeColor (int fgcolor);
114 void setBackColor (int bgcolor); 114 void setBackColor (int bgcolor);
115 // 115 //
116 void setDefaultRendition(); 116 void setDefaultRendition();
117 void setForeColorToDefault(); 117 void setForeColorToDefault();
118 void setBackColorToDefault(); 118 void setBackColorToDefault();
119 // 119 //
120 // ------------------------------------- 120 // -------------------------------------
121 // 121 //
122 BOOL getMode (int n); 122 BOOL getMode (int n);
123 // 123 //
124 // only for report cursor position 124 // only for report cursor position
125 // 125 //
126 int getCursorX(); 126 int getCursorX();
127 int getCursorY(); 127 int getCursorY();
128 // 128 //
129 // ------------------------------------- 129 // -------------------------------------
130 // 130 //
131 void clear(); 131 void clear();
132 void home(); 132 void home();
133 void reset(); 133 void reset();
134 // 134 //
135 void ShowCharacter(unsigned short c); 135 void ShowCharacter(unsigned short c);
136 // 136 //
137 void resizeImage(int new_lines, int new_columns); 137 void resizeImage(int new_lines, int new_columns);
138 // 138 //
139 ca* getCookedImage(); 139 ca* getCookedImage();
140 140
141 /*! return the number of lines. */ 141 /*! return the number of lines. */
142 int getLines() { return lines; } 142 int getLines() { return lines; }
143 /*! return the number of columns. */ 143 /*! return the number of columns. */
144 int getColumns() { return columns; } 144 int getColumns() { return columns; }
145 145
146 /*! set the position of the history cursor. */ 146 /*! set the position of the history cursor. */
147 void setHistCursor(int cursor); 147 void setHistCursor(int cursor);
148 /*! return the position of the history cursor. */ 148 /*! return the position of the history cursor. */
149 int getHistCursor(); 149 int getHistCursor();
150 150
151 int getHistLines (); 151 int getHistLines ();
152 void setScroll(bool on); 152 void setScroll(bool on);
153 bool hasScroll(); 153 bool hasScroll();
154 154
155 // 155 //
156 // Selection 156 // Selection
157 // 157 //
158 void setSelBeginXY(const int x, const int y); 158 void setSelBeginXY(const int x, const int y);
159 void setSelExtentXY(const int x, const int y); 159 void setSelExtentXY(const int x, const int y);
160 void clearSelection(); 160 void clearSelection();
161 QString getSelText(const BOOL preserve_line_breaks); 161 QString getSelText(const BOOL preserve_line_breaks);
162 162
163 void checkSelection(int from, int to); 163 void checkSelection(int from, int to);
164 164
165 QString getHistory();
166
165private: // helper 167private: // helper
166 168
167 void clearImage(int loca, int loce, char c); 169 void clearImage(int loca, int loce, char c);
168 void moveImage(int dst, int loca, int loce); 170 void moveImage(int dst, int loca, int loce);
169 171
170 void scrollUp(int from, int i); 172 void scrollUp(int from, int i);
171 void scrollDown(int from, int i); 173 void scrollDown(int from, int i);
172 174
173 void addHistLine(); 175 void addHistLine();
174 176
175 void initTabStops(); 177 void initTabStops();
176 178
177 void effectiveRendition(); 179 void effectiveRendition();
178 void reverseRendition(ca* p); 180 void reverseRendition(ca* p);
179 181
180private: 182private:
181 183
182 /* 184 /*
183 The state of the screen is more complex as one would 185 The state of the screen is more complex as one would
184 expect first. The screem does really do part of the 186 expect first. The screem does really do part of the
185 emulation providing state informations in form of modes, 187 emulation providing state informations in form of modes,
186 margins, tabulators, cursor etc. 188 margins, tabulators, cursor etc.
187 189
188 Even more unexpected are variables to save and restore 190 Even more unexpected are variables to save and restore
189 parts of the state. 191 parts of the state.
190 */ 192 */
191 193
192 // screen image ---------------- 194 // screen image ----------------
193 195
194 int lines; 196 int lines;
195 int columns; 197 int columns;
196 ca *image; // [lines][columns] 198 ca *image; // [lines][columns]
197 199
198 // history buffer --------------- 200 // history buffer ---------------
199 201
200 int histCursor; // display position relative to start of the history buffer 202 int histCursor; // display position relative to start of the history buffer
201 HistoryScroll hist; 203 HistoryScroll hist;
202 204
203 // cursor location 205 // cursor location
204 206
205 int cuX; 207 int cuX;
206 int cuY; 208 int cuY;
207 209
208 // cursor color and rendition info 210 // cursor color and rendition info
209 211
210 UINT8 cu_fg; // foreground 212 UINT8 cu_fg; // foreground
211 UINT8 cu_bg; // background 213 UINT8 cu_bg; // background
212 UINT8 cu_re; // rendition 214 UINT8 cu_re; // rendition
213 215
214 // margins ---------------- 216 // margins ----------------
215 217
216 int tmargin; // top margin 218 int tmargin; // top margin
217 int bmargin; // bottom margin 219 int bmargin; // bottom margin
218 220
219 // states ---------------- 221 // states ----------------
220 222
221 ScreenParm currParm; 223 ScreenParm currParm;
222 224
223 // ---------------------------- 225 // ----------------------------
224 226
225 bool* tabstops; 227 bool* tabstops;
226 228
227 // selection ------------------- 229 // selection -------------------
228 230
229 int sel_begin; // The first location selected. 231 int sel_begin; // The first location selected.
230 int sel_TL; // TopLeft Location. 232 int sel_TL; // TopLeft Location.
231 int sel_BR; // Bottom Right Location. 233 int sel_BR; // Bottom Right Location.
232 234
233 // effective colors and rendition ------------ 235 // effective colors and rendition ------------
234 236
235 UINT8 ef_fg; // These are derived from 237 UINT8 ef_fg; // These are derived from
236 UINT8 ef_bg; // the cu_* variables above 238 UINT8 ef_bg; // the cu_* variables above
237 UINT8 ef_re; // to speed up operation 239 UINT8 ef_re; // to speed up operation
238 240
239 // 241 //
240 // save cursor, rendition & states ------------ 242 // save cursor, rendition & states ------------
241 // 243 //
242 244
243 // cursor location 245 // cursor location
244 246
245 int sa_cuX; 247 int sa_cuX;
246 int sa_cuY; 248 int sa_cuY;
247 249
248 // rendition info 250 // rendition info
249 251
250 UINT8 sa_cu_re; 252 UINT8 sa_cu_re;
251 UINT8 sa_cu_fg; 253 UINT8 sa_cu_fg;
252 UINT8 sa_cu_bg; 254 UINT8 sa_cu_bg;
253 255
254 // modes 256 // modes
255 257
256 ScreenParm saveParm; 258 ScreenParm saveParm;
257}; 259};
258 260
259#endif // TESCREEN_H 261#endif // TESCREEN_H
diff --git a/noncore/apps/opie-console/TEmulation.cpp b/noncore/apps/opie-console/TEmulation.cpp
index 7a0c624..3b1b9e1 100644
--- a/noncore/apps/opie-console/TEmulation.cpp
+++ b/noncore/apps/opie-console/TEmulation.cpp
@@ -1,364 +1,366 @@
1/* -------------------------------------------------------------------------- */ 1/* -------------------------------------------------------------------------- */
2/* */ 2/* */
3/* [TEmulation.cpp] Terminal Emulation Decoder */ 3/* [TEmulation.cpp] Terminal Emulation Decoder */
4/* */ 4/* */
5/* -------------------------------------------------------------------------- */ 5/* -------------------------------------------------------------------------- */
6/* */ 6/* */
7/* Copyright (c) 1997,1998 by Lars Doelle <lars.doelle@on-line.de> */ 7/* Copyright (c) 1997,1998 by Lars Doelle <lars.doelle@on-line.de> */
8/* */ 8/* */
9/* This file is part of Konsole - an X terminal for KDE */ 9/* This file is part of Konsole - an X terminal for KDE */
10/* */ 10/* */
11/* -------------------------------------------------------------------------- */ 11/* -------------------------------------------------------------------------- */
12 /* */ 12 /* */
13/* Ported Konsole to Qt/Embedded */ 13/* Ported Konsole to Qt/Embedded */
14 /* */ 14 /* */
15/* Copyright (C) 2000 by John Ryland <jryland@trolltech.com> */ 15/* Copyright (C) 2000 by John Ryland <jryland@trolltech.com> */
16 /* */ 16 /* */
17/* -------------------------------------------------------------------------- */ 17/* -------------------------------------------------------------------------- */
18 18
19/*! \class TEmulation 19/*! \class TEmulation
20 20
21 \brief Mediator between TEWidget and TEScreen. 21 \brief Mediator between TEWidget and TEScreen.
22 22
23 This class is responsible to scan the escapes sequences of the terminal 23 This class is responsible to scan the escapes sequences of the terminal
24 emulation and to map it to their corresponding semantic complements. 24 emulation and to map it to their corresponding semantic complements.
25 Thus this module knows mainly about decoding escapes sequences and 25 Thus this module knows mainly about decoding escapes sequences and
26 is a stateless device w.r.t. the semantics. 26 is a stateless device w.r.t. the semantics.
27 27
28 It is also responsible to refresh the TEWidget by certain rules. 28 It is also responsible to refresh the TEWidget by certain rules.
29 29
30 \sa TEWidget \sa TEScreen 30 \sa TEWidget \sa TEScreen
31 31
32 \par A note on refreshing 32 \par A note on refreshing
33 33
34 Although the modifications to the current screen image could immediately 34 Although the modifications to the current screen image could immediately
35 be propagated via `TEWidget' to the graphical surface, we have chosen 35 be propagated via `TEWidget' to the graphical surface, we have chosen
36 another way here. 36 another way here.
37 37
38 The reason for doing so is twofold. 38 The reason for doing so is twofold.
39 39
40 First, experiments show that directly displaying the operation results 40 First, experiments show that directly displaying the operation results
41 in slowing down the overall performance of emulations. Displaying 41 in slowing down the overall performance of emulations. Displaying
42 individual characters using X11 creates a lot of overhead. 42 individual characters using X11 creates a lot of overhead.
43 43
44 Second, by using the following refreshing method, the screen operations 44 Second, by using the following refreshing method, the screen operations
45 can be completely separated from the displaying. This greatly simplifies 45 can be completely separated from the displaying. This greatly simplifies
46 the programmer's task of coding and maintaining the screen operations, 46 the programmer's task of coding and maintaining the screen operations,
47 since one need not worry about differential modifications on the 47 since one need not worry about differential modifications on the
48 display affecting the operation of concern. 48 display affecting the operation of concern.
49 49
50 We use a refreshing algorithm here that has been adoped from rxvt/kvt. 50 We use a refreshing algorithm here that has been adoped from rxvt/kvt.
51 51
52 By this, refreshing is driven by a timer, which is (re)started whenever 52 By this, refreshing is driven by a timer, which is (re)started whenever
53 a new bunch of data to be interpreted by the emulation arives at `onRcvBlock'. 53 a new bunch of data to be interpreted by the emulation arives at `onRcvBlock'.
54 As soon as no more data arrive for `BULK_TIMEOUT' milliseconds, we trigger 54 As soon as no more data arrive for `BULK_TIMEOUT' milliseconds, we trigger
55 refresh. This rule suits both bulk display operation as done by curses as 55 refresh. This rule suits both bulk display operation as done by curses as
56 well as individual characters typed. 56 well as individual characters typed.
57 (BULK_TIMEOUT < 1000 / max characters received from keyboard per second). 57 (BULK_TIMEOUT < 1000 / max characters received from keyboard per second).
58 58
59 Additionally, we trigger refreshing by newlines comming in to make visual 59 Additionally, we trigger refreshing by newlines comming in to make visual
60 snapshots of lists as produced by `cat', `ls' and likely programs, thereby 60 snapshots of lists as produced by `cat', `ls' and likely programs, thereby
61 producing the illusion of a permanent and immediate display operation. 61 producing the illusion of a permanent and immediate display operation.
62 62
63 As a sort of catch-all needed for cases where none of the above 63 As a sort of catch-all needed for cases where none of the above
64 conditions catch, the screen refresh is also triggered by a count 64 conditions catch, the screen refresh is also triggered by a count
65 of incoming bulks (`bulk_incnt'). 65 of incoming bulks (`bulk_incnt').
66*/ 66*/
67 67
68/* FIXME 68/* FIXME
69 - evtl. the bulk operations could be made more transparent. 69 - evtl. the bulk operations could be made more transparent.
70*/ 70*/
71 71
72#include "TEmulation.h" 72#include "TEmulation.h"
73#include "TEWidget.h" 73#include "TEWidget.h"
74#include "TEScreen.h" 74#include "TEScreen.h"
75#include <stdio.h> 75#include <stdio.h>
76#include <stdlib.h> 76#include <stdlib.h>
77#include <unistd.h> 77#include <unistd.h>
78#include <qkeycode.h> 78#include <qkeycode.h>
79 79
80 80
81/* ------------------------------------------------------------------------- */ 81/* ------------------------------------------------------------------------- */
82/* */ 82/* */
83/* TEmulation */ 83/* TEmulation */
84/* */ 84/* */
85/* ------------------------------------------------------------------------- */ 85/* ------------------------------------------------------------------------- */
86 86
87#define CNTL(c) ((c)-'@') 87#define CNTL(c) ((c)-'@')
88 88
89/*! 89/*!
90*/ 90*/
91 91
92TEmulation::TEmulation(TEWidget* gui) 92TEmulation::TEmulation(TEWidget* gui)
93: decoder((QTextDecoder*)NULL) 93: decoder((QTextDecoder*)NULL)
94{ 94{
95 this->gui = gui; 95 this->gui = gui;
96 96
97 screen[0] = new TEScreen(gui->Lines(),gui->Columns()); 97 screen[0] = new TEScreen(gui->Lines(),gui->Columns());
98 screen[1] = new TEScreen(gui->Lines(),gui->Columns()); 98 screen[1] = new TEScreen(gui->Lines(),gui->Columns());
99 scr = screen[0]; 99 scr = screen[0];
100 100
101 bulk_nlcnt = 0; // reset bulk newline counter 101 bulk_nlcnt = 0; // reset bulk newline counter
102 bulk_incnt = 0; // reset bulk counter 102 bulk_incnt = 0; // reset bulk counter
103 connected = FALSE; 103 connected = FALSE;
104 104
105 QObject::connect(&bulk_timer, SIGNAL(timeout()), this, SLOT(showBulk()) ); 105 QObject::connect(&bulk_timer, SIGNAL(timeout()), this, SLOT(showBulk()) );
106 QObject::connect(gui,SIGNAL(changedImageSizeSignal(int,int)), 106 QObject::connect(gui,SIGNAL(changedImageSizeSignal(int,int)),
107 this,SLOT(onImageSizeChange(int,int))); 107 this,SLOT(onImageSizeChange(int,int)));
108 QObject::connect(gui,SIGNAL(changedHistoryCursor(int)), 108 QObject::connect(gui,SIGNAL(changedHistoryCursor(int)),
109 this,SLOT(onHistoryCursorChange(int))); 109 this,SLOT(onHistoryCursorChange(int)));
110 QObject::connect(gui,SIGNAL(keyPressedSignal(QKeyEvent*)), 110 QObject::connect(gui,SIGNAL(keyPressedSignal(QKeyEvent*)),
111 this,SLOT(onKeyPress(QKeyEvent*))); 111 this,SLOT(onKeyPress(QKeyEvent*)));
112 QObject::connect(gui,SIGNAL(beginSelectionSignal(const int,const int)), 112 QObject::connect(gui,SIGNAL(beginSelectionSignal(const int,const int)),
113 this,SLOT(onSelectionBegin(const int,const int)) ); 113 this,SLOT(onSelectionBegin(const int,const int)) );
114 QObject::connect(gui,SIGNAL(extendSelectionSignal(const int,const int)), 114 QObject::connect(gui,SIGNAL(extendSelectionSignal(const int,const int)),
115 this,SLOT(onSelectionExtend(const int,const int)) ); 115 this,SLOT(onSelectionExtend(const int,const int)) );
116 QObject::connect(gui,SIGNAL(endSelectionSignal(const BOOL)), 116 QObject::connect(gui,SIGNAL(endSelectionSignal(const BOOL)),
117 this,SLOT(setSelection(const BOOL)) ); 117 this,SLOT(setSelection(const BOOL)) );
118 QObject::connect(gui,SIGNAL(clearSelectionSignal()), 118 QObject::connect(gui,SIGNAL(clearSelectionSignal()),
119 this,SLOT(clearSelection()) ); 119 this,SLOT(clearSelection()) );
120} 120}
121 121
122/*! 122/*!
123*/ 123*/
124 124
125TEmulation::~TEmulation() 125TEmulation::~TEmulation()
126{ 126{
127 delete screen[0]; 127 delete screen[0];
128 delete screen[1]; 128 delete screen[1];
129 bulk_timer.stop(); 129 bulk_timer.stop();
130} 130}
131 131
132/*! change between primary and alternate screen 132/*! change between primary and alternate screen
133*/ 133*/
134 134
135void TEmulation::setScreen(int n) 135void TEmulation::setScreen(int n)
136{ 136{
137 scr = screen[n&1]; 137 scr = screen[n&1];
138} 138}
139 139
140void TEmulation::setHistory(bool on) 140void TEmulation::setHistory(bool on)
141{ 141{
142 screen[0]->setScroll(on); 142 screen[0]->setScroll(on);
143 if (!connected) return; 143 if (!connected) return;
144 showBulk(); 144 showBulk();
145} 145}
146 146
147bool TEmulation::history() 147bool TEmulation::history()
148{ 148{
149 return screen[0]->hasScroll(); 149 return screen[0]->hasScroll();
150} 150}
151 151
152void TEmulation::setCodec(int c) 152void TEmulation::setCodec(int c)
153{ 153{
154 //FIXME: check whether we have to free codec 154 //FIXME: check whether we have to free codec
155 codec = c ? QTextCodec::codecForName("utf8") 155 codec = c ? QTextCodec::codecForName("utf8")
156 : QTextCodec::codecForLocale(); 156 : QTextCodec::codecForLocale();
157 if (decoder) delete decoder; 157 if (decoder) delete decoder;
158 decoder = codec->makeDecoder(); 158 decoder = codec->makeDecoder();
159} 159}
160 160
161void TEmulation::setKeytrans(int no) 161void TEmulation::setKeytrans(int no)
162{ 162{
163 keytrans = KeyTrans::find(no); 163 keytrans = KeyTrans::find(no);
164} 164}
165 165
166void TEmulation::setKeytrans(const char * no) 166void TEmulation::setKeytrans(const char * no)
167{ 167{
168 keytrans = KeyTrans::find(no); 168 keytrans = KeyTrans::find(no);
169} 169}
170 170
171// Interpreting Codes --------------------------------------------------------- 171// Interpreting Codes ---------------------------------------------------------
172 172
173/* 173/*
174 This section deals with decoding the incoming character stream. 174 This section deals with decoding the incoming character stream.
175 Decoding means here, that the stream is first seperated into `tokens' 175 Decoding means here, that the stream is first seperated into `tokens'
176 which are then mapped to a `meaning' provided as operations by the 176 which are then mapped to a `meaning' provided as operations by the
177 `Screen' class. 177 `Screen' class.
178*/ 178*/
179 179
180/*! 180/*!
181*/ 181*/
182 182
183void TEmulation::onRcvChar(int c) 183void TEmulation::onRcvChar(int c)
184// process application unicode input to terminal 184// process application unicode input to terminal
185// this is a trivial scanner 185// this is a trivial scanner
186{ 186{
187 c &= 0xff; 187 c &= 0xff;
188 switch (c) 188 switch (c)
189 { 189 {
190 case '\b' : scr->BackSpace(); break; 190 case '\b' : scr->BackSpace(); break;
191 case '\t' : scr->Tabulate(); break; 191 case '\t' : scr->Tabulate(); break;
192 case '\n' : scr->NewLine(); break; 192 case '\n' : scr->NewLine(); break;
193 case '\r' : scr->Return(); break; 193 case '\r' : scr->Return(); break;
194 case 0x07 : gui->Bell(); break; 194 case 0x07 : gui->Bell(); break;
195 default : scr->ShowCharacter(c); break; 195 default : scr->ShowCharacter(c); break;
196 }; 196 };
197} 197}
198 198
199/* ------------------------------------------------------------------------- */ 199/* ------------------------------------------------------------------------- */
200/* */ 200/* */
201/* Keyboard Handling */ 201/* Keyboard Handling */
202/* */ 202/* */
203/* ------------------------------------------------------------------------- */ 203/* ------------------------------------------------------------------------- */
204 204
205/*! 205/*!
206*/ 206*/
207 207
208void TEmulation::onKeyPress( QKeyEvent* ev ) 208void TEmulation::onKeyPress( QKeyEvent* ev )
209{ 209{
210 qWarning("onKeyPress,...."); 210 qWarning("onKeyPress,....");
211 if (!connected) return; // someone else gets the keys 211 if (!connected) return; // someone else gets the keys
212 if (scr->getHistCursor() != scr->getHistLines()); 212 if (scr->getHistCursor() != scr->getHistLines());
213 scr->setHistCursor(scr->getHistLines()); 213 scr->setHistCursor(scr->getHistLines());
214 if (!ev->text().isEmpty()) 214 if (!ev->text().isEmpty())
215 { // A block of text 215 { // A block of text
216 // Note that the text is proper unicode. 216 // Note that the text is proper unicode.
217 // We should do a conversion here, but since this 217 // We should do a conversion here, but since this
218 // routine will never be used, we simply emit plain ascii. 218 // routine will never be used, we simply emit plain ascii.
219 emit sndBlock(ev->text().ascii(),ev->text().length()); 219 emit sndBlock(ev->text().ascii(),ev->text().length());
220 } 220 }
221 else if (ev->ascii()>0) 221 else if (ev->ascii()>0)
222 { unsigned char c[1]; 222 { unsigned char c[1];
223 c[0] = ev->ascii(); 223 c[0] = ev->ascii();
224 emit sndBlock((char*)c,1); 224 emit sndBlock((char*)c,1);
225 } 225 }
226} 226}
227 227
228// Unblocking, Byte to Unicode translation --------------------------------- -- 228// Unblocking, Byte to Unicode translation --------------------------------- --
229 229
230/* 230/*
231 We are doing code conversion from locale to unicode first. 231 We are doing code conversion from locale to unicode first.
232*/ 232*/
233 233
234void TEmulation::onRcvBlock(const char *s, int len) 234void TEmulation::onRcvBlock(const char *s, int len)
235{ 235{
236 bulkStart(); 236 bulkStart();
237 bulk_incnt += 1; 237 bulk_incnt += 1;
238 for (int i = 0; i < len; i++) 238 for (int i = 0; i < len; i++)
239 { 239 {
240 QString result = decoder->toUnicode(&s[i],1); 240 QString result = decoder->toUnicode(&s[i],1);
241 int reslen = result.length(); 241 int reslen = result.length();
242 for (int j = 0; j < reslen; j++) 242 for (int j = 0; j < reslen; j++)
243 onRcvChar(result[j].unicode()); 243 onRcvChar(result[j].unicode());
244 if (s[i] == '\n') bulkNewline(); 244 if (s[i] == '\n') bulkNewline();
245 } 245 }
246 bulkEnd(); 246 bulkEnd();
247} 247}
248 248
249// Selection --------------------------------------------------------------- -- 249// Selection --------------------------------------------------------------- --
250 250
251void TEmulation::onSelectionBegin(const int x, const int y) { 251void TEmulation::onSelectionBegin(const int x, const int y) {
252 if (!connected) return; 252 if (!connected) return;
253 scr->setSelBeginXY(x,y); 253 scr->setSelBeginXY(x,y);
254 showBulk(); 254 showBulk();
255} 255}
256 256
257void TEmulation::onSelectionExtend(const int x, const int y) { 257void TEmulation::onSelectionExtend(const int x, const int y) {
258 if (!connected) return; 258 if (!connected) return;
259 scr->setSelExtentXY(x,y); 259 scr->setSelExtentXY(x,y);
260 showBulk(); 260 showBulk();
261} 261}
262 262
263void TEmulation::setSelection(const BOOL preserve_line_breaks) { 263void TEmulation::setSelection(const BOOL preserve_line_breaks) {
264 if (!connected) return; 264 if (!connected) return;
265 QString t = scr->getSelText(preserve_line_breaks); 265 QString t = scr->getSelText(preserve_line_breaks);
266 if (!t.isNull()) gui->setSelection(t); 266 if (!t.isNull()) gui->setSelection(t);
267} 267}
268 268
269void TEmulation::clearSelection() { 269void TEmulation::clearSelection() {
270 if (!connected) return; 270 if (!connected) return;
271 scr->clearSelection(); 271 scr->clearSelection();
272 showBulk(); 272 showBulk();
273} 273}
274 274void TEmulation::streamHistory(QTextStream* stream) {
275 *stream << scr->getHistory();
276}
275// Refreshing -------------------------------------------------------------- -- 277// Refreshing -------------------------------------------------------------- --
276 278
277#define BULK_TIMEOUT 20 279#define BULK_TIMEOUT 20
278 280
279/*! 281/*!
280 called when \n comes in. Evtl. triggers showBulk at endBulk 282 called when \n comes in. Evtl. triggers showBulk at endBulk
281*/ 283*/
282 284
283void TEmulation::bulkNewline() 285void TEmulation::bulkNewline()
284{ 286{
285 bulk_nlcnt += 1; 287 bulk_nlcnt += 1;
286 bulk_incnt = 0; // reset bulk counter since `nl' rule applies 288 bulk_incnt = 0; // reset bulk counter since `nl' rule applies
287} 289}
288 290
289/*! 291/*!
290*/ 292*/
291 293
292void TEmulation::showBulk() 294void TEmulation::showBulk()
293{ 295{
294 bulk_nlcnt = 0; // reset bulk newline counter 296 bulk_nlcnt = 0; // reset bulk newline counter
295 bulk_incnt = 0; // reset bulk counter 297 bulk_incnt = 0; // reset bulk counter
296 if (connected) 298 if (connected)
297 { 299 {
298 ca* image = scr->getCookedImage(); // get the image 300 ca* image = scr->getCookedImage(); // get the image
299 gui->setImage(image, 301 gui->setImage(image,
300 scr->getLines(), 302 scr->getLines(),
301 scr->getColumns()); // actual refresh 303 scr->getColumns()); // actual refresh
302 free(image); 304 free(image);
303 //FIXME: check that we do not trigger other draw event here. 305 //FIXME: check that we do not trigger other draw event here.
304 gui->setScroll(scr->getHistCursor(),scr->getHistLines()); 306 gui->setScroll(scr->getHistCursor(),scr->getHistLines());
305 } 307 }
306} 308}
307 309
308void TEmulation::bulkStart() 310void TEmulation::bulkStart()
309{ 311{
310 if (bulk_timer.isActive()) bulk_timer.stop(); 312 if (bulk_timer.isActive()) bulk_timer.stop();
311} 313}
312 314
313void TEmulation::bulkEnd() 315void TEmulation::bulkEnd()
314{ 316{
315 if ( bulk_nlcnt > gui->Lines() || bulk_incnt > 20 ) 317 if ( bulk_nlcnt > gui->Lines() || bulk_incnt > 20 )
316 showBulk(); // resets bulk_??cnt to 0, too. 318 showBulk(); // resets bulk_??cnt to 0, too.
317 else 319 else
318 bulk_timer.start(BULK_TIMEOUT,TRUE); 320 bulk_timer.start(BULK_TIMEOUT,TRUE);
319} 321}
320 322
321void TEmulation::setConnect(bool c) 323void TEmulation::setConnect(bool c)
322{ 324{
323 connected = c; 325 connected = c;
324 if ( connected) 326 if ( connected)
325 { 327 {
326 onImageSizeChange(gui->Lines(), gui->Columns()); 328 onImageSizeChange(gui->Lines(), gui->Columns());
327 showBulk(); 329 showBulk();
328 } 330 }
329 else 331 else
330 { 332 {
331 scr->clearSelection(); 333 scr->clearSelection();
332 } 334 }
333} 335}
334 336
335// --------------------------------------------------------------------------- 337// ---------------------------------------------------------------------------
336 338
337/*! triggered by image size change of the TEWidget `gui'. 339/*! triggered by image size change of the TEWidget `gui'.
338 340
339 This event is simply propagated to the attached screens 341 This event is simply propagated to the attached screens
340 and to the related serial line. 342 and to the related serial line.
341*/ 343*/
342 344
343void TEmulation::onImageSizeChange(int lines, int columns) 345void TEmulation::onImageSizeChange(int lines, int columns)
344{ 346{
345 if (!connected) return; 347 if (!connected) return;
346 screen[0]->resizeImage(lines,columns); 348 screen[0]->resizeImage(lines,columns);
347 screen[1]->resizeImage(lines,columns); 349 screen[1]->resizeImage(lines,columns);
348 showBulk(); 350 showBulk();
349 emit ImageSizeChanged(lines,columns); // propagate event to serial line 351 emit ImageSizeChanged(lines,columns); // propagate event to serial line
350} 352}
351 353
352void TEmulation::onHistoryCursorChange(int cursor) 354void TEmulation::onHistoryCursorChange(int cursor)
353{ 355{
354 if (!connected) return; 356 if (!connected) return;
355 scr->setHistCursor(cursor); 357 scr->setHistCursor(cursor);
356 showBulk(); 358 showBulk();
357} 359}
358 360
359void TEmulation::setColumns(int columns) 361void TEmulation::setColumns(int columns)
360{ 362{
361 //FIXME: this goes strange ways. 363 //FIXME: this goes strange ways.
362 // Can we put this straight or explain it at least? 364 // Can we put this straight or explain it at least?
363 emit changeColumns(columns); 365 emit changeColumns(columns);
364} 366}
diff --git a/noncore/apps/opie-console/TEmulation.h b/noncore/apps/opie-console/TEmulation.h
index ec15e7a..d7b3d6d 100644
--- a/noncore/apps/opie-console/TEmulation.h
+++ b/noncore/apps/opie-console/TEmulation.h
@@ -1,117 +1,122 @@
1/* -------------------------------------------------------------------------- */ 1/* -------------------------------------------------------------------------- */
2/* */ 2/* */
3/* [emulation.h] Fundamental Terminal Emulation */ 3/* [emulation.h] Fundamental Terminal Emulation */
4/* */ 4/* */
5/* -------------------------------------------------------------------------- */ 5/* -------------------------------------------------------------------------- */
6/* */ 6/* */
7/* Copyright (c) 1997,1998 by Lars Doelle <lars.doelle@on-line.de> */ 7/* Copyright (c) 1997,1998 by Lars Doelle <lars.doelle@on-line.de> */
8/* */ 8/* */
9/* This file is part of Konsole - an X terminal for KDE */ 9/* This file is part of Konsole - an X terminal for KDE */
10/* */ 10/* */
11/* -------------------------------------------------------------------------- */ 11/* -------------------------------------------------------------------------- */
12 /* */ 12 /* */
13/* Ported Konsole to Qt/Embedded */ 13/* Ported Konsole to Qt/Embedded */
14 /* */ 14 /* */
15/* Copyright (C) 2000 by John Ryland <jryland@trolltech.com> */ 15/* Copyright (C) 2000 by John Ryland <jryland@trolltech.com> */
16 /* */ 16 /* */
17/* -------------------------------------------------------------------------- */ 17/* -------------------------------------------------------------------------- */
18 18
19#ifndef EMULATION_H 19#ifndef EMULATION_H
20#define EMULATION_H 20#define EMULATION_H
21 21
22#include "TEWidget.h" 22#include "TEWidget.h"
23#include "TEScreen.h" 23#include "TEScreen.h"
24#include <qtimer.h> 24#include <qtimer.h>
25#include <stdio.h> 25#include <stdio.h>
26#include <qtextcodec.h> 26#include <qtextcodec.h>
27#include <qtextstream.h>
28
27#include "keytrans.h" 29#include "keytrans.h"
28 30
29class TEmulation : public QObject 31class TEmulation : public QObject
30{ Q_OBJECT 32{ Q_OBJECT
31 33
32public: 34public:
33 35
34 TEmulation(TEWidget* gui); 36 TEmulation(TEWidget* gui);
35 ~TEmulation(); 37 ~TEmulation();
36 38
37public: 39public:
38 virtual void setHistory(bool on); 40 virtual void setHistory(bool on);
39 virtual bool history(); 41 virtual bool history();
42 virtual void streamHistory( QTextStream* );
40 43
41public slots: // signals incoming from TEWidget 44public slots: // signals incoming from TEWidget
42 45
43 virtual void onImageSizeChange(int lines, int columns); 46 virtual void onImageSizeChange(int lines, int columns);
44 virtual void onHistoryCursorChange(int cursor); 47 virtual void onHistoryCursorChange(int cursor);
45 virtual void onKeyPress(QKeyEvent*); 48 virtual void onKeyPress(QKeyEvent*);
46 49
47 virtual void clearSelection(); 50 virtual void clearSelection();
48 virtual void onSelectionBegin(const int x, const int y); 51 virtual void onSelectionBegin(const int x, const int y);
49 virtual void onSelectionExtend(const int x, const int y); 52 virtual void onSelectionExtend(const int x, const int y);
50 virtual void setSelection(const BOOL preserve_line_breaks); 53 virtual void setSelection(const BOOL preserve_line_breaks);
51 54
52public slots: // signals incoming from data source 55public slots: // signals incoming from data source
53 56
54 void onRcvBlock(const char* txt,int len); 57 void onRcvBlock(const char* txt,int len);
55 58
56signals: 59signals:
57 60
58 void sndBlock(const char* txt,int len); 61 void sndBlock(const char* txt,int len);
59 void ImageSizeChanged(int lines, int columns); 62 void ImageSizeChanged(int lines, int columns);
60 void changeColumns(int columns); 63 void changeColumns(int columns);
61 void changeTitle(int arg, const char* str); 64 void changeTitle(int arg, const char* str);
62 65
63public: 66public:
64 67
65 virtual void onRcvChar(int); 68 virtual void onRcvChar(int);
66 69
67 virtual void setMode (int) = 0; 70 virtual void setMode (int) = 0;
68 virtual void resetMode(int) = 0; 71 virtual void resetMode(int) = 0;
69 72
70 virtual void sendString(const char*) = 0; 73 virtual void sendString(const char*) = 0;
71 74
72 virtual void setConnect(bool r); 75 virtual void setConnect(bool r);
73 void setColumns(int columns); 76 void setColumns(int columns);
74 77
75 void setKeytrans(int no); 78 void setKeytrans(int no);
76 void setKeytrans(const char * no); 79 void setKeytrans(const char * no);
77 80
81
82
78protected: 83protected:
79 84
80 TEWidget* gui; 85 TEWidget* gui;
81 TEScreen* scr; // referes to one `screen' 86 TEScreen* scr; // referes to one `screen'
82 TEScreen* screen[2]; // 0 = primary, 1 = alternate 87 TEScreen* screen[2]; // 0 = primary, 1 = alternate
83 void setScreen(int n); // set `scr' to `screen[n]' 88 void setScreen(int n); // set `scr' to `screen[n]'
84 89
85 bool connected; // communicate with widget 90 bool connected; // communicate with widget
86 91
87 void setCodec(int c); // codec number, 0 = locale, 1=utf8 92 void setCodec(int c); // codec number, 0 = locale, 1=utf8
88 93
89 QTextCodec* codec; 94 QTextCodec* codec;
90 QTextCodec* localeCodec; 95 QTextCodec* localeCodec;
91 QTextDecoder* decoder; 96 QTextDecoder* decoder;
92 97
93 KeyTrans* keytrans; 98 KeyTrans* keytrans;
94 99
95// refreshing related material. 100// refreshing related material.
96// this is localized in the class. 101// this is localized in the class.
97private slots: // triggered by timer 102private slots: // triggered by timer
98 103
99 void showBulk(); 104 void showBulk();
100 105
101private: 106private:
102 107
103 void bulkNewline(); 108 void bulkNewline();
104 void bulkStart(); 109 void bulkStart();
105 void bulkEnd(); 110 void bulkEnd();
106 111
107private: 112private:
108 113
109 QTimer bulk_timer; 114 QTimer bulk_timer;
110 int bulk_nlcnt; // bulk newline counter 115 int bulk_nlcnt; // bulk newline counter
111 char* SelectedText; 116 char* SelectedText;
112 int bulk_incnt; // bulk counter 117 int bulk_incnt; // bulk counter
113 118
114 119
115}; 120};
116 121
117#endif // ifndef EMULATION_H 122#endif // ifndef EMULATION_H
diff --git a/noncore/apps/opie-console/emulation_handler.cpp b/noncore/apps/opie-console/emulation_handler.cpp
index 7924568..235facb 100644
--- a/noncore/apps/opie-console/emulation_handler.cpp
+++ b/noncore/apps/opie-console/emulation_handler.cpp
@@ -1,206 +1,209 @@
1#include <qwidget.h> 1#include <qwidget.h>
2#include <qpushbutton.h> 2#include <qpushbutton.h>
3 3
4#include "TEWidget.h" 4#include "TEWidget.h"
5#include "TEmuVt102.h" 5#include "TEmuVt102.h"
6 6
7#include "profile.h" 7#include "profile.h"
8#include "emulation_handler.h" 8#include "emulation_handler.h"
9#include "script.h" 9#include "script.h"
10 10
11EmulationHandler::EmulationHandler( const Profile& prof, QWidget* parent,const char* name ) 11EmulationHandler::EmulationHandler( const Profile& prof, QWidget* parent,const char* name )
12 : QObject(0, name ) 12 : QObject(0, name )
13{ 13{
14 m_teWid = new TEWidget( parent, "TerminalMain"); 14 m_teWid = new TEWidget( parent, "TerminalMain");
15 // use setWrapAt(0) for classic behaviour (wrap at screen width, no scrollbar) 15 // use setWrapAt(0) for classic behaviour (wrap at screen width, no scrollbar)
16 // use setWrapAt(80) for normal console with scrollbar 16 // use setWrapAt(80) for normal console with scrollbar
17 setWrap(prof.readNumEntry("Wrap", 0) ? 0 : 80); 17 setWrap(prof.readNumEntry("Wrap", 0) ? 0 : 80);
18 m_teWid->setMinimumSize(150, 70 ); 18 m_teWid->setMinimumSize(150, 70 );
19 m_script = 0; 19 m_script = 0;
20 parent->resize( m_teWid->calcSize(80, 24 ) ); 20 parent->resize( m_teWid->calcSize(80, 24 ) );
21 m_teEmu = new TEmuVt102(m_teWid ); 21 m_teEmu = new TEmuVt102(m_teWid );
22 22
23 connect(m_teEmu,SIGNAL(ImageSizeChanged(int, int) ), 23 connect(m_teEmu,SIGNAL(ImageSizeChanged(int, int) ),
24 this, SIGNAL(changeSize(int, int) ) ); 24 this, SIGNAL(changeSize(int, int) ) );
25 connect(m_teEmu, SIGNAL(sndBlock(const char*, int) ), 25 connect(m_teEmu, SIGNAL(sndBlock(const char*, int) ),
26 this, SLOT(recvEmulation(const char*, int) ) ); 26 this, SLOT(recvEmulation(const char*, int) ) );
27 m_teEmu->setConnect( true ); 27 m_teEmu->setConnect( true );
28 m_teEmu->setHistory( TRUE ); 28 m_teEmu->setHistory( TRUE );
29 load( prof ); 29 load( prof );
30 30
31 31
32 32
33} 33}
34TEmulation* EmulationHandler::emulation() {
35 return m_teEmu;
36}
34EmulationHandler::~EmulationHandler() { 37EmulationHandler::~EmulationHandler() {
35 if (isRecording()) 38 if (isRecording())
36 clearScript(); 39 clearScript();
37 delete m_teEmu; 40 delete m_teEmu;
38 delete m_teWid; 41 delete m_teWid;
39} 42}
40 43
41void EmulationHandler::load( const Profile& prof) { 44void EmulationHandler::load( const Profile& prof) {
42 m_teWid->setVTFont( font( prof.readNumEntry("Font") ) ); 45 m_teWid->setVTFont( font( prof.readNumEntry("Font") ) );
43 int num = prof.readNumEntry("Color"); 46 int num = prof.readNumEntry("Color");
44 setColor( foreColor(num), backColor(num) ); 47 setColor( foreColor(num), backColor(num) );
45 m_teWid->setBackgroundColor(backColor(num) ); 48 m_teWid->setBackgroundColor(backColor(num) );
46 49
47 int term = prof.readNumEntry("Terminal", 0) ; 50 int term = prof.readNumEntry("Terminal", 0) ;
48 switch(term) { 51 switch(term) {
49 default: 52 default:
50 case Profile::VT102: 53 case Profile::VT102:
51 case Profile::VT100: 54 case Profile::VT100:
52 m_teEmu->setKeytrans("vt100.keytab"); 55 m_teEmu->setKeytrans("vt100.keytab");
53 break; 56 break;
54 case Profile::Linux: 57 case Profile::Linux:
55 m_teEmu->setKeytrans("linux.keytab"); 58 m_teEmu->setKeytrans("linux.keytab");
56 break; 59 break;
57 case Profile::XTerm: 60 case Profile::XTerm:
58 m_teEmu->setKeytrans("default.Keytab"); 61 m_teEmu->setKeytrans("default.Keytab");
59 break; 62 break;
60 } 63 }
61} 64}
62void EmulationHandler::recv( const QByteArray& ar) { 65void EmulationHandler::recv( const QByteArray& ar) {
63 m_teEmu->onRcvBlock(ar.data(), ar.count() ); 66 m_teEmu->onRcvBlock(ar.data(), ar.count() );
64} 67}
65void EmulationHandler::recvEmulation(const char* src, int len ) { 68void EmulationHandler::recvEmulation(const char* src, int len ) {
66 QByteArray ar(len); 69 QByteArray ar(len);
67 70
68 memcpy(ar.data(), src, sizeof(char) * len ); 71 memcpy(ar.data(), src, sizeof(char) * len );
69 if (isRecording()) 72 if (isRecording())
70 m_script->append(ar); 73 m_script->append(ar);
71 emit send(ar); 74 emit send(ar);
72} 75}
73QWidget* EmulationHandler::widget() { 76QWidget* EmulationHandler::widget() {
74 return m_teWid; 77 return m_teWid;
75} 78}
76/* 79/*
77 * allocate a new table of colors 80 * allocate a new table of colors
78 */ 81 */
79void EmulationHandler::setColor( const QColor& fore, const QColor& back ) { 82void EmulationHandler::setColor( const QColor& fore, const QColor& back ) {
80 ColorEntry table[TABLE_COLORS]; 83 ColorEntry table[TABLE_COLORS];
81 const ColorEntry *defaultCt = m_teWid->getdefaultColorTable(); 84 const ColorEntry *defaultCt = m_teWid->getdefaultColorTable();
82 85
83 for (int i = 0; i < TABLE_COLORS; i++ ) { 86 for (int i = 0; i < TABLE_COLORS; i++ ) {
84 if ( i == 0 || i == 10 ) { 87 if ( i == 0 || i == 10 ) {
85 table[i].color = fore; 88 table[i].color = fore;
86 }else if ( i == 1 || i == 11 ) { 89 }else if ( i == 1 || i == 11 ) {
87 table[i].color = back; 90 table[i].color = back;
88 table[i].transparent = 0; 91 table[i].transparent = 0;
89 }else { 92 }else {
90 table[i].color = defaultCt[i].color; 93 table[i].color = defaultCt[i].color;
91 } 94 }
92 } 95 }
93 m_teWid->setColorTable(table ); 96 m_teWid->setColorTable(table );
94 m_teWid->update(); 97 m_teWid->update();
95} 98}
96QFont EmulationHandler::font( int id ) { 99QFont EmulationHandler::font( int id ) {
97 QString name; 100 QString name;
98 int size = 0; 101 int size = 0;
99 switch(id ) { 102 switch(id ) {
100 default: // fall through 103 default: // fall through
101 case 0: 104 case 0:
102 name = QString::fromLatin1("Micro"); 105 name = QString::fromLatin1("Micro");
103 size = 4; 106 size = 4;
104 break; 107 break;
105 case 1: 108 case 1:
106 name = QString::fromLatin1("Fixed"); 109 name = QString::fromLatin1("Fixed");
107 size = 7; 110 size = 7;
108 break; 111 break;
109 case 2: 112 case 2:
110 name = QString::fromLatin1("Fixed"); 113 name = QString::fromLatin1("Fixed");
111 size = 12; 114 size = 12;
112 break; 115 break;
113 } 116 }
114 QFont font(name, size, QFont::Normal ); 117 QFont font(name, size, QFont::Normal );
115 font.setFixedPitch(TRUE ); 118 font.setFixedPitch(TRUE );
116 return font; 119 return font;
117} 120}
118QColor EmulationHandler::foreColor(int col) { 121QColor EmulationHandler::foreColor(int col) {
119 QColor co; 122 QColor co;
120 /* we need to switch it */ 123 /* we need to switch it */
121 switch( col ) { 124 switch( col ) {
122 default: 125 default:
123 case Profile::White: 126 case Profile::White:
124 /* color is black */ 127 /* color is black */
125 co = Qt::white; 128 co = Qt::white;
126 break; 129 break;
127 case Profile::Black: 130 case Profile::Black:
128 co = Qt::black; 131 co = Qt::black;
129 break; 132 break;
130 case Profile::Green: 133 case Profile::Green:
131 qWarning("Foreground green"); 134 qWarning("Foreground green");
132 co = Qt::green; 135 co = Qt::green;
133 break; 136 break;
134 case Profile::Orange: 137 case Profile::Orange:
135 qWarning("Foreground orange"); 138 qWarning("Foreground orange");
136 co.setRgb( 231, 184, 98 ); 139 co.setRgb( 231, 184, 98 );
137 break; 140 break;
138 } 141 }
139 142
140 return co; 143 return co;
141} 144}
142QColor EmulationHandler::backColor(int col ) { 145QColor EmulationHandler::backColor(int col ) {
143 QColor co; 146 QColor co;
144 /* we need to switch it */ 147 /* we need to switch it */
145 switch( col ) { 148 switch( col ) {
146 default: 149 default:
147 case Profile::White: 150 case Profile::White:
148 /* color is white */ 151 /* color is white */
149 co = Qt::black; 152 co = Qt::black;
150 break; 153 break;
151 case Profile::Black: 154 case Profile::Black:
152 co = Qt::white; 155 co = Qt::white;
153 break; 156 break;
154 case Profile::Green: 157 case Profile::Green:
155 qWarning("Background black"); 158 qWarning("Background black");
156 co = Qt::black; 159 co = Qt::black;
157 break; 160 break;
158 case Profile::Orange: 161 case Profile::Orange:
159 qWarning("Background black"); 162 qWarning("Background black");
160 co = Qt::black; 163 co = Qt::black;
161 break; 164 break;
162 } 165 }
163 166
164 return co; 167 return co;
165} 168}
166 169
167QPushButton* EmulationHandler::cornerButton() { 170QPushButton* EmulationHandler::cornerButton() {
168 return m_teWid->cornerButton(); 171 return m_teWid->cornerButton();
169} 172}
170 173
171 174
172Script *EmulationHandler::script() { 175Script *EmulationHandler::script() {
173 return m_script; 176 return m_script;
174} 177}
175 178
176bool EmulationHandler::isRecording() { 179bool EmulationHandler::isRecording() {
177 return (m_script != 0); 180 return (m_script != 0);
178} 181}
179 182
180void EmulationHandler::startRecording() { 183void EmulationHandler::startRecording() {
181 if (!isRecording()) 184 if (!isRecording())
182 m_script = new Script(); 185 m_script = new Script();
183} 186}
184 187
185void EmulationHandler::clearScript() { 188void EmulationHandler::clearScript() {
186 if (isRecording()) { 189 if (isRecording()) {
187 delete m_script; 190 delete m_script;
188 m_script = 0; 191 m_script = 0;
189 } 192 }
190} 193}
191 194
192void EmulationHandler::runScript(const Script *script) { 195void EmulationHandler::runScript(const Script *script) {
193 emit send(script->script()); 196 emit send(script->script());
194} 197}
195 198
196void EmulationHandler::copy() { 199void EmulationHandler::copy() {
197 m_teWid->emitSelection(); 200 m_teWid->emitSelection();
198} 201}
199void EmulationHandler::paste() { 202void EmulationHandler::paste() {
200 m_teWid->pasteClipboard(); 203 m_teWid->pasteClipboard();
201} 204}
202 205
203void EmulationHandler::setWrap(int columns) { 206void EmulationHandler::setWrap(int columns) {
204 m_teWid->setWrapAt(columns); 207 m_teWid->setWrapAt(columns);
205} 208}
206 209
diff --git a/noncore/apps/opie-console/emulation_handler.h b/noncore/apps/opie-console/emulation_handler.h
index 7bc6f16..1338525 100644
--- a/noncore/apps/opie-console/emulation_handler.h
+++ b/noncore/apps/opie-console/emulation_handler.h
@@ -1,94 +1,95 @@
1#ifndef OPIE_EMULATION_HANDLER_H 1#ifndef OPIE_EMULATION_HANDLER_H
2#define OPIE_EMULATION_HANDLER_H 2#define OPIE_EMULATION_HANDLER_H
3 3
4#include <qobject.h> 4#include <qobject.h>
5#include <qcolor.h> 5#include <qcolor.h>
6#include <qcstring.h> 6#include <qcstring.h>
7 7
8/* 8/*
9 * Badly ibotty lacks the time to finish 9 * Badly ibotty lacks the time to finish
10 * his widget in time.. 10 * his widget in time..
11 * Never the less we've to have an EmulationWidget 11 * Never the less we've to have an EmulationWidget
12 * This is why I'm taking the inferior not cleaned 12 * This is why I'm taking the inferior not cleaned
13 * up TE* KDE STUFF 13 * up TE* KDE STUFF
14 */ 14 */
15 15
16/** 16/**
17 * This is the layer above the IOLayer* 17 * This is the layer above the IOLayer*
18 * This nice QObject here will get stuff from 18 * This nice QObject here will get stuff from
19 * got a slot and a signal 19 * got a slot and a signal
20 * the signal for data 20 * the signal for data
21 * the slot for receiving 21 * the slot for receiving
22 * it'll set up the widget internally 22 * it'll set up the widget internally
23 * and manage the communication between 23 * and manage the communication between
24 * the pre QByteArray world! 24 * the pre QByteArray world!
25 */ 25 */
26class Profile; 26class Profile;
27class QWidget; 27class QWidget;
28class QPushButton; 28class QPushButton;
29class TEWidget; 29class TEWidget;
30class TEmulation; 30class TEmulation;
31class QFont; 31class QFont;
32class Script; 32class Script;
33class EmulationHandler : public QObject { 33class EmulationHandler : public QObject {
34 Q_OBJECT 34 Q_OBJECT
35public: 35public:
36 /** 36 /**
37 * simple c'tor the parent of the TEWdiget 37 * simple c'tor the parent of the TEWdiget
38 * and a name 38 * and a name
39 * and a Profile 39 * and a Profile
40 */ 40 */
41 EmulationHandler( const Profile&, QWidget* parent, const char* name = 0l ); 41 EmulationHandler( const Profile&, QWidget* parent, const char* name = 0l );
42 42
43 /** 43 /**
44 * delete all components 44 * delete all components
45 */ 45 */
46 ~EmulationHandler(); 46 ~EmulationHandler();
47 47
48 void load( const Profile& ); 48 void load( const Profile& );
49 QWidget* widget(); 49 QWidget* widget();
50 TEmulation *emulation();
50 void setColor( const QColor& fore, const QColor& back ); 51 void setColor( const QColor& fore, const QColor& back );
51 QPushButton* cornerButton(); 52 QPushButton* cornerButton();
52 53
53 /* Scripts */ 54 /* Scripts */
54 /* Create a new script and record all typed characters */ 55 /* Create a new script and record all typed characters */
55 void startRecording(); 56 void startRecording();
56 57
57 /* Return whether we are currently recording a script */ 58 /* Return whether we are currently recording a script */
58 bool isRecording(); 59 bool isRecording();
59 60
60 /* Return the current script (or NULL) */ 61 /* Return the current script (or NULL) */
61 Script *script(); 62 Script *script();
62 63
63 /* Stop recording and remove the current script from memory */ 64 /* Stop recording and remove the current script from memory */
64 void clearScript(); 65 void clearScript();
65 66
66 /* Run a script by forwarding its keys to the EmulationLayer */ 67 /* Run a script by forwarding its keys to the EmulationLayer */
67 void runScript(const Script *); 68 void runScript(const Script *);
68 69
69 /* Propagate change to widget */ 70 /* Propagate change to widget */
70 void setWrap(int columns); 71 void setWrap(int columns);
71signals: 72signals:
72 void send( const QByteArray& ); 73 void send( const QByteArray& );
73 void changeSize(int rows, int cols ); 74 void changeSize(int rows, int cols );
74 75
75 76
76public slots: 77public slots:
77 void recv( const QByteArray& ); 78 void recv( const QByteArray& );
78 void paste(); 79 void paste();
79 void copy(); 80 void copy();
80 81
81private slots: 82private slots:
82 void recvEmulation( const char*, int len ); 83 void recvEmulation( const char*, int len );
83private: 84private:
84 QFont font( int ); 85 QFont font( int );
85 QColor foreColor(int ); 86 QColor foreColor(int );
86 QColor backColor(int ); 87 QColor backColor(int );
87 88
88private: 89private:
89 TEWidget* m_teWid; 90 TEWidget* m_teWid;
90 TEmulation* m_teEmu; 91 TEmulation* m_teEmu;
91 Script * m_script; 92 Script * m_script;
92}; 93};
93 94
94#endif 95#endif
diff --git a/noncore/apps/opie-console/mainwindow.cpp b/noncore/apps/opie-console/mainwindow.cpp
index d221715..01468ca 100644
--- a/noncore/apps/opie-console/mainwindow.cpp
+++ b/noncore/apps/opie-console/mainwindow.cpp
@@ -1,770 +1,803 @@
1#include <assert.h> 1#include <assert.h>
2 2
3#include <qaction.h> 3#include <qaction.h>
4#include <qmenubar.h> 4#include <qmenubar.h>
5#include <qlabel.h> 5#include <qlabel.h>
6#include <qpopupmenu.h> 6#include <qpopupmenu.h>
7#include <qtoolbar.h> 7#include <qtoolbar.h>
8#include <qmessagebox.h> 8#include <qmessagebox.h>
9#include <qpushbutton.h> 9#include <qpushbutton.h>
10#include <qwhatsthis.h> 10#include <qwhatsthis.h>
11#include <qfileinfo.h> 11#include <qfileinfo.h>
12#include <qtextstream.h>
12 13
13#include <qpe/resource.h> 14#include <qpe/resource.h>
14#include <qpe/qpeapplication.h> 15#include <qpe/qpeapplication.h>
15#include <qpe/filemanager.h> 16#include <qpe/filemanager.h>
16#include <qpe/mimetype.h> 17#include <qpe/mimetype.h>
17 18
18#include <opie/ofiledialog.h> 19#include <opie/ofiledialog.h>
19 20
21#include "TEmulation.h"
20#include "keytrans.h" 22#include "keytrans.h"
21#include "profileeditordialog.h" 23#include "profileeditordialog.h"
22#include "configdialog.h" 24#include "configdialog.h"
23#include "default.h" 25#include "default.h"
24#include "metafactory.h" 26#include "metafactory.h"
25#include "profile.h" 27#include "profile.h"
26#include "profilemanager.h" 28#include "profilemanager.h"
27#include "mainwindow.h" 29#include "mainwindow.h"
28#include "tabwidget.h" 30#include "tabwidget.h"
29#include "transferdialog.h" 31#include "transferdialog.h"
30#include "function_keyboard.h" 32#include "function_keyboard.h"
31#include "emulation_handler.h" 33#include "emulation_handler.h"
32#include "script.h" 34#include "script.h"
33 35
34static char * filesave_xpm[] = { 36static char * filesave_xpm[] = {
35"16 16 78 1", 37"16 16 78 1",
36" c None", 38" c None",
37". c #343434", 39". c #343434",
38"+ c #A0A0A0", 40"+ c #A0A0A0",
39"@ c #565656", 41"@ c #565656",
40"# c #9E9E9E", 42"# c #9E9E9E",
41"$ c #525252", 43"$ c #525252",
42"% c #929292", 44"% c #929292",
43"& c #676767", 45"& c #676767",
44"* c #848484", 46"* c #848484",
45"= c #666666", 47"= c #666666",
46"- c #D8D8D8", 48"- c #D8D8D8",
47"; c #FFFFFF", 49"; c #FFFFFF",
48"> c #DBDBDB", 50"> c #DBDBDB",
49", c #636363", 51", c #636363",
50"' c #989898", 52"' c #989898",
51") c #2D2D2D", 53") c #2D2D2D",
52"! c #909090", 54"! c #909090",
53"~ c #AEAEAE", 55"~ c #AEAEAE",
54"{ c #EAEAEA", 56"{ c #EAEAEA",
55"] c #575757", 57"] c #575757",
56"^ c #585858", 58"^ c #585858",
57"/ c #8A8A8A", 59"/ c #8A8A8A",
58"( c #828282", 60"( c #828282",
59"_ c #6F6F6F", 61"_ c #6F6F6F",
60": c #C9C9C9", 62": c #C9C9C9",
61"< c #050505", 63"< c #050505",
62"[ c #292929", 64"[ c #292929",
63"} c #777777", 65"} c #777777",
64"| c #616161", 66"| c #616161",
65"1 c #3A3A3A", 67"1 c #3A3A3A",
66"2 c #BEBEBE", 68"2 c #BEBEBE",
67"3 c #2C2C2C", 69"3 c #2C2C2C",
68"4 c #7C7C7C", 70"4 c #7C7C7C",
69"5 c #F6F6F6", 71"5 c #F6F6F6",
70"6 c #FCFCFC", 72"6 c #FCFCFC",
71"7 c #6B6B6B", 73"7 c #6B6B6B",
72"8 c #959595", 74"8 c #959595",
73"9 c #4F4F4F", 75"9 c #4F4F4F",
74"0 c #808080", 76"0 c #808080",
75"a c #767676", 77"a c #767676",
76"b c #818181", 78"b c #818181",
77"c c #B8B8B8", 79"c c #B8B8B8",
78"d c #FBFBFB", 80"d c #FBFBFB",
79"e c #F9F9F9", 81"e c #F9F9F9",
80"f c #CCCCCC", 82"f c #CCCCCC",
81"g c #030303", 83"g c #030303",
82"h c #737373", 84"h c #737373",
83"i c #7A7A7A", 85"i c #7A7A7A",
84"j c #7E7E7E", 86"j c #7E7E7E",
85"k c #6A6A6A", 87"k c #6A6A6A",
86"l c #FAFAFA", 88"l c #FAFAFA",
87"m c #505050", 89"m c #505050",
88"n c #9D9D9D", 90"n c #9D9D9D",
89"o c #333333", 91"o c #333333",
90"p c #7B7B7B", 92"p c #7B7B7B",
91"q c #787878", 93"q c #787878",
92"r c #696969", 94"r c #696969",
93"s c #494949", 95"s c #494949",
94"t c #555555", 96"t c #555555",
95"u c #949494", 97"u c #949494",
96"v c #E6E6E6", 98"v c #E6E6E6",
97"w c #424242", 99"w c #424242",
98"x c #515151", 100"x c #515151",
99"y c #535353", 101"y c #535353",
100"z c #3E3E3E", 102"z c #3E3E3E",
101"A c #D4D4D4", 103"A c #D4D4D4",
102"B c #0C0C0C", 104"B c #0C0C0C",
103"C c #353535", 105"C c #353535",
104"D c #474747", 106"D c #474747",
105"E c #ECECEC", 107"E c #ECECEC",
106"F c #919191", 108"F c #919191",
107"G c #7D7D7D", 109"G c #7D7D7D",
108"H c #000000", 110"H c #000000",
109"I c #404040", 111"I c #404040",
110"J c #858585", 112"J c #858585",
111"K c #323232", 113"K c #323232",
112"L c #D0D0D0", 114"L c #D0D0D0",
113"M c #1C1C1C", 115"M c #1C1C1C",
114" ...+ ", 116" ...+ ",
115" @#$%&..+ ", 117" @#$%&..+ ",
116" .*=-;;>,..+ ", 118" .*=-;;>,..+ ",
117" ')!~;;;;;;{]..", 119" ')!~;;;;;;{]..",
118" ^/(-;;;;;;;_:<", 120" ^/(-;;;;;;;_:<",
119" [}|;;;;;;;{12$", 121" [}|;;;;;;;{12$",
120" #34-55;;;;678$+", 122" #34-55;;;;678$+",
121" 90ab=c;dd;e1fg ", 123" 90ab=c;dd;e1fg ",
122" [ahij((kbl0mn$ ", 124" [ahij((kbl0mn$ ",
123" op^q^^7r&]s/$+ ", 125" op^q^^7r&]s/$+ ",
124"@btu;vbwxy]zAB ", 126"@btu;vbwxy]zAB ",
125"CzDEvEv;;DssF$ ", 127"CzDEvEv;;DssF$ ",
126"G.H{E{E{IxsJ$+ ", 128"G.H{E{E{IxsJ$+ ",
127" +...vEKxzLM ", 129" +...vEKxzLM ",
128" +...z]n$ ", 130" +...z]n$ ",
129" +... "}; 131" +... "};
130 132
131 133
132 134
133MainWindow::MainWindow(QWidget *parent, const char *name, WFlags) : QMainWindow(parent, name, WStyle_ContextHelp) { 135MainWindow::MainWindow(QWidget *parent, const char *name, WFlags) : QMainWindow(parent, name, WStyle_ContextHelp) {
134 KeyTrans::loadAll(); 136 KeyTrans::loadAll();
135 for (int i = 0; i < KeyTrans::count(); i++ ) { 137 for (int i = 0; i < KeyTrans::count(); i++ ) {
136 KeyTrans* s = KeyTrans::find(i ); 138 KeyTrans* s = KeyTrans::find(i );
137 assert( s ); 139 assert( s );
138 } 140 }
139 m_factory = new MetaFactory(); 141 m_factory = new MetaFactory();
140 Default def(m_factory); 142 Default def(m_factory);
141 m_sessions.setAutoDelete( TRUE ); 143 m_sessions.setAutoDelete( TRUE );
142 m_curSession = 0; 144 m_curSession = 0;
143 m_manager = new ProfileManager( m_factory ); 145 m_manager = new ProfileManager( m_factory );
144 m_manager->load(); 146 m_manager->load();
145 m_scriptsData.setAutoDelete(TRUE); 147 m_scriptsData.setAutoDelete(TRUE);
146 148
147 initUI(); 149 initUI();
148 populateProfiles(); 150 populateProfiles();
149 populateScripts(); 151 populateScripts();
150} 152}
151void MainWindow::initUI() { 153void MainWindow::initUI() {
152 setToolBarsMovable( FALSE ); 154 setToolBarsMovable( FALSE );
153 155
154 /* tool bar for the menu */ 156 /* tool bar for the menu */
155 m_tool = new QToolBar( this ); 157 m_tool = new QToolBar( this );
156 m_tool->setHorizontalStretchable( TRUE ); 158 m_tool->setHorizontalStretchable( TRUE );
157 159
158 m_bar = new QMenuBar( m_tool ); 160 m_bar = new QMenuBar( m_tool );
159 m_console = new QPopupMenu( this ); 161 m_console = new QPopupMenu( this );
160 m_scripts = new QPopupMenu( this ); 162 m_scripts = new QPopupMenu( this );
161 m_sessionsPop= new QPopupMenu( this ); 163 m_sessionsPop= new QPopupMenu( this );
162 m_scriptsPop = new QPopupMenu( this ); 164 m_scriptsPop = new QPopupMenu( this );
163 165
164 /* add a toolbar for icons */ 166 /* add a toolbar for icons */
165 m_icons = new QToolBar(this); 167 m_icons = new QToolBar(this);
166 168
167 /* 169 /*
168 * the settings action 170 * the settings action
169 */ 171 */
170 m_setProfiles = new QAction(tr("Configure Profiles"), 172 m_setProfiles = new QAction(tr("Configure Profiles"),
171 Resource::loadPixmap( "SettingsIcon" ), 173 Resource::loadPixmap( "SettingsIcon" ),
172 QString::null, 0, this, 0); 174 QString::null, 0, this, 0);
173 m_setProfiles->addTo( m_console ); 175 m_setProfiles->addTo( m_console );
174 connect( m_setProfiles, SIGNAL(activated() ), 176 connect( m_setProfiles, SIGNAL(activated() ),
175 this, SLOT(slotConfigure() ) ); 177 this, SLOT(slotConfigure() ) );
176 178
177 m_console->insertSeparator(); 179 m_console->insertSeparator();
178 /* 180 /*
179 * new Action for new sessions 181 * new Action for new sessions
180 */ 182 */
181 QAction* newCon = new QAction(tr("New Connection"), 183 QAction* newCon = new QAction(tr("New Connection"),
182 Resource::loadPixmap( "new" ), 184 Resource::loadPixmap( "new" ),
183 QString::null, 0, this, 0); 185 QString::null, 0, this, 0);
184 newCon->addTo( m_console ); 186 newCon->addTo( m_console );
185 connect( newCon, SIGNAL(activated() ), 187 connect( newCon, SIGNAL(activated() ),
186 this, SLOT(slotNew() ) ); 188 this, SLOT(slotNew() ) );
187 189
188 m_console->insertSeparator(); 190 m_console->insertSeparator();
189 191
190 QAction *saveCon = new QAction(tr("Save Connection"), 192 QAction *saveCon = new QAction(tr("Save Connection"),
191 QPixmap( ( const char** ) filesave_xpm ) , QString::null, 193 QPixmap( ( const char** ) filesave_xpm ) , QString::null,
192 0, this, 0 ); 194 0, this, 0 );
193 saveCon->addTo( m_console ); 195 saveCon->addTo( m_console );
194 connect( saveCon, SIGNAL(activated() ), 196 connect( saveCon, SIGNAL(activated() ),
195 this, SLOT(slotSaveSession() ) ); 197 this, SLOT(slotSaveSession() ) );
196 m_console->insertSeparator(); 198 m_console->insertSeparator();
197 199
198 /* 200 /*
199 * connect action 201 * connect action
200 */ 202 */
201 m_connect = new QAction( tr("Connect"), Resource::loadPixmap("console/connected"), 203 m_connect = new QAction( tr("Connect"), Resource::loadPixmap("console/connected"),
202 QString::null, 0, this, 0 ); 204 QString::null, 0, this, 0 );
203 m_connect->addTo( m_console ); 205 m_connect->addTo( m_console );
204 connect(m_connect, SIGNAL(activated() ), 206 connect(m_connect, SIGNAL(activated() ),
205 this, SLOT(slotConnect() ) ); 207 this, SLOT(slotConnect() ) );
206 208
207 /* 209 /*
208 * disconnect action 210 * disconnect action
209 */ 211 */
210 m_disconnect = new QAction( tr("Disconnect"), Resource::loadPixmap("console/notconnected"), 212 m_disconnect = new QAction( tr("Disconnect"), Resource::loadPixmap("console/notconnected"),
211 QString::null, 0, this, 0 ); 213 QString::null, 0, this, 0 );
212 m_disconnect->addTo( m_console ); 214 m_disconnect->addTo( m_console );
213 connect(m_disconnect, SIGNAL(activated() ), 215 connect(m_disconnect, SIGNAL(activated() ),
214 this, SLOT(slotDisconnect() ) ); 216 this, SLOT(slotDisconnect() ) );
215 217
216 m_console->insertSeparator(); 218 m_console->insertSeparator();
217 219
218 m_transfer = new QAction( tr("Transfer file..."), Resource::loadPixmap("pass") , QString::null, 220 m_transfer = new QAction( tr("Transfer file..."), Resource::loadPixmap("pass") , QString::null,
219 0, this, 0 ); 221 0, this, 0 );
220 m_transfer->addTo( m_console ); 222 m_transfer->addTo( m_console );
221 connect(m_transfer, SIGNAL(activated() ), 223 connect(m_transfer, SIGNAL(activated() ),
222 this, SLOT(slotTransfer() ) ); 224 this, SLOT(slotTransfer() ) );
223 225
224 /* 226 /*
225 * immediate change of line wrap policy 227 * immediate change of line wrap policy
226 */ 228 */
227 m_isWrapped = false; 229 m_isWrapped = false;
228 m_wrap = new QAction( tr("Line wrap"), Resource::loadPixmap( "linewrap" ), QString::null, 0, this, 0 ); 230 m_wrap = new QAction( tr("Line wrap"), Resource::loadPixmap( "linewrap" ), QString::null, 0, this, 0 );
229 m_wrap->addTo( m_console ); 231 m_wrap->addTo( m_console );
230 connect( m_wrap, SIGNAL( activated() ), SLOT( slotWrap() ) ); 232 connect( m_wrap, SIGNAL( activated() ), SLOT( slotWrap() ) );
231 233
232 /* 234 /*
233 * fullscreen 235 * fullscreen
234 */ 236 */
235 m_isFullscreen = false; 237 m_isFullscreen = false;
236 238
237 m_fullscreen = new QAction( tr("Full screen"), Resource::loadPixmap( "fullscreen" ) 239 m_fullscreen = new QAction( tr("Full screen"), Resource::loadPixmap( "fullscreen" )
238 , QString::null, 0, this, 0); 240 , QString::null, 0, this, 0);
239 m_fullscreen->addTo( m_console ); 241 m_fullscreen->addTo( m_console );
240 connect( m_fullscreen, SIGNAL( activated() ), 242 connect( m_fullscreen, SIGNAL( activated() ),
241 this, SLOT( slotFullscreen() ) ); 243 this, SLOT( slotFullscreen() ) );
242 244
243 m_console->insertSeparator(); 245 m_console->insertSeparator();
246
247 QAction *a = new QAction();
248 a->setText( tr("Save history") );
249 a->addTo( m_console );
250 connect(a, SIGNAL(activated() ),
251 this, SLOT(slotSaveHistory() ) );
244 /* 252 /*
245 * terminate action 253 * terminate action
246 */ 254 */
247 m_terminate = new QAction(); 255 m_terminate = new QAction();
248 m_terminate->setText( tr("Terminate") ); 256 m_terminate->setText( tr("Terminate") );
249 m_terminate->addTo( m_console ); 257 m_terminate->addTo( m_console );
250 connect(m_terminate, SIGNAL(activated() ), 258 connect(m_terminate, SIGNAL(activated() ),
251 this, SLOT(slotTerminate() ) ); 259 this, SLOT(slotTerminate() ) );
252 260
253 m_closewindow = new QAction(); 261 m_closewindow = new QAction();
254 m_closewindow->setText( tr("Close Window") ); 262 m_closewindow->setText( tr("Close Window") );
255 m_closewindow->addTo( m_console ); 263 m_closewindow->addTo( m_console );
256 connect( m_closewindow, SIGNAL(activated() ), 264 connect( m_closewindow, SIGNAL(activated() ),
257 this, SLOT(slotClose() ) ); 265 this, SLOT(slotClose() ) );
258 266
259 267
260 /* 268 /*
261 * script actions 269 * script actions
262 */ 270 */
263 m_runScript_id = m_scripts->insertItem(tr("Run Script"), m_scriptsPop, -1, 0); 271 m_runScript_id = m_scripts->insertItem(tr("Run Script"), m_scriptsPop, -1, 0);
264 connect(m_scriptsPop, SIGNAL(activated(int)), this, SLOT(slotRunScript(int))); 272 connect(m_scriptsPop, SIGNAL(activated(int)), this, SLOT(slotRunScript(int)));
265 273
266 m_recordScript = new QAction(tr("Record Script"), QString::null, 0, this, 0); 274 m_recordScript = new QAction(tr("Record Script"), QString::null, 0, this, 0);
267 m_recordScript->addTo(m_scripts); 275 m_recordScript->addTo(m_scripts);
268 connect(m_recordScript, SIGNAL(activated()), this, SLOT(slotRecordScript())); 276 connect(m_recordScript, SIGNAL(activated()), this, SLOT(slotRecordScript()));
269 277
270 m_saveScript = new QAction(tr("Save Script"), QString::null, 0, this, 0); 278 m_saveScript = new QAction(tr("Save Script"), QString::null, 0, this, 0);
271 m_saveScript->addTo(m_scripts); 279 m_saveScript->addTo(m_scripts);
272 connect(m_saveScript, SIGNAL(activated()), this, SLOT(slotSaveScript())); 280 connect(m_saveScript, SIGNAL(activated()), this, SLOT(slotSaveScript()));
273 281
274 282
275 /* 283 /*
276 * action that open/closes the keyboard 284 * action that open/closes the keyboard
277 */ 285 */
278 m_openKeys = new QAction (tr("Open Keyboard..."), 286 m_openKeys = new QAction (tr("Open Keyboard..."),
279 Resource::loadPixmap( "console/keys/keyboard_icon" ), 287 Resource::loadPixmap( "console/keys/keyboard_icon" ),
280 QString::null, 0, this, 0); 288 QString::null, 0, this, 0);
281 m_openKeys->setToggleAction(true); 289 m_openKeys->setToggleAction(true);
282 connect (m_openKeys, SIGNAL(toggled(bool)), this, SLOT(slotOpenKeb(bool))); 290 connect (m_openKeys, SIGNAL(toggled(bool)), this, SLOT(slotOpenKeb(bool)));
283 291
284 /* insert the submenu */ 292 /* insert the submenu */
285 m_console->insertItem(tr("New from Profile"), m_sessionsPop, 293 m_console->insertItem(tr("New from Profile"), m_sessionsPop,
286 -1, 0); 294 -1, 0);
287 295
288 /* insert the connection menu */ 296 /* insert the connection menu */
289 m_bar->insertItem( tr("Connection"), m_console ); 297 m_bar->insertItem( tr("Connection"), m_console );
290 298
291 /* the scripts menu */ 299 /* the scripts menu */
292 m_bar->insertItem( tr("Scripts"), m_scripts ); 300 m_bar->insertItem( tr("Scripts"), m_scripts );
293 301
294 /* and the keyboard */ 302 /* and the keyboard */
295 m_keyBar = new QToolBar(this); 303 m_keyBar = new QToolBar(this);
296 addToolBar( m_keyBar, "Keyboard", QMainWindow::Top, TRUE ); 304 addToolBar( m_keyBar, "Keyboard", QMainWindow::Top, TRUE );
297 m_keyBar->setHorizontalStretchable( TRUE ); 305 m_keyBar->setHorizontalStretchable( TRUE );
298 m_keyBar->hide(); 306 m_keyBar->hide();
299 307
300 m_kb = new FunctionKeyboard(m_keyBar); 308 m_kb = new FunctionKeyboard(m_keyBar);
301 connect(m_kb, SIGNAL(keyPressed(FKey, ushort, ushort, bool)), 309 connect(m_kb, SIGNAL(keyPressed(FKey, ushort, ushort, bool)),
302 this, SLOT(slotKeyReceived(FKey, ushort, ushort, bool))); 310 this, SLOT(slotKeyReceived(FKey, ushort, ushort, bool)));
303 311
304 312
305 QAction *a = new QAction(tr("Copy"), 313 a = new QAction(tr("Copy"),
306 Resource::loadPixmap("copy"), QString::null, 314 Resource::loadPixmap("copy"), QString::null,
307 0, this, 0 ); 315 0, this, 0 );
308 //a->addTo( m_icons ); 316 //a->addTo( m_icons );
309 connect( a, SIGNAL(activated() ), 317 connect( a, SIGNAL(activated() ),
310 this, SLOT(slotCopy() ) ); 318 this, SLOT(slotCopy() ) );
311 319
312 QAction *paste = new QAction(tr("Paste"), 320 QAction *paste = new QAction(tr("Paste"),
313 Resource::loadPixmap("paste"), QString::null, 321 Resource::loadPixmap("paste"), QString::null,
314 0, this, 0 ); 322 0, this, 0 );
315 connect( paste, SIGNAL(activated() ), 323 connect( paste, SIGNAL(activated() ),
316 this, SLOT(slotPaste() ) ); 324 this, SLOT(slotPaste() ) );
317 325
318 326
319 newCon->addTo( m_icons ); 327 newCon->addTo( m_icons );
320 m_setProfiles->addTo( m_icons ); 328 m_setProfiles->addTo( m_icons );
321 paste->addTo( m_icons ); 329 paste->addTo( m_icons );
322 m_openKeys->addTo(m_icons); 330 m_openKeys->addTo(m_icons);
323 m_fullscreen->addTo( m_icons ); 331 m_fullscreen->addTo( m_icons );
324 332
325 m_connect->setEnabled( false ); 333 m_connect->setEnabled( false );
326 m_disconnect->setEnabled( false ); 334 m_disconnect->setEnabled( false );
327 m_terminate->setEnabled( false ); 335 m_terminate->setEnabled( false );
328 m_transfer->setEnabled( false ); 336 m_transfer->setEnabled( false );
329 m_scripts->setItemEnabled(m_runScript_id, false); 337 m_scripts->setItemEnabled(m_runScript_id, false);
330 m_recordScript->setEnabled( false ); 338 m_recordScript->setEnabled( false );
331 m_saveScript->setEnabled( false ); 339 m_saveScript->setEnabled( false );
332 m_fullscreen->setEnabled( false ); 340 m_fullscreen->setEnabled( false );
333 m_closewindow->setEnabled( false ); 341 m_closewindow->setEnabled( false );
334 m_wrap->setEnabled( false ); 342 m_wrap->setEnabled( false );
335 343
336 /* 344 /*
337 * connect to the menu activation 345 * connect to the menu activation
338 */ 346 */
339 connect( m_sessionsPop, SIGNAL(activated( int ) ), 347 connect( m_sessionsPop, SIGNAL(activated( int ) ),
340 this, SLOT(slotProfile( int ) ) ); 348 this, SLOT(slotProfile( int ) ) );
341 349
342 m_consoleWindow = new TabWidget( this, "blah"); 350 m_consoleWindow = new TabWidget( this, "blah");
343 connect(m_consoleWindow, SIGNAL(activated(Session*) ), 351 connect(m_consoleWindow, SIGNAL(activated(Session*) ),
344 this, SLOT(slotSessionChanged(Session*) ) ); 352 this, SLOT(slotSessionChanged(Session*) ) );
345 setCentralWidget( m_consoleWindow ); 353 setCentralWidget( m_consoleWindow );
346 354
347} 355}
348 356
349ProfileManager* MainWindow::manager() { 357ProfileManager* MainWindow::manager() {
350 return m_manager; 358 return m_manager;
351} 359}
352TabWidget* MainWindow::tabWidget() { 360TabWidget* MainWindow::tabWidget() {
353 return m_consoleWindow; 361 return m_consoleWindow;
354} 362}
355void MainWindow::populateProfiles() { 363void MainWindow::populateProfiles() {
356 m_sessionsPop->clear(); 364 m_sessionsPop->clear();
357 Profile::ValueList list = manager()->all(); 365 Profile::ValueList list = manager()->all();
358 for (Profile::ValueList::Iterator it = list.begin(); it != list.end(); ++it ) { 366 for (Profile::ValueList::Iterator it = list.begin(); it != list.end(); ++it ) {
359 m_sessionsPop->insertItem( (*it).name() ); 367 m_sessionsPop->insertItem( (*it).name() );
360 } 368 }
361 369
362} 370}
363 371
364void MainWindow::populateScripts() { 372void MainWindow::populateScripts() {
365 m_scriptsPop->clear(); 373 m_scriptsPop->clear();
366 m_scriptsData.clear(); 374 m_scriptsData.clear();
367 DocLnkSet files(QPEApplication::documentDir(), "text/plain"); 375 DocLnkSet files(QPEApplication::documentDir(), "text/plain");
368 QListIterator<DocLnk> dit(files.children()); 376 QListIterator<DocLnk> dit(files.children());
369 for (; dit.current(); ++dit) { 377 for (; dit.current(); ++dit) {
370 if (*dit && (*dit)->name().length()>0) { 378 if (*dit && (*dit)->name().length()>0) {
371 QFileInfo info((*dit)->file()); 379 QFileInfo info((*dit)->file());
372 if (info.extension(false) == "script") { 380 if (info.extension(false) == "script") {
373 m_scriptsData.append(new DocLnk(**dit)); 381 m_scriptsData.append(new DocLnk(**dit));
374 m_scriptsPop->insertItem((*dit)->name()); 382 m_scriptsPop->insertItem((*dit)->name());
375 } 383 }
376 } 384 }
377 } 385 }
378 386
379} 387}
380 388
381MainWindow::~MainWindow() { 389MainWindow::~MainWindow() {
382 delete m_factory; 390 delete m_factory;
383 manager()->save(); 391 manager()->save();
384} 392}
385 393
386MetaFactory* MainWindow::factory() { 394MetaFactory* MainWindow::factory() {
387 return m_factory; 395 return m_factory;
388} 396}
389 397
390Session* MainWindow::currentSession() { 398Session* MainWindow::currentSession() {
391 return m_curSession; 399 return m_curSession;
392} 400}
393 401
394QList<Session> MainWindow::sessions() { 402QList<Session> MainWindow::sessions() {
395 return m_sessions; 403 return m_sessions;
396} 404}
397 405
398void MainWindow::slotNew() { 406void MainWindow::slotNew() {
399 ProfileEditorDialog dlg(factory() ); 407 ProfileEditorDialog dlg(factory() );
400 dlg.showMaximized(); 408 dlg.showMaximized();
401 dlg.setCaption( tr("New Connection") ); 409 dlg.setCaption( tr("New Connection") );
402 int ret = dlg.exec(); 410 int ret = dlg.exec();
403 411
404 if ( ret == QDialog::Accepted ) { 412 if ( ret == QDialog::Accepted ) {
405 create( dlg.profile() ); 413 create( dlg.profile() );
406 } 414 }
407} 415}
408 416
409void MainWindow::slotRecordScript() { 417void MainWindow::slotRecordScript() {
410 if (currentSession()) { 418 if (currentSession()) {
411 currentSession()->emulationHandler()->startRecording(); 419 currentSession()->emulationHandler()->startRecording();
412 m_saveScript->setEnabled(true); 420 m_saveScript->setEnabled(true);
413 m_recordScript->setEnabled(false); 421 m_recordScript->setEnabled(false);
414 } 422 }
415} 423}
416 424
417void MainWindow::slotSaveScript() { 425void MainWindow::slotSaveScript() {
418 if (currentSession() && currentSession()->emulationHandler()->isRecording()) { 426 if (currentSession() && currentSession()->emulationHandler()->isRecording()) {
419 QMap<QString, QStringList> map; 427 QMap<QString, QStringList> map;
420 QStringList text; 428 QStringList text;
421 text << "text/plain"; 429 text << "text/plain";
422 map.insert(tr("Script"), text ); 430 map.insert(tr("Script"), text );
423 QString filename = OFileDialog::getSaveFileName(2, QPEApplication::documentDir(), QString::null, map); 431 QString filename = OFileDialog::getSaveFileName(2, QPEApplication::documentDir(), QString::null, map);
424 if (!filename.isEmpty()) { 432 if (!filename.isEmpty()) {
425 QFileInfo info(filename); 433 QFileInfo info(filename);
426 if (info.extension(FALSE) != "script") 434 if (info.extension(FALSE) != "script")
427 filename += ".script"; 435 filename += ".script";
428 DocLnk nf; 436 DocLnk nf;
429 nf.setType("text/plain"); 437 nf.setType("text/plain");
430 nf.setFile(filename); 438 nf.setFile(filename);
431 nf.setName(info.fileName()); 439 nf.setName(info.fileName());
432 FileManager fm; 440 FileManager fm;
433 fm.saveFile(nf, currentSession()->emulationHandler()->script()->script()); 441 fm.saveFile(nf, currentSession()->emulationHandler()->script()->script());
434 currentSession()->emulationHandler()->clearScript(); 442 currentSession()->emulationHandler()->clearScript();
435 m_saveScript->setEnabled(false); 443 m_saveScript->setEnabled(false);
436 m_recordScript->setEnabled(true); 444 m_recordScript->setEnabled(true);
437 populateScripts(); 445 populateScripts();
438 } 446 }
439 } 447 }
440} 448}
441 449
442void MainWindow::slotRunScript(int id) { 450void MainWindow::slotRunScript(int id) {
443 if (currentSession()) { 451 if (currentSession()) {
444 int index = m_scriptsPop->indexOf(id); 452 int index = m_scriptsPop->indexOf(id);
445 DocLnk *lnk = m_scriptsData.at(index); 453 DocLnk *lnk = m_scriptsData.at(index);
446 QString filePath = lnk->file(); 454 QString filePath = lnk->file();
447 Script script(filePath); 455 Script script(filePath);
448 currentSession()->emulationHandler()->runScript(&script); 456 currentSession()->emulationHandler()->runScript(&script);
449 } 457 }
450} 458}
451 459
452void MainWindow::slotConnect() { 460void MainWindow::slotConnect() {
453 if ( currentSession() ) { 461 if ( currentSession() ) {
454 bool ret = currentSession()->layer()->open(); 462 bool ret = currentSession()->layer()->open();
455 if(!ret) QMessageBox::warning(currentSession()->widgetStack(), 463 if(!ret) QMessageBox::warning(currentSession()->widgetStack(),
456 QObject::tr("Failed"), 464 QObject::tr("Failed"),
457 QObject::tr("Connecting failed for this session.")); 465 QObject::tr("Connecting failed for this session."));
458 else { 466 else {
459 m_connect->setEnabled( false ); 467 m_connect->setEnabled( false );
460 m_disconnect->setEnabled( true ); 468 m_disconnect->setEnabled( true );
461 469
462 // if it does not support file transfer, disable the menu entry 470 // if it does not support file transfer, disable the menu entry
463 if ( ( m_curSession->layer() )->supports()[1] == 0 ) { 471 if ( ( m_curSession->layer() )->supports()[1] == 0 ) {
464 m_transfer->setEnabled( false ); 472 m_transfer->setEnabled( false );
465 } else { 473 } else {
466 m_transfer->setEnabled( true ); 474 m_transfer->setEnabled( true );
467 } 475 }
468 476
469 m_recordScript->setEnabled( true ); 477 m_recordScript->setEnabled( true );
470 m_scripts->setItemEnabled(m_runScript_id, true); 478 m_scripts->setItemEnabled(m_runScript_id, true);
471 } 479 }
472 } 480 }
473} 481}
474 482
475void MainWindow::slotDisconnect() { 483void MainWindow::slotDisconnect() {
476 if ( currentSession() ) { 484 if ( currentSession() ) {
477 currentSession()->layer()->close(); 485 currentSession()->layer()->close();
478 m_connect->setEnabled( true ); 486 m_connect->setEnabled( true );
479 m_disconnect->setEnabled( false ); 487 m_disconnect->setEnabled( false );
480 m_transfer->setEnabled( false ); 488 m_transfer->setEnabled( false );
481 m_recordScript->setEnabled( false); 489 m_recordScript->setEnabled( false);
482 m_saveScript->setEnabled( false ); 490 m_saveScript->setEnabled( false );
483 m_scripts->setItemEnabled(m_runScript_id, false); 491 m_scripts->setItemEnabled(m_runScript_id, false);
484 } 492 }
485} 493}
486 494
487void MainWindow::slotTerminate() { 495void MainWindow::slotTerminate() {
488 if ( currentSession() ) 496 if ( currentSession() )
489 currentSession()->layer()->close(); 497 currentSession()->layer()->close();
490 498
491 slotClose(); 499 slotClose();
492 /* FIXME move to the next session */ 500 /* FIXME move to the next session */
493} 501}
494 502
495void MainWindow::slotConfigure() { 503void MainWindow::slotConfigure() {
496 ConfigDialog conf( manager()->all(), factory() ); 504 ConfigDialog conf( manager()->all(), factory() );
497 conf.showMaximized(); 505 conf.showMaximized();
498 506
499 int ret = conf.exec(); 507 int ret = conf.exec();
500 508
501 if ( QDialog::Accepted == ret ) { 509 if ( QDialog::Accepted == ret ) {
502 manager()->setProfiles( conf.list() ); 510 manager()->setProfiles( conf.list() );
503 manager()->save(); 511 manager()->save();
504 populateProfiles(); 512 populateProfiles();
505 } 513 }
506} 514}
507/* 515/*
508 * we will remove 516 * we will remove
509 * this window from the tabwidget 517 * this window from the tabwidget
510 * remove it from the list 518 * remove it from the list
511 * delete it 519 * delete it
512 * and set the currentSession() 520 * and set the currentSession()
513 */ 521 */
514void MainWindow::slotClose() { 522void MainWindow::slotClose() {
515 if (!currentSession() ) 523 if (!currentSession() )
516 return; 524 return;
517 525
518 Session* ses = currentSession(); 526 Session* ses = currentSession();
519 qWarning("removing! currentSession %s", currentSession()->name().latin1() ); 527 qWarning("removing! currentSession %s", currentSession()->name().latin1() );
520 /* set to NULL to be safe, if its needed slotSessionChanged resets it automatically */ 528 /* set to NULL to be safe, if its needed slotSessionChanged resets it automatically */
521 m_curSession = NULL; 529 m_curSession = NULL;
522 tabWidget()->remove( /*currentSession()*/ses ); 530 tabWidget()->remove( /*currentSession()*/ses );
523 /*it's autodelete */ 531 /*it's autodelete */
524 m_sessions.remove( ses ); 532 m_sessions.remove( ses );
525 qWarning("after remove!!"); 533 qWarning("after remove!!");
526 534
527 if (!currentSession() ) { 535 if (!currentSession() ) {
528 m_connect->setEnabled( false ); 536 m_connect->setEnabled( false );
529 m_disconnect->setEnabled( false ); 537 m_disconnect->setEnabled( false );
530 m_terminate->setEnabled( false ); 538 m_terminate->setEnabled( false );
531 m_transfer->setEnabled( false ); 539 m_transfer->setEnabled( false );
532 m_recordScript->setEnabled( false ); 540 m_recordScript->setEnabled( false );
533 m_saveScript->setEnabled( false ); 541 m_saveScript->setEnabled( false );
534 m_scripts->setItemEnabled(m_runScript_id, false); 542 m_scripts->setItemEnabled(m_runScript_id, false);
535 m_fullscreen->setEnabled( false ); 543 m_fullscreen->setEnabled( false );
536 m_wrap->setEnabled( false ); 544 m_wrap->setEnabled( false );
537 m_closewindow->setEnabled( false ); 545 m_closewindow->setEnabled( false );
538 } 546 }
539 547
540 m_kb->loadDefaults(); 548 m_kb->loadDefaults();
541} 549}
542 550
543/* 551/*
544 * We will get the name 552 * We will get the name
545 * Then the profile 553 * Then the profile
546 * and then we will make a profile 554 * and then we will make a profile
547 */ 555 */
548void MainWindow::slotProfile( int id) { 556void MainWindow::slotProfile( int id) {
549 Profile prof = manager()->profile( m_sessionsPop->text( id) ); 557 Profile prof = manager()->profile( m_sessionsPop->text( id) );
550 create( prof ); 558 create( prof );
551} 559}
552void MainWindow::create( const Profile& prof ) { 560void MainWindow::create( const Profile& prof ) {
553 if(m_curSession) 561 if(m_curSession)
554 if(m_curSession->transferDialog()) m_curSession->transferDialog()->hide(); 562 if(m_curSession->transferDialog()) m_curSession->transferDialog()->hide();
555 563
556 Session *ses = manager()->fromProfile( prof, tabWidget() ); 564 Session *ses = manager()->fromProfile( prof, tabWidget() );
557 565
558 if((!ses) || (!ses->layer()) || (!ses->widgetStack())) 566 if((!ses) || (!ses->layer()) || (!ses->widgetStack()))
559 { 567 {
560 QMessageBox::warning(this, 568 QMessageBox::warning(this,
561 QObject::tr("Session failed"), 569 QObject::tr("Session failed"),
562 QObject::tr("<qt>Cannot open session: Not all components were found.</qt>")); 570 QObject::tr("<qt>Cannot open session: Not all components were found.</qt>"));
563 //if(ses) delete ses; 571 //if(ses) delete ses;
564 return; 572 return;
565 } 573 }
566 574
567 m_sessions.append( ses ); 575 m_sessions.append( ses );
568 tabWidget()->add( ses ); 576 tabWidget()->add( ses );
569 tabWidget()->repaint(); 577 tabWidget()->repaint();
570 m_curSession = ses; 578 m_curSession = ses;
571 579
572 // dicide if its a local term ( then no connction and no tranfer), maybe make a wrapper method out of it 580 // dicide if its a local term ( then no connction and no tranfer), maybe make a wrapper method out of it
573 m_connect->setEnabled( true ); 581 m_connect->setEnabled( true );
574 m_disconnect->setEnabled( false ); 582 m_disconnect->setEnabled( false );
575 m_terminate->setEnabled( true ); 583 m_terminate->setEnabled( true );
576 m_fullscreen->setEnabled( true ); 584 m_fullscreen->setEnabled( true );
577 m_wrap->setEnabled( true ); 585 m_wrap->setEnabled( true );
578 m_closewindow->setEnabled( true ); 586 m_closewindow->setEnabled( true );
579 m_transfer->setEnabled( false ); 587 m_transfer->setEnabled( false );
580 m_recordScript->setEnabled( false ); 588 m_recordScript->setEnabled( false );
581 m_saveScript->setEnabled( false ); 589 m_saveScript->setEnabled( false );
582 m_scripts->setItemEnabled(m_runScript_id, false); 590 m_scripts->setItemEnabled(m_runScript_id, false);
583 591
584 // is io_layer wants direct connection, then autoconnect 592 // is io_layer wants direct connection, then autoconnect
585 //if ( ( m_curSession->layer() )->supports()[0] == 1 ) { 593 //if ( ( m_curSession->layer() )->supports()[0] == 1 ) {
586 if (prof.autoConnect()) { 594 if (prof.autoConnect()) {
587 slotConnect(); 595 slotConnect();
588 } 596 }
589 597
590 598
591 QWidget *w = currentSession()->widget(); 599 QWidget *w = currentSession()->widget();
592 if(w) w->setFocus(); 600 if(w) w->setFocus();
593 601
594 if(currentSession()->profile().readNumEntry("Wrap", 80)){ 602 if(currentSession()->profile().readNumEntry("Wrap", 80)){
595 m_isWrapped = true; 603 m_isWrapped = true;
596 } else { 604 } else {
597 m_isWrapped = false; 605 m_isWrapped = false;
598 } 606 }
599 607
600 m_kb->load(currentSession()->profile()); 608 m_kb->load(currentSession()->profile());
601} 609}
602 610
603void MainWindow::slotTransfer() 611void MainWindow::slotTransfer()
604{ 612{
605 if ( currentSession() ) { 613 if ( currentSession() ) {
606 Session *mysession = currentSession(); 614 Session *mysession = currentSession();
607 TransferDialog dlg(/*mysession->widgetStack()*/this, this); 615 TransferDialog dlg(/*mysession->widgetStack()*/this, this);
608 mysession->setTransferDialog(&dlg); 616 mysession->setTransferDialog(&dlg);
609 //dlg.reparent(mysession->widgetStack(), QPoint(0, 0)); 617 //dlg.reparent(mysession->widgetStack(), QPoint(0, 0));
610 //dlg.showMaximized(); 618 //dlg.showMaximized();
611 currentSession()->widgetStack()->addWidget(&dlg, -1); 619 currentSession()->widgetStack()->addWidget(&dlg, -1);
612 dlg.show(); 620 dlg.show();
613 //dlg.exec(); 621 //dlg.exec();
614 while(dlg.isRunning()) qApp->processEvents(); 622 while(dlg.isRunning()) qApp->processEvents();
615 mysession->setTransferDialog(0l); 623 mysession->setTransferDialog(0l);
616 } 624 }
617} 625}
618 626
619 627
620void MainWindow::slotOpenKeb(bool state) { 628void MainWindow::slotOpenKeb(bool state) {
621 629
622 if (state) m_keyBar->show(); 630 if (state) m_keyBar->show();
623 else m_keyBar->hide(); 631 else m_keyBar->hide();
624 632
625} 633}
626 634
627 635
628void MainWindow::slotOpenButtons( bool state ) { 636void MainWindow::slotOpenButtons( bool state ) {
629 637
630 if ( state ) { 638 if ( state ) {
631 m_buttonBar->show(); 639 m_buttonBar->show();
632 } else { 640 } else {
633 m_buttonBar->hide(); 641 m_buttonBar->hide();
634 } 642 }
635} 643}
636 644
637 645
638 646
639void MainWindow::slotSessionChanged( Session* ses ) { 647void MainWindow::slotSessionChanged( Session* ses ) {
640 qWarning("changed!"); 648 qWarning("changed!");
641 649
642 if(m_curSession) 650 if(m_curSession)
643 if(m_curSession->transferDialog()) m_curSession->transferDialog()->hide(); 651 if(m_curSession->transferDialog()) m_curSession->transferDialog()->hide();
644 if(ses) 652 if(ses)
645 if(ses->transferDialog()) ses->transferDialog()->show(); 653 if(ses->transferDialog()) ses->transferDialog()->show();
646 654
647 if ( ses ) { 655 if ( ses ) {
648 m_curSession = ses; 656 m_curSession = ses;
649 qDebug(QString("is connected : %1").arg( m_curSession->layer()->isConnected() ) ); 657 qDebug(QString("is connected : %1").arg( m_curSession->layer()->isConnected() ) );
650 if ( m_curSession->layer()->isConnected() ) { 658 if ( m_curSession->layer()->isConnected() ) {
651 m_connect->setEnabled( false ); 659 m_connect->setEnabled( false );
652 m_disconnect->setEnabled( true ); 660 m_disconnect->setEnabled( true );
653 m_recordScript->setEnabled(!m_curSession->emulationHandler()->isRecording()); 661 m_recordScript->setEnabled(!m_curSession->emulationHandler()->isRecording());
654 m_saveScript->setEnabled(m_curSession->emulationHandler()->isRecording()); 662 m_saveScript->setEnabled(m_curSession->emulationHandler()->isRecording());
655 m_scripts->setItemEnabled(m_runScript_id, true); 663 m_scripts->setItemEnabled(m_runScript_id, true);
656 } else { 664 } else {
657 m_connect->setEnabled( true ); 665 m_connect->setEnabled( true );
658 m_disconnect->setEnabled( false ); 666 m_disconnect->setEnabled( false );
659 m_recordScript->setEnabled( false ); 667 m_recordScript->setEnabled( false );
660 m_saveScript->setEnabled( false ); 668 m_saveScript->setEnabled( false );
661 m_scripts->setItemEnabled(m_runScript_id, false); 669 m_scripts->setItemEnabled(m_runScript_id, false);
662 } 670 }
663 671
664 if ( ( m_curSession->layer() )->supports()[1] == 0 ) { 672 if ( ( m_curSession->layer() )->supports()[1] == 0 ) {
665 m_transfer->setEnabled( false ); 673 m_transfer->setEnabled( false );
666 } else { 674 } else {
667 m_transfer->setEnabled( true ); 675 m_transfer->setEnabled( true );
668 } 676 }
669 677
670 QWidget *w = m_curSession->widget(); 678 QWidget *w = m_curSession->widget();
671 if(w) w->setFocus(); 679 if(w) w->setFocus();
672 680
673 if(currentSession()->profile().readNumEntry("Wrap", 80)){ 681 if(currentSession()->profile().readNumEntry("Wrap", 80)){
674 m_isWrapped = true; 682 m_isWrapped = true;
675 } else { 683 } else {
676 m_isWrapped = false; 684 m_isWrapped = false;
677 } 685 }
678 686
679 m_kb->load(currentSession()->profile()); 687 m_kb->load(currentSession()->profile());
680 } 688 }
681} 689}
682 690
683void MainWindow::slotWrap() 691void MainWindow::slotWrap()
684{ 692{
685 if(m_curSession) 693 if(m_curSession)
686 { 694 {
687 EmulationHandler *e = m_curSession->emulationHandler(); 695 EmulationHandler *e = m_curSession->emulationHandler();
688 if(e) 696 if(e)
689 { 697 {
690 if(m_isWrapped) 698 if(m_isWrapped)
691 { 699 {
692 e->setWrap(80); 700 e->setWrap(80);
693 m_isWrapped = false; 701 m_isWrapped = false;
694 } 702 }
695 else 703 else
696 { 704 {
697 e->setWrap(0); 705 e->setWrap(0);
698 m_isWrapped = true; 706 m_isWrapped = true;
699 } 707 }
700 } 708 }
701 } 709 }
702} 710}
703 711
704void MainWindow::slotFullscreen() { 712void MainWindow::slotFullscreen() {
705 713
706 714
707 715
708 if ( m_isFullscreen ) { 716 if ( m_isFullscreen ) {
709 ( m_curSession->widgetStack() )->reparent( savedParentFullscreen, 0, QPoint(0,0), true ); 717 ( m_curSession->widgetStack() )->reparent( savedParentFullscreen, 0, QPoint(0,0), true );
710 ( m_curSession->widgetStack() )->resize( savedParentFullscreen->width(), savedParentFullscreen->height() ); 718 ( m_curSession->widgetStack() )->resize( savedParentFullscreen->width(), savedParentFullscreen->height() );
711 ( m_curSession->emulationHandler() )->cornerButton()->hide(); 719 ( m_curSession->emulationHandler() )->cornerButton()->hide();
712 disconnect( ( m_curSession->emulationHandler() )->cornerButton(), SIGNAL( pressed() ), this, SLOT( slotFullscreen() ) ); 720 disconnect( ( m_curSession->emulationHandler() )->cornerButton(), SIGNAL( pressed() ), this, SLOT( slotFullscreen() ) );
713 721
714 } else { 722 } else {
715 savedParentFullscreen = ( m_curSession->widgetStack() )->parentWidget(); 723 savedParentFullscreen = ( m_curSession->widgetStack() )->parentWidget();
716 ( m_curSession->widgetStack() )->setFrameStyle( QFrame::NoFrame ); 724 ( m_curSession->widgetStack() )->setFrameStyle( QFrame::NoFrame );
717 ( m_curSession->widgetStack() )->reparent( 0, WStyle_Tool | WStyle_Customize | WStyle_StaysOnTop 725 ( m_curSession->widgetStack() )->reparent( 0, WStyle_Tool | WStyle_Customize | WStyle_StaysOnTop
718 , QPoint(0,0), false ); 726 , QPoint(0,0), false );
719 ( m_curSession->widgetStack() )->resize( qApp->desktop()->width(), qApp->desktop()->height() ); 727 ( m_curSession->widgetStack() )->resize( qApp->desktop()->width(), qApp->desktop()->height() );
720 ( m_curSession->widgetStack() )->setFocus(); 728 ( m_curSession->widgetStack() )->setFocus();
721 ( m_curSession->widgetStack() )->show(); 729 ( m_curSession->widgetStack() )->show();
722 730
723 ( ( m_curSession->emulationHandler() )->cornerButton() )->show(); 731 ( ( m_curSession->emulationHandler() )->cornerButton() )->show();
724 732
725 connect( ( m_curSession->emulationHandler() )->cornerButton(), SIGNAL( pressed() ), this, SLOT( slotFullscreen() ) ); 733 connect( ( m_curSession->emulationHandler() )->cornerButton(), SIGNAL( pressed() ), this, SLOT( slotFullscreen() ) );
726 } 734 }
727 735
728 m_isFullscreen = !m_isFullscreen; 736 m_isFullscreen = !m_isFullscreen;
729} 737}
730 738
731 739
732void MainWindow::slotKeyReceived(FKey k, ushort, ushort, bool pressed) { 740void MainWindow::slotKeyReceived(FKey k, ushort, ushort, bool pressed) {
733 741
734 if ( m_curSession ) { 742 if ( m_curSession ) {
735 743
736 QEvent::Type state; 744 QEvent::Type state;
737 745
738 if (pressed) state = QEvent::KeyPress; 746 if (pressed) state = QEvent::KeyPress;
739 else state = QEvent::KeyRelease; 747 else state = QEvent::KeyRelease;
740 748
741 QKeyEvent ke(state, k.qcode, k.unicode, 0, QString(QChar(k.unicode))); 749 QKeyEvent ke(state, k.qcode, k.unicode, 0, QString(QChar(k.unicode)));
742 750
743 // is this the best way to do this? cant figure out any other way to work 751 // is this the best way to do this? cant figure out any other way to work
744 QApplication::sendEvent((QObject *)m_curSession->widget(), &ke); 752 QApplication::sendEvent((QObject *)m_curSession->widget(), &ke);
745 ke.ignore(); 753 ke.ignore();
746 } 754 }
747} 755}
748void MainWindow::slotCopy() { 756void MainWindow::slotCopy() {
749 if (!currentSession() ) return; 757 if (!currentSession() ) return;
750 currentSession()->emulationHandler()->copy(); 758 currentSession()->emulationHandler()->copy();
751} 759}
752void MainWindow::slotPaste() { 760void MainWindow::slotPaste() {
753 if (!currentSession() ) return; 761 if (!currentSession() ) return;
754 currentSession()->emulationHandler()->paste(); 762 currentSession()->emulationHandler()->paste();
755} 763}
756 764
757/* 765/*
758 * Save the session 766 * Save the session
759 */ 767 */
760 768
761void MainWindow::slotSaveSession() { 769void MainWindow::slotSaveSession() {
762 if (!currentSession() ) { 770 if (!currentSession() ) {
763 QMessageBox::information(this, tr("Save Connection"), 771 QMessageBox::information(this, tr("Save Connection"),
764 tr("<qt>There is no Connection.</qt>"), 1 ); 772 tr("<qt>There is no Connection.</qt>"), 1 );
765 return; 773 return;
766 } 774 }
767 manager()->add( currentSession()->profile() ); 775 manager()->add( currentSession()->profile() );
768 manager()->save(); 776 manager()->save();
769 populateProfiles(); 777 populateProfiles();
770} 778}
779void MainWindow::slotSaveHistory() {
780 QMap<QString, QStringList> map;
781 QStringList text;
782 text << "text/plain";
783 map.insert(tr("History"), text );
784 QString filename = OFileDialog::getSaveFileName(2, QPEApplication::documentDir(), QString::null, map);
785 if (filename.isEmpty() ) return;
786
787 QFileInfo info(filename);
788
789 DocLnk nf;
790 nf.setType("text/plain");
791 nf.setFile(filename);
792 nf.setName(info.fileName());
793
794
795 QFile file(filename);
796 file.open(IO_WriteOnly );
797 QTextStream str(&file );
798 if ( currentSession() )
799 currentSession()->emulationHandler()->emulation()->streamHistory(&str);
800
801 file.close();
802 nf.writeLink();
803}
diff --git a/noncore/apps/opie-console/mainwindow.h b/noncore/apps/opie-console/mainwindow.h
index 37219c5..0fac38b 100644
--- a/noncore/apps/opie-console/mainwindow.h
+++ b/noncore/apps/opie-console/mainwindow.h
@@ -1,135 +1,136 @@
1#ifndef OPIE_MAIN_WINDOW_H 1#ifndef OPIE_MAIN_WINDOW_H
2#define OPIE_MAIN_WINDOW_H 2#define OPIE_MAIN_WINDOW_H
3 3
4#include <qmainwindow.h> 4#include <qmainwindow.h>
5#include <qlist.h> 5#include <qlist.h>
6 6
7#include "session.h" 7#include "session.h"
8 8
9/** 9/**
10 * this is the MainWindow of the new opie console 10 * this is the MainWindow of the new opie console
11 * it's also the dispatcher between the different 11 * it's also the dispatcher between the different
12 * actions supported by the gui 12 * actions supported by the gui
13 */ 13 */
14class QToolBar; 14class QToolBar;
15class QToolButton; 15class QToolButton;
16class QMenuBar; 16class QMenuBar;
17class QAction; 17class QAction;
18class MetaFactory; 18class MetaFactory;
19class TabWidget; 19class TabWidget;
20class ProfileManager; 20class ProfileManager;
21class Profile; 21class Profile;
22class FunctionKeyboard; 22class FunctionKeyboard;
23class FKey; 23class FKey;
24class DocLnk; 24class DocLnk;
25 25
26class MainWindow : public QMainWindow { 26class MainWindow : public QMainWindow {
27 Q_OBJECT 27 Q_OBJECT
28public: 28public:
29 MainWindow( QWidget *parent = 0, const char *name = 0, WFlags fl = 0 ); 29 MainWindow( QWidget *parent = 0, const char *name = 0, WFlags fl = 0 );
30 ~MainWindow(); 30 ~MainWindow();
31 31
32 /** 32 /**
33 * our factory to generate IOLayer and so on 33 * our factory to generate IOLayer and so on
34 * 34 *
35 */ 35 */
36 MetaFactory* factory(); 36 MetaFactory* factory();
37 37
38 /** 38 /**
39 * A session contains a QWidget*, 39 * A session contains a QWidget*,
40 * an IOLayer* and some infos for us 40 * an IOLayer* and some infos for us
41 */ 41 */
42 Session* currentSession(); 42 Session* currentSession();
43 43
44 /** 44 /**
45 * the session list 45 * the session list
46 */ 46 */
47 QList<Session> sessions(); 47 QList<Session> sessions();
48 48
49 /** 49 /**
50 * 50 *
51 */ 51 */
52 ProfileManager* manager(); 52 ProfileManager* manager();
53 TabWidget* tabWidget(); 53 TabWidget* tabWidget();
54 54
55private slots: 55private slots:
56 void slotNew(); 56 void slotNew();
57 void slotConnect(); 57 void slotConnect();
58 void slotDisconnect(); 58 void slotDisconnect();
59 void slotTerminate(); 59 void slotTerminate();
60 void slotConfigure(); 60 void slotConfigure();
61 void slotClose(); 61 void slotClose();
62 void slotProfile(int); 62 void slotProfile(int);
63 void slotTransfer(); 63 void slotTransfer();
64 void slotOpenKeb(bool); 64 void slotOpenKeb(bool);
65 void slotOpenButtons(bool); 65 void slotOpenButtons(bool);
66 void slotRecordScript(); 66 void slotRecordScript();
67 void slotSaveScript(); 67 void slotSaveScript();
68 void slotRunScript(int); 68 void slotRunScript(int);
69 void slotFullscreen(); 69 void slotFullscreen();
70 void slotWrap(); 70 void slotWrap();
71 void slotSessionChanged( Session* ); 71 void slotSessionChanged( Session* );
72 void slotKeyReceived(FKey, ushort, ushort, bool); 72 void slotKeyReceived(FKey, ushort, ushort, bool);
73 void slotSaveHistory();
73 74
74 /* what could these both slot do? */ 75 /* what could these both slot do? */
75 void slotCopy(); 76 void slotCopy();
76 void slotPaste(); 77 void slotPaste();
77 78
78 /* save the currentSession() to Profiles */ 79 /* save the currentSession() to Profiles */
79 void slotSaveSession(); 80 void slotSaveSession();
80 81
81private: 82private:
82 void initUI(); 83 void initUI();
83 void populateProfiles(); 84 void populateProfiles();
84 void populateScripts(); 85 void populateScripts();
85 void create( const Profile& ); 86 void create( const Profile& );
86 /** 87 /**
87 * the current session 88 * the current session
88 */ 89 */
89 Session* m_curSession; 90 Session* m_curSession;
90 91
91 /** 92 /**
92 * the session list 93 * the session list
93 */ 94 */
94 QList<Session> m_sessions; 95 QList<Session> m_sessions;
95 QList<DocLnk> m_scriptsData; 96 QList<DocLnk> m_scriptsData;
96 97
97 /** 98 /**
98 * the metafactory 99 * the metafactory
99 */ 100 */
100 MetaFactory* m_factory; 101 MetaFactory* m_factory;
101 ProfileManager* m_manager; 102 ProfileManager* m_manager;
102 103
103 TabWidget* m_consoleWindow; 104 TabWidget* m_consoleWindow;
104 QToolBar* m_tool; 105 QToolBar* m_tool;
105 QToolBar* m_icons; 106 QToolBar* m_icons;
106 QToolBar* m_keyBar; 107 QToolBar* m_keyBar;
107 QToolBar* m_buttonBar; 108 QToolBar* m_buttonBar;
108 QMenuBar* m_bar; 109 QMenuBar* m_bar;
109 QPopupMenu* m_console; 110 QPopupMenu* m_console;
110 QPopupMenu* m_sessionsPop; 111 QPopupMenu* m_sessionsPop;
111 QPopupMenu* m_scriptsPop; 112 QPopupMenu* m_scriptsPop;
112 QPopupMenu* m_scripts; 113 QPopupMenu* m_scripts;
113 QAction* m_connect; 114 QAction* m_connect;
114 QAction* m_disconnect; 115 QAction* m_disconnect;
115 QAction* m_terminate; 116 QAction* m_terminate;
116 QAction* m_transfer; 117 QAction* m_transfer;
117 QAction* m_setProfiles; 118 QAction* m_setProfiles;
118 QAction* m_openKeys; 119 QAction* m_openKeys;
119 QAction* m_openButtons; 120 QAction* m_openButtons;
120 QAction* m_recordScript; 121 QAction* m_recordScript;
121 QAction* m_saveScript; 122 QAction* m_saveScript;
122 QAction* m_fullscreen; 123 QAction* m_fullscreen;
123 QAction* m_wrap; 124 QAction* m_wrap;
124 QAction* m_closewindow; 125 QAction* m_closewindow;
125 126
126 FunctionKeyboard *m_kb; 127 FunctionKeyboard *m_kb;
127 int m_runScript_id; 128 int m_runScript_id;
128 bool m_isFullscreen; 129 bool m_isFullscreen;
129 bool m_isWrapped; 130 bool m_isWrapped;
130 131
131 QWidget* savedParentFullscreen; 132 QWidget* savedParentFullscreen;
132}; 133};
133 134
134 135
135#endif 136#endif
diff --git a/noncore/apps/opie-console/metafactory.cpp b/noncore/apps/opie-console/metafactory.cpp
index 0b43e17..24928e7 100644
--- a/noncore/apps/opie-console/metafactory.cpp
+++ b/noncore/apps/opie-console/metafactory.cpp
@@ -1,190 +1,165 @@
1#include <qpe/config.h> 1#include <qpe/config.h>
2#include "metafactory.h" 2#include "metafactory.h"
3 3
4MetaFactory::MetaFactory() { 4MetaFactory::MetaFactory() {
5} 5}
6MetaFactory::~MetaFactory() { 6MetaFactory::~MetaFactory() {
7 7
8} 8}
9void MetaFactory::addConnectionWidgetFactory( const QCString& name, 9void MetaFactory::addConnectionWidgetFactory( const QCString& name,
10 const QString& str, 10 const QString& str,
11 configWidget wid) { 11 configWidget wid) {
12 m_strings.insert( str, name ); 12 m_strings.insert( str, name );
13 m_conFact.insert( str, wid ); 13 m_conFact.insert( str, wid );
14} 14}
15void MetaFactory::addTerminalWidgetFactory( const QCString& name, 15void MetaFactory::addTerminalWidgetFactory( const QCString& name,
16 const QString& str, 16 const QString& str,
17 configWidget wid ) { 17 configWidget wid ) {
18 m_strings.insert( str, name ); 18 m_strings.insert( str, name );
19 m_termFact.insert( str, wid ); 19 m_termFact.insert( str, wid );
20} 20}
21void MetaFactory::addKeyboardWidgetFactory( const QCString& name, 21void MetaFactory::addKeyboardWidgetFactory( const QCString& name,
22 const QString & str, 22 const QString & str,
23 configWidget wid) { 23 configWidget wid) {
24 m_strings.insert( str, name ); 24 m_strings.insert( str, name );
25 m_keyFact.insert( str, wid ); 25 m_keyFact.insert( str, wid );
26 26
27} 27}
28void MetaFactory::addIOLayerFactory( const QCString& name, 28void MetaFactory::addIOLayerFactory( const QCString& name,
29 const QString& str, 29 const QString& str,
30 iolayer lay) { 30 iolayer lay) {
31 m_strings.insert( str, name ); 31 m_strings.insert( str, name );
32 m_layerFact.insert( str, lay ); 32 m_layerFact.insert( str, lay );
33} 33}
34void MetaFactory::addFileTransferLayer( const QCString& name, 34void MetaFactory::addFileTransferLayer( const QCString& name,
35 const QString& str, 35 const QString& str,
36 filelayer lay) { 36 filelayer lay) {
37 m_strings.insert(str, name ); 37 m_strings.insert(str, name );
38 m_fileFact.insert( str, lay ); 38 m_fileFact.insert( str, lay );
39} 39}
40void MetaFactory::addReceiveLayer( const QCString& name, 40void MetaFactory::addReceiveLayer( const QCString& name,
41 const QString& str, 41 const QString& str,
42 receivelayer lay) { 42 receivelayer lay) {
43 m_strings.insert(str, name ); 43 m_strings.insert(str, name );
44 m_receiveFact.insert( str, lay ); 44 m_receiveFact.insert( str, lay );
45} 45}
46void MetaFactory::addEmulationLayer( const QCString& name,
47 const QString& str,
48 emulationLayer em) {
49 m_strings.insert(str, name );
50 m_emu.insert( str, em );
51}
52QStringList MetaFactory::ioLayers()const { 46QStringList MetaFactory::ioLayers()const {
53 QStringList list; 47 QStringList list;
54 QMap<QString, iolayer>::ConstIterator it; 48 QMap<QString, iolayer>::ConstIterator it;
55 for (it = m_layerFact.begin(); it != m_layerFact.end(); ++it ) { 49 for (it = m_layerFact.begin(); it != m_layerFact.end(); ++it ) {
56 list << it.key(); 50 list << it.key();
57 } 51 }
58 return list; 52 return list;
59} 53}
60QStringList MetaFactory::connectionWidgets()const { 54QStringList MetaFactory::connectionWidgets()const {
61 QStringList list; 55 QStringList list;
62 QMap<QString, configWidget>::ConstIterator it; 56 QMap<QString, configWidget>::ConstIterator it;
63 for ( it = m_conFact.begin(); it != m_conFact.end(); ++it ) { 57 for ( it = m_conFact.begin(); it != m_conFact.end(); ++it ) {
64 list << it.key(); 58 list << it.key();
65 } 59 }
66 return list; 60 return list;
67} 61}
68QStringList MetaFactory::terminalWidgets()const { 62QStringList MetaFactory::terminalWidgets()const {
69 QStringList list; 63 QStringList list;
70 QMap<QString, configWidget>::ConstIterator it; 64 QMap<QString, configWidget>::ConstIterator it;
71 for ( it = m_termFact.begin(); it != m_termFact.end(); ++it ) { 65 for ( it = m_termFact.begin(); it != m_termFact.end(); ++it ) {
72 list << it.key(); 66 list << it.key();
73 } 67 }
74 return list; 68 return list;
75} 69}
76QStringList MetaFactory::fileTransferLayers()const { 70QStringList MetaFactory::fileTransferLayers()const {
77 QStringList list; 71 QStringList list;
78 QMap<QString, filelayer>::ConstIterator it; 72 QMap<QString, filelayer>::ConstIterator it;
79 for ( it = m_fileFact.begin(); it != m_fileFact.end(); ++it ) { 73 for ( it = m_fileFact.begin(); it != m_fileFact.end(); ++it ) {
80 list << it.key(); 74 list << it.key();
81 } 75 }
82 return list; 76 return list;
83} 77}
84QStringList MetaFactory::receiveLayers()const { 78QStringList MetaFactory::receiveLayers()const {
85 QStringList list; 79 QStringList list;
86 QMap<QString, receivelayer>::ConstIterator it; 80 QMap<QString, receivelayer>::ConstIterator it;
87 for ( it = m_receiveFact.begin(); it != m_receiveFact.end(); ++it ) { 81 for ( it = m_receiveFact.begin(); it != m_receiveFact.end(); ++it ) {
88 list << it.key(); 82 list << it.key();
89 } 83 }
90 return list; 84 return list;
91} 85}
92QStringList MetaFactory::emulationLayers()const {
93 QStringList list;
94 QMap<QString, emulationLayer>::ConstIterator it;
95 for ( it = m_emu.begin(); it != m_emu.end(); ++it ) {
96 list << it.key();
97 }
98 return list;
99}
100 86
101IOLayer* MetaFactory::newIOLayer( const QString& str,const Profile& prof ) { 87IOLayer* MetaFactory::newIOLayer( const QString& str,const Profile& prof ) {
102 IOLayer* lay = 0l; 88 IOLayer* lay = 0l;
103 89
104 QMap<QString, iolayer>::Iterator it; 90 QMap<QString, iolayer>::Iterator it;
105 it = m_layerFact.find( str ); 91 it = m_layerFact.find( str );
106 if ( it != m_layerFact.end() ) { 92 if ( it != m_layerFact.end() ) {
107 lay = (*(it.data()))(prof); 93 lay = (*(it.data()))(prof);
108 /* 94 /*
109 iolayer laye = it.data(); 95 iolayer laye = it.data();
110 lay = (*laye )(conf);*/ 96 lay = (*laye )(conf);*/
111 } 97 }
112 98
113 return lay; 99 return lay;
114} 100}
115 101
116ProfileDialogWidget *MetaFactory::newConnectionPlugin ( const QString& str, QWidget *parent) { 102ProfileDialogWidget *MetaFactory::newConnectionPlugin ( const QString& str, QWidget *parent) {
117 ProfileDialogWidget* wid = 0l; 103 ProfileDialogWidget* wid = 0l;
118 104
119 QMap<QString, configWidget>::Iterator it; 105 QMap<QString, configWidget>::Iterator it;
120 it = m_conFact.find( str ); 106 it = m_conFact.find( str );
121 if ( it != m_conFact.end() ) { 107 if ( it != m_conFact.end() ) {
122 wid = (*(it.data() ) )(str,parent); 108 wid = (*(it.data() ) )(str,parent);
123 } 109 }
124 return wid; 110 return wid;
125} 111}
126ProfileDialogWidget *MetaFactory::newTerminalPlugin( const QString& str, QWidget *parent) { 112ProfileDialogWidget *MetaFactory::newTerminalPlugin( const QString& str, QWidget *parent) {
127 if (str.isEmpty() ) 113 if (str.isEmpty() )
128 return 0l; 114 return 0l;
129 ProfileDialogWidget* wid = 0l; 115 ProfileDialogWidget* wid = 0l;
130 116
131 QMap<QString, configWidget>::Iterator it; 117 QMap<QString, configWidget>::Iterator it;
132 it = m_termFact.find( str ); 118 it = m_termFact.find( str );
133 if ( it != m_termFact.end() ) { 119 if ( it != m_termFact.end() ) {
134 wid = (*(it.data() ) )(str,parent); 120 wid = (*(it.data() ) )(str,parent);
135 } 121 }
136 return wid; 122 return wid;
137} 123}
138ProfileDialogWidget *MetaFactory::newKeyboardPlugin( const QString& str, QWidget *parent) { 124ProfileDialogWidget *MetaFactory::newKeyboardPlugin( const QString& str, QWidget *parent) {
139 125
140 if (str.isEmpty() ) 126 if (str.isEmpty() )
141 return 0l; 127 return 0l;
142 ProfileDialogWidget* wid = 0l; 128 ProfileDialogWidget* wid = 0l;
143 129
144 QMap<QString, configWidget>::Iterator it; 130 QMap<QString, configWidget>::Iterator it;
145 it = m_keyFact.find( str ); 131 it = m_keyFact.find( str );
146 if ( it != m_keyFact.end() ) { 132 if ( it != m_keyFact.end() ) {
147 wid = (*(it.data() ) )(str,parent); 133 wid = (*(it.data() ) )(str,parent);
148 } 134 }
149 return wid; 135 return wid;
150} 136}
151EmulationLayer* MetaFactory::newEmulationLayer( const QString& str, WidgetLayer* wid) {
152 EmulationLayer* lay = 0l;
153
154 QMap<QString, emulationLayer>::Iterator it;
155 it = m_emu.find( str );
156 if ( it != m_emu.end() ) {
157 lay = (*(it.data() ) )(wid);
158 }
159
160 return lay;
161}
162FileTransferLayer* MetaFactory::newFileTransfer(const QString& str, IOLayer* lay ) { 137FileTransferLayer* MetaFactory::newFileTransfer(const QString& str, IOLayer* lay ) {
163 FileTransferLayer* file = 0l; 138 FileTransferLayer* file = 0l;
164 QMap<QString, filelayer>::Iterator it; 139 QMap<QString, filelayer>::Iterator it;
165 it = m_fileFact.find( str ); 140 it = m_fileFact.find( str );
166 if ( it != m_fileFact.end() ) { 141 if ( it != m_fileFact.end() ) {
167 file = (*(it.data() ) )(lay); 142 file = (*(it.data() ) )(lay);
168 } 143 }
169 return file; 144 return file;
170} 145}
171ReceiveLayer* MetaFactory::newReceive(const QString& str, IOLayer* lay ) { 146ReceiveLayer* MetaFactory::newReceive(const QString& str, IOLayer* lay ) {
172 ReceiveLayer* file = 0l; 147 ReceiveLayer* file = 0l;
173 QMap<QString, receivelayer>::Iterator it; 148 QMap<QString, receivelayer>::Iterator it;
174 it = m_receiveFact.find( str ); 149 it = m_receiveFact.find( str );
175 if ( it != m_receiveFact.end() ) { 150 if ( it != m_receiveFact.end() ) {
176 file = (*(it.data() ) )(lay); 151 file = (*(it.data() ) )(lay);
177 } 152 }
178 return file; 153 return file;
179} 154}
180QCString MetaFactory::internal( const QString& str )const { 155QCString MetaFactory::internal( const QString& str )const {
181 return m_strings[str]; 156 return m_strings[str];
182} 157}
183QString MetaFactory::external( const QCString& str )const { 158QString MetaFactory::external( const QCString& str )const {
184 QMap<QString, QCString>::ConstIterator it; 159 QMap<QString, QCString>::ConstIterator it;
185 for ( it = m_strings.begin(); it != m_strings.end(); ++it ) { 160 for ( it = m_strings.begin(); it != m_strings.end(); ++it ) {
186 if ( it.data() == str ) 161 if ( it.data() == str )
187 return it.key(); 162 return it.key();
188 } 163 }
189 return QString::null; 164 return QString::null;
190} 165}
diff --git a/noncore/apps/opie-console/metafactory.h b/noncore/apps/opie-console/metafactory.h
index f89136c..bcc40db 100644
--- a/noncore/apps/opie-console/metafactory.h
+++ b/noncore/apps/opie-console/metafactory.h
@@ -1,120 +1,109 @@
1#ifndef OPIE_META_FACTORY_H 1#ifndef OPIE_META_FACTORY_H
2#define OPIE_META_FACTORY_H 2#define OPIE_META_FACTORY_H
3 3
4/** 4/**
5 * The MetaFactory is used to keep track of all IOLayers, FileTransferLayers and ConfigWidgets 5 * The MetaFactory is used to keep track of all IOLayers, FileTransferLayers and ConfigWidgets
6 * and to instantiate these implementations on demand 6 * and to instantiate these implementations on demand
7 */ 7 */
8 8
9#include <qwidget.h> 9#include <qwidget.h>
10#include <qmap.h> 10#include <qmap.h>
11 11
12#include <qpe/config.h> 12#include <qpe/config.h>
13 13
14#include "io_layer.h" 14#include "io_layer.h"
15#include "file_layer.h" 15#include "file_layer.h"
16#include "receive_layer.h" 16#include "receive_layer.h"
17#include "profile.h" 17#include "profile.h"
18#include "profiledialogwidget.h" 18#include "profiledialogwidget.h"
19#include "emulation_layer.h"
20 19
21class WidgetLayer; 20class WidgetLayer;
22class MetaFactory { 21class MetaFactory {
23public: 22public:
24 typedef ProfileDialogWidget* (*configWidget)(const QString&, QWidget* parent); 23 typedef ProfileDialogWidget* (*configWidget)(const QString&, QWidget* parent);
25 typedef IOLayer* (*iolayer)(const Profile& ); 24 typedef IOLayer* (*iolayer)(const Profile& );
26 typedef FileTransferLayer* (*filelayer)(IOLayer*); 25 typedef FileTransferLayer* (*filelayer)(IOLayer*);
27 typedef ReceiveLayer* (*receivelayer)(IOLayer*); 26 typedef ReceiveLayer* (*receivelayer)(IOLayer*);
28 typedef EmulationLayer* (*emulationLayer)(WidgetLayer* );
29 27
30 MetaFactory(); 28 MetaFactory();
31 ~MetaFactory(); 29 ~MetaFactory();
32 30
33 /** 31 /**
34 * add a ProfileDialogWidget to the factory 32 * add a ProfileDialogWidget to the factory
35 * name is the name shown to the user 33 * name is the name shown to the user
36 */ 34 */
37 void addConnectionWidgetFactory( const QCString& internalName, 35 void addConnectionWidgetFactory( const QCString& internalName,
38 const QString& uiString, 36 const QString& uiString,
39 configWidget ); 37 configWidget );
40 void addTerminalWidgetFactory ( const QCString& internalName, 38 void addTerminalWidgetFactory ( const QCString& internalName,
41 const QString& name, 39 const QString& name,
42 configWidget ); 40 configWidget );
43 void addKeyboardWidgetFactory ( const QCString& internalName, 41 void addKeyboardWidgetFactory ( const QCString& internalName,
44 const QString& name, 42 const QString& name,
45 configWidget ); 43 configWidget );
46 44
47 /** 45 /**
48 * adds an IOLayer factory 46 * adds an IOLayer factory
49 */ 47 */
50 void addIOLayerFactory( const QCString&, 48 void addIOLayerFactory( const QCString&,
51 const QString&, 49 const QString&,
52 iolayer ); 50 iolayer );
53 51
54 /** 52 /**
55 * adds a FileTransfer Layer 53 * adds a FileTransfer Layer
56 */ 54 */
57 void addFileTransferLayer( const QCString& name, 55 void addFileTransferLayer( const QCString& name,
58 const QString&, 56 const QString&,
59 filelayer ); 57 filelayer );
60 void addReceiveLayer( const QCString& name, 58 void addReceiveLayer( const QCString& name,
61 const QString&, 59 const QString&,
62 receivelayer); 60 receivelayer);
63 61
64 /**
65 * adds a Factory for Emulation to the Layer..
66 */
67 void addEmulationLayer ( const QCString& name,
68 const QString& uiString,
69 emulationLayer );
70 62
71 /* translated UI Strings */ 63 /* translated UI Strings */
72 QStringList ioLayers()const; 64 QStringList ioLayers()const;
73 QStringList connectionWidgets()const; 65 QStringList connectionWidgets()const;
74 66
75 /** 67 /**
76 * Terminal Configuration widgets 68 * Terminal Configuration widgets
77 */ 69 */
78 QStringList terminalWidgets()const; 70 QStringList terminalWidgets()const;
79 QStringList fileTransferLayers()const; 71 QStringList fileTransferLayers()const;
80 QStringList receiveLayers()const; 72 QStringList receiveLayers()const;
81 QStringList emulationLayers()const;
82 73
83 /** 74 /**
84 * the generation... 75 * the generation...
85 */ 76 */
86 IOLayer* newIOLayer( const QString&,const Profile& ); 77 IOLayer* newIOLayer( const QString&,const Profile& );
87 ProfileDialogWidget *newConnectionPlugin ( const QString&, QWidget* ); 78 ProfileDialogWidget *newConnectionPlugin ( const QString&, QWidget* );
88 ProfileDialogWidget* newTerminalPlugin( const QString&, QWidget* ); 79 ProfileDialogWidget* newTerminalPlugin( const QString&, QWidget* );
89 ProfileDialogWidget* newKeyboardPlugin( const QString&, QWidget* ); 80 ProfileDialogWidget* newKeyboardPlugin( const QString&, QWidget* );
90 EmulationLayer* newEmulationLayer(const QString&, WidgetLayer* );
91 FileTransferLayer* newFileTransfer(const QString&, IOLayer* ); 81 FileTransferLayer* newFileTransfer(const QString&, IOLayer* );
92 ReceiveLayer* newReceive(const QString&, IOLayer* ); 82 ReceiveLayer* newReceive(const QString&, IOLayer* );
93 83
94 /* 84 /*
95 * internal takes the maybe translated 85 * internal takes the maybe translated
96 * public QString and maps it to the internal 86 * public QString and maps it to the internal
97 * not translatable QCString 87 * not translatable QCString
98 */ 88 */
99 QCString internal( const QString& )const; 89 QCString internal( const QString& )const;
100 90
101 /* 91 /*
102 * external takes the internal name 92 * external takes the internal name
103 * it returns a translated name 93 * it returns a translated name
104 */ 94 */
105 QString external( const QCString& )const; 95 QString external( const QCString& )const;
106 96
107 97
108private: 98private:
109 QMap<QString, QCString> m_strings; 99 QMap<QString, QCString> m_strings;
110 QMap<QString, configWidget> m_conFact; 100 QMap<QString, configWidget> m_conFact;
111 QMap<QString, configWidget> m_termFact; 101 QMap<QString, configWidget> m_termFact;
112 QMap<QString, configWidget> m_keyFact; 102 QMap<QString, configWidget> m_keyFact;
113 QMap<QString, iolayer> m_layerFact; 103 QMap<QString, iolayer> m_layerFact;
114 QMap<QString, filelayer> m_fileFact; 104 QMap<QString, filelayer> m_fileFact;
115 QMap<QString, receivelayer> m_receiveFact; 105 QMap<QString, receivelayer> m_receiveFact;
116 QMap<QString, emulationLayer> m_emu;
117}; 106};
118 107
119 108
120#endif 109#endif