summaryrefslogtreecommitdiff
path: root/noncore/apps
authorzecke <zecke>2002-10-21 21:43:43 (UTC)
committer zecke <zecke>2002-10-21 21:43:43 (UTC)
commit21d29dbf8a9c1a12c7c23f96b80307e87ffaa50a (patch) (unidiff)
tree98586789ecce5eea1f1d3eb1e5a2184412f90a06 /noncore/apps
parente2f94235dae5ec84a5e888e4114ce0bdd91db7e7 (diff)
downloadopie-21d29dbf8a9c1a12c7c23f96b80307e87ffaa50a.zip
opie-21d29dbf8a9c1a12c7c23f96b80307e87ffaa50a.tar.gz
opie-21d29dbf8a9c1a12c7c23f96b80307e87ffaa50a.tar.bz2
add a quirk mode into main. if you -DFSCKED_DISTRIBUTION
opie-console will take care of some magic... Add a No Configuration Widget instead of a big fat gray thing above my beloved OTabWidget Fix some compiler warning
Diffstat (limited to 'noncore/apps') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/opie-console/file_layer.h6
-rw-r--r--noncore/apps/opie-console/main.cpp102
-rw-r--r--noncore/apps/opie-console/profiledialogwidget.cpp21
-rw-r--r--noncore/apps/opie-console/profiledialogwidget.h9
-rw-r--r--noncore/apps/opie-console/profileeditordialog.cpp29
-rw-r--r--noncore/apps/opie-console/serialconfigwidget.cpp4
6 files changed, 147 insertions, 24 deletions
diff --git a/noncore/apps/opie-console/file_layer.h b/noncore/apps/opie-console/file_layer.h
index edb30e1..caa7478 100644
--- a/noncore/apps/opie-console/file_layer.h
+++ b/noncore/apps/opie-console/file_layer.h
@@ -40,27 +40,27 @@ public:
40 Block_1k, 40 Block_1k,
41 Block_4k, 41 Block_4k,
42 Block_8k 42 Block_8k
43 }; 43 };
44 /** 44 /**
45 *the io layer to be used 45 *the io layer to be used
46 */ 46 */
47 FileTransferLayer( IOLayer* ); 47 FileTransferLayer( IOLayer* );
48 virtual ~FileTransferLayer(); 48 virtual ~FileTransferLayer();
49 49
50public slots: 50public slots:
51 51
52 virtual void sendFile( const QString& file, 52 virtual void sendFile( const QString&,
53 Mode mode, BlockSize blk, 53 Mode, BlockSize,
54 Features feat ) {}; 54 Features ) {};
55 55
56 /** 56 /**
57 * send a file over the layer 57 * send a file over the layer
58 */ 58 */
59 virtual void sendFile( const QString& file ) = 0; 59 virtual void sendFile( const QString& file ) = 0;
60 virtual void sendFile( const QFile& ) = 0; 60 virtual void sendFile( const QFile& ) = 0;
61 virtual void cancel() = 0; 61 virtual void cancel() = 0;
62 62
63signals: 63signals:
64 /** 64 /**
65 * sent the file 65 * sent the file
66 */ 66 */
diff --git a/noncore/apps/opie-console/main.cpp b/noncore/apps/opie-console/main.cpp
index 350bb3e..78a91a2 100644
--- a/noncore/apps/opie-console/main.cpp
+++ b/noncore/apps/opie-console/main.cpp
@@ -1,13 +1,113 @@
1#include <sys/types.h>
2
3#include <stdio.h>
4#include <stdlib.h>
5#include <signal.h>
6
7#include <qfile.h>
8
1#include <qpe/qpeapplication.h> 9#include <qpe/qpeapplication.h>
2 10
3#include "mainwindow.h" 11#include "mainwindow.h"
4 12
13//#define FSCKED_DISTRIBUTION 1
14#ifdef FSCKED_DISTRIBUTION
15/*
16 * The Zaurus rom
17 */
18class FixIt {
19public:
20 FixIt();
21 ~FixIt();
22 void fixIt();
23 /* no real interested in implementing it */
24 void breakIt() {
25
26 };
27 char* m_file;
28};
29
30FixIt::FixIt() {
31 /* the new inittab */
32 m_file = "#\n# /etc/inittab
33#
34
35# 0 - halt (Do NOT set initdefault to this)
36# 1 - Single user mode
37# 2 - Multiuser, without NFS (The same as 3, if you do not have networking)
38# 3 - Full multiuser mode
39# 4 - JavaVM(Intent) developer mode
40# 5 - JavaVM(Intent)
41# 6 - reboot (Do NOT set initdefault to this)
42#
43id:5:initdefault:
44
45# Specify things to do when starting
46si::sysinit:/etc/rc.d/rc.sysinit
47
48l0:0:wait:/root/etc/rc.d/rc 0
49l1:1:wait:/etc/rc.d/rc 1
50l2:2:wait:/etc/rc.d/rc 2
51l3:3:wait:/etc/rc.d/rc 3
52l4:4:wait:/etc/rc.d/rc 4
53l5:5:wait:/etc/rc.d/rc 5
54l6:6:wait:/root/etc/rc.d/rc 6
55
56# Specify things to do before rebooting
57um::ctrlaltdel:/bin/umount -a -r > /dev/null 2>&1
58sw::ctrlaltdel:/sbin/swapoff -a > /dev/null 2>&1
59
60# Specify program to run on ttyS0
61s0:24:respawn:/sbin/getty 9600 ttyS0
62#pd:5:respawn:/etc/sync/serialctl
63
64# Specify program to run on tty1
651:2:respawn:/sbin/getty 9600 tty1
66ln:345:respawn:survive -l 6 /sbin/launch
67#qt:5:respawn:/sbin/qt
68
69# collie sp.
70sy::respawn:/sbin/shsync\n";
71
72
73}
74FixIt::~FixIt() {
75}
76/*
77 * the retail Zaurus is broken in many ways
78 * one is that pppd is listening on our port...
79 * we've to stop it from that and then do kill(SIGHUP,1);
80 */
81void FixIt::fixIt() {
82 ::rename("/etc/inittab", QPEApplication::qpeDir() + "/etc/inittab" );
83 QFile file( "/etc/inittab" );
84 if ( file.open(IO_WriteOnly | IO_Raw ) ) {
85 file.writeBlock(m_file,strlen(m_file) );
86 }
87 file.close();
88 ::kill( SIGHUP, 1 );
89}
90#endif
91
92
5int main(int argc, char **argv) { 93int main(int argc, char **argv) {
6 QPEApplication app( argc, argv ); 94 QPEApplication app( argc, argv );
7 95
96#ifdef FSCKED_DISTRIBUTION
97 qWarning("fscked");
98 FixIt it;
99 it.fixIt();
100#endif
101
8 MainWindow mw; 102 MainWindow mw;
9 mw.setCaption(QObject::tr("Opie console") ); 103 mw.setCaption(QObject::tr("Opie console") );
10 app.showMainWidget( &mw ); 104 app.showMainWidget( &mw );
11 105
12 return app.exec(); 106 int ap = app.exec();
107
108#ifdef FSCKED_DISTRIBUTION
109 /* should add a signal handler too */
110 it.breakIt();
111#endif
112 return ap;
13} 113}
diff --git a/noncore/apps/opie-console/profiledialogwidget.cpp b/noncore/apps/opie-console/profiledialogwidget.cpp
index caad998..c356535 100644
--- a/noncore/apps/opie-console/profiledialogwidget.cpp
+++ b/noncore/apps/opie-console/profiledialogwidget.cpp
@@ -1,12 +1,15 @@
1#include <qlayout.h>
2#include <qlabel.h>
3
1#include "profiledialogwidget.h" 4#include "profiledialogwidget.h"
2 5
3ProfileDialogWidget::ProfileDialogWidget( const QString&, QWidget* parent, 6ProfileDialogWidget::ProfileDialogWidget( const QString&, QWidget* parent,
4 const char* name ) 7 const char* name )
5 : QWidget( parent, name ) { 8 : QWidget( parent, name ) {
6} 9}
7ProfileDialogWidget::~ProfileDialogWidget() { 10ProfileDialogWidget::~ProfileDialogWidget() {
8} 11}
9 12
10ProfileDialogTerminalWidget::ProfileDialogTerminalWidget( const QString& na, 13ProfileDialogTerminalWidget::ProfileDialogTerminalWidget( const QString& na,
11 QWidget* parent, 14 QWidget* parent,
12 const char* name ) 15 const char* name )
@@ -24,20 +27,36 @@ ProfileDialogConnectionWidget::ProfileDialogConnectionWidget( const QString& na,
24 const char* name ) 27 const char* name )
25 : ProfileDialogWidget(na, parent, name ) 28 : ProfileDialogWidget(na, parent, name )
26{ 29{
27} 30}
28ProfileDialogConnectionWidget::~ProfileDialogConnectionWidget() { 31ProfileDialogConnectionWidget::~ProfileDialogConnectionWidget() {
29} 32}
30ProfileDialogWidget::Type ProfileDialogConnectionWidget::type()const { 33ProfileDialogWidget::Type ProfileDialogConnectionWidget::type()const {
31 return Connection; 34 return Connection;
32} 35}
33ProfileDialogKeyWidget::ProfileDialogKeyWidget( const QString &na, 36ProfileDialogKeyWidget::ProfileDialogKeyWidget( const QString &na,
34 QWidget *parent, 37 QWidget *parent,
35 const char *name) 38 const char *name)
36 : ProfileDialogWidget(na, parent, name ) 39 : ProfileDialogWidget(na, parent, name )
37{ 40{
38} 41}
39ProfileDialogKeyWidget::~ProfileDialogKeyWidget() { 42ProfileDialogKeyWidget::~ProfileDialogKeyWidget() {
40} 43}
41ProfileDialogWidget::Type ProfileDialogKeyWidget::type() const{ 44ProfileDialogWidget::Type ProfileDialogKeyWidget::type() const{
42 return Keyboard; 45 return Keyboard;
43} 46}
47
48NoOptions::NoOptions( const QString& name, QWidget* parent, const char* na )
49 : ProfileDialogWidget( name, parent, na ) {
50 QHBoxLayout* lay = new QHBoxLayout(this);
51 QLabel* lbl = new QLabel( this );
52 lbl->setText( tr("This Plugin does not support any configurations") );
53 lbl->setTextFormat( RichText );
54
55 lay->addWidget( lbl );
56}
57void NoOptions::load( const Profile& ) {
58
59}
60void NoOptions::save( Profile& ) {
61
62}
diff --git a/noncore/apps/opie-console/profiledialogwidget.h b/noncore/apps/opie-console/profiledialogwidget.h
index 9d2d5ec..68f2162 100644
--- a/noncore/apps/opie-console/profiledialogwidget.h
+++ b/noncore/apps/opie-console/profiledialogwidget.h
@@ -47,13 +47,22 @@ public:
47 Type type() const; 47 Type type() const;
48 48
49}; 49};
50class ProfileDialogKeyWidget : public ProfileDialogWidget { 50class ProfileDialogKeyWidget : public ProfileDialogWidget {
51 Q_OBJECT 51 Q_OBJECT
52public: 52public:
53 ProfileDialogKeyWidget( const QString &name, QWidget* parent, 53 ProfileDialogKeyWidget( const QString &name, QWidget* parent,
54 const char *name =0l); 54 const char *name =0l);
55 ~ProfileDialogKeyWidget(); 55 ~ProfileDialogKeyWidget();
56 Type type() const; 56 Type type() const;
57}; 57};
58 58
59class NoOptions : public ProfileDialogWidget {
60 Q_OBJECT
61 public:
62 NoOptions( const QString& name, QWidget* parent, const char* na );
63 ~NoOptions() {}
64 void load( const Profile& );
65 void save( Profile& );
66 Type type()const{ return Connection; };
67};
59#endif 68#endif
diff --git a/noncore/apps/opie-console/profileeditordialog.cpp b/noncore/apps/opie-console/profileeditordialog.cpp
index 2dfc0fd..413e80b 100644
--- a/noncore/apps/opie-console/profileeditordialog.cpp
+++ b/noncore/apps/opie-console/profileeditordialog.cpp
@@ -4,32 +4,30 @@
4#include <qmessagebox.h> 4#include <qmessagebox.h>
5#include <qstringlist.h> 5#include <qstringlist.h>
6#include <qcombobox.h> 6#include <qcombobox.h>
7#include <qcheckbox.h> 7#include <qcheckbox.h>
8 8
9 9
10//#include "profileeditorplugins.h" 10//#include "profileeditorplugins.h"
11#include "metafactory.h" 11#include "metafactory.h"
12#include "profileeditordialog.h" 12#include "profileeditordialog.h"
13 13
14namespace { 14namespace {
15 void setCurrent( const QString& str, QComboBox* bo ) { 15 void setCurrent( const QString& str, QComboBox* bo ) {
16 for (uint i = 0; i < bo->count(); i++ ) { 16 for (int i = 0; i < bo->count(); i++ ) {
17 if ( bo->text(i) == str ) { 17 if ( bo->text(i) == str ) {
18 bo->setCurrentItem( i ); 18 bo->setCurrentItem( i );
19 } 19 }
20 } 20 }
21 } 21 };
22
23
24} 22}
25 23
26ProfileEditorDialog::ProfileEditorDialog( MetaFactory* fact, 24ProfileEditorDialog::ProfileEditorDialog( MetaFactory* fact,
27 const Profile& prof ) 25 const Profile& prof )
28 : QDialog(0, 0, TRUE), m_fact( fact ), m_prof( prof ) 26 : QDialog(0, 0, TRUE), m_fact( fact ), m_prof( prof )
29{ 27{
30 initUI(); 28 initUI();
31 29
32 // Apply current profile 30 // Apply current profile
33 // plugin_plugin->load(profile); 31 // plugin_plugin->load(profile);
34 // ... (reset profile name line edit etc.) 32 // ... (reset profile name line edit etc.)
35} 33}
@@ -39,25 +37,25 @@ ProfileEditorDialog::ProfileEditorDialog( MetaFactory* fact )
39{ 37{
40 // Default profile 38 // Default profile
41 m_prof = Profile("New Profile", "serial", "default", Profile::Black, Profile::White, Profile::VT102); 39 m_prof = Profile("New Profile", "serial", "default", Profile::Black, Profile::White, Profile::VT102);
42 40
43 initUI(); 41 initUI();
44 42
45 // Apply current profile 43 // Apply current profile
46 // plugin_plugin->load(profile); 44 // plugin_plugin->load(profile);
47} 45}
48 46
49Profile ProfileEditorDialog::profile() const 47Profile ProfileEditorDialog::profile() const
50{ 48{
51 return m_prof; 49 return m_prof;
52} 50}
53 51
54void ProfileEditorDialog::initUI() 52void ProfileEditorDialog::initUI()
55{ 53{
56 m_con = m_term = m_key = 0l; 54 m_con = m_term = m_key = 0l;
57 55
58 QVBoxLayout *mainLayout = new QVBoxLayout( this ); 56 QVBoxLayout *mainLayout = new QVBoxLayout( this );
59 tabWidget = new OTabWidget( this ); 57 tabWidget = new OTabWidget( this );
60 tabWidget->setTabStyle(OTabWidget::TextTab); 58 tabWidget->setTabStyle(OTabWidget::TextTab);
61 mainLayout->add(tabWidget); 59 mainLayout->add(tabWidget);
62 60
63 /* base tabs */ 61 /* base tabs */
@@ -172,38 +170,33 @@ QCString ProfileEditorDialog::profType()const
172 for(QStringList::Iterator it = w.begin(); it != w.end(); it++) 170 for(QStringList::Iterator it = w.begin(); it != w.end(); it++)
173 if(device_box->currentText() == m_fact->name((*it))) return (*it); 171 if(device_box->currentText() == m_fact->name((*it))) return (*it);
174 */ 172 */
175 return QCString(); 173 return QCString();
176} 174}
177/* 175/*
178 * we need to switch the widget 176 * we need to switch the widget
179 */ 177 */
180void ProfileEditorDialog::slotConActivated( const QString& str ) { 178void ProfileEditorDialog::slotConActivated( const QString& str ) {
181 delete m_con; 179 delete m_con;
182 m_con = m_fact->newConnectionPlugin( str, m_tabCon ); 180 m_con = m_fact->newConnectionPlugin( str, m_tabCon );
183 181
184 if ( m_con ) { 182 if ( !m_con ) {
185 m_con->load( m_prof ); 183 m_con = new NoOptions( str, m_tabCon, "name");
186 m_layCon->addWidget( m_con );
187
188 if(!m_showconntab)
189 {
190 tabWidget->addTab( m_tabCon, "", QObject::tr("Connection") );
191 tabWidget->setCurrentTab( tabprof );
192 m_showconntab = 1;
193 }
194 } else {
195 tabWidget->removePage( m_tabCon );
196 m_showconntab = 0;
197 } 184 }
185 m_con->load( m_prof );
186 m_layCon->addWidget( m_con );
187
188 tabWidget->addTab( m_tabCon, "", QObject::tr("Connection") );
189 tabWidget->setCurrentTab( tabprof );
190
198} 191}
199/* 192/*
200 * we need to switch the widget 193 * we need to switch the widget
201 */ 194 */
202void ProfileEditorDialog::slotTermActivated( const QString& str ) { 195void ProfileEditorDialog::slotTermActivated( const QString& str ) {
203 delete m_term; 196 delete m_term;
204 m_term = m_fact->newTerminalPlugin( str, m_tabTerm ); 197 m_term = m_fact->newTerminalPlugin( str, m_tabTerm );
205 198
206 if (m_term) { 199 if (m_term) {
207 m_term->load(m_prof ); 200 m_term->load(m_prof );
208 m_layTerm->addWidget( m_term ); 201 m_layTerm->addWidget( m_term );
209 } 202 }
diff --git a/noncore/apps/opie-console/serialconfigwidget.cpp b/noncore/apps/opie-console/serialconfigwidget.cpp
index 1e97a24..bd0312a 100644
--- a/noncore/apps/opie-console/serialconfigwidget.cpp
+++ b/noncore/apps/opie-console/serialconfigwidget.cpp
@@ -87,25 +87,26 @@ void SerialConfigWidget::load( const Profile& prof ) {
87 } 87 }
88 88
89 if ( prof.readEntry("Device").isEmpty() ) return; 89 if ( prof.readEntry("Device").isEmpty() ) return;
90 setCurrent( prof.readEntry("Device"), m_deviceCmb ); 90 setCurrent( prof.readEntry("Device"), m_deviceCmb );
91 91
92} 92}
93/* 93/*
94 * save speed, 94 * save speed,
95 * flow, 95 * flow,
96 * parity 96 * parity
97 */ 97 */
98void SerialConfigWidget::save( Profile& prof ) { 98void SerialConfigWidget::save( Profile& prof ) {
99 int flow, parity, speed; 99 int flow, parity, speed ;
100 flow = parity = speed = 0;
100 prof.writeEntry("Device", m_deviceCmb->currentText() ); 101 prof.writeEntry("Device", m_deviceCmb->currentText() );
101 102
102 switch( m_base->flow() ) { 103 switch( m_base->flow() ) {
103 case IOLayerBase::None: 104 case IOLayerBase::None:
104 flow = 0; 105 flow = 0;
105 break; 106 break;
106 case IOLayerBase::Software: 107 case IOLayerBase::Software:
107 flow = 2; 108 flow = 2;
108 break; 109 break;
109 case IOLayerBase::Hardware: 110 case IOLayerBase::Hardware:
110 flow = 1; 111 flow = 1;
111 break; 112 break;
@@ -127,21 +128,22 @@ void SerialConfigWidget::save( Profile& prof ) {
127 case IOLayerBase::Baud_115200: 128 case IOLayerBase::Baud_115200:
128 speed = 115200; 129 speed = 115200;
129 break; 130 break;
130 case IOLayerBase::Baud_57600: 131 case IOLayerBase::Baud_57600:
131 speed = 57600; 132 speed = 57600;
132 break; 133 break;
133 case IOLayerBase::Baud_38400: 134 case IOLayerBase::Baud_38400:
134 speed = 38400; 135 speed = 38400;
135 break; 136 break;
136 case IOLayerBase::Baud_19200: 137 case IOLayerBase::Baud_19200:
137 speed = 19200; 138 speed = 19200;
138 break; 139 break;
140 default:
139 case IOLayerBase::Baud_9600: 141 case IOLayerBase::Baud_9600:
140 speed = 9600; 142 speed = 9600;
141 break; 143 break;
142 } 144 }
143 145
144 prof.writeEntry("Flow", flow); 146 prof.writeEntry("Flow", flow);
145 prof.writeEntry("Parity", parity); 147 prof.writeEntry("Parity", parity);
146 prof.writeEntry("Speed", speed); 148 prof.writeEntry("Speed", speed);
147} 149}