-rw-r--r-- | noncore/apps/opie-console/metafactory.cpp | 2 | ||||
-rw-r--r-- | noncore/apps/opie-console/metafactory.h | 6 | ||||
-rw-r--r-- | noncore/apps/opie-console/profilemanager.cpp | 5 | ||||
-rw-r--r-- | noncore/apps/opie-console/session.cpp | 6 | ||||
-rw-r--r-- | noncore/apps/opie-console/session.h | 8 | ||||
-rw-r--r-- | noncore/apps/opie-console/widget.cpp | 12 | ||||
-rw-r--r-- | noncore/apps/opie-console/widget_layer.h | 3 |
7 files changed, 23 insertions, 19 deletions
diff --git a/noncore/apps/opie-console/metafactory.cpp b/noncore/apps/opie-console/metafactory.cpp index 02a9f9b..2b672cf 100644 --- a/noncore/apps/opie-console/metafactory.cpp +++ b/noncore/apps/opie-console/metafactory.cpp | |||
@@ -1,139 +1,139 @@ | |||
1 | #include <qpe/config.h> | 1 | #include <qpe/config.h> |
2 | #include "metafactory.h" | 2 | #include "metafactory.h" |
3 | 3 | ||
4 | MetaFactory::MetaFactory() { | 4 | MetaFactory::MetaFactory() { |
5 | } | 5 | } |
6 | MetaFactory::~MetaFactory() { | 6 | MetaFactory::~MetaFactory() { |
7 | 7 | ||
8 | } | 8 | } |
9 | void MetaFactory::addConnectionWidgetFactory( const QCString& name, | 9 | void 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 | } |
15 | void MetaFactory::addTerminalWidgetFactory( const QCString& name, | 15 | void 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 | } |
21 | void MetaFactory::addIOLayerFactory( const QCString& name, | 21 | void MetaFactory::addIOLayerFactory( const QCString& name, |
22 | const QString& str, | 22 | const QString& str, |
23 | iolayer lay) { | 23 | iolayer lay) { |
24 | m_strings.insert( str, name ); | 24 | m_strings.insert( str, name ); |
25 | m_layerFact.insert( str, lay ); | 25 | m_layerFact.insert( str, lay ); |
26 | } | 26 | } |
27 | void MetaFactory::addFileTransferLayer( const QCString& name, | 27 | void MetaFactory::addFileTransferLayer( const QCString& name, |
28 | const QString& str, | 28 | const QString& str, |
29 | filelayer lay) { | 29 | filelayer lay) { |
30 | m_strings.insert(str, name ); | 30 | m_strings.insert(str, name ); |
31 | m_fileFact.insert( str, lay ); | 31 | m_fileFact.insert( str, lay ); |
32 | } | 32 | } |
33 | void MetaFactory::addEmulationLayer( const QCString& name, | 33 | void MetaFactory::addEmulationLayer( const QCString& name, |
34 | const QString& str, | 34 | const QString& str, |
35 | emulationLayer em) { | 35 | emulationLayer em) { |
36 | m_strings.insert(str, name ); | 36 | m_strings.insert(str, name ); |
37 | m_emu.insert( str, em ); | 37 | m_emu.insert( str, em ); |
38 | } | 38 | } |
39 | QStringList MetaFactory::ioLayers()const { | 39 | QStringList MetaFactory::ioLayers()const { |
40 | QStringList list; | 40 | QStringList list; |
41 | QMap<QString, iolayer>::ConstIterator it; | 41 | QMap<QString, iolayer>::ConstIterator it; |
42 | for (it = m_layerFact.begin(); it != m_layerFact.end(); ++it ) { | 42 | for (it = m_layerFact.begin(); it != m_layerFact.end(); ++it ) { |
43 | list << it.key(); | 43 | list << it.key(); |
44 | } | 44 | } |
45 | return list; | 45 | return list; |
46 | } | 46 | } |
47 | QStringList MetaFactory::connectionWidgets()const { | 47 | QStringList MetaFactory::connectionWidgets()const { |
48 | QStringList list; | 48 | QStringList list; |
49 | QMap<QString, configWidget>::ConstIterator it; | 49 | QMap<QString, configWidget>::ConstIterator it; |
50 | for ( it = m_conFact.begin(); it != m_conFact.end(); ++it ) { | 50 | for ( it = m_conFact.begin(); it != m_conFact.end(); ++it ) { |
51 | list << it.key(); | 51 | list << it.key(); |
52 | } | 52 | } |
53 | return list; | 53 | return list; |
54 | } | 54 | } |
55 | QStringList MetaFactory::terminalWidgets()const { | 55 | QStringList MetaFactory::terminalWidgets()const { |
56 | QStringList list; | 56 | QStringList list; |
57 | QMap<QString, configWidget>::ConstIterator it; | 57 | QMap<QString, configWidget>::ConstIterator it; |
58 | for ( it = m_termFact.begin(); it != m_termFact.end(); ++it ) { | 58 | for ( it = m_termFact.begin(); it != m_termFact.end(); ++it ) { |
59 | list << it.key(); | 59 | list << it.key(); |
60 | } | 60 | } |
61 | return list; | 61 | return list; |
62 | } | 62 | } |
63 | QStringList MetaFactory::fileTransferLayers()const { | 63 | QStringList MetaFactory::fileTransferLayers()const { |
64 | QStringList list; | 64 | QStringList list; |
65 | QMap<QString, filelayer>::ConstIterator it; | 65 | QMap<QString, filelayer>::ConstIterator it; |
66 | for ( it = m_fileFact.begin(); it != m_fileFact.end(); ++it ) { | 66 | for ( it = m_fileFact.begin(); it != m_fileFact.end(); ++it ) { |
67 | list << it.key(); | 67 | list << it.key(); |
68 | } | 68 | } |
69 | return list; | 69 | return list; |
70 | } | 70 | } |
71 | QStringList MetaFactory::emulationLayers()const { | 71 | QStringList MetaFactory::emulationLayers()const { |
72 | QStringList list; | 72 | QStringList list; |
73 | QMap<QString, emulationLayer>::ConstIterator it; | 73 | QMap<QString, emulationLayer>::ConstIterator it; |
74 | for ( it = m_emu.begin(); it != m_emu.end(); ++it ) { | 74 | for ( it = m_emu.begin(); it != m_emu.end(); ++it ) { |
75 | list << it.key(); | 75 | list << it.key(); |
76 | } | 76 | } |
77 | return list; | 77 | return list; |
78 | } | 78 | } |
79 | 79 | ||
80 | IOLayer* MetaFactory::newIOLayer( const QString& str,const Profile& prof ) { | 80 | IOLayer* MetaFactory::newIOLayer( const QString& str,const Profile& prof ) { |
81 | IOLayer* lay = 0l; | 81 | IOLayer* lay = 0l; |
82 | 82 | ||
83 | QMap<QString, iolayer>::Iterator it; | 83 | QMap<QString, iolayer>::Iterator it; |
84 | it = m_layerFact.find( str ); | 84 | it = m_layerFact.find( str ); |
85 | if ( it != m_layerFact.end() ) { | 85 | if ( it != m_layerFact.end() ) { |
86 | lay = (*(it.data()))(prof); | 86 | lay = (*(it.data()))(prof); |
87 | /* | 87 | /* |
88 | iolayer laye = it.data(); | 88 | iolayer laye = it.data(); |
89 | lay = (*laye )(conf);*/ | 89 | lay = (*laye )(conf);*/ |
90 | } | 90 | } |
91 | 91 | ||
92 | return lay; | 92 | return lay; |
93 | } | 93 | } |
94 | 94 | ||
95 | ProfileDialogWidget *MetaFactory::newConnectionPlugin ( const QString& str, QWidget *parent) { | 95 | ProfileDialogWidget *MetaFactory::newConnectionPlugin ( const QString& str, QWidget *parent) { |
96 | ProfileDialogWidget* wid = 0l; | 96 | ProfileDialogWidget* wid = 0l; |
97 | 97 | ||
98 | QMap<QString, configWidget>::Iterator it; | 98 | QMap<QString, configWidget>::Iterator it; |
99 | it = m_conFact.find( str ); | 99 | it = m_conFact.find( str ); |
100 | if ( it != m_conFact.end() ) { | 100 | if ( it != m_conFact.end() ) { |
101 | wid = (*(it.data() ) )(str,parent); | 101 | wid = (*(it.data() ) )(str,parent); |
102 | } | 102 | } |
103 | return wid; | 103 | return wid; |
104 | } | 104 | } |
105 | ProfileDialogWidget *MetaFactory::newTerminalPlugin( const QString& str, QWidget *parent) { | 105 | ProfileDialogWidget *MetaFactory::newTerminalPlugin( const QString& str, QWidget *parent) { |
106 | if (str.isEmpty() ) | 106 | if (str.isEmpty() ) |
107 | return 0l; | 107 | return 0l; |
108 | ProfileDialogWidget* wid = 0l; | 108 | ProfileDialogWidget* wid = 0l; |
109 | qWarning("new terminalPlugin %s %l", str.latin1(), parent ); | 109 | qWarning("new terminalPlugin %s %l", str.latin1(), parent ); |
110 | 110 | ||
111 | QMap<QString, configWidget>::Iterator it; | 111 | QMap<QString, configWidget>::Iterator it; |
112 | it = m_termFact.find( str ); | 112 | it = m_termFact.find( str ); |
113 | if ( it != m_termFact.end() ) { | 113 | if ( it != m_termFact.end() ) { |
114 | wid = (*(it.data() ) )(str,parent); | 114 | wid = (*(it.data() ) )(str,parent); |
115 | } | 115 | } |
116 | return wid; | 116 | return wid; |
117 | } | 117 | } |
118 | EmulationLayer* MetaFactory::newEmulationLayer( const QString& str, Widget* wid) { | 118 | EmulationLayer* MetaFactory::newEmulationLayer( const QString& str, WidgetLayer* wid) { |
119 | EmulationLayer* lay = 0l; | 119 | EmulationLayer* lay = 0l; |
120 | 120 | ||
121 | QMap<QString, emulationLayer>::Iterator it; | 121 | QMap<QString, emulationLayer>::Iterator it; |
122 | it = m_emu.find( str ); | 122 | it = m_emu.find( str ); |
123 | if ( it != m_emu.end() ) { | 123 | if ( it != m_emu.end() ) { |
124 | lay = (*(it.data() ) )(wid); | 124 | lay = (*(it.data() ) )(wid); |
125 | } | 125 | } |
126 | 126 | ||
127 | return lay; | 127 | return lay; |
128 | } | 128 | } |
129 | QCString MetaFactory::internal( const QString& str )const { | 129 | QCString MetaFactory::internal( const QString& str )const { |
130 | return m_strings[str]; | 130 | return m_strings[str]; |
131 | } | 131 | } |
132 | QString MetaFactory::external( const QCString& str )const { | 132 | QString MetaFactory::external( const QCString& str )const { |
133 | QMap<QString, QCString>::ConstIterator it; | 133 | QMap<QString, QCString>::ConstIterator it; |
134 | for ( it = m_strings.begin(); it != m_strings.end(); ++it ) { | 134 | for ( it = m_strings.begin(); it != m_strings.end(); ++it ) { |
135 | if ( it.data() == str ) | 135 | if ( it.data() == str ) |
136 | return it.key(); | 136 | return it.key(); |
137 | } | 137 | } |
138 | return QString::null; | 138 | return QString::null; |
139 | } | 139 | } |
diff --git a/noncore/apps/opie-console/metafactory.h b/noncore/apps/opie-console/metafactory.h index 71c35a2..d05ece4 100644 --- a/noncore/apps/opie-console/metafactory.h +++ b/noncore/apps/opie-console/metafactory.h | |||
@@ -1,106 +1,106 @@ | |||
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 "profile.h" | 16 | #include "profile.h" |
17 | #include "profiledialogwidget.h" | 17 | #include "profiledialogwidget.h" |
18 | #include "emulation_layer.h" | 18 | #include "emulation_layer.h" |
19 | 19 | ||
20 | class Widget; | 20 | class WidgetLayer; |
21 | class MetaFactory { | 21 | class MetaFactory { |
22 | public: | 22 | public: |
23 | typedef ProfileDialogWidget* (*configWidget)(const QString&, QWidget* parent); | 23 | typedef ProfileDialogWidget* (*configWidget)(const QString&, QWidget* parent); |
24 | typedef IOLayer* (*iolayer)(const Profile& ); | 24 | typedef IOLayer* (*iolayer)(const Profile& ); |
25 | typedef FileTransferLayer* (*filelayer)(IOLayer*); | 25 | typedef FileTransferLayer* (*filelayer)(IOLayer*); |
26 | typedef EmulationLayer* (*emulationLayer)(Widget* ); | 26 | typedef EmulationLayer* (*emulationLayer)(WidgetLayer* ); |
27 | 27 | ||
28 | MetaFactory(); | 28 | MetaFactory(); |
29 | ~MetaFactory(); | 29 | ~MetaFactory(); |
30 | 30 | ||
31 | /** | 31 | /** |
32 | * add a ProfileDialogWidget to the factory | 32 | * add a ProfileDialogWidget to the factory |
33 | * name is the name shown to the user | 33 | * name is the name shown to the user |
34 | */ | 34 | */ |
35 | void addConnectionWidgetFactory( const QCString& internalName, | 35 | void addConnectionWidgetFactory( const QCString& internalName, |
36 | const QString& uiString, | 36 | const QString& uiString, |
37 | configWidget ); | 37 | configWidget ); |
38 | void addTerminalWidgetFactory ( const QCString& internalName, | 38 | void addTerminalWidgetFactory ( const QCString& internalName, |
39 | const QString& name, | 39 | const QString& name, |
40 | configWidget ); | 40 | configWidget ); |
41 | 41 | ||
42 | /** | 42 | /** |
43 | * adds an IOLayer factory | 43 | * adds an IOLayer factory |
44 | */ | 44 | */ |
45 | void addIOLayerFactory( const QCString&, | 45 | void addIOLayerFactory( const QCString&, |
46 | const QString&, | 46 | const QString&, |
47 | iolayer ); | 47 | iolayer ); |
48 | 48 | ||
49 | /** | 49 | /** |
50 | * adds a FileTransfer Layer | 50 | * adds a FileTransfer Layer |
51 | */ | 51 | */ |
52 | void addFileTransferLayer( const QCString& name, | 52 | void addFileTransferLayer( const QCString& name, |
53 | const QString&, | 53 | const QString&, |
54 | filelayer ); | 54 | filelayer ); |
55 | 55 | ||
56 | /** | 56 | /** |
57 | * adds a Factory for Emulation to the Layer.. | 57 | * adds a Factory for Emulation to the Layer.. |
58 | */ | 58 | */ |
59 | void addEmulationLayer ( const QCString& name, | 59 | void addEmulationLayer ( const QCString& name, |
60 | const QString& uiString, | 60 | const QString& uiString, |
61 | emulationLayer ); | 61 | emulationLayer ); |
62 | 62 | ||
63 | /* translated UI Strings */ | 63 | /* translated UI Strings */ |
64 | QStringList ioLayers()const; | 64 | QStringList ioLayers()const; |
65 | QStringList connectionWidgets()const; | 65 | QStringList connectionWidgets()const; |
66 | 66 | ||
67 | /** | 67 | /** |
68 | * Terminal Configuration widgets | 68 | * Terminal Configuration widgets |
69 | */ | 69 | */ |
70 | QStringList terminalWidgets()const; | 70 | QStringList terminalWidgets()const; |
71 | QStringList fileTransferLayers()const; | 71 | QStringList fileTransferLayers()const; |
72 | QStringList emulationLayers()const; | 72 | QStringList emulationLayers()const; |
73 | 73 | ||
74 | /** | 74 | /** |
75 | * the generation... | 75 | * the generation... |
76 | */ | 76 | */ |
77 | IOLayer* newIOLayer( const QString&,const Profile& ); | 77 | IOLayer* newIOLayer( const QString&,const Profile& ); |
78 | ProfileDialogWidget *newConnectionPlugin ( const QString&, QWidget* ); | 78 | ProfileDialogWidget *newConnectionPlugin ( const QString&, QWidget* ); |
79 | ProfileDialogWidget* newTerminalPlugin( const QString&, QWidget* ); | 79 | ProfileDialogWidget* newTerminalPlugin( const QString&, QWidget* ); |
80 | EmulationLayer* newEmulationLayer(const QString&, Widget* ); | 80 | EmulationLayer* newEmulationLayer(const QString&, WidgetLayer* ); |
81 | 81 | ||
82 | /* | 82 | /* |
83 | * internal takes the maybe translated | 83 | * internal takes the maybe translated |
84 | * public QString and maps it to the internal | 84 | * public QString and maps it to the internal |
85 | * not translatable QCString | 85 | * not translatable QCString |
86 | */ | 86 | */ |
87 | QCString internal( const QString& )const; | 87 | QCString internal( const QString& )const; |
88 | 88 | ||
89 | /* | 89 | /* |
90 | * external takes the internal name | 90 | * external takes the internal name |
91 | * it returns a translated name | 91 | * it returns a translated name |
92 | */ | 92 | */ |
93 | QString external( const QCString& )const; | 93 | QString external( const QCString& )const; |
94 | 94 | ||
95 | 95 | ||
96 | private: | 96 | private: |
97 | QMap<QString, QCString> m_strings; | 97 | QMap<QString, QCString> m_strings; |
98 | QMap<QString, configWidget> m_conFact; | 98 | QMap<QString, configWidget> m_conFact; |
99 | QMap<QString, configWidget> m_termFact; | 99 | QMap<QString, configWidget> m_termFact; |
100 | QMap<QString, iolayer> m_layerFact; | 100 | QMap<QString, iolayer> m_layerFact; |
101 | QMap<QString, filelayer> m_fileFact; | 101 | QMap<QString, filelayer> m_fileFact; |
102 | QMap<QString, emulationLayer> m_emu; | 102 | QMap<QString, emulationLayer> m_emu; |
103 | }; | 103 | }; |
104 | 104 | ||
105 | 105 | ||
106 | #endif | 106 | #endif |
diff --git a/noncore/apps/opie-console/profilemanager.cpp b/noncore/apps/opie-console/profilemanager.cpp index dcf3cbd..78751e7 100644 --- a/noncore/apps/opie-console/profilemanager.cpp +++ b/noncore/apps/opie-console/profilemanager.cpp | |||
@@ -1,126 +1,127 @@ | |||
1 | #include <stdio.h> | 1 | #include <stdio.h> |
2 | #include <stdlib.h> | 2 | #include <stdlib.h> |
3 | 3 | ||
4 | #include <qfile.h> | 4 | #include <qfile.h> |
5 | #include <qlayout.h> | 5 | #include <qlayout.h> |
6 | #include <qwidgetstack.h> | 6 | #include <qwidgetstack.h> |
7 | 7 | ||
8 | #include <qpe/config.h> | 8 | #include <qpe/config.h> |
9 | 9 | ||
10 | #include "widget.h" | 10 | #include "widget_layer.h" |
11 | #include "emulation_widget.h" | ||
11 | #include "metafactory.h" | 12 | #include "metafactory.h" |
12 | #include "profileconfig.h" | 13 | #include "profileconfig.h" |
13 | #include "profilemanager.h" | 14 | #include "profilemanager.h" |
14 | 15 | ||
15 | ProfileManager::ProfileManager( MetaFactory* fact ) | 16 | ProfileManager::ProfileManager( MetaFactory* fact ) |
16 | : m_fact( fact ) | 17 | : m_fact( fact ) |
17 | { | 18 | { |
18 | 19 | ||
19 | } | 20 | } |
20 | ProfileManager::~ProfileManager() { | 21 | ProfileManager::~ProfileManager() { |
21 | 22 | ||
22 | } | 23 | } |
23 | void ProfileManager::load() { | 24 | void ProfileManager::load() { |
24 | m_list.clear(); | 25 | m_list.clear(); |
25 | qWarning("load"); | 26 | qWarning("load"); |
26 | ProfileConfig conf("opie-console-profiles"); | 27 | ProfileConfig conf("opie-console-profiles"); |
27 | QStringList groups = conf.groups(); | 28 | QStringList groups = conf.groups(); |
28 | QStringList::Iterator it; | 29 | QStringList::Iterator it; |
29 | 30 | ||
30 | /* | 31 | /* |
31 | * for each profile | 32 | * for each profile |
32 | */ | 33 | */ |
33 | for ( it = groups.begin(); it != groups.end(); ++it ) { | 34 | for ( it = groups.begin(); it != groups.end(); ++it ) { |
34 | qWarning("group " + (*it) ); | 35 | qWarning("group " + (*it) ); |
35 | conf.setGroup( (*it) ); | 36 | conf.setGroup( (*it) ); |
36 | Profile prof; | 37 | Profile prof; |
37 | prof.setName( conf.readEntry("name") ); | 38 | prof.setName( conf.readEntry("name") ); |
38 | prof.setIOLayer( conf.readEntry("iolayer").utf8() ); | 39 | prof.setIOLayer( conf.readEntry("iolayer").utf8() ); |
39 | prof.setTerminalName( conf.readEntry("term").utf8() ); | 40 | prof.setTerminalName( conf.readEntry("term").utf8() ); |
40 | qWarning(" %s %s", conf.readEntry("iolayer").latin1(), prof.ioLayerName().data() ); | 41 | qWarning(" %s %s", conf.readEntry("iolayer").latin1(), prof.ioLayerName().data() ); |
41 | prof.setBackground( conf.readNumEntry("back") ); | 42 | prof.setBackground( conf.readNumEntry("back") ); |
42 | prof.setForeground( conf.readNumEntry("fore") ); | 43 | prof.setForeground( conf.readNumEntry("fore") ); |
43 | prof.setTerminal( conf.readNumEntry("terminal") ); | 44 | prof.setTerminal( conf.readNumEntry("terminal") ); |
44 | prof.setConf( conf.items( (*it) ) ); | 45 | prof.setConf( conf.items( (*it) ) ); |
45 | 46 | ||
46 | /* now add it */ | 47 | /* now add it */ |
47 | m_list.append( prof ); | 48 | m_list.append( prof ); |
48 | } | 49 | } |
49 | 50 | ||
50 | } | 51 | } |
51 | void ProfileManager::clear() { | 52 | void ProfileManager::clear() { |
52 | m_list.clear(); | 53 | m_list.clear(); |
53 | } | 54 | } |
54 | Profile::ValueList ProfileManager::all()const { | 55 | Profile::ValueList ProfileManager::all()const { |
55 | return m_list; | 56 | return m_list; |
56 | } | 57 | } |
57 | /* | 58 | /* |
58 | * Our goal is to create a Session | 59 | * Our goal is to create a Session |
59 | * We will load the the IOLayer and EmulationLayer | 60 | * We will load the the IOLayer and EmulationLayer |
60 | * from the factory | 61 | * from the factory |
61 | * we will generate a QWidgetStack | 62 | * we will generate a QWidgetStack |
62 | * add a dummy widget with layout | 63 | * add a dummy widget with layout |
63 | * add "Widget" to the layout | 64 | * add "Widget" to the layout |
64 | * add the dummy to the stack | 65 | * add the dummy to the stack |
65 | * raise the dummy | 66 | * raise the dummy |
66 | * call session->connect(= | 67 | * call session->connect(= |
67 | * this way we only need to reparent | 68 | * this way we only need to reparent |
68 | * in TabWidget | 69 | * in TabWidget |
69 | */ | 70 | */ |
70 | Session* ProfileManager::fromProfile( const Profile& prof, QWidget* parent) { | 71 | Session* ProfileManager::fromProfile( const Profile& prof, QWidget* parent) { |
71 | Session* session = new Session(); | 72 | Session* session = new Session(); |
72 | session->setName( prof.name() ); | 73 | session->setName( prof.name() ); |
73 | /* translate the internal name to the external */ | 74 | /* translate the internal name to the external */ |
74 | session->setIOLayer(m_fact->newIOLayer( m_fact->external(prof.ioLayerName()) , | 75 | session->setIOLayer(m_fact->newIOLayer( m_fact->external(prof.ioLayerName()) , |
75 | prof) ); | 76 | prof) ); |
76 | 77 | ||
77 | QWidgetStack *stack = new QWidgetStack(parent); | 78 | QWidgetStack *stack = new QWidgetStack(parent); |
78 | session->setWidgetStack( stack ); | 79 | session->setWidgetStack( stack ); |
79 | QWidget* dummy = new QWidget(stack ); | 80 | QWidget* dummy = new QWidget(stack ); |
80 | QHBoxLayout* lay = new QHBoxLayout(dummy ); | 81 | QHBoxLayout* lay = new QHBoxLayout(dummy ); |
81 | stack->addWidget( dummy, 0 ); | 82 | stack->addWidget( dummy, 0 ); |
82 | stack->raiseWidget( 0 ); | 83 | stack->raiseWidget( 0 ); |
83 | Widget* wid = new Widget(dummy ); | 84 | WidgetLayer* wid = new EmulationWidget( prof, dummy ); |
84 | lay->addWidget( wid ); | 85 | lay->addWidget( wid ); |
85 | 86 | ||
86 | session->setEmulationWidget( wid ); | 87 | session->setEmulationWidget( wid ); |
87 | session->setEmulationLayer( m_fact->newEmulationLayer( m_fact->external( prof.terminalName() ), | 88 | session->setEmulationLayer( m_fact->newEmulationLayer( m_fact->external( prof.terminalName() ), |
88 | wid ) ); | 89 | wid ) ); |
89 | session->connect(); | 90 | session->connect(); |
90 | 91 | ||
91 | return session; | 92 | return session; |
92 | } | 93 | } |
93 | void ProfileManager::save( ) { | 94 | void ProfileManager::save( ) { |
94 | QFile::remove( (QString(getenv("HOME") )+ "/Settings/opie-console-profiles.conf" ) ); | 95 | QFile::remove( (QString(getenv("HOME") )+ "/Settings/opie-console-profiles.conf" ) ); |
95 | ProfileConfig conf("opie-console-profiles"); | 96 | ProfileConfig conf("opie-console-profiles"); |
96 | Profile::ValueList::Iterator it; | 97 | Profile::ValueList::Iterator it; |
97 | for (it = m_list.begin(); it != m_list.end(); ++it ) { | 98 | for (it = m_list.begin(); it != m_list.end(); ++it ) { |
98 | conf.setGroup( (*it).name() ); | 99 | conf.setGroup( (*it).name() ); |
99 | conf.writeEntry( "name", (*it).name() ); | 100 | conf.writeEntry( "name", (*it).name() ); |
100 | conf.writeEntry( "iolayer", QString::fromUtf8( (*it).ioLayerName() ) ); | 101 | conf.writeEntry( "iolayer", QString::fromUtf8( (*it).ioLayerName() ) ); |
101 | conf.writeEntry( "term", QString::fromUtf8( (*it).terminalName() ) ); | 102 | conf.writeEntry( "term", QString::fromUtf8( (*it).terminalName() ) ); |
102 | conf.writeEntry( "back", (*it).background() ); | 103 | conf.writeEntry( "back", (*it).background() ); |
103 | conf.writeEntry( "fore", (*it).foreground() ); | 104 | conf.writeEntry( "fore", (*it).foreground() ); |
104 | conf.writeEntry( "terminal", (*it).terminal() ); | 105 | conf.writeEntry( "terminal", (*it).terminal() ); |
105 | /* now the config stuff */ | 106 | /* now the config stuff */ |
106 | QMap<QString, QString> map = (*it).conf(); | 107 | QMap<QString, QString> map = (*it).conf(); |
107 | QMap<QString, QString>::Iterator it; | 108 | QMap<QString, QString>::Iterator it; |
108 | for ( it = map.begin(); it != map.end(); ++it ) { | 109 | for ( it = map.begin(); it != map.end(); ++it ) { |
109 | conf.writeEntry( it.key(), it.data() ); | 110 | conf.writeEntry( it.key(), it.data() ); |
110 | } | 111 | } |
111 | } | 112 | } |
112 | } | 113 | } |
113 | void ProfileManager::setProfiles( const Profile::ValueList& list ) { | 114 | void ProfileManager::setProfiles( const Profile::ValueList& list ) { |
114 | m_list = list; | 115 | m_list = list; |
115 | }; | 116 | }; |
116 | Profile ProfileManager::profile( const QString& name )const { | 117 | Profile ProfileManager::profile( const QString& name )const { |
117 | Profile prof; | 118 | Profile prof; |
118 | Profile::ValueList::ConstIterator it; | 119 | Profile::ValueList::ConstIterator it; |
119 | for ( it = m_list.begin(); it != m_list.end(); ++it ) { | 120 | for ( it = m_list.begin(); it != m_list.end(); ++it ) { |
120 | if ( name == (*it).name() ) { | 121 | if ( name == (*it).name() ) { |
121 | prof = (*it); | 122 | prof = (*it); |
122 | break; | 123 | break; |
123 | } | 124 | } |
124 | } | 125 | } |
125 | return prof; | 126 | return prof; |
126 | } | 127 | } |
diff --git a/noncore/apps/opie-console/session.cpp b/noncore/apps/opie-console/session.cpp index 42b0583..ff2c3e2 100644 --- a/noncore/apps/opie-console/session.cpp +++ b/noncore/apps/opie-console/session.cpp | |||
@@ -1,81 +1,81 @@ | |||
1 | 1 | ||
2 | 2 | ||
3 | #include "io_layer.h" | 3 | #include "io_layer.h" |
4 | #include "file_layer.h" | 4 | #include "file_layer.h" |
5 | #include "widget.h" | 5 | #include "widget_layer.h" |
6 | #include "emulation_layer.h" | 6 | #include "emulation_layer.h" |
7 | #include "session.h" | 7 | #include "session.h" |
8 | 8 | ||
9 | 9 | ||
10 | Session::Session() { | 10 | Session::Session() { |
11 | m_widget = 0l; | 11 | m_widget = 0l; |
12 | m_layer = 0l; | 12 | m_layer = 0l; |
13 | m_widLay = 0l; | 13 | m_widLay = 0l; |
14 | m_emLay = 0l; | 14 | m_emLay = 0l; |
15 | } | 15 | } |
16 | Session::Session( const QString& na, QWidgetStack* widget, IOLayer* lay) | 16 | Session::Session( const QString& na, QWidgetStack* widget, IOLayer* lay) |
17 | : m_name( na ), m_widget( widget ), m_layer( lay ) | 17 | : m_name( na ), m_widget( widget ), m_layer( lay ) |
18 | { | 18 | { |
19 | m_widLay = 0l; | 19 | m_widLay = 0l; |
20 | m_emLay = 0l; | 20 | m_emLay = 0l; |
21 | } | 21 | } |
22 | Session::~Session() { | 22 | Session::~Session() { |
23 | delete m_layer; | 23 | delete m_layer; |
24 | delete m_emLay; | 24 | delete m_emLay; |
25 | delete m_widget; | 25 | delete m_widget; |
26 | /* the widget layer should be deleted by the m_widget */ | 26 | /* the widget layer should be deleted by the m_widget */ |
27 | } | 27 | } |
28 | QString Session::name()const { | 28 | QString Session::name()const { |
29 | return m_name; | 29 | return m_name; |
30 | } | 30 | } |
31 | QWidgetStack* Session::widgetStack() { | 31 | QWidgetStack* Session::widgetStack() { |
32 | return m_widget; | 32 | return m_widget; |
33 | } | 33 | } |
34 | IOLayer* Session::layer() { | 34 | IOLayer* Session::layer() { |
35 | return m_layer; | 35 | return m_layer; |
36 | } | 36 | } |
37 | EmulationLayer* Session::emulationLayer() { | 37 | EmulationLayer* Session::emulationLayer() { |
38 | return m_emLay; | 38 | return m_emLay; |
39 | } | 39 | } |
40 | Widget* Session::emulationWidget() { | 40 | WidgetLayer* Session::emulationWidget() { |
41 | return m_widLay; | 41 | return m_widLay; |
42 | } | 42 | } |
43 | void Session::connect() { | 43 | void Session::connect() { |
44 | if ( !m_layer || !m_emLay ) | 44 | if ( !m_layer || !m_emLay ) |
45 | return; | 45 | return; |
46 | 46 | ||
47 | QObject::connect(m_layer, SIGNAL(received(const QByteArray&) ), | 47 | QObject::connect(m_layer, SIGNAL(received(const QByteArray&) ), |
48 | m_emLay, SLOT(onRcvBlock(const QByteArray&) ) ); | 48 | m_emLay, SLOT(onRcvBlock(const QByteArray&) ) ); |
49 | QObject::connect(m_emLay, SIGNAL(sndBlock(const QByteArray&) ), | 49 | QObject::connect(m_emLay, SIGNAL(sndBlock(const QByteArray&) ), |
50 | m_layer, SLOT(send(const QByteArray&) ) ); | 50 | m_layer, SLOT(send(const QByteArray&) ) ); |
51 | } | 51 | } |
52 | void Session::disconnect() { | 52 | void Session::disconnect() { |
53 | if ( !m_layer || !m_emLay ) | 53 | if ( !m_layer || !m_emLay ) |
54 | return; | 54 | return; |
55 | 55 | ||
56 | QObject::disconnect(m_layer, SIGNAL(received(const QByteArray&) ), | 56 | QObject::disconnect(m_layer, SIGNAL(received(const QByteArray&) ), |
57 | m_emLay, SLOT(onRcvBlock(const QByteArray&) ) ); | 57 | m_emLay, SLOT(onRcvBlock(const QByteArray&) ) ); |
58 | QObject::disconnect(m_emLay, SIGNAL(sndBlock(const QByteArray&) ), | 58 | QObject::disconnect(m_emLay, SIGNAL(sndBlock(const QByteArray&) ), |
59 | m_layer, SLOT(send(const QByteArray&) ) ); | 59 | m_layer, SLOT(send(const QByteArray&) ) ); |
60 | } | 60 | } |
61 | void Session::setName( const QString& na){ | 61 | void Session::setName( const QString& na){ |
62 | m_name = na; | 62 | m_name = na; |
63 | } | 63 | } |
64 | void Session::setWidgetStack( QWidgetStack* wid ) { | 64 | void Session::setWidgetStack( QWidgetStack* wid ) { |
65 | delete m_widget; | 65 | delete m_widget; |
66 | /* the EmulationLayer was destroyed... */ | 66 | /* the EmulationLayer was destroyed... */ |
67 | delete m_emLay; | 67 | delete m_emLay; |
68 | m_widget = wid; | 68 | m_widget = wid; |
69 | } | 69 | } |
70 | void Session::setIOLayer( IOLayer* lay ) { | 70 | void Session::setIOLayer( IOLayer* lay ) { |
71 | delete m_layer; | 71 | delete m_layer; |
72 | m_layer = lay; | 72 | m_layer = lay; |
73 | } | 73 | } |
74 | void Session::setEmulationLayer( EmulationLayer* lay ) { | 74 | void Session::setEmulationLayer( EmulationLayer* lay ) { |
75 | delete m_emLay; | 75 | delete m_emLay; |
76 | m_emLay = lay; | 76 | m_emLay = lay; |
77 | } | 77 | } |
78 | void Session::setEmulationWidget( Widget* lay ) { | 78 | void Session::setEmulationWidget( WidgetLayer* lay ) { |
79 | delete m_widLay; | 79 | delete m_widLay; |
80 | m_widLay = lay; | 80 | m_widLay = lay; |
81 | } | 81 | } |
diff --git a/noncore/apps/opie-console/session.h b/noncore/apps/opie-console/session.h index c3673fc..64c2cdb 100644 --- a/noncore/apps/opie-console/session.h +++ b/noncore/apps/opie-console/session.h | |||
@@ -1,74 +1,74 @@ | |||
1 | #ifndef OPIE_SESSION_H | 1 | #ifndef OPIE_SESSION_H |
2 | #define OPIE_SESSION_H | 2 | #define OPIE_SESSION_H |
3 | 3 | ||
4 | #include <qwidgetstack.h> | 4 | #include <qwidgetstack.h> |
5 | 5 | ||
6 | class IOLayer; | 6 | class IOLayer; |
7 | class EmulationLayer; | 7 | class EmulationLayer; |
8 | class Widget; | 8 | class WidgetLayer; |
9 | /** | 9 | /** |
10 | * This is a Session. A session contains | 10 | * This is a Session. A session contains |
11 | * a QWidget pointer and a IOLayer | 11 | * a QWidget pointer and a IOLayer |
12 | * Imagine a session like a collection of what | 12 | * Imagine a session like a collection of what |
13 | * is needed to show your widget in a tab ;) | 13 | * is needed to show your widget in a tab ;) |
14 | */ | 14 | */ |
15 | class Session { | 15 | class Session { |
16 | public: | 16 | public: |
17 | /** | 17 | /** |
18 | * c'tor with widget and layer | 18 | * c'tor with widget and layer |
19 | * ownership get's transfered | 19 | * ownership get's transfered |
20 | */ | 20 | */ |
21 | Session(); | 21 | Session(); |
22 | Session( const QString&, QWidgetStack* widget, IOLayer* ); | 22 | Session( const QString&, QWidgetStack* widget, IOLayer* ); |
23 | ~Session(); | 23 | ~Session(); |
24 | 24 | ||
25 | /** | 25 | /** |
26 | * return the name of the session | 26 | * return the name of the session |
27 | */ | 27 | */ |
28 | QString name()const; | 28 | QString name()const; |
29 | 29 | ||
30 | /** | 30 | /** |
31 | * return the widgetstack | 31 | * return the widgetstack |
32 | * this is used to be semi modal | 32 | * this is used to be semi modal |
33 | * for FileTransfer | 33 | * for FileTransfer |
34 | * | 34 | * |
35 | * semi modal == SessionModal | 35 | * semi modal == SessionModal |
36 | */ | 36 | */ |
37 | QWidgetStack* widgetStack(); | 37 | QWidgetStack* widgetStack(); |
38 | 38 | ||
39 | /** | 39 | /** |
40 | * return the layer | 40 | * return the layer |
41 | */ | 41 | */ |
42 | IOLayer* layer(); | 42 | IOLayer* layer(); |
43 | 43 | ||
44 | EmulationLayer* emulationLayer(); | 44 | EmulationLayer* emulationLayer(); |
45 | Widget* emulationWidget(); | 45 | WidgetLayer* emulationWidget(); |
46 | 46 | ||
47 | /* | 47 | /* |
48 | * connects the data flow from | 48 | * connects the data flow from |
49 | * the IOLayer to the EmulationLayer | 49 | * the IOLayer to the EmulationLayer |
50 | */ | 50 | */ |
51 | void connect(); | 51 | void connect(); |
52 | 52 | ||
53 | /* | 53 | /* |
54 | * disconnect the dataflow | 54 | * disconnect the dataflow |
55 | * this will be done for ft | 55 | * this will be done for ft |
56 | */ | 56 | */ |
57 | void disconnect(); | 57 | void disconnect(); |
58 | 58 | ||
59 | void setWidgetStack( QWidgetStack* widget ); | 59 | void setWidgetStack( QWidgetStack* widget ); |
60 | void setEmulationLayer( EmulationLayer* lay ); | 60 | void setEmulationLayer( EmulationLayer* lay ); |
61 | void setEmulationWidget( Widget* lay ); | 61 | void setEmulationWidget( WidgetLayer* lay ); |
62 | void setIOLayer( IOLayer* ); | 62 | void setIOLayer( IOLayer* ); |
63 | void setName( const QString& ); | 63 | void setName( const QString& ); |
64 | 64 | ||
65 | private: | 65 | private: |
66 | QString m_name; | 66 | QString m_name; |
67 | QWidgetStack* m_widget; | 67 | QWidgetStack* m_widget; |
68 | IOLayer* m_layer; | 68 | IOLayer* m_layer; |
69 | EmulationLayer* m_emLay; | 69 | EmulationLayer* m_emLay; |
70 | Widget* m_widLay; | 70 | WidgetLayer* m_widLay; |
71 | 71 | ||
72 | }; | 72 | }; |
73 | 73 | ||
74 | #endif | 74 | #endif |
diff --git a/noncore/apps/opie-console/widget.cpp b/noncore/apps/opie-console/widget.cpp index b8f2906..d948179 100644 --- a/noncore/apps/opie-console/widget.cpp +++ b/noncore/apps/opie-console/widget.cpp | |||
@@ -1,151 +1,152 @@ | |||
1 | /* ------------------------------------------------------------------------ */ | 1 | /* ------------------------------------------------------------------------ */ |
2 | /* */ | 2 | /* */ |
3 | /* [TEWidget.C] Terminal Emulation Widget */ | 3 | /* [TEWidget.C] Terminal Emulation Widget */ |
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 | /* ibot: | 19 | /* ibot: |
20 | i changed | 20 | i changed |
21 | "currentSession->getEmulation()->sendString()" to | 21 | "currentSession->getEmulation()->sendString()" to |
22 | "currentSession->layer()->send()" | 22 | "currentSession->layer()->send()" |
23 | # this is not right! EmulationLayer should send it... | 23 | # this is not right! EmulationLayer should send it... |
24 | i changed all those to use emulationLayer()->send() instead | ||
24 | i had to create a QByteArray before... | 25 | i had to create a QByteArray before... |
25 | 26 | ||
26 | TODO: | 27 | TODO: |
27 | alter Widget to use only QByteArray, where applicable. | 28 | alter Widget to use only QByteArray, where applicable. |
28 | */ | 29 | */ |
29 | 30 | ||
30 | 31 | ||
31 | 32 | ||
32 | /*! \class Widget | 33 | /*! \class Widget |
33 | 34 | ||
34 | \brief Visible screen contents | 35 | \brief Visible screen contents |
35 | 36 | ||
36 | This class is responsible to map the `image' of a terminal emulation to the | 37 | This class is responsible to map the `image' of a terminal emulation to the |
37 | display. All the dependency of the emulation to a specific GUI or toolkit is | 38 | display. All the dependency of the emulation to a specific GUI or toolkit is |
38 | localized here. Further, this widget has no knowledge about being part of an | 39 | localized here. Further, this widget has no knowledge about being part of an |
39 | emulation, it simply work within the terminal emulation framework by exposing | 40 | emulation, it simply work within the terminal emulation framework by exposing |
40 | size and key events and by being ordered to show a new image. | 41 | size and key events and by being ordered to show a new image. |
41 | 42 | ||
42 | <ul> | 43 | <ul> |
43 | <li> The internal image has the size of the widget (evtl. rounded up) | 44 | <li> The internal image has the size of the widget (evtl. rounded up) |
44 | <li> The external image used in setImage can have any size. | 45 | <li> The external image used in setImage can have any size. |
45 | <li> (internally) the external image is simply copied to the internal | 46 | <li> (internally) the external image is simply copied to the internal |
46 | when a setImage happens. During a resizeEvent no painting is done | 47 | when a setImage happens. During a resizeEvent no painting is done |
47 | a paintEvent is expected to follow anyway. | 48 | a paintEvent is expected to follow anyway. |
48 | </ul> | 49 | </ul> |
49 | 50 | ||
50 | \sa TEScreen \sa Emulation | 51 | \sa TEScreen \sa Emulation |
51 | */ | 52 | */ |
52 | 53 | ||
53 | /* FIXME: | 54 | /* FIXME: |
54 | - 'image' may also be used uninitialized (it isn't in fact) in resizeEvent | 55 | - 'image' may also be used uninitialized (it isn't in fact) in resizeEvent |
55 | - 'font_a' not used in mouse events | 56 | - 'font_a' not used in mouse events |
56 | - add destructor | 57 | - add destructor |
57 | */ | 58 | */ |
58 | 59 | ||
59 | /* TODO | 60 | /* TODO |
60 | - evtl. be sensitive to `paletteChange' while using default colors. | 61 | - evtl. be sensitive to `paletteChange' while using default colors. |
61 | - set different 'rounding' styles? I.e. have a mode to show clipped chars? | 62 | - set different 'rounding' styles? I.e. have a mode to show clipped chars? |
62 | */ | 63 | */ |
63 | 64 | ||
64 | // #include "config.h" | 65 | // #include "config.h" |
65 | #include "widget.h" | 66 | #include "widget.h" |
66 | #include "session.h" | 67 | #include "session.h" |
67 | #include <qpe/config.h> | 68 | #include <qpe/config.h> |
68 | #include <qapplication.h> | 69 | #include <qapplication.h> |
69 | 70 | ||
70 | #include <qcursor.h> | 71 | #include <qcursor.h> |
71 | #include <qregexp.h> | 72 | #include <qregexp.h> |
72 | #include <qpainter.h> | 73 | #include <qpainter.h> |
73 | #include <qclipboard.h> | 74 | #include <qclipboard.h> |
74 | #include <qstyle.h> | 75 | #include <qstyle.h> |
75 | #include <qfile.h> | 76 | #include <qfile.h> |
76 | #include <qdragobject.h> | 77 | #include <qdragobject.h> |
77 | 78 | ||
78 | #include <stdio.h> | 79 | #include <stdio.h> |
79 | #include <stdlib.h> | 80 | #include <stdlib.h> |
80 | #include <unistd.h> | 81 | #include <unistd.h> |
81 | #include <ctype.h> | 82 | #include <ctype.h> |
82 | #include <sys/stat.h> | 83 | #include <sys/stat.h> |
83 | #include <sys/types.h> | 84 | #include <sys/types.h> |
84 | #include <signal.h> | 85 | #include <signal.h> |
85 | 86 | ||
86 | #include <assert.h> | 87 | #include <assert.h> |
87 | 88 | ||
88 | // #include "widget.moc" | 89 | // #include "widget.moc" |
89 | //#include <kapp.h> | 90 | //#include <kapp.h> |
90 | //#include <kcursor.h> | 91 | //#include <kcursor.h> |
91 | //#include <kurl.h> | 92 | //#include <kurl.h> |
92 | //#include <kdebug.h> | 93 | //#include <kdebug.h> |
93 | //#include <klocale.h> | 94 | //#include <klocale.h> |
94 | 95 | ||
95 | #define HERE printf("%s(%d): %s\n",__FILE__,__LINE__,__FUNCTION__) | 96 | #define HERE printf("%s(%d): %s\n",__FILE__,__LINE__,__FUNCTION__) |
96 | #define HCNT(Name) // { static int cnt = 1; printf("%s(%d): %s %d\n",__FILE__,__LINE__,Name,cnt++); } | 97 | #define HCNT(Name) // { static int cnt = 1; printf("%s(%d): %s %d\n",__FILE__,__LINE__,Name,cnt++); } |
97 | 98 | ||
98 | #define loc(X,Y) ((Y)*columns+(X)) | 99 | #define loc(X,Y) ((Y)*columns+(X)) |
99 | 100 | ||
100 | //FIXME: the rim should normally be 1, 0 only when running in full screen mode. | 101 | //FIXME: the rim should normally be 1, 0 only when running in full screen mode. |
101 | #define rimX 0 // left/right rim width | 102 | #define rimX 0 // left/right rim width |
102 | #define rimY 0 // top/bottom rim high | 103 | #define rimY 0 // top/bottom rim high |
103 | 104 | ||
104 | #define SCRWIDTH 16 // width of the scrollbar | 105 | #define SCRWIDTH 16 // width of the scrollbar |
105 | 106 | ||
106 | #define yMouseScroll 1 | 107 | #define yMouseScroll 1 |
107 | // scroll increment used when dragging selection at top/bottom of window. | 108 | // scroll increment used when dragging selection at top/bottom of window. |
108 | 109 | ||
109 | /* ------------------------------------------------------------------------- */ | 110 | /* ------------------------------------------------------------------------- */ |
110 | /* */ | 111 | /* */ |
111 | /* Colors */ | 112 | /* Colors */ |
112 | /* */ | 113 | /* */ |
113 | /* ------------------------------------------------------------------------- */ | 114 | /* ------------------------------------------------------------------------- */ |
114 | 115 | ||
115 | //FIXME: the default color table is in session.C now. | 116 | //FIXME: the default color table is in session.C now. |
116 | // We need a way to get rid of this one, here. | 117 | // We need a way to get rid of this one, here. |
117 | static const ColorEntry base_color_table[TABLE_COLORS] = | 118 | static const ColorEntry base_color_table[TABLE_COLORS] = |
118 | // The following are almost IBM standard color codes, with some slight | 119 | // The following are almost IBM standard color codes, with some slight |
119 | // gamma correction for the dim colors to compensate for bright X screens. | 120 | // gamma correction for the dim colors to compensate for bright X screens. |
120 | // It contains the 8 ansiterm/xterm colors in 2 intensities. | 121 | // It contains the 8 ansiterm/xterm colors in 2 intensities. |
121 | { | 122 | { |
122 | // Fixme: could add faint colors here, also. | 123 | // Fixme: could add faint colors here, also. |
123 | // normal | 124 | // normal |
124 | ColorEntry(QColor(0x00,0x00,0x00), 0, 0 ), ColorEntry( QColor(0xB2,0xB2,0xB2), 1, 0 ), // Dfore, Dback | 125 | ColorEntry(QColor(0x00,0x00,0x00), 0, 0 ), ColorEntry( QColor(0xB2,0xB2,0xB2), 1, 0 ), // Dfore, Dback |
125 | ColorEntry(QColor(0x00,0x00,0x00), 0, 0 ), ColorEntry( QColor(0xB2,0x18,0x18), 0, 0 ), // Black, Red | 126 | ColorEntry(QColor(0x00,0x00,0x00), 0, 0 ), ColorEntry( QColor(0xB2,0x18,0x18), 0, 0 ), // Black, Red |
126 | ColorEntry(QColor(0x18,0xB2,0x18), 0, 0 ), ColorEntry( QColor(0xB2,0x68,0x18), 0, 0 ), // Green, Yellow | 127 | ColorEntry(QColor(0x18,0xB2,0x18), 0, 0 ), ColorEntry( QColor(0xB2,0x68,0x18), 0, 0 ), // Green, Yellow |
127 | ColorEntry(QColor(0x18,0x18,0xB2), 0, 0 ), ColorEntry( QColor(0xB2,0x18,0xB2), 0, 0 ), // Blue, Magenta | 128 | ColorEntry(QColor(0x18,0x18,0xB2), 0, 0 ), ColorEntry( QColor(0xB2,0x18,0xB2), 0, 0 ), // Blue, Magenta |
128 | ColorEntry(QColor(0x18,0xB2,0xB2), 0, 0 ), ColorEntry( QColor(0xB2,0xB2,0xB2), 0, 0 ), // Cyan, White | 129 | ColorEntry(QColor(0x18,0xB2,0xB2), 0, 0 ), ColorEntry( QColor(0xB2,0xB2,0xB2), 0, 0 ), // Cyan, White |
129 | // intensiv | 130 | // intensiv |
130 | ColorEntry(QColor(0x00,0x00,0x00), 0, 1 ), ColorEntry( QColor(0xFF,0xFF,0xFF), 1, 0 ), | 131 | ColorEntry(QColor(0x00,0x00,0x00), 0, 1 ), ColorEntry( QColor(0xFF,0xFF,0xFF), 1, 0 ), |
131 | ColorEntry(QColor(0x68,0x68,0x68), 0, 0 ), ColorEntry( QColor(0xFF,0x54,0x54), 0, 0 ), | 132 | ColorEntry(QColor(0x68,0x68,0x68), 0, 0 ), ColorEntry( QColor(0xFF,0x54,0x54), 0, 0 ), |
132 | ColorEntry(QColor(0x54,0xFF,0x54), 0, 0 ), ColorEntry( QColor(0xFF,0xFF,0x54), 0, 0 ), | 133 | ColorEntry(QColor(0x54,0xFF,0x54), 0, 0 ), ColorEntry( QColor(0xFF,0xFF,0x54), 0, 0 ), |
133 | ColorEntry(QColor(0x54,0x54,0xFF), 0, 0 ), ColorEntry( QColor(0xB2,0x18,0xB2), 0, 0 ), | 134 | ColorEntry(QColor(0x54,0x54,0xFF), 0, 0 ), ColorEntry( QColor(0xB2,0x18,0xB2), 0, 0 ), |
134 | ColorEntry(QColor(0x54,0xFF,0xFF), 0, 0 ), ColorEntry( QColor(0xFF,0xFF,0xFF), 0, 0 ) | 135 | ColorEntry(QColor(0x54,0xFF,0xFF), 0, 0 ), ColorEntry( QColor(0xFF,0xFF,0xFF), 0, 0 ) |
135 | }; | 136 | }; |
136 | 137 | ||
137 | /* Note that we use ANSI color order (bgr), while IBMPC color order is (rgb) | 138 | /* Note that we use ANSI color order (bgr), while IBMPC color order is (rgb) |
138 | 139 | ||
139 | Code 0 1 2 3 4 5 6 7 | 140 | Code 0 1 2 3 4 5 6 7 |
140 | ----------- ------- ------- ------- ------- ------- ------- ------- ------- | 141 | ----------- ------- ------- ------- ------- ------- ------- ------- ------- |
141 | ANSI (bgr) Black Red Green Yellow Blue Magenta Cyan White | 142 | ANSI (bgr) Black Red Green Yellow Blue Magenta Cyan White |
142 | IBMPC (rgb) Black Blue Green Cyan Red Magenta Yellow White | 143 | IBMPC (rgb) Black Blue Green Cyan Red Magenta Yellow White |
143 | */ | 144 | */ |
144 | 145 | ||
145 | QColor Widget::getDefaultBackColor() | 146 | QColor Widget::getDefaultBackColor() |
146 | { | 147 | { |
147 | return color_table[DEFAULT_BACK_COLOR].color; | 148 | return color_table[DEFAULT_BACK_COLOR].color; |
148 | } | 149 | } |
149 | 150 | ||
150 | const ColorEntry* Widget::getColorTable() const | 151 | const ColorEntry* Widget::getColorTable() const |
151 | { | 152 | { |
@@ -1105,187 +1106,188 @@ void Widget::clearImage() | |||
1105 | for (int x = 0; x < columns; x++) | 1106 | for (int x = 0; x < columns; x++) |
1106 | { | 1107 | { |
1107 | image[loc(x,y)].c = 0xff; //' '; | 1108 | image[loc(x,y)].c = 0xff; //' '; |
1108 | image[loc(x,y)].f = 0xff; //DEFAULT_FORE_COLOR; | 1109 | image[loc(x,y)].f = 0xff; //DEFAULT_FORE_COLOR; |
1109 | image[loc(x,y)].b = 0xff; //DEFAULT_BACK_COLOR; | 1110 | image[loc(x,y)].b = 0xff; //DEFAULT_BACK_COLOR; |
1110 | image[loc(x,y)].r = 0xff; //DEFAULT_RENDITION; | 1111 | image[loc(x,y)].r = 0xff; //DEFAULT_RENDITION; |
1111 | } | 1112 | } |
1112 | } | 1113 | } |
1113 | 1114 | ||
1114 | // Create Image /////////////////////////////////////////////////////// | 1115 | // Create Image /////////////////////////////////////////////////////// |
1115 | 1116 | ||
1116 | void Widget::calcGeometry() | 1117 | void Widget::calcGeometry() |
1117 | { | 1118 | { |
1118 | //FIXME: set rimX == rimY == 0 when running in full screen mode. | 1119 | //FIXME: set rimX == rimY == 0 when running in full screen mode. |
1119 | 1120 | ||
1120 | scrollbar->resize(QApplication::style().scrollBarExtent().width(), | 1121 | scrollbar->resize(QApplication::style().scrollBarExtent().width(), |
1121 | contentsRect().height()); | 1122 | contentsRect().height()); |
1122 | switch(scrollLoc) | 1123 | switch(scrollLoc) |
1123 | { | 1124 | { |
1124 | case SCRNONE : | 1125 | case SCRNONE : |
1125 | columns = ( contentsRect().width() - 2 * rimX ) / font_w; | 1126 | columns = ( contentsRect().width() - 2 * rimX ) / font_w; |
1126 | blX = (contentsRect().width() - (columns*font_w) ) / 2; | 1127 | blX = (contentsRect().width() - (columns*font_w) ) / 2; |
1127 | brX = blX; | 1128 | brX = blX; |
1128 | scrollbar->hide(); | 1129 | scrollbar->hide(); |
1129 | break; | 1130 | break; |
1130 | case SCRLEFT : | 1131 | case SCRLEFT : |
1131 | columns = ( contentsRect().width() - 2 * rimX - scrollbar->width()) / font_w; | 1132 | columns = ( contentsRect().width() - 2 * rimX - scrollbar->width()) / font_w; |
1132 | brX = (contentsRect().width() - (columns*font_w) - scrollbar->width() ) / 2; | 1133 | brX = (contentsRect().width() - (columns*font_w) - scrollbar->width() ) / 2; |
1133 | blX = brX + scrollbar->width(); | 1134 | blX = brX + scrollbar->width(); |
1134 | scrollbar->move(contentsRect().topLeft()); | 1135 | scrollbar->move(contentsRect().topLeft()); |
1135 | scrollbar->show(); | 1136 | scrollbar->show(); |
1136 | break; | 1137 | break; |
1137 | case SCRRIGHT: | 1138 | case SCRRIGHT: |
1138 | columns = ( contentsRect().width() - 2 * rimX - scrollbar->width()) / font_w; | 1139 | columns = ( contentsRect().width() - 2 * rimX - scrollbar->width()) / font_w; |
1139 | blX = (contentsRect().width() - (columns*font_w) - scrollbar->width() ) / 2; | 1140 | blX = (contentsRect().width() - (columns*font_w) - scrollbar->width() ) / 2; |
1140 | brX = blX; | 1141 | brX = blX; |
1141 | scrollbar->move(contentsRect().topRight() - QPoint(scrollbar->width()-1,0)); | 1142 | scrollbar->move(contentsRect().topRight() - QPoint(scrollbar->width()-1,0)); |
1142 | scrollbar->show(); | 1143 | scrollbar->show(); |
1143 | break; | 1144 | break; |
1144 | } | 1145 | } |
1145 | //FIXME: support 'rounding' styles | 1146 | //FIXME: support 'rounding' styles |
1146 | lines = ( contentsRect().height() - 2 * rimY ) / font_h; | 1147 | lines = ( contentsRect().height() - 2 * rimY ) / font_h; |
1147 | bY = (contentsRect().height() - (lines *font_h)) / 2; | 1148 | bY = (contentsRect().height() - (lines *font_h)) / 2; |
1148 | } | 1149 | } |
1149 | 1150 | ||
1150 | void Widget::makeImage() | 1151 | void Widget::makeImage() |
1151 | //FIXME: rename 'calcGeometry? | 1152 | //FIXME: rename 'calcGeometry? |
1152 | { | 1153 | { |
1153 | calcGeometry(); | 1154 | calcGeometry(); |
1154 | image = (Character*) malloc(lines*columns*sizeof(Character)); | 1155 | image = (Character*) malloc(lines*columns*sizeof(Character)); |
1155 | clearImage(); | 1156 | clearImage(); |
1156 | } | 1157 | } |
1157 | 1158 | ||
1158 | // calculate the needed size | 1159 | // calculate the needed size |
1159 | QSize Widget::calcSize(int cols, int lins) const | 1160 | QSize Widget::calcSize(int cols, int lins) const |
1160 | { | 1161 | { |
1161 | int frw = width() - contentsRect().width(); | 1162 | int frw = width() - contentsRect().width(); |
1162 | int frh = height() - contentsRect().height(); | 1163 | int frh = height() - contentsRect().height(); |
1163 | int scw = (scrollLoc==SCRNONE?0:scrollbar->width()); | 1164 | int scw = (scrollLoc==SCRNONE?0:scrollbar->width()); |
1164 | return QSize( font_w*cols + 2*rimX + frw + scw, font_h*lins + 2*rimY + frh ); | 1165 | return QSize( font_w*cols + 2*rimX + frw + scw, font_h*lins + 2*rimY + frh ); |
1165 | } | 1166 | } |
1166 | 1167 | ||
1167 | QSize Widget::sizeHint() const | 1168 | QSize Widget::sizeHint() const |
1168 | { | 1169 | { |
1169 | return size(); | 1170 | return size(); |
1170 | } | 1171 | } |
1171 | 1172 | ||
1172 | void Widget::styleChange(QStyle &) | 1173 | void Widget::styleChange(QStyle &) |
1173 | { | 1174 | { |
1174 | propagateSize(); | 1175 | propagateSize(); |
1175 | } | 1176 | } |
1176 | 1177 | ||
1177 | #ifndef QT_NO_DRAGANDDROP | 1178 | #ifndef QT_NO_DRAGANDDROP |
1178 | 1179 | ||
1179 | /* --------------------------------------------------------------------- */ | 1180 | /* --------------------------------------------------------------------- */ |
1180 | /* */ | 1181 | /* */ |
1181 | /* Drag & Drop */ | 1182 | /* Drag & Drop */ |
1182 | /* */ | 1183 | /* */ |
1183 | /* --------------------------------------------------------------------- */ | 1184 | /* --------------------------------------------------------------------- */ |
1184 | 1185 | ||
1185 | 1186 | ||
1186 | void Widget::dragEnterEvent(QDragEnterEvent* e) | 1187 | void Widget::dragEnterEvent(QDragEnterEvent* e) |
1187 | { | 1188 | { |
1188 | e->accept(QTextDrag::canDecode(e) || | 1189 | e->accept(QTextDrag::canDecode(e) || |
1189 | QUriDrag::canDecode(e)); | 1190 | QUriDrag::canDecode(e)); |
1190 | } | 1191 | } |
1191 | 1192 | ||
1192 | void Widget::dropEvent(QDropEvent* event) | 1193 | void Widget::dropEvent(QDropEvent* event) |
1193 | { | 1194 | { |
1194 | // The current behaviour when url(s) are dropped is | 1195 | // The current behaviour when url(s) are dropped is |
1195 | // * if there is only ONE url and if it's a LOCAL one, ask for paste or cd | 1196 | // * if there is only ONE url and if it's a LOCAL one, ask for paste or cd |
1196 | // * in all other cases, just paste | 1197 | // * in all other cases, just paste |
1197 | // (for non-local ones, or for a list of URLs, 'cd' is nonsense) | 1198 | // (for non-local ones, or for a list of URLs, 'cd' is nonsense) |
1198 | QStrList strlist; | 1199 | QStrList strlist; |
1199 | int file_count = 0; | 1200 | int file_count = 0; |
1200 | dropText = ""; | 1201 | dropText = ""; |
1201 | bool bPopup = true; | 1202 | bool bPopup = true; |
1202 | 1203 | ||
1203 | if(QUriDrag::decode(event, strlist)) { | 1204 | if(QUriDrag::decode(event, strlist)) { |
1204 | if (strlist.count()) { | 1205 | if (strlist.count()) { |
1205 | for(const char* p = strlist.first(); p; p = strlist.next()) { | 1206 | for(const char* p = strlist.first(); p; p = strlist.next()) { |
1206 | if(file_count++ > 0) { | 1207 | if(file_count++ > 0) { |
1207 | dropText += " "; | 1208 | dropText += " "; |
1208 | bPopup = false; // more than one file, don't popup | 1209 | bPopup = false; // more than one file, don't popup |
1209 | } | 1210 | } |
1210 | 1211 | ||
1211 | /* | 1212 | /* |
1212 | KURL url(p); | 1213 | KURL url(p); |
1213 | if (url.isLocalFile()) { | 1214 | if (url.isLocalFile()) { |
1214 | dropText += url.path(); // local URL : remove protocol | 1215 | dropText += url.path(); // local URL : remove protocol |
1215 | } | 1216 | } |
1216 | else { | 1217 | else { |
1217 | dropText += url.prettyURL(); | 1218 | dropText += url.prettyURL(); |
1218 | bPopup = false; // a non-local file, don't popup | 1219 | bPopup = false; // a non-local file, don't popup |
1219 | } | 1220 | } |
1220 | */ | 1221 | */ |
1221 | 1222 | ||
1222 | } | 1223 | } |
1223 | 1224 | ||
1224 | if (bPopup) | 1225 | if (bPopup) |
1225 | // m_drop->popup(pos() + event->pos()); | 1226 | // m_drop->popup(pos() + event->pos()); |
1226 | m_drop->popup(mapToGlobal(event->pos())); | 1227 | m_drop->popup(mapToGlobal(event->pos())); |
1227 | else | 1228 | else |
1228 | { | 1229 | { |
1229 | if (currentSession) { | 1230 | if (currentSession) { |
1230 | //currentSession->getEmulation()->sendString(dropText.local8Bit()); | 1231 | //currentSession->getEmulation()->sendString(dropText.local8Bit()); |
1231 | QByteArray tmp; | 1232 | QByteArray tmp; |
1232 | // ibot: this should be pretty wrong... | 1233 | // ibot: this should be pretty wrong... |
1233 | currentSession->layer()->send( tmp.setRawData( dropText.local8Bit())); | 1234 | // now it sends to the right layer |
1235 | currentSession-> emulationLayer()->send( tmp.setRawData( dropText.local8Bit())); | ||
1234 | } | 1236 | } |
1235 | // kdDebug() << "Drop:" << dropText.local8Bit() << "\n"; | 1237 | // kdDebug() << "Drop:" << dropText.local8Bit() << "\n"; |
1236 | } | 1238 | } |
1237 | } | 1239 | } |
1238 | } | 1240 | } |
1239 | else if(QTextDrag::decode(event, dropText)) { | 1241 | else if(QTextDrag::decode(event, dropText)) { |
1240 | // kdDebug() << "Drop:" << dropText.local8Bit() << "\n"; | 1242 | // kdDebug() << "Drop:" << dropText.local8Bit() << "\n"; |
1241 | if (currentSession) { | 1243 | if (currentSession) { |
1242 | //currentSession->getEmulation()->sendString(dropText.local8Bit()); | 1244 | //currentSession->getEmulation()->sendString(dropText.local8Bit()); |
1243 | QByteArray tmp; | 1245 | QByteArray tmp; |
1244 | currentSession->layer()->send( tmp.setRawData( dropText.local8Bit())); | 1246 | currentSession->emulationLayer()->send( tmp.setRawData( dropText.local8Bit())); |
1245 | } | 1247 | } |
1246 | // Paste it | 1248 | // Paste it |
1247 | } | 1249 | } |
1248 | } | 1250 | } |
1249 | #endif | 1251 | #endif |
1250 | 1252 | ||
1251 | 1253 | ||
1252 | void Widget::drop_menu_activated(int item) | 1254 | void Widget::drop_menu_activated(int item) |
1253 | { | 1255 | { |
1254 | #ifndef QT_NO_DRAGANDDROP | 1256 | #ifndef QT_NO_DRAGANDDROP |
1255 | QByteArray tmp; | 1257 | QByteArray tmp; |
1256 | switch (item) | 1258 | switch (item) |
1257 | { | 1259 | { |
1258 | case 0: // paste | 1260 | case 0: // paste |
1259 | //currentSession->getEmulation()->sendString(dropText.local8Bit()); | 1261 | //currentSession->getEmulation()->sendString(dropText.local8Bit()); |
1260 | currentSession->layer()->send( tmp.setRawData( dropText.local8Bit())); | 1262 | currentSession->emulationLayer()->send( tmp.setRawData( dropText.local8Bit())); |
1261 | 1263 | ||
1262 | // KWM::activate((Window)this->winId()); | 1264 | // KWM::activate((Window)this->winId()); |
1263 | break; | 1265 | break; |
1264 | case 1: // cd ... | 1266 | case 1: // cd ... |
1265 | //currentSession->getEmulation()->sendString("cd "); | 1267 | //currentSession->getEmulation()->sendString("cd "); |
1266 | tmp.setRawData( "cd " ); | 1268 | tmp.setRawData( "cd " ); |
1267 | currentSession->layer()->send( tmp ); | 1269 | currentSession->emulationLayer()->send( tmp ); |
1268 | struct stat statbuf; | 1270 | struct stat statbuf; |
1269 | if ( ::stat( QFile::encodeName( dropText ), &statbuf ) == 0 ) | 1271 | if ( ::stat( QFile::encodeName( dropText ), &statbuf ) == 0 ) |
1270 | { | 1272 | { |
1271 | if ( !S_ISDIR(statbuf.st_mode) ) | 1273 | if ( !S_ISDIR(statbuf.st_mode) ) |
1272 | { | 1274 | { |
1273 | /* | 1275 | /* |
1274 | KURL url; | 1276 | KURL url; |
1275 | url.setPath( dropText ); | 1277 | url.setPath( dropText ); |
1276 | dropText = url.directory( true, false ); // remove filename | 1278 | dropText = url.directory( true, false ); // remove filename |
1277 | */ | 1279 | */ |
1278 | } | 1280 | } |
1279 | } | 1281 | } |
1280 | dropText.replace(QRegExp(" "), "\\ "); // escape spaces | 1282 | dropText.replace(QRegExp(" "), "\\ "); // escape spaces |
1281 | QByteArray tmp2; | 1283 | QByteArray tmp2; |
1282 | tmp.setRawDate( dropText.local8Bit() + "\n" ); | 1284 | tmp.setRawDate( dropText.local8Bit() + "\n" ); |
1283 | //currentSession->getEmulation()->sendString(dropText.local8Bit()); | 1285 | //currentSession->getEmulation()->sendString(dropText.local8Bit()); |
1284 | //currentSession->getEmulation()->sendString("\n"); | 1286 | //currentSession->getEmulation()->sendString("\n"); |
1285 | currentSession->layer()->send( tmp ); | 1287 | currentSession->emulationLayer()->send( tmp ); |
1286 | // KWM::activate((Window)this->winId()); | 1288 | // KWM::activate((Window)this->winId()); |
1287 | break; | 1289 | break; |
1288 | } | 1290 | } |
1289 | #endif | 1291 | #endif |
1290 | } | 1292 | } |
1291 | 1293 | ||
diff --git a/noncore/apps/opie-console/widget_layer.h b/noncore/apps/opie-console/widget_layer.h index 5bd2ef9..01a4614 100644 --- a/noncore/apps/opie-console/widget_layer.h +++ b/noncore/apps/opie-console/widget_layer.h | |||
@@ -1,234 +1,235 @@ | |||
1 | /* -------------------------------------------------------------------------- */ | 1 | /* -------------------------------------------------------------------------- */ |
2 | /* */ | 2 | /* */ |
3 | /* [widget_layer.h] Widget Layer */ | 3 | /* [widget_layer.h] Widget Layer */ |
4 | /* */ | 4 | /* */ |
5 | /* -------------------------------------------------------------------------- */ | 5 | /* -------------------------------------------------------------------------- */ |
6 | 6 | ||
7 | // proposal of a widget Layer in opie-console | 7 | // proposal of a widget Layer in opie-console |
8 | // | 8 | // |
9 | // fellow devels: | 9 | // fellow devels: |
10 | // just mail me (ibotty@web.de), what you additionally need from the main widget | 10 | // just mail me (ibotty@web.de), what you additionally need from the main widget |
11 | // (or say in chat) | 11 | // (or say in chat) |
12 | 12 | ||
13 | #ifndef WIDGET_LAYER_H | 13 | #ifndef WIDGET_LAYER_H |
14 | #define WIDGET_LAYER_H | 14 | #define WIDGET_LAYER_H |
15 | 15 | ||
16 | // qt includes | 16 | // qt includes |
17 | #include <qapplication.h> | 17 | #include <qapplication.h> |
18 | #include <qframe.h> | 18 | #include <qframe.h> |
19 | #include <qarray.h> | 19 | #include <qarray.h> |
20 | #include <qtimer.h> | 20 | #include <qtimer.h> |
21 | #include <qkeycode.h> | 21 | #include <qkeycode.h> |
22 | #include <qclipboard.h> | 22 | #include <qclipboard.h> |
23 | 23 | ||
24 | 24 | ||
25 | // opie-console includes | 25 | // opie-console includes |
26 | #include "session.h" | 26 | #include "session.h" |
27 | #include "common.h" | 27 | #include "common.h" |
28 | #include "profile.h" | 28 | #include "profile.h" |
29 | /* | 29 | /* |
30 | * given a pseudo location ( column, line ), | 30 | * given a pseudo location ( column, line ), |
31 | * returns the actual index, in the QArray<Character> | 31 | * returns the actual index, in the QArray<Character> |
32 | */ | 32 | */ |
33 | #define loc(X,Y) ((Y)*m_columns+(X)) | 33 | #define loc(X,Y) ((Y)*m_columns+(X)) |
34 | 34 | ||
35 | 35 | ||
36 | 36 | ||
37 | 37 | ||
38 | class WidgetLayer : public QFrame | 38 | class WidgetLayer : public QFrame |
39 | { Q_OBJECT | 39 | { Q_OBJECT |
40 | 40 | ||
41 | public: | 41 | public: |
42 | 42 | ||
43 | /** | 43 | /** |
44 | * constructor | 44 | * constructor |
45 | * @param const Profile &config, the configuration for this widget | 45 | * @param const Profile &config, the configuration for this widget |
46 | * @param QWidget *parent, the parent widget | 46 | * @param QWidget *parent, the parent widget |
47 | * @param const char *name, the name of the widget, defaults to "" | 47 | * @param const char *name, the name of the widget, defaults to "" |
48 | */ | 48 | */ |
49 | WidgetLayer( const Profile& config, QWidget *parent=0, const char *name=0 ); | 49 | WidgetLayer( const Profile& config, QWidget *parent=0, const char *name=0 ); |
50 | 50 | ||
51 | /** | 51 | /** |
52 | * destructor | 52 | * destructor |
53 | */ | 53 | */ |
54 | virtual ~WidgetLayer(); | 54 | virtual ~WidgetLayer(); |
55 | 55 | ||
56 | public: | 56 | public: |
57 | /** | 57 | /** |
58 | * sets the image | 58 | * sets the image |
59 | * @param QArray<Character> const newimg, the new image | 59 | * @param QArray<Character> const newimg, the new image |
60 | * @param int lines, lines count of newimg | 60 | * @param int lines, lines count of newimg |
61 | * @param int columns, columns count of newimg | 61 | * @param int columns, columns count of newimg |
62 | */ | 62 | */ |
63 | virtual void setImage( QArray<Character> const newimg, int lines, int colums ) = 0; | 63 | virtual void setImage( QArray<Character> const newimg, int lines, int colums ) = 0; |
64 | 64 | ||
65 | /** | 65 | /** |
66 | * annoy the user | 66 | * annoy the user |
67 | */ | 67 | */ |
68 | void bell(); | 68 | void bell(); |
69 | 69 | ||
70 | /** | 70 | /** |
71 | * @return int m_lines, the lines count | 71 | * @return int m_lines, the lines count |
72 | */ | 72 | */ |
73 | int lines(){ return m_lines; } | 73 | int lines(){ return m_lines; } |
74 | 74 | ||
75 | /** | 75 | /** |
76 | * @return int m_columns, the columns count | 76 | * @return int m_columns, the columns count |
77 | */ | 77 | */ |
78 | int columns(){ return m_columns; } | 78 | int columns(){ return m_columns; } |
79 | 79 | ||
80 | /** | 80 | /** |
81 | * insert current selection (currently this is only the clipboard) | 81 | * insert current selection (currently this is only the clipboard) |
82 | */ | 82 | */ |
83 | void insertSelection(); | 83 | void insertSelection(); |
84 | 84 | ||
85 | /** | 85 | /** |
86 | * insert text | 86 | * insert text |
87 | * @param QString text, the text to be inserted | 87 | * @param QString text, the text to be inserted |
88 | */ | 88 | */ |
89 | void insertText( QString text ); | 89 | void insertText( QString text ); |
90 | 90 | ||
91 | /** | 91 | /** |
92 | * set selection (clipboard) to text | 92 | * set selection (clipboard) to text |
93 | * @param const QString &text, the text to be selected | 93 | * @param const QString &text, the text to be selected |
94 | */ | 94 | */ |
95 | void setSelection( const QString &text ); | 95 | void setSelection( const QString &text ); |
96 | 96 | ||
97 | /** | 97 | /** |
98 | * paste content of clipboard | 98 | * paste content of clipboard |
99 | */ | 99 | */ |
100 | void pasteClipboard(); | 100 | void pasteClipboard(); |
101 | 101 | ||
102 | 102 | ||
103 | /** | 103 | /** |
104 | * reload configuration | 104 | * reload configuration |
105 | * @param const Profile& config, the config to be used (may be the same as in constructor) | ||
105 | */ | 106 | */ |
106 | virtual void reloadConfig() = 0; | 107 | virtual void reloadConfig( const Profile& config ) = 0; |
107 | 108 | ||
108 | 109 | ||
109 | /** | 110 | /** |
110 | * sets the scrollbar (if implemented by successor of this class) | 111 | * sets the scrollbar (if implemented by successor of this class) |
111 | */ | 112 | */ |
112 | virtual void setScroll( int cursor, int slines ); | 113 | virtual void setScroll( int cursor, int slines ); |
113 | 114 | ||
114 | /** | 115 | /** |
115 | * scrolls (if implemented, by successor of this class) | 116 | * scrolls (if implemented, by successor of this class) |
116 | * @param int value, how much the widget should scroll up (positive value) or down (negative value) | 117 | * @param int value, how much the widget should scroll up (positive value) or down (negative value) |
117 | */ | 118 | */ |
118 | virtual void scroll( int value ); | 119 | virtual void scroll( int value ); |
119 | 120 | ||
120 | signals: | 121 | signals: |
121 | 122 | ||
122 | /** | 123 | /** |
123 | * key was pressed | 124 | * key was pressed |
124 | */ | 125 | */ |
125 | void keyPressed( QKeyEvent *e ); | 126 | void keyPressed( QKeyEvent *e ); |
126 | 127 | ||
127 | /** | 128 | /** |
128 | * whenever Mouse selects something | 129 | * whenever Mouse selects something |
129 | * @param int button, the button that us pressed : | 130 | * @param int button, the button that us pressed : |
130 | * 0left Button | 131 | * 0left Button |
131 | * 3Button released | 132 | * 3Button released |
132 | * @param int x, x position | 133 | * @param int x, x position |
133 | * @param int y, y position | 134 | * @param int y, y position |
134 | * | 135 | * |
135 | * // numbering due to layout in old TEWidget | 136 | * // numbering due to layout in old TEWidget |
136 | */ | 137 | */ |
137 | void mousePressed( int button, int x, int y ); | 138 | void mousePressed( int button, int x, int y ); |
138 | 139 | ||
139 | /** | 140 | /** |
140 | * size of image changed | 141 | * size of image changed |
141 | * @param int lines, line count of new size | 142 | * @param int lines, line count of new size |
142 | * @param int columns, column count of new size | 143 | * @param int columns, column count of new size |
143 | */ | 144 | */ |
144 | void imageSizeChanged( int lines, int columns ); | 145 | void imageSizeChanged( int lines, int columns ); |
145 | 146 | ||
146 | /** | 147 | /** |
147 | * cursor in history changed | 148 | * cursor in history changed |
148 | * @param int value, value of history cursor | 149 | * @param int value, value of history cursor |
149 | */ | 150 | */ |
150 | void historyCursorChanged( int value ); | 151 | void historyCursorChanged( int value ); |
151 | 152 | ||
152 | /** | 153 | /** |
153 | * selection should be cleared | 154 | * selection should be cleared |
154 | */ | 155 | */ |
155 | void selectionCleared(); | 156 | void selectionCleared(); |
156 | 157 | ||
157 | /** | 158 | /** |
158 | * selection begin | 159 | * selection begin |
159 | * @param const int x, x position | 160 | * @param const int x, x position |
160 | * @param const int y, y position | 161 | * @param const int y, y position |
161 | */ | 162 | */ |
162 | void selectionBegin( const int x, const int y ); | 163 | void selectionBegin( const int x, const int y ); |
163 | 164 | ||
164 | /** | 165 | /** |
165 | * selection extended | 166 | * selection extended |
166 | * (from begin (s.a.) to x, y) | 167 | * (from begin (s.a.) to x, y) |
167 | * @param const int x, x position | 168 | * @param const int x, x position |
168 | * @param const int y, y position | 169 | * @param const int y, y position |
169 | */ | 170 | */ |
170 | void selectionExtended( const int x, const int y ); | 171 | void selectionExtended( const int x, const int y ); |
171 | 172 | ||
172 | /** | 173 | /** |
173 | * selection end | 174 | * selection end |
174 | * @param const bool lineBreakPreserve, preserve line breaks in selection | 175 | * @param const bool lineBreakPreserve, preserve line breaks in selection |
175 | */ | 176 | */ |
176 | void selectionEnd( const bool lineBreakPreserve ); | 177 | void selectionEnd( const bool lineBreakPreserve ); |
177 | 178 | ||
178 | 179 | ||
179 | 180 | ||
180 | // protected methods | 181 | // protected methods |
181 | protected: | 182 | protected: |
182 | 183 | ||
183 | // image operations | 184 | // image operations |
184 | 185 | ||
185 | /** | 186 | /** |
186 | * changes image, to suit new size | 187 | * changes image, to suit new size |
187 | * TODO: find meaningful name! | 188 | * TODO: find meaningful name! |
188 | */ | 189 | */ |
189 | void propagateSize(); | 190 | void propagateSize(); |
190 | 191 | ||
191 | /** | 192 | /** |
192 | *determines count of lines and columns | 193 | *determines count of lines and columns |
193 | */ | 194 | */ |
194 | virtual void calcGeometry() = 0; | 195 | virtual void calcGeometry() = 0; |
195 | 196 | ||
196 | /** | 197 | /** |
197 | * makes an empty image | 198 | * makes an empty image |
198 | */ | 199 | */ |
199 | void makeImage(); | 200 | void makeImage(); |
200 | 201 | ||
201 | /** | 202 | /** |
202 | * clears the image | 203 | * clears the image |
203 | */ | 204 | */ |
204 | void clearImage(); | 205 | void clearImage(); |
205 | 206 | ||
206 | protected slots: | 207 | protected slots: |
207 | 208 | ||
208 | /** | 209 | /** |
209 | * clear selection | 210 | * clear selection |
210 | */ | 211 | */ |
211 | void onClearSelection(); | 212 | void onClearSelection(); |
212 | 213 | ||
213 | 214 | ||
214 | // protected vars | 215 | // protected vars |
215 | protected: | 216 | protected: |
216 | 217 | ||
217 | /** | 218 | /** |
218 | * current Session | 219 | * current Session |
219 | */ | 220 | */ |
220 | Session *m_session; | 221 | Session *m_session; |
221 | 222 | ||
222 | /** | 223 | /** |
223 | * current character image | 224 | * current character image |
224 | * | 225 | * |
225 | * a Character at loc( column, line ) | 226 | * a Character at loc( column, line ) |
226 | * has the actual index: | 227 | * has the actual index: |
227 | * ix = line * m_columns + column; | 228 | * ix = line * m_columns + column; |
228 | * | 229 | * |
229 | * use loc( x, y ) macro to access. | 230 | * use loc( x, y ) macro to access. |
230 | */ | 231 | */ |
231 | QArray<Character> m_image; | 232 | QArray<Character> m_image; |
232 | 233 | ||
233 | /** | 234 | /** |
234 | * lines count | 235 | * lines count |