-rw-r--r-- | noncore/apps/opie-console/btconfigwidget.cpp | 4 | ||||
-rw-r--r-- | noncore/apps/opie-console/default.cpp | 2 | ||||
-rw-r--r-- | noncore/apps/opie-console/dialer.cpp | 4 | ||||
-rw-r--r-- | noncore/apps/opie-console/dialer.h | 2 | ||||
-rw-r--r-- | noncore/apps/opie-console/function_keyboard.cpp | 64 | ||||
-rw-r--r-- | noncore/apps/opie-console/io_modem.cpp | 2 | ||||
-rw-r--r-- | noncore/apps/opie-console/iolayerbase.cpp | 4 | ||||
-rw-r--r-- | noncore/apps/opie-console/irdaconfigwidget.cpp | 4 | ||||
-rw-r--r-- | noncore/apps/opie-console/main.cpp | 1 | ||||
-rw-r--r-- | noncore/apps/opie-console/modemconfigwidget.cpp | 3 | ||||
-rw-r--r-- | noncore/apps/opie-console/procctl.cpp | 1 | ||||
-rw-r--r-- | noncore/apps/opie-console/profileeditordialog.cpp | 3 | ||||
-rw-r--r-- | noncore/apps/opie-console/serialconfigwidget.cpp | 2 | ||||
-rw-r--r-- | noncore/apps/opie-console/transferdialog.cpp | 8 |
14 files changed, 57 insertions, 47 deletions
diff --git a/noncore/apps/opie-console/btconfigwidget.cpp b/noncore/apps/opie-console/btconfigwidget.cpp index 6246f92..64046d8 100644 --- a/noncore/apps/opie-console/btconfigwidget.cpp +++ b/noncore/apps/opie-console/btconfigwidget.cpp | |||
@@ -1,188 +1,190 @@ | |||
1 | #include <qlabel.h> | 1 | #include <qlabel.h> |
2 | #include <qlayout.h> | 2 | #include <qlayout.h> |
3 | #include <qlineedit.h> | 3 | #include <qlineedit.h> |
4 | #include <qcombobox.h> | 4 | #include <qcombobox.h> |
5 | #include <qhbox.h> | 5 | #include <qhbox.h> |
6 | #include <qradiobutton.h> | 6 | #include <qradiobutton.h> |
7 | 7 | ||
8 | #include "iolayerbase.h" | 8 | #include "iolayerbase.h" |
9 | #include "btconfigwidget.h" | 9 | #include "btconfigwidget.h" |
10 | 10 | ||
11 | namespace { | 11 | namespace { |
12 | void setCurrent( const QString& str, QComboBox* bo ) { | 12 | void setCurrent( const QString& str, QComboBox* bo ) { |
13 | uint b = bo->count(); | 13 | uint b = bo->count(); |
14 | for (uint i = 0; i < bo->count(); i++ ) { | 14 | for (int i = 0; i < bo->count(); i++ ) { |
15 | if ( bo->text(i) == str ) { | 15 | if ( bo->text(i) == str ) { |
16 | bo->setCurrentItem( i ); | 16 | bo->setCurrentItem( i ); |
17 | return; | 17 | return; |
18 | } | 18 | } |
19 | } | 19 | } |
20 | bo->insertItem( str ); | 20 | bo->insertItem( str ); |
21 | bo->setCurrentItem( b ); | 21 | bo->setCurrentItem( b ); |
22 | } | 22 | } |
23 | } | 23 | } |
24 | 24 | ||
25 | BTConfigWidget::BTConfigWidget( const QString& name, | 25 | BTConfigWidget::BTConfigWidget( const QString& name, |
26 | QWidget* parent, | 26 | QWidget* parent, |
27 | const char* na ) | 27 | const char* na ) |
28 | : ProfileDialogConnectionWidget( name, parent, na ) { | 28 | : ProfileDialogConnectionWidget( name, parent, na ) { |
29 | 29 | ||
30 | m_lay = new QVBoxLayout( this ); | 30 | m_lay = new QVBoxLayout( this ); |
31 | 31 | ||
32 | m_device = new QLabel( tr( "Device" ), this ); | 32 | m_device = new QLabel( tr( "Device" ), this ); |
33 | QHBox *deviceBox = new QHBox( this ); | 33 | QHBox *deviceBox = new QHBox( this ); |
34 | m_devRadio = new QRadioButton( deviceBox ); | 34 | m_devRadio = new QRadioButton( deviceBox ); |
35 | connect( m_devRadio, SIGNAL( toggled( bool ) ), this, SLOT( slotDevRadio( bool ) ) ); | 35 | connect( m_devRadio, SIGNAL( toggled( bool ) ), this, SLOT( slotDevRadio( bool ) ) ); |
36 | m_deviceCmb = new QComboBox( deviceBox ); | 36 | m_deviceCmb = new QComboBox( deviceBox ); |
37 | m_deviceCmb->setEditable( TRUE ); | 37 | m_deviceCmb->setEditable( TRUE ); |
38 | 38 | ||
39 | QLabel *macLabel = new QLabel( this ); | 39 | QLabel *macLabel = new QLabel( this ); |
40 | macLabel->setText( tr( "Or peer mac address" ) ); | 40 | macLabel->setText( tr( "Or peer mac address" ) ); |
41 | QHBox *macBox = new QHBox( this ); | 41 | QHBox *macBox = new QHBox( this ); |
42 | m_macRadio = new QRadioButton( macBox ); | 42 | m_macRadio = new QRadioButton( macBox ); |
43 | connect( m_macRadio, SIGNAL( toggled( bool ) ), this, SLOT( slotMacRadio( bool ) ) ); | 43 | connect( m_macRadio, SIGNAL( toggled( bool ) ), this, SLOT( slotMacRadio( bool ) ) ); |
44 | m_mac = new QLineEdit( macBox ); | 44 | m_mac = new QLineEdit( macBox ); |
45 | 45 | ||
46 | m_base = new IOLayerBase(this, "base"); | 46 | m_base = new IOLayerBase(this, "base"); |
47 | 47 | ||
48 | m_lay->addWidget( m_device ); | 48 | m_lay->addWidget( m_device ); |
49 | m_lay->addWidget( deviceBox ); | 49 | m_lay->addWidget( deviceBox ); |
50 | m_lay->addWidget( macLabel ); | 50 | m_lay->addWidget( macLabel ); |
51 | m_lay->addWidget( macBox ); | 51 | m_lay->addWidget( macBox ); |
52 | m_lay->addWidget( m_base ); | 52 | m_lay->addWidget( m_base ); |
53 | 53 | ||
54 | m_deviceCmb->insertItem( "/dev/ttyU0" ); | 54 | m_deviceCmb->insertItem( "/dev/ttyU0" ); |
55 | m_deviceCmb->insertItem( "/dev/ttyU1" ); | 55 | m_deviceCmb->insertItem( "/dev/ttyU1" ); |
56 | } | 56 | } |
57 | 57 | ||
58 | BTConfigWidget::~BTConfigWidget() { | 58 | BTConfigWidget::~BTConfigWidget() { |
59 | 59 | ||
60 | } | 60 | } |
61 | void BTConfigWidget::load( const Profile& prof ) { | 61 | void BTConfigWidget::load( const Profile& prof ) { |
62 | int rad_flow = prof.readNumEntry("Flow"); | 62 | int rad_flow = prof.readNumEntry("Flow"); |
63 | int rad_parity = prof.readNumEntry("Parity"); | 63 | int rad_parity = prof.readNumEntry("Parity"); |
64 | int speed = prof.readNumEntry("Speed"); | 64 | int speed = prof.readNumEntry("Speed"); |
65 | QString mac = prof.readEntry("Mac"); | 65 | QString mac = prof.readEntry("Mac"); |
66 | 66 | ||
67 | if (!mac.isEmpty() ) { | 67 | if (!mac.isEmpty() ) { |
68 | m_mac->setText( mac ); | 68 | m_mac->setText( mac ); |
69 | } else { | 69 | } else { |
70 | m_devRadio->setChecked( true ); | 70 | m_devRadio->setChecked( true ); |
71 | } | 71 | } |
72 | 72 | ||
73 | if (rad_flow == 1) { | 73 | if (rad_flow == 1) { |
74 | m_base->setFlow( IOLayerBase::Hardware ); | 74 | m_base->setFlow( IOLayerBase::Hardware ); |
75 | } else if (rad_flow == 2) { | 75 | } else if (rad_flow == 2) { |
76 | m_base->setFlow( IOLayerBase::Software ); | 76 | m_base->setFlow( IOLayerBase::Software ); |
77 | } else if (rad_flow == 0) { | 77 | } else if (rad_flow == 0) { |
78 | m_base->setFlow( IOLayerBase::None ); | 78 | m_base->setFlow( IOLayerBase::None ); |
79 | } | 79 | } |
80 | 80 | ||
81 | if (rad_parity == 1) { | 81 | if (rad_parity == 1) { |
82 | m_base->setParity( IOLayerBase::Even ); | 82 | m_base->setParity( IOLayerBase::Even ); |
83 | } else if ( rad_parity == 2 ) { | 83 | } else if ( rad_parity == 2 ) { |
84 | m_base->setParity( IOLayerBase::Odd ); | 84 | m_base->setParity( IOLayerBase::Odd ); |
85 | } else { | 85 | } else { |
86 | m_base->setParity( IOLayerBase::NonePar ); | 86 | m_base->setParity( IOLayerBase::NonePar ); |
87 | } | 87 | } |
88 | 88 | ||
89 | switch( speed ) { | 89 | switch( speed ) { |
90 | case 115200: | 90 | case 115200: |
91 | m_base->setSpeed(IOLayerBase::Baud_115200 ); | 91 | m_base->setSpeed(IOLayerBase::Baud_115200 ); |
92 | break; | 92 | break; |
93 | case 57600: | 93 | case 57600: |
94 | m_base->setSpeed( IOLayerBase::Baud_57600 ); | 94 | m_base->setSpeed( IOLayerBase::Baud_57600 ); |
95 | break; | 95 | break; |
96 | case 38400: | 96 | case 38400: |
97 | m_base->setSpeed(IOLayerBase::Baud_38400 ); | 97 | m_base->setSpeed(IOLayerBase::Baud_38400 ); |
98 | break; | 98 | break; |
99 | case 19200: | 99 | case 19200: |
100 | m_base->setSpeed( IOLayerBase::Baud_19200 ); | 100 | m_base->setSpeed( IOLayerBase::Baud_19200 ); |
101 | break; | 101 | break; |
102 | case 9600: | 102 | case 9600: |
103 | default: | 103 | default: |
104 | m_base->setSpeed(IOLayerBase::Baud_9600 ); | 104 | m_base->setSpeed(IOLayerBase::Baud_9600 ); |
105 | break; | 105 | break; |
106 | } | 106 | } |
107 | 107 | ||
108 | if ( prof.readEntry("Device").isEmpty() ) return; | 108 | if ( prof.readEntry("Device").isEmpty() ) return; |
109 | setCurrent( prof.readEntry("Device"), m_deviceCmb ); | 109 | setCurrent( prof.readEntry("Device"), m_deviceCmb ); |
110 | 110 | ||
111 | } | 111 | } |
112 | /* | 112 | /* |
113 | * save speed, | 113 | * save speed, |
114 | * flow, | 114 | * flow, |
115 | * parity | 115 | * parity |
116 | */ | 116 | */ |
117 | void BTConfigWidget::save( Profile& prof ) { | 117 | void BTConfigWidget::save( Profile& prof ) { |
118 | int flow, parity, speed; | 118 | int flow, parity, speed; |
119 | flow = parity = speed = 0; | ||
119 | prof.writeEntry("Device", m_deviceCmb->currentText() ); | 120 | prof.writeEntry("Device", m_deviceCmb->currentText() ); |
120 | 121 | ||
121 | 122 | ||
122 | switch( m_base->flow() ) { | 123 | switch( m_base->flow() ) { |
123 | case IOLayerBase::None: | 124 | case IOLayerBase::None: |
124 | flow = 0; | 125 | flow = 0; |
125 | break; | 126 | break; |
126 | case IOLayerBase::Software: | 127 | case IOLayerBase::Software: |
127 | flow = 2; | 128 | flow = 2; |
128 | break; | 129 | break; |
129 | case IOLayerBase::Hardware: | 130 | case IOLayerBase::Hardware: |
130 | flow = 1; | 131 | flow = 1; |
131 | break; | 132 | break; |
132 | } | 133 | } |
133 | 134 | ||
134 | switch( m_base->parity() ) { | 135 | switch( m_base->parity() ) { |
135 | case IOLayerBase::Odd: | 136 | case IOLayerBase::Odd: |
136 | parity = 2; | 137 | parity = 2; |
137 | break; | 138 | break; |
138 | case IOLayerBase::Even: | 139 | case IOLayerBase::Even: |
139 | parity = 1; | 140 | parity = 1; |
140 | break; | 141 | break; |
141 | case IOLayerBase::NonePar: | 142 | case IOLayerBase::NonePar: |
142 | parity = 0; | 143 | parity = 0; |
143 | break; | 144 | break; |
144 | } | 145 | } |
145 | 146 | ||
146 | switch( m_base->speed() ) { | 147 | switch( m_base->speed() ) { |
147 | case IOLayerBase::Baud_115200: | 148 | case IOLayerBase::Baud_115200: |
148 | speed = 115200; | 149 | speed = 115200; |
149 | break; | 150 | break; |
150 | case IOLayerBase::Baud_57600: | 151 | case IOLayerBase::Baud_57600: |
151 | speed = 57600; | 152 | speed = 57600; |
152 | break; | 153 | break; |
153 | case IOLayerBase::Baud_38400: | 154 | case IOLayerBase::Baud_38400: |
154 | speed = 38400; | 155 | speed = 38400; |
155 | break; | 156 | break; |
156 | case IOLayerBase::Baud_19200: | 157 | case IOLayerBase::Baud_19200: |
157 | speed = 19200; | 158 | speed = 19200; |
158 | break; | 159 | break; |
160 | default: | ||
159 | case IOLayerBase::Baud_9600: | 161 | case IOLayerBase::Baud_9600: |
160 | speed = 9600; | 162 | speed = 9600; |
161 | break; | 163 | break; |
162 | } | 164 | } |
163 | 165 | ||
164 | prof.writeEntry("Flow", flow); | 166 | prof.writeEntry("Flow", flow); |
165 | prof.writeEntry("Parity", parity); | 167 | prof.writeEntry("Parity", parity); |
166 | prof.writeEntry("Speed", speed); | 168 | prof.writeEntry("Speed", speed); |
167 | prof.writeEntry("Mac", m_mac->text() ); | 169 | prof.writeEntry("Mac", m_mac->text() ); |
168 | } | 170 | } |
169 | 171 | ||
170 | void BTConfigWidget::slotMacRadio( bool on ) { | 172 | void BTConfigWidget::slotMacRadio( bool on ) { |
171 | if ( on ) { | 173 | if ( on ) { |
172 | m_devRadio->setChecked( false ); | 174 | m_devRadio->setChecked( false ); |
173 | m_deviceCmb->setEnabled( false ); | 175 | m_deviceCmb->setEnabled( false ); |
174 | m_mac->setEnabled( true ); | 176 | m_mac->setEnabled( true ); |
175 | } else { | 177 | } else { |
176 | m_devRadio->setChecked( true ); | 178 | m_devRadio->setChecked( true ); |
177 | } | 179 | } |
178 | } | 180 | } |
179 | 181 | ||
180 | void BTConfigWidget::slotDevRadio( bool on ) { | 182 | void BTConfigWidget::slotDevRadio( bool on ) { |
181 | if ( on ) { | 183 | if ( on ) { |
182 | m_macRadio->setChecked( false ); | 184 | m_macRadio->setChecked( false ); |
183 | m_deviceCmb->setEnabled( true ); | 185 | m_deviceCmb->setEnabled( true ); |
184 | m_mac->setEnabled( false ); | 186 | m_mac->setEnabled( false ); |
185 | } else { | 187 | } else { |
186 | m_macRadio->setChecked( true ); | 188 | m_macRadio->setChecked( true ); |
187 | } | 189 | } |
188 | } | 190 | } |
diff --git a/noncore/apps/opie-console/default.cpp b/noncore/apps/opie-console/default.cpp index 0160b56..19640d8 100644 --- a/noncore/apps/opie-console/default.cpp +++ b/noncore/apps/opie-console/default.cpp | |||
@@ -1,121 +1,121 @@ | |||
1 | #include "io_serial.h" | 1 | #include "io_serial.h" |
2 | #include "io_irda.h" | 2 | #include "io_irda.h" |
3 | #include "io_bt.h" | 3 | #include "io_bt.h" |
4 | #include "io_modem.h" | 4 | #include "io_modem.h" |
5 | #include "filetransfer.h" | 5 | #include "filetransfer.h" |
6 | #include "filereceive.h" | 6 | #include "filereceive.h" |
7 | #include "serialconfigwidget.h" | 7 | #include "serialconfigwidget.h" |
8 | #include "irdaconfigwidget.h" | 8 | #include "irdaconfigwidget.h" |
9 | #include "btconfigwidget.h" | 9 | #include "btconfigwidget.h" |
10 | #include "modemconfigwidget.h" | 10 | #include "modemconfigwidget.h" |
11 | #include "terminalwidget.h" | 11 | #include "terminalwidget.h" |
12 | #include "function_keyboard.h" | 12 | #include "function_keyboard.h" |
13 | #include "MyPty.h" | 13 | #include "MyPty.h" |
14 | 14 | ||
15 | #include "default.h" | 15 | #include "default.h" |
16 | 16 | ||
17 | extern "C" { | 17 | extern "C" { |
18 | // FILE Transfer Stuff | 18 | // FILE Transfer Stuff |
19 | FileTransferLayer* newSZTransfer(IOLayer* lay) { | 19 | FileTransferLayer* newSZTransfer(IOLayer* lay) { |
20 | return new FileTransfer( FileTransfer::SZ, lay ); | 20 | return new FileTransfer( FileTransfer::SZ, lay ); |
21 | } | 21 | } |
22 | FileTransferLayer* newSYTransfer(IOLayer* lay) { | 22 | FileTransferLayer* newSYTransfer(IOLayer* lay) { |
23 | return new FileTransfer( FileTransfer::SY, lay ); | 23 | return new FileTransfer( FileTransfer::SY, lay ); |
24 | } | 24 | } |
25 | FileTransferLayer* newSXTransfer(IOLayer* lay) { | 25 | FileTransferLayer* newSXTransfer(IOLayer* lay) { |
26 | return new FileTransfer(FileTransfer ::SX, lay ); | 26 | return new FileTransfer(FileTransfer ::SX, lay ); |
27 | } | 27 | } |
28 | 28 | ||
29 | // FILE Transfer Receive Stuff | 29 | // FILE Transfer Receive Stuff |
30 | ReceiveLayer* newSZReceive(IOLayer* lay) { | 30 | ReceiveLayer* newSZReceive(IOLayer* lay) { |
31 | return new FileReceive( FileReceive::SZ, lay ); | 31 | return new FileReceive( FileReceive::SZ, lay ); |
32 | } | 32 | } |
33 | ReceiveLayer* newSYReceive(IOLayer* lay) { | 33 | ReceiveLayer* newSYReceive(IOLayer* lay) { |
34 | return new FileReceive( FileReceive::SY, lay ); | 34 | return new FileReceive( FileReceive::SY, lay ); |
35 | } | 35 | } |
36 | ReceiveLayer* newSXReceive(IOLayer* lay) { | 36 | ReceiveLayer* newSXReceive(IOLayer* lay) { |
37 | return new FileReceive(FileReceive::SX, lay ); | 37 | return new FileReceive(FileReceive::SX, lay ); |
38 | } | 38 | } |
39 | 39 | ||
40 | // Layer stuff | 40 | // Layer stuff |
41 | IOLayer* newSerialLayer( const Profile& prof) { | 41 | IOLayer* newSerialLayer( const Profile& prof) { |
42 | return new IOSerial( prof ); | 42 | return new IOSerial( prof ); |
43 | } | 43 | } |
44 | IOLayer* newBTLayer( const Profile& prof ) { | 44 | IOLayer* newBTLayer( const Profile& prof ) { |
45 | return new IOBt( prof ); | 45 | return new IOBt( prof ); |
46 | } | 46 | } |
47 | IOLayer* newIrDaLayer( const Profile& prof ) { | 47 | IOLayer* newIrDaLayer( const Profile& prof ) { |
48 | return new IOIrda( prof ); | 48 | return new IOIrda( prof ); |
49 | } | 49 | } |
50 | IOLayer* newModemLayer( const Profile& prof ) { | 50 | IOLayer* newModemLayer( const Profile& prof ) { |
51 | return new IOModem( prof ); | 51 | return new IOModem( prof ); |
52 | } | 52 | } |
53 | IOLayer* newConsole( const Profile& prof ) { | 53 | IOLayer* newConsole( const Profile& prof ) { |
54 | return new MyPty( prof ); | 54 | return new MyPty( prof ); |
55 | } | 55 | } |
56 | 56 | ||
57 | // Connection Widgets | 57 | // Connection Widgets |
58 | ProfileDialogWidget* newSerialWidget( const QString& str, QWidget* wid ) { | 58 | ProfileDialogWidget* newSerialWidget( const QString& str, QWidget* wid ) { |
59 | return new SerialConfigWidget( str, wid ); | 59 | return new SerialConfigWidget( str, wid ); |
60 | } | 60 | } |
61 | ProfileDialogWidget* newIrDaWidget( const QString& str, QWidget* wid ) { | 61 | ProfileDialogWidget* newIrDaWidget( const QString& str, QWidget* wid ) { |
62 | return new IrdaConfigWidget( str, wid ); | 62 | return new IrdaConfigWidget( str, wid ); |
63 | } | 63 | } |
64 | ProfileDialogWidget* newModemWidget( const QString& str, QWidget* wid ) { | 64 | ProfileDialogWidget* newModemWidget( const QString& str, QWidget* wid ) { |
65 | return new ModemConfigWidget(str, wid ); | 65 | return new ModemConfigWidget(str, wid ); |
66 | } | 66 | } |
67 | ProfileDialogWidget* newBTWidget( const QString& str, QWidget* wid ) { | 67 | ProfileDialogWidget* newBTWidget( const QString& str, QWidget* wid ) { |
68 | return new BTConfigWidget(str, wid ); | 68 | return new BTConfigWidget(str, wid ); |
69 | } | 69 | } |
70 | ProfileDialogWidget* newConsoleWid( const QString& str, QWidget* wid ) { | 70 | ProfileDialogWidget* newConsoleWid( const QString& , QWidget* ) { |
71 | return 0l; | 71 | return 0l; |
72 | } | 72 | } |
73 | 73 | ||
74 | 74 | ||
75 | // Terminal Widget(s) | 75 | // Terminal Widget(s) |
76 | ProfileDialogWidget* newTerminalWidget(const QString& na, QWidget* wid) { | 76 | ProfileDialogWidget* newTerminalWidget(const QString& na, QWidget* wid) { |
77 | return new TerminalWidget(na, wid,0 ); | 77 | return new TerminalWidget(na, wid,0 ); |
78 | } | 78 | } |
79 | 79 | ||
80 | // Function Keyboard Widget | 80 | // Function Keyboard Widget |
81 | ProfileDialogWidget* newKeyboardWidget(const QString& na, QWidget *wid) { | 81 | ProfileDialogWidget* newKeyboardWidget(const QString& na, QWidget *wid) { |
82 | return new FunctionKeyboardConfig(na, wid); | 82 | return new FunctionKeyboardConfig(na, wid); |
83 | } | 83 | } |
84 | 84 | ||
85 | /* // VT Emulations | 85 | /* // VT Emulations |
86 | EmulationLayer* newVT102( WidgetLayer* wid ) { | 86 | EmulationLayer* newVT102( WidgetLayer* wid ) { |
87 | return new Vt102Emulation( wid ); | 87 | return new Vt102Emulation( wid ); |
88 | } | 88 | } |
89 | */ | 89 | */ |
90 | }; | 90 | }; |
91 | 91 | ||
92 | Default::Default( MetaFactory* fact ) { | 92 | Default::Default( MetaFactory* fact ) { |
93 | fact->addFileTransferLayer( "SZ", QObject::tr("Z-Modem"), newSZTransfer ); | 93 | fact->addFileTransferLayer( "SZ", QObject::tr("Z-Modem"), newSZTransfer ); |
94 | fact->addFileTransferLayer( "SY", QObject::tr("Y-Modem"), newSYTransfer ); | 94 | fact->addFileTransferLayer( "SY", QObject::tr("Y-Modem"), newSYTransfer ); |
95 | fact->addFileTransferLayer( "SX", QObject::tr("X-Modem"), newSXTransfer ); | 95 | fact->addFileTransferLayer( "SX", QObject::tr("X-Modem"), newSXTransfer ); |
96 | 96 | ||
97 | fact->addReceiveLayer( "SZ", QObject::tr("Z-Modem"), newSZReceive ); | 97 | fact->addReceiveLayer( "SZ", QObject::tr("Z-Modem"), newSZReceive ); |
98 | fact->addReceiveLayer( "SY", QObject::tr("Y-Modem"), newSYReceive ); | 98 | fact->addReceiveLayer( "SY", QObject::tr("Y-Modem"), newSYReceive ); |
99 | fact->addReceiveLayer( "SX", QObject::tr("X-Modem"), newSXReceive ); | 99 | fact->addReceiveLayer( "SX", QObject::tr("X-Modem"), newSXReceive ); |
100 | 100 | ||
101 | fact->addIOLayerFactory( "serial", QObject::tr("Serial"), newSerialLayer ); | 101 | fact->addIOLayerFactory( "serial", QObject::tr("Serial"), newSerialLayer ); |
102 | fact->addIOLayerFactory( "irda", QObject::tr("Infrared"), newIrDaLayer ); | 102 | fact->addIOLayerFactory( "irda", QObject::tr("Infrared"), newIrDaLayer ); |
103 | fact->addIOLayerFactory( "bt", QObject::tr("Bluetooth"), newBTLayer ); | 103 | fact->addIOLayerFactory( "bt", QObject::tr("Bluetooth"), newBTLayer ); |
104 | fact->addIOLayerFactory( "modem", QObject::tr("Modem"), newModemLayer ); | 104 | fact->addIOLayerFactory( "modem", QObject::tr("Modem"), newModemLayer ); |
105 | fact->addIOLayerFactory( "console", QObject::tr("Console"), newConsole ); | 105 | fact->addIOLayerFactory( "console", QObject::tr("Console"), newConsole ); |
106 | 106 | ||
107 | fact->addConnectionWidgetFactory( "serial", QObject::tr("Serial"), newSerialWidget ); | 107 | fact->addConnectionWidgetFactory( "serial", QObject::tr("Serial"), newSerialWidget ); |
108 | fact->addConnectionWidgetFactory( "irda", QObject::tr("Infrared"), newIrDaWidget ); | 108 | fact->addConnectionWidgetFactory( "irda", QObject::tr("Infrared"), newIrDaWidget ); |
109 | fact->addConnectionWidgetFactory( "modem", QObject::tr("Modem"), newModemWidget ); | 109 | fact->addConnectionWidgetFactory( "modem", QObject::tr("Modem"), newModemWidget ); |
110 | fact->addConnectionWidgetFactory( "bt", QObject::tr("Bluetooth"), newBTWidget ); | 110 | fact->addConnectionWidgetFactory( "bt", QObject::tr("Bluetooth"), newBTWidget ); |
111 | fact->addConnectionWidgetFactory( "console", QObject::tr("Console"), newConsoleWid ); | 111 | fact->addConnectionWidgetFactory( "console", QObject::tr("Console"), newConsoleWid ); |
112 | 112 | ||
113 | fact->addTerminalWidgetFactory( "default", QObject::tr("Default Terminal"), newTerminalWidget ); | 113 | fact->addTerminalWidgetFactory( "default", QObject::tr("Default Terminal"), newTerminalWidget ); |
114 | fact->addKeyboardWidgetFactory( "defaultKeys", QObject::tr("Default Keyboard"), | 114 | fact->addKeyboardWidgetFactory( "defaultKeys", QObject::tr("Default Keyboard"), |
115 | newKeyboardWidget ); | 115 | newKeyboardWidget ); |
116 | 116 | ||
117 | // fact->addEmulationLayer( "default", QObject::tr("Default Terminal"), newVT102 ); | 117 | // fact->addEmulationLayer( "default", QObject::tr("Default Terminal"), newVT102 ); |
118 | } | 118 | } |
119 | Default::~Default() { | 119 | Default::~Default() { |
120 | 120 | ||
121 | } | 121 | } |
diff --git a/noncore/apps/opie-console/dialer.cpp b/noncore/apps/opie-console/dialer.cpp index d37e406..5056040 100644 --- a/noncore/apps/opie-console/dialer.cpp +++ b/noncore/apps/opie-console/dialer.cpp | |||
@@ -1,301 +1,301 @@ | |||
1 | #include "dialer.h" | 1 | #include "dialer.h" |
2 | 2 | ||
3 | #include <qlayout.h> | 3 | #include <qlayout.h> |
4 | #include <qprogressbar.h> | 4 | #include <qprogressbar.h> |
5 | #include <qlabel.h> | 5 | #include <qlabel.h> |
6 | #include <qpushbutton.h> | 6 | #include <qpushbutton.h> |
7 | #include <qapp.h> | 7 | #include <qapp.h> |
8 | #include <qtimer.h> | 8 | #include <qtimer.h> |
9 | #include <qmessagebox.h> | 9 | #include <qmessagebox.h> |
10 | 10 | ||
11 | #include <unistd.h> | 11 | #include <unistd.h> |
12 | #include <string.h> | 12 | #include <string.h> |
13 | #include <fcntl.h> | 13 | #include <fcntl.h> |
14 | #include <errno.h> | 14 | #include <errno.h> |
15 | 15 | ||
16 | // State machine: | When an error occurs, we don't have to | 16 | // State machine: | When an error occurs, we don't have to |
17 | // | reset everything. | 17 | // | reset everything. |
18 | // (init) <------+ | But if the user wants to reset, | 18 | // (init) <------+ | But if the user wants to reset, |
19 | // | | | we stop dialing immediately. | 19 | // | | | we stop dialing immediately. |
20 | // v | | | 20 | // v | | |
21 | // (options) ----+ | Following the state machine is necessary | 21 | // (options) ----+ | Following the state machine is necessary |
22 | // | \ | to get determinable results. | 22 | // | \ | to get determinable results. |
23 | // v ^ | | 23 | // v ^ | |
24 | // (dial) ----+ | | 24 | // (dial) ----+ | |
25 | // | ^ | | 25 | // | ^ | |
26 | // v | | | 26 | // v | | |
27 | // (online) --+ | | 27 | // (online) --+ | |
28 | // | | | 28 | // | | |
29 | // v | | 29 | // v | |
30 | 30 | ||
31 | 31 | ||
32 | // from atconfigdialog | 32 | // from atconfigdialog |
33 | //initStringLine->setText( config.readEntry("InitString", MODEM_DEFAULT_INIT_STRING ) ); | 33 | //initStringLine->setText( config.readEntry("InitString", MODEM_DEFAULT_INIT_STRING ) ); |
34 | //resetStringLine->setText( config.readEntry("ResetString", MODEM_DEFAULT_RESET_STRING ) ); | 34 | //resetStringLine->setText( config.readEntry("ResetString", MODEM_DEFAULT_RESET_STRING ) ); |
35 | //dialPref1Line->setText( config.readEntry("DialPrefix1", MODEM_DEFAULT_DIAL_PREFIX1 ) ); | 35 | //dialPref1Line->setText( config.readEntry("DialPrefix1", MODEM_DEFAULT_DIAL_PREFIX1 ) ); |
36 | //dialSuf1Line->setText( config.readEntry("DialSuffix1", MODEM_DEFAULT_DIAL_SUFFIX1 ) ); | 36 | //dialSuf1Line->setText( config.readEntry("DialSuffix1", MODEM_DEFAULT_DIAL_SUFFIX1 ) ); |
37 | //dialPref2Line->setText( config.readEntry("DialPrefix2", MODEM_DEFAULT_DIAL_PREFIX1 ) ); | 37 | //dialPref2Line->setText( config.readEntry("DialPrefix2", MODEM_DEFAULT_DIAL_PREFIX1 ) ); |
38 | //dialSuf2Line->setText( config.readEntry("DialSuffix2", MODEM_DEFAULT_DIAL_SUFFIX1 ) ); | 38 | //dialSuf2Line->setText( config.readEntry("DialSuffix2", MODEM_DEFAULT_DIAL_SUFFIX1 ) ); |
39 | //dialPref3Line->setText( config.readEntry("DialPrefix3", MODEM_DEFAULT_DIAL_PREFIX1 ) ); | 39 | //dialPref3Line->setText( config.readEntry("DialPrefix3", MODEM_DEFAULT_DIAL_PREFIX1 ) ); |
40 | //dialSuf3Line->setText( config.readEntry("DialSuffix3", MODEM_DEFAULT_DIAL_SUFFIX1 ) ); | 40 | //dialSuf3Line->setText( config.readEntry("DialSuffix3", MODEM_DEFAULT_DIAL_SUFFIX1 ) ); |
41 | //connectLine->setText( config.readEntry("DefaultConnect" MODEM_DEFAULT_CONNECT_STRING ) ); | 41 | //connectLine->setText( config.readEntry("DefaultConnect" MODEM_DEFAULT_CONNECT_STRING ) ); |
42 | //hangupLine->setText( config.readEntry("HangupString", MODEM_DEFAULT_HANGUP_STRING ) ); | 42 | //hangupLine->setText( config.readEntry("HangupString", MODEM_DEFAULT_HANGUP_STRING ) ); |
43 | 43 | ||
44 | // from modemconfigwidget | 44 | // from modemconfigwidget |
45 | //int rad_flow = prof.readNumEntry("Flow"); | 45 | //int rad_flow = prof.readNumEntry("Flow"); |
46 | //int rad_parity = prof.readNumEntry("Parity"); | 46 | //int rad_parity = prof.readNumEntry("Parity"); |
47 | //int speed = prof.readNumEntry("Speed"); | 47 | //int speed = prof.readNumEntry("Speed"); |
48 | //QString number = prof.readEntry("Number"); | 48 | //QString number = prof.readEntry("Number"); |
49 | 49 | ||
50 | Dialer::Dialer(const Profile& profile, int fd, QWidget *parent, const char *name) | 50 | Dialer::Dialer(const Profile& profile, int fd, QWidget *parent, const char *name) |
51 | : QDialog(parent, name, true), m_fd(fd), m_profile(profile) | 51 | : QDialog(parent, name, true), m_fd(fd), m_profile(profile) |
52 | { | 52 | { |
53 | QVBoxLayout *vbox; | 53 | QVBoxLayout *vbox; |
54 | QLabel *desc; | 54 | QLabel *desc; |
55 | 55 | ||
56 | //m_profile.writeEntry("InitString", "ATZ"); | 56 | //m_profile.writeEntry("InitString", "ATZ"); |
57 | //m_profile.writeEntry("DialPrefix1", "ATDT"); | 57 | //m_profile.writeEntry("DialPrefix1", "ATDT"); |
58 | //m_profile.writeEntry("Termination", "\n"); | 58 | //m_profile.writeEntry("Termination", "\n"); |
59 | 59 | ||
60 | usercancel = 0; | 60 | usercancel = 0; |
61 | cleanshutdown = 0; | 61 | cleanshutdown = 0; |
62 | 62 | ||
63 | fcntl(m_fd, F_SETFL, O_NONBLOCK); | 63 | fcntl(m_fd, F_SETFL, O_NONBLOCK); |
64 | 64 | ||
65 | desc = new QLabel(QObject::tr("Dialing number: %1").arg(m_profile.readEntry("Number")), this); | 65 | desc = new QLabel(QObject::tr("Dialing number: %1").arg(m_profile.readEntry("Number")), this); |
66 | progress = new QProgressBar(this); | 66 | progress = new QProgressBar(this); |
67 | status = new QLabel("", this); | 67 | status = new QLabel("", this); |
68 | status->setFrameStyle(QFrame::Panel | QFrame::Sunken); | 68 | status->setFrameStyle(QFrame::Panel | QFrame::Sunken); |
69 | cancel = new QPushButton(QObject::tr("Cancel"), this); | 69 | cancel = new QPushButton(QObject::tr("Cancel"), this); |
70 | 70 | ||
71 | vbox = new QVBoxLayout(this, 2); | 71 | vbox = new QVBoxLayout(this, 2); |
72 | vbox->add(desc); | 72 | vbox->add(desc); |
73 | vbox->add(progress); | 73 | vbox->add(progress); |
74 | vbox->add(status); | 74 | vbox->add(status); |
75 | vbox->add(cancel); | 75 | vbox->add(cancel); |
76 | 76 | ||
77 | connect(cancel, SIGNAL(clicked()), SLOT(slotCancel())); | 77 | connect(cancel, SIGNAL(clicked()), SLOT(slotCancel())); |
78 | 78 | ||
79 | show(); | 79 | show(); |
80 | 80 | ||
81 | QTimer::singleShot(500, this, SLOT(slotAutostart())); | 81 | QTimer::singleShot(500, this, SLOT(slotAutostart())); |
82 | } | 82 | } |
83 | 83 | ||
84 | Dialer::~Dialer() | 84 | Dialer::~Dialer() |
85 | { | 85 | { |
86 | } | 86 | } |
87 | 87 | ||
88 | void Dialer::setHangupOnly() | 88 | void Dialer::setHangupOnly() |
89 | { | 89 | { |
90 | state = state_cancel; | 90 | state = state_cancel; |
91 | usercancel = 1; | 91 | usercancel = 1; |
92 | } | 92 | } |
93 | 93 | ||
94 | void Dialer::slotCancel() | 94 | void Dialer::slotCancel() |
95 | { | 95 | { |
96 | if(state != state_online) | 96 | if(state != state_online) |
97 | { | 97 | { |
98 | usercancel = 1; | 98 | usercancel = 1; |
99 | reset(); | 99 | reset(); |
100 | } | 100 | } |
101 | else accept(); | 101 | else accept(); |
102 | } | 102 | } |
103 | 103 | ||
104 | void Dialer::reset() | 104 | void Dialer::reset() |
105 | { | 105 | { |
106 | switchState(state_cancel); | 106 | switchState(state_cancel); |
107 | } | 107 | } |
108 | 108 | ||
109 | void Dialer::slotAutostart() | 109 | void Dialer::slotAutostart() |
110 | { | 110 | { |
111 | //state = state_preinit; | 111 | //state = state_preinit; |
112 | dial(m_profile.readEntry("Number")); | 112 | dial(m_profile.readEntry("Number")); |
113 | } | 113 | } |
114 | 114 | ||
115 | void Dialer::dial(const QString& number) | 115 | void Dialer::dial(const QString& number) |
116 | { | 116 | { |
117 | while(state != state_online) | 117 | while(state != state_online) |
118 | { | 118 | { |
119 | if(!usercancel) | 119 | if(!usercancel) |
120 | { | 120 | { |
121 | state = state_preinit; | 121 | state = state_preinit; |
122 | trydial(number); | 122 | trydial(number); |
123 | } | 123 | } |
124 | else break; | 124 | else break; |
125 | } | 125 | } |
126 | 126 | ||
127 | if(usercancel) | 127 | if(usercancel) |
128 | { | 128 | { |
129 | // modem hangup | 129 | // modem hangup |
130 | trydial(QString::null); | 130 | trydial(QString::null); |
131 | reject(); | 131 | reject(); |
132 | } | 132 | } |
133 | } | 133 | } |
134 | 134 | ||
135 | void Dialer::trydial(const QString& number) | 135 | void Dialer::trydial(const QString& number) |
136 | { | 136 | { |
137 | if(state != state_cancel) switchState(state_preinit); | 137 | if(state != state_cancel) switchState(state_preinit); |
138 | if(cleanshutdown) | 138 | if(cleanshutdown) |
139 | { | 139 | { |
140 | send(m_profile.readEntry("HangupString")); | 140 | send(m_profile.readEntry("HangupString")); |
141 | //send("+++ATH"); | 141 | //send("+++ATH"); |
142 | send(""); | 142 | send(""); |
143 | } | 143 | } |
144 | 144 | ||
145 | if(state != state_cancel) | 145 | if(state != state_cancel) |
146 | { | 146 | { |
147 | switchState(state_init); | 147 | switchState(state_init); |
148 | //send("ATZ"); | 148 | //send("ATZ"); |
149 | send(m_profile.readEntry("InitString")); | 149 | send(m_profile.readEntry("InitString")); |
150 | QString response2 = receive(); | 150 | QString response2 = receive(); |
151 | if(!response2.contains("\nOK\r")) | 151 | if(!response2.contains("\nOK\r")) |
152 | reset(); | 152 | reset(); |
153 | } | 153 | } |
154 | 154 | ||
155 | if(state != state_cancel) | 155 | if(state != state_cancel) |
156 | { | 156 | { |
157 | switchState(state_options); | 157 | switchState(state_options); |
158 | 158 | ||
159 | send("ATM3L3"); | 159 | send("ATM3L3"); |
160 | QString response3 = receive(); | 160 | QString response3 = receive(); |
161 | if(!response3.contains("\nOK\r")) | 161 | if(!response3.contains("\nOK\r")) |
162 | reset(); | 162 | reset(); |
163 | } | 163 | } |
164 | 164 | ||
165 | if(state != state_cancel) | 165 | if(state != state_cancel) |
166 | { | 166 | { |
167 | switchState(state_dialtone); | 167 | switchState(state_dialtone); |
168 | 168 | ||
169 | send("ATX1"); | 169 | send("ATX1"); |
170 | QString response4 = receive(); | 170 | QString response4 = receive(); |
171 | if(!response4.contains("\nOK\r")) | 171 | if(!response4.contains("\nOK\r")) |
172 | reset(); | 172 | reset(); |
173 | } | 173 | } |
174 | 174 | ||
175 | if(state != state_cancel) | 175 | if(state != state_cancel) |
176 | { | 176 | { |
177 | switchState(state_dialing); | 177 | switchState(state_dialing); |
178 | 178 | ||
179 | //send(QString("ATDT %1").arg(number)); | 179 | //send(QString("ATDT %1").arg(number)); |
180 | send(QString("%1 %2").arg(m_profile.readEntry("DialPrefix1")).arg(number)); | 180 | send(QString("%1 %2").arg(m_profile.readEntry("DialPrefix1")).arg(number)); |
181 | QString response5 = receive(); | 181 | QString response5 = receive(); |
182 | if(!response5.contains("\n" + m_profile.readEntry("DefaultConnect"))) | 182 | if(!response5.contains("\n" + m_profile.readEntry("DefaultConnect"))) |
183 | { | 183 | { |
184 | if(response5.contains("BUSY")) | 184 | if(response5.contains("BUSY")) |
185 | switchState(state_dialing); | 185 | switchState(state_dialing); |
186 | else | 186 | else |
187 | { | 187 | { |
188 | QMessageBox::warning(this, | 188 | QMessageBox::warning(this, |
189 | QObject::tr("Failure"), | 189 | QObject::tr("Failure"), |
190 | QObject::tr("Dialing the number failed.")); | 190 | QObject::tr("Dialing the number failed.")); |
191 | slotCancel(); | 191 | slotCancel(); |
192 | } | 192 | } |
193 | } | 193 | } |
194 | } | 194 | } |
195 | 195 | ||
196 | if(state != state_cancel) | 196 | if(state != state_cancel) |
197 | { | 197 | { |
198 | switchState(state_online); | 198 | switchState(state_online); |
199 | } | 199 | } |
200 | } | 200 | } |
201 | 201 | ||
202 | void Dialer::send(const QString& msg) | 202 | void Dialer::send(const QString& msg) |
203 | { | 203 | { |
204 | QString m = msg; | 204 | QString m = msg; |
205 | int bytes; | 205 | int bytes; |
206 | QString termination; | 206 | QString termination; |
207 | 207 | ||
208 | //qWarning("Sending: '%s'", m.latin1()); | 208 | //qWarning("Sending: '%s'", m.latin1()); |
209 | 209 | ||
210 | termination = "\r"; | 210 | termination = "\r"; |
211 | //termination = m_profile.readEntry("Termination"); | 211 | //termination = m_profile.readEntry("Termination"); |
212 | if(termination == "\n") m = m + "\n"; | 212 | if(termination == "\n") m = m + "\n"; |
213 | else if(termination == "\r") m = m + "\r"; | 213 | else if(termination == "\r") m = m + "\r"; |
214 | else m = m + "\r\n"; | 214 | else m = m + "\r\n"; |
215 | 215 | ||
216 | bytes = ::write(m_fd, m.local8Bit(), strlen(m.local8Bit())); | 216 | bytes = ::write(m_fd, m.local8Bit(), strlen(m.local8Bit())); |
217 | if(bytes < 0) | 217 | if(bytes < 0) |
218 | { | 218 | { |
219 | reset(); | 219 | reset(); |
220 | } | 220 | } |
221 | } | 221 | } |
222 | 222 | ||
223 | QString Dialer::receive() | 223 | QString Dialer::receive() |
224 | { | 224 | { |
225 | QString buf; | 225 | QString buf; |
226 | char buffer[1024]; | 226 | char buffer[1024]; |
227 | int ret; | 227 | int ret; |
228 | int counter; | 228 | int counter = 0; |
229 | 229 | ||
230 | while(1) | 230 | while(1) |
231 | { | 231 | { |
232 | ret = ::read(m_fd, buffer, sizeof(buffer)); | 232 | ret = ::read(m_fd, buffer, sizeof(buffer)); |
233 | 233 | ||
234 | if(ret > 0) | 234 | if(ret > 0) |
235 | { | 235 | { |
236 | for(int i = 0; i < ret; i++) | 236 | for(int i = 0; i < ret; i++) |
237 | buffer[i] = buffer[i] & 0x7F; | 237 | buffer[i] = buffer[i] & 0x7F; |
238 | buffer[ret] = 0; | 238 | buffer[ret] = 0; |
239 | //qWarning("Got: '%s'", buffer); | 239 | //qWarning("Got: '%s'", buffer); |
240 | buf.append(QString(buffer)); | 240 | buf.append(QString(buffer)); |
241 | if(buf.contains("OK") || buf.contains("ERROR") || buf.contains("CONNECT") || (buf.contains("BUSY"))) | 241 | if(buf.contains("OK") || buf.contains("ERROR") || buf.contains("CONNECT") || (buf.contains("BUSY"))) |
242 | { | 242 | { |
243 | //qWarning("Receiving: '%s'", buf.latin1()); | 243 | //qWarning("Receiving: '%s'", buf.latin1()); |
244 | cleanshutdown = 1; | 244 | cleanshutdown = 1; |
245 | return buf; | 245 | return buf; |
246 | } | 246 | } |
247 | } | 247 | } |
248 | else if(ret < 0) | 248 | else if(ret < 0) |
249 | { | 249 | { |
250 | if(errno != EAGAIN) reset(); | 250 | if(errno != EAGAIN) reset(); |
251 | else if(!(counter++ % 100)) qApp->processEvents(); | 251 | else if(!(counter++ % 100)) qApp->processEvents(); |
252 | } | 252 | } |
253 | else if(!(counter++ % 100)) qApp->processEvents(); | 253 | else if(!(counter++ % 100)) qApp->processEvents(); |
254 | 254 | ||
255 | if(usercancel) return QString::null; | 255 | if(usercancel) return QString::null; |
256 | } | 256 | } |
257 | 257 | ||
258 | cleanshutdown = 1; | 258 | cleanshutdown = 1; |
259 | return QString::null; | 259 | return QString::null; |
260 | } | 260 | } |
261 | 261 | ||
262 | void Dialer::switchState(int newstate) | 262 | void Dialer::switchState(int newstate) |
263 | { | 263 | { |
264 | int oldstate = state; | 264 | int oldstate = state; |
265 | state = newstate; | 265 | state = newstate; |
266 | 266 | ||
267 | switch(state) | 267 | switch(state) |
268 | { | 268 | { |
269 | case state_cancel: | 269 | case state_cancel: |
270 | status->setText(QObject::tr("Cancelling...")); | 270 | status->setText(QObject::tr("Cancelling...")); |
271 | progress->setProgress(0); | 271 | progress->setProgress(0); |
272 | break; | 272 | break; |
273 | case state_preinit: | 273 | case state_preinit: |
274 | status->setText(QObject::tr("Searching modem")); | 274 | status->setText(QObject::tr("Searching modem")); |
275 | progress->setProgress(10); | 275 | progress->setProgress(10); |
276 | break; | 276 | break; |
277 | case state_init: | 277 | case state_init: |
278 | status->setText(QObject::tr("Initializing...")); | 278 | status->setText(QObject::tr("Initializing...")); |
279 | progress->setProgress(20); | 279 | progress->setProgress(20); |
280 | break; | 280 | break; |
281 | case state_options: | 281 | case state_options: |
282 | status->setText(QObject::tr("Reset speakers")); | 282 | status->setText(QObject::tr("Reset speakers")); |
283 | progress->setProgress(30); | 283 | progress->setProgress(30); |
284 | break; | 284 | break; |
285 | case state_dialtone: | 285 | case state_dialtone: |
286 | status->setText(QObject::tr("Turning off dialtone")); | 286 | status->setText(QObject::tr("Turning off dialtone")); |
287 | progress->setProgress(40); | 287 | progress->setProgress(40); |
288 | break; | 288 | break; |
289 | case state_dialing: | 289 | case state_dialing: |
290 | if(oldstate != state_dialing) status->setText(QObject::tr("Dial number")); | 290 | if(oldstate != state_dialing) status->setText(QObject::tr("Dial number")); |
291 | else status->setText(QObject::tr("Line busy, redialing number")); | 291 | else status->setText(QObject::tr("Line busy, redialing number")); |
292 | progress->setProgress(50); | 292 | progress->setProgress(50); |
293 | break; | 293 | break; |
294 | case state_online: | 294 | case state_online: |
295 | status->setText(QObject::tr("Connection established")); | 295 | status->setText(QObject::tr("Connection established")); |
296 | progress->setProgress(100); | 296 | progress->setProgress(100); |
297 | cancel->setText(QObject::tr("Dismiss")); | 297 | cancel->setText(QObject::tr("Dismiss")); |
298 | break; | 298 | break; |
299 | } | 299 | } |
300 | } | 300 | } |
301 | 301 | ||
diff --git a/noncore/apps/opie-console/dialer.h b/noncore/apps/opie-console/dialer.h index 28303f3..88681a3 100644 --- a/noncore/apps/opie-console/dialer.h +++ b/noncore/apps/opie-console/dialer.h | |||
@@ -1,54 +1,54 @@ | |||
1 | #ifndef DIALER_H | 1 | #ifndef DIALER_H |
2 | #define DIALER_H | 2 | #define DIALER_H |
3 | 3 | ||
4 | #include <qdialog.h> | 4 | #include <qdialog.h> |
5 | 5 | ||
6 | #include "profile.h" | 6 | #include "profile.h" |
7 | 7 | ||
8 | class QLabel; | 8 | class QLabel; |
9 | class QProgressBar; | 9 | class QProgressBar; |
10 | 10 | ||
11 | class Dialer : public QDialog | 11 | class Dialer : public QDialog |
12 | { | 12 | { |
13 | Q_OBJECT | 13 | Q_OBJECT |
14 | public: | 14 | public: |
15 | Dialer(const Profile& profile, int fd, QWidget *parent = NULL, const char *name = NULL); | 15 | Dialer(const Profile& profile, int fd, QWidget *parent = NULL, const char *name = NULL); |
16 | ~Dialer(); | 16 | ~Dialer(); |
17 | void setHangupOnly(); | 17 | void setHangupOnly(); |
18 | 18 | ||
19 | public slots: | 19 | public slots: |
20 | void slotCancel(); | 20 | void slotCancel(); |
21 | void slotAutostart(); | 21 | void slotAutostart(); |
22 | 22 | ||
23 | private: | 23 | private: |
24 | void switchState(int newstate); | 24 | void switchState(int newstate); |
25 | void reset(); | 25 | void reset(); |
26 | void dial(const QString& number); | 26 | void dial(const QString& number); |
27 | void trydial(const QString& number); | 27 | void trydial(const QString& number); |
28 | 28 | ||
29 | void send(const QString& msg); | 29 | void send(const QString& msg); |
30 | QString receive(); | 30 | QString receive(); |
31 | 31 | ||
32 | enum States | 32 | enum States |
33 | { | 33 | { |
34 | state_cancel, | 34 | state_cancel, |
35 | state_preinit, | 35 | state_preinit, |
36 | state_init, | 36 | state_init, |
37 | state_options, | 37 | state_options, |
38 | state_dialtone, | 38 | state_dialtone, |
39 | state_dialing, | 39 | state_dialing, |
40 | state_online | 40 | state_online |
41 | }; | 41 | }; |
42 | 42 | ||
43 | QLabel *status; | 43 | QLabel *status; |
44 | QProgressBar *progress; | 44 | QProgressBar *progress; |
45 | QPushButton *cancel; | 45 | QPushButton *cancel; |
46 | int state; | 46 | int state; |
47 | int usercancel; | 47 | int usercancel; |
48 | int m_fd; | ||
48 | const Profile& m_profile; | 49 | const Profile& m_profile; |
49 | int m_fd; | ||
50 | int cleanshutdown; | 50 | int cleanshutdown; |
51 | }; | 51 | }; |
52 | 52 | ||
53 | #endif | 53 | #endif |
54 | 54 | ||
diff --git a/noncore/apps/opie-console/function_keyboard.cpp b/noncore/apps/opie-console/function_keyboard.cpp index fd20e99..100fdfc 100644 --- a/noncore/apps/opie-console/function_keyboard.cpp +++ b/noncore/apps/opie-console/function_keyboard.cpp | |||
@@ -1,182 +1,182 @@ | |||
1 | #include "function_keyboard.h" | 1 | #include "function_keyboard.h" |
2 | #include <qsizepolicy.h> | 2 | #include <qsizepolicy.h> |
3 | #include <qevent.h> | 3 | #include <qevent.h> |
4 | #include <qwindowsystem_qws.h> | 4 | #include <qwindowsystem_qws.h> |
5 | #include <qapplication.h> | 5 | #include <qapplication.h> |
6 | #include <qlayout.h> | 6 | #include <qlayout.h> |
7 | 7 | ||
8 | FunctionKeyboard::FunctionKeyboard(QWidget *parent) : | 8 | FunctionKeyboard::FunctionKeyboard(QWidget *parent) : |
9 | QFrame(parent), numRows(2), numCols(11), | 9 | QFrame(parent), numRows(2), numCols(11), |
10 | pressedRow(0), pressedCol(0) { | 10 | pressedRow(0), pressedCol(0) { |
11 | 11 | ||
12 | setSizePolicy(QSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::Fixed)); | 12 | setSizePolicy(QSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::Fixed)); |
13 | 13 | ||
14 | Config conf("opie-console-keys"); | 14 | Config conf("opie-console-keys"); |
15 | conf.setGroup("keys"); | 15 | conf.setGroup("keys"); |
16 | for (uint r = 0; r < numRows; r++) | 16 | for (uint r = 0; r < numRows; r++) |
17 | for (uint c = 0; c < numCols; c++) { | 17 | for (uint c = 0; c < numCols; c++) { |
18 | 18 | ||
19 | QString handle = "r" + QString::number(r) + "c" + QString::number(c); | 19 | QString handle = "r" + QString::number(r) + "c" + QString::number(c); |
20 | QStringList value_list = conf.readListEntry( handle, '|'); | 20 | QStringList value_list = conf.readListEntry( handle, '|'); |
21 | 21 | ||
22 | if (value_list.isEmpty()) continue; | 22 | if (value_list.isEmpty()) continue; |
23 | 23 | ||
24 | keys.insert( | 24 | keys.insert( |
25 | 25 | ||
26 | handle, | 26 | handle, |
27 | FKey (value_list[0], value_list[1].toUShort(), value_list[2].toUShort()) | 27 | FKey (value_list[0], value_list[1].toUShort(), value_list[2].toUShort()) |
28 | ); | 28 | ); |
29 | } | 29 | } |
30 | //qWarning("loaded %d keys", keys.count()); | 30 | //qWarning("loaded %d keys", keys.count()); |
31 | if (keys.isEmpty()) loadDefaults(); | 31 | if (keys.isEmpty()) loadDefaults(); |
32 | 32 | ||
33 | 33 | ||
34 | 34 | ||
35 | } | 35 | } |
36 | 36 | ||
37 | FunctionKeyboard::~FunctionKeyboard() { | 37 | FunctionKeyboard::~FunctionKeyboard() { |
38 | 38 | ||
39 | } | 39 | } |
40 | 40 | ||
41 | void FunctionKeyboard::paintEvent(QPaintEvent *e) { | 41 | void FunctionKeyboard::paintEvent(QPaintEvent *e) { |
42 | 42 | ||
43 | QPainter p(this); | 43 | QPainter p(this); |
44 | p.setClipRect(e->rect()); | 44 | p.setClipRect(e->rect()); |
45 | p.fillRect(0, 0, width(), height(), QColor(255,255,255)); | 45 | p.fillRect(0, 0, width(), height(), QColor(255,255,255)); |
46 | 46 | ||
47 | p.setPen(QColor(0,0,0)); | 47 | p.setPen(QColor(0,0,0)); |
48 | 48 | ||
49 | /* those decimals do count! becomes short if use plain int */ | 49 | /* those decimals do count! becomes short if use plain int */ |
50 | for (double i = 0; i <= width(); i += keyWidth) { | 50 | for (double i = 0; i <= width(); i += keyWidth) { |
51 | 51 | ||
52 | p.drawLine((int)i, 0, (int)i, height()); | 52 | p.drawLine((int)i, 0, (int)i, height()); |
53 | } | 53 | } |
54 | 54 | ||
55 | // sometimes the last line doesnt get drawn | 55 | // sometimes the last line doesnt get drawn |
56 | p.drawLine(width() -1, 0, width() -1, height()); | 56 | p.drawLine(width() -1, 0, width() -1, height()); |
57 | 57 | ||
58 | for (int i = 0; i <= height(); i += keyHeight) { | 58 | for (int i = 0; i <= height(); i += keyHeight) { |
59 | 59 | ||
60 | p.drawLine(0, i, width(), i); | 60 | p.drawLine(0, i, width(), i); |
61 | } | 61 | } |
62 | 62 | ||
63 | for (uint r = 0; r < numRows; r++) { | 63 | for (uint r = 0; r < numRows; r++) { |
64 | for (uint c = 0; c < numCols; c++) { | 64 | for (uint c = 0; c < numCols; c++) { |
65 | 65 | ||
66 | QString handle = "r" + QString::number(r) + "c" + QString::number(c); | 66 | QString handle = "r" + QString::number(r) + "c" + QString::number(c); |
67 | if (keys.contains(handle)) { | 67 | if (keys.contains(handle)) { |
68 | 68 | ||
69 | p.drawText( | 69 | p.drawText( |
70 | c * keyWidth + 1, r * keyHeight + 1, | 70 | c * keyWidth + 1, r * keyHeight + 1, |
71 | keyWidth, keyHeight, | 71 | keyWidth, keyHeight, |
72 | Qt::AlignHCenter | Qt::AlignVCenter, | 72 | Qt::AlignHCenter | Qt::AlignVCenter, |
73 | keys[handle].getL() | 73 | keys[handle].getL() |
74 | ); | 74 | ); |
75 | } | 75 | } |
76 | } | 76 | } |
77 | } | 77 | } |
78 | } | 78 | } |
79 | 79 | ||
80 | void FunctionKeyboard::paintKey(int row, int col) { | 80 | void FunctionKeyboard::paintKey(int row, int col) { |
81 | 81 | ||
82 | QPainter p(this); | 82 | QPainter p(this); |
83 | 83 | ||
84 | p.fillRect(QRect(QPoint(col * keyWidth + 1, row * keyHeight + 1), | 84 | p.fillRect(QRect(QPoint(col * keyWidth + 1, row * keyHeight + 1), |
85 | QPoint((col + 1) * keyWidth - 1, row * keyHeight + keyHeight- 1)), | 85 | QPoint((col + 1) * keyWidth - 1, row * keyHeight + keyHeight- 1)), |
86 | (pressedRow != -1 && pressedCol != -1 ) ? QColor(97,119,155) : QColor(255,255,255)); | 86 | (pressedRow != -1 && pressedCol != -1 ) ? QColor(97,119,155) : QColor(255,255,255)); |
87 | p.drawText( | 87 | p.drawText( |
88 | col * keyWidth + 1, row * keyHeight + 1, | 88 | col * keyWidth + 1, row * keyHeight + 1, |
89 | keyWidth, keyHeight, | 89 | keyWidth, keyHeight, |
90 | Qt::AlignHCenter | Qt::AlignVCenter, | 90 | Qt::AlignHCenter | Qt::AlignVCenter, |
91 | keys["r" + QString::number(row) + "c" + QString::number(col)].getL() | 91 | keys["r" + QString::number(row) + "c" + QString::number(col)].getL() |
92 | ); | 92 | ); |
93 | 93 | ||
94 | } | 94 | } |
95 | 95 | ||
96 | void FunctionKeyboard::mousePressEvent(QMouseEvent *e) { | 96 | void FunctionKeyboard::mousePressEvent(QMouseEvent *e) { |
97 | 97 | ||
98 | pressedRow = e->y() / keyHeight; | 98 | pressedRow = e->y() / keyHeight; |
99 | pressedCol = (int) (e->x() / keyWidth); | 99 | pressedCol = (int) (e->x() / keyWidth); |
100 | 100 | ||
101 | paintKey(pressedRow, pressedCol); | 101 | paintKey(pressedRow, pressedCol); |
102 | 102 | ||
103 | // emit that sucker! | 103 | // emit that sucker! |
104 | FKey k = keys["r" + QString::number(pressedRow) + "c" + QString::number(pressedCol)]; | 104 | FKey k = keys["r" + QString::number(pressedRow) + "c" + QString::number(pressedCol)]; |
105 | emit keyPressed(k.getU(), k.getQ(), 0, 1, 0); | 105 | emit keyPressed(k.getU(), k.getQ(), 0, 1, 0); |
106 | 106 | ||
107 | } | 107 | } |
108 | 108 | ||
109 | void FunctionKeyboard::mouseReleaseEvent(QMouseEvent *) { | 109 | void FunctionKeyboard::mouseReleaseEvent(QMouseEvent *) { |
110 | 110 | ||
111 | if (pressedRow != -1 && pressedRow != -1) { | 111 | if (pressedRow != -1 && pressedRow != -1) { |
112 | 112 | ||
113 | int row = pressedRow; pressedRow = -1; | 113 | int row = pressedRow; pressedRow = -1; |
114 | int col = pressedCol; pressedCol = -1; | 114 | int col = pressedCol; pressedCol = -1; |
115 | paintKey(row, col); | 115 | paintKey(row, col); |
116 | 116 | ||
117 | FKey k = keys["r" + QString::number(row) + "c" + QString::number(col)]; | 117 | FKey k = keys["r" + QString::number(row) + "c" + QString::number(col)]; |
118 | emit keyPressed(k.getU(), k.getQ(), 0, 0, 0); | 118 | emit keyPressed(k.getU(), k.getQ(), 0, 0, 0); |
119 | } | 119 | } |
120 | 120 | ||
121 | } | 121 | } |
122 | 122 | ||
123 | 123 | ||
124 | void FunctionKeyboard::resizeEvent(QResizeEvent*) { | 124 | void FunctionKeyboard::resizeEvent(QResizeEvent*) { |
125 | 125 | ||
126 | /* set he default font height/width */ | 126 | /* set he default font height/width */ |
127 | QFontMetrics fm=fontMetrics(); | 127 | QFontMetrics fm=fontMetrics(); |
128 | keyHeight = fm.lineSpacing() + 2; | 128 | keyHeight = fm.lineSpacing() + 2; |
129 | keyWidth = (double)width()/numCols; | 129 | keyWidth = (double)width()/numCols; |
130 | 130 | ||
131 | } | 131 | } |
132 | 132 | ||
133 | QSize FunctionKeyboard::sizeHint() const { | 133 | QSize FunctionKeyboard::sizeHint() const { |
134 | 134 | ||
135 | return QSize(width(), keyHeight * numRows + 1); | 135 | return QSize(width(), keyHeight * numRows + 1); |
136 | } | 136 | } |
137 | 137 | ||
138 | void FunctionKeyboard::loadDefaults() { | 138 | void FunctionKeyboard::loadDefaults() { |
139 | 139 | ||
140 | /* what keys should be default? */ | 140 | /* what keys should be default? */ |
141 | keys.insert( "r0c0", FKey ("F1", 4144, 0)); | 141 | keys.insert( "r0c0", FKey ("F1", 4144, 0)); |
142 | keys.insert( "r0c1", FKey ("F2", 4145, 0)); | 142 | keys.insert( "r0c1", FKey ("F2", 4145, 0)); |
143 | keys.insert( "r0c2", FKey ("F3", 4145, 0)); | 143 | keys.insert( "r0c2", FKey ("F3", 4145, 0)); |
144 | keys.insert( "r0c3", FKey ("F4", 4146, 0)); | 144 | keys.insert( "r0c3", FKey ("F4", 4146, 0)); |
145 | keys.insert( "r0c4", FKey ("F5", 4147, 0)); | 145 | keys.insert( "r0c4", FKey ("F5", 4147, 0)); |
146 | keys.insert( "r0c5", FKey ("F6", 4148, 0)); | 146 | keys.insert( "r0c5", FKey ("F6", 4148, 0)); |
147 | keys.insert( "r0c6", FKey ("F7", 4149, 0)); | 147 | keys.insert( "r0c6", FKey ("F7", 4149, 0)); |
148 | keys.insert( "r0c7", FKey ("F8", 4150, 0)); | 148 | keys.insert( "r0c7", FKey ("F8", 4150, 0)); |
149 | keys.insert( "r0c8", FKey ("F9", 4151, 0)); | 149 | keys.insert( "r0c8", FKey ("F9", 4151, 0)); |
150 | keys.insert( "r0c9", FKey ("F10", 4152, 0)); | 150 | keys.insert( "r0c9", FKey ("F10", 4152, 0)); |
151 | keys.insert( "r0c10", FKey ("F11", 4153, 0)); | 151 | keys.insert( "r0c10", FKey ("F11", 4153, 0)); |
152 | 152 | ||
153 | keys.insert( "r1c7", FKey ("Ho", 4112, 0)); | 153 | keys.insert( "r1c7", FKey ("Ho", 4112, 0)); |
154 | keys.insert( "r1c8", FKey ("End", 4113, 0)); | 154 | keys.insert( "r1c8", FKey ("End", 4113, 0)); |
155 | keys.insert( "r1c9", FKey ("PU", 4118, 0)); | 155 | keys.insert( "r1c9", FKey ("PU", 4118, 0)); |
156 | keys.insert( "r1c10", FKey ("PD", 4119, 0)); | 156 | keys.insert( "r1c10", FKey ("PD", 4119, 0)); |
157 | 157 | ||
158 | } | 158 | } |
159 | 159 | ||
160 | 160 | ||
161 | FunctionKeyboardConfig::FunctionKeyboardConfig(const QString& name, QWidget* parent) : | 161 | FunctionKeyboardConfig::FunctionKeyboardConfig(const QString& name, QWidget* parent) : |
162 | ProfileDialogKeyWidget(name, parent) { | 162 | ProfileDialogKeyWidget(name, parent) { |
163 | 163 | ||
164 | 164 | ||
165 | FunctionKeyboard *kb = new FunctionKeyboard(this); | 165 | FunctionKeyboard *kb = new FunctionKeyboard(this); |
166 | QGroupBox *dimentions = new QGroupBox(2, Qt::Horizontal, tr("Dimentions"), this); | 166 | QGroupBox *dimentions = new QGroupBox(2, Qt::Horizontal, tr("Dimentions"), this); |
167 | QGroupBox *editKey = new QGroupBox(2, Qt::Horizontal, tr("Edit"), this); | 167 | QGroupBox *editKey = new QGroupBox(2, Qt::Horizontal, tr("Edit"), this); |
168 | 168 | ||
169 | QVBoxLayout *root = new QVBoxLayout(this, 2); | 169 | QVBoxLayout *root = new QVBoxLayout(this, 2); |
170 | root->addWidget(kb); | 170 | root->addWidget(kb); |
171 | root->addWidget(dimentions); | 171 | root->addWidget(dimentions); |
172 | root->addWidget(editKey); | 172 | root->addWidget(editKey); |
173 | } | 173 | } |
174 | FunctionKeyboardConfig::~FunctionKeyboardConfig() { | 174 | FunctionKeyboardConfig::~FunctionKeyboardConfig() { |
175 | 175 | ||
176 | } | 176 | } |
177 | void FunctionKeyboardConfig::load (const Profile& prof) { | 177 | void FunctionKeyboardConfig::load (const Profile& ) { |
178 | 178 | ||
179 | } | 179 | } |
180 | void FunctionKeyboardConfig::save (Profile& prof) { | 180 | void FunctionKeyboardConfig::save (Profile& ) { |
181 | 181 | ||
182 | } | 182 | } |
diff --git a/noncore/apps/opie-console/io_modem.cpp b/noncore/apps/opie-console/io_modem.cpp index f246d81..d4ea0b2 100644 --- a/noncore/apps/opie-console/io_modem.cpp +++ b/noncore/apps/opie-console/io_modem.cpp | |||
@@ -1,89 +1,91 @@ | |||
1 | 1 | ||
2 | #include "io_modem.h" | 2 | #include "io_modem.h" |
3 | 3 | ||
4 | #include "dialer.h" | 4 | #include "dialer.h" |
5 | 5 | ||
6 | IOModem::IOModem( const Profile &profile ) | 6 | IOModem::IOModem( const Profile &profile ) |
7 | : IOSerial( profile ) { | 7 | : IOSerial( profile ) { |
8 | m_profile = profile; | 8 | m_profile = profile; |
9 | } | 9 | } |
10 | 10 | ||
11 | 11 | ||
12 | IOModem::~IOModem() { | 12 | IOModem::~IOModem() { |
13 | 13 | ||
14 | } | 14 | } |
15 | 15 | ||
16 | 16 | ||
17 | void IOModem::close() { | 17 | void IOModem::close() { |
18 | // Hangup, discarding result | 18 | // Hangup, discarding result |
19 | int fd = rawIO(); | 19 | int fd = rawIO(); |
20 | Dialer d(m_profile, fd); | 20 | Dialer d(m_profile, fd); |
21 | d.setHangupOnly(); | 21 | d.setHangupOnly(); |
22 | d.exec(); | 22 | d.exec(); |
23 | closeRawIO(fd); | 23 | closeRawIO(fd); |
24 | 24 | ||
25 | IOSerial::close(); | 25 | IOSerial::close(); |
26 | } | 26 | } |
27 | 27 | ||
28 | bool IOModem::open() { | 28 | bool IOModem::open() { |
29 | bool ret = IOSerial::open(); | 29 | bool ret = IOSerial::open(); |
30 | if(!ret) return false; | 30 | if(!ret) return false; |
31 | 31 | ||
32 | int fd = rawIO(); | 32 | int fd = rawIO(); |
33 | Dialer d(m_profile, fd); | 33 | Dialer d(m_profile, fd); |
34 | 34 | ||
35 | int result = d.exec(); | 35 | int result = d.exec(); |
36 | closeRawIO(fd); | 36 | closeRawIO(fd); |
37 | if(result == QDialog::Accepted) | 37 | if(result == QDialog::Accepted) |
38 | { | 38 | { |
39 | return true; | 39 | return true; |
40 | } | 40 | } |
41 | else | 41 | else |
42 | { | 42 | { |
43 | close(); | 43 | close(); |
44 | return false; | 44 | return false; |
45 | } | 45 | } |
46 | } | 46 | } |
47 | 47 | ||
48 | void IOModem::reload( const Profile &config ) { | 48 | void IOModem::reload( const Profile &config ) { |
49 | 49 | ||
50 | m_device = config.readEntry("Device", MODEM_DEFAULT_DEVICE); | 50 | m_device = config.readEntry("Device", MODEM_DEFAULT_DEVICE); |
51 | m_baud = config.readNumEntry("Baud", MODEM_DEFAULT_BAUD); | 51 | m_baud = config.readNumEntry("Baud", MODEM_DEFAULT_BAUD); |
52 | m_parity = config.readNumEntry("Parity", MODEM_DEFAULT_PARITY); | 52 | m_parity = config.readNumEntry("Parity", MODEM_DEFAULT_PARITY); |
53 | m_dbits = config.readNumEntry("DataBits", MODEM_DEFAULT_DBITS); | 53 | m_dbits = config.readNumEntry("DataBits", MODEM_DEFAULT_DBITS); |
54 | m_sbits = config.readNumEntry("StopBits", MODEM_DEFAULT_SBITS); | 54 | m_sbits = config.readNumEntry("StopBits", MODEM_DEFAULT_SBITS); |
55 | m_flow = config.readNumEntry("Flow", MODEM_DEFAULT_FLOW); | 55 | m_flow = config.readNumEntry("Flow", MODEM_DEFAULT_FLOW); |
56 | 56 | ||
57 | m_initString = config.readEntry("InitString", MODEM_DEFAULT_INIT_STRING ); | 57 | m_initString = config.readEntry("InitString", MODEM_DEFAULT_INIT_STRING ); |
58 | m_resetString = config.readEntry("ResetString", MODEM_DEFAULT_RESET_STRING ); | 58 | m_resetString = config.readEntry("ResetString", MODEM_DEFAULT_RESET_STRING ); |
59 | m_dialPref1 = config.readEntry("DialPrefix1", MODEM_DEFAULT_DIAL_PREFIX1 ); | 59 | m_dialPref1 = config.readEntry("DialPrefix1", MODEM_DEFAULT_DIAL_PREFIX1 ); |
60 | m_dialSuf1 = config.readEntry("DialSuffix1", MODEM_DEFAULT_DIAL_SUFFIX1 ); | 60 | m_dialSuf1 = config.readEntry("DialSuffix1", MODEM_DEFAULT_DIAL_SUFFIX1 ); |
61 | m_dialPref2 = config.readEntry("DialPrefix2", MODEM_DEFAULT_DIAL_PREFIX1 ); | 61 | m_dialPref2 = config.readEntry("DialPrefix2", MODEM_DEFAULT_DIAL_PREFIX1 ); |
62 | m_dialSuf2 = config.readEntry("DialSuffix2", MODEM_DEFAULT_DIAL_SUFFIX1 ); | 62 | m_dialSuf2 = config.readEntry("DialSuffix2", MODEM_DEFAULT_DIAL_SUFFIX1 ); |
63 | m_dialPref3 = config.readEntry("DialPrefix3", MODEM_DEFAULT_DIAL_PREFIX1 ); | 63 | m_dialPref3 = config.readEntry("DialPrefix3", MODEM_DEFAULT_DIAL_PREFIX1 ); |
64 | m_dialSuf3 = config.readEntry("DialSuffix3", MODEM_DEFAULT_DIAL_SUFFIX1 ); | 64 | m_dialSuf3 = config.readEntry("DialSuffix3", MODEM_DEFAULT_DIAL_SUFFIX1 ); |
65 | m_connect = config.readEntry("DefaultConnect" MODEM_DEFAULT_CONNECT_STRING ); | 65 | m_connect = config.readEntry("DefaultConnect" MODEM_DEFAULT_CONNECT_STRING ); |
66 | m_hangup = config.readEntry("HangupString", MODEM_DEFAULT_HANGUP_STRING ); | 66 | m_hangup = config.readEntry("HangupString", MODEM_DEFAULT_HANGUP_STRING ); |
67 | m_cancel = config.readEntry("CancelString", MODEM_DEFAULT_CANCEL_STRING ); | 67 | m_cancel = config.readEntry("CancelString", MODEM_DEFAULT_CANCEL_STRING ); |
68 | m_dialTime = config.readNumEntry("DialTime", MODEM_DEFAULT_DIAL_TIME ); | 68 | m_dialTime = config.readNumEntry("DialTime", MODEM_DEFAULT_DIAL_TIME ); |
69 | m_delayRedial = config.readNumEntry("DelayRedial", MODEM_DEFAULT_DELAY_REDIAL ); | 69 | m_delayRedial = config.readNumEntry("DelayRedial", MODEM_DEFAULT_DELAY_REDIAL ); |
70 | m_numberTries = config.readNumEntry("NumberTries", MODEM_DEFAULT_NUMBER_TRIES ); | 70 | m_numberTries = config.readNumEntry("NumberTries", MODEM_DEFAULT_NUMBER_TRIES ); |
71 | m_dtrDropTime = config.readNumEntry("DTRDRopTime", MODEM_DEFAULT_DTR_DROP_TIME ); | 71 | m_dtrDropTime = config.readNumEntry("DTRDRopTime", MODEM_DEFAULT_DTR_DROP_TIME ); |
72 | m_bpsDetect = config.readBoolEntry("BPSDetect", MODEM_DEFAULT_BPS_DETECT ); | 72 | m_bpsDetect = config.readBoolEntry("BPSDetect", MODEM_DEFAULT_BPS_DETECT ); |
73 | m_dcdLines = config.readBoolEntry("DCDLines", MODEM_DEFAULT_DCD_LINES ); | 73 | m_dcdLines = config.readBoolEntry("DCDLines", MODEM_DEFAULT_DCD_LINES ); |
74 | m_multiLineUntag = config.readBoolEntry("MultiLineUntag", MODEM_DEFAULT_MULTI_LINE_UNTAG ); | 74 | m_multiLineUntag = config.readBoolEntry("MultiLineUntag", MODEM_DEFAULT_MULTI_LINE_UNTAG ); |
75 | } | 75 | } |
76 | 76 | ||
77 | 77 | ||
78 | QString IOModem::identifier() const { | 78 | QString IOModem::identifier() const { |
79 | return "modem"; | 79 | return "modem"; |
80 | } | 80 | } |
81 | 81 | ||
82 | QString IOModem::name() const { | 82 | QString IOModem::name() const { |
83 | return "Modem IO Layer"; | 83 | return "Modem IO Layer"; |
84 | } | 84 | } |
85 | 85 | ||
86 | void IOModem::slotExited(OProcess* proc ){ | 86 | void IOModem::slotExited(OProcess* proc ){ |
87 | close(); | 87 | close(); |
88 | /* delete it afterwards */ | ||
89 | delete proc; | ||
88 | } | 90 | } |
89 | 91 | ||
diff --git a/noncore/apps/opie-console/iolayerbase.cpp b/noncore/apps/opie-console/iolayerbase.cpp index b0df02d..47f9e76 100644 --- a/noncore/apps/opie-console/iolayerbase.cpp +++ b/noncore/apps/opie-console/iolayerbase.cpp | |||
@@ -1,167 +1,169 @@ | |||
1 | #include <qlabel.h> | 1 | #include <qlabel.h> |
2 | #include <qlayout.h> | 2 | #include <qlayout.h> |
3 | #include <qcombobox.h> | 3 | #include <qcombobox.h> |
4 | #include <qbuttongroup.h> | 4 | #include <qbuttongroup.h> |
5 | #include <qhbuttongroup.h> | 5 | #include <qhbuttongroup.h> |
6 | #include <qradiobutton.h> | 6 | #include <qradiobutton.h> |
7 | 7 | ||
8 | #include "iolayerbase.h" | 8 | #include "iolayerbase.h" |
9 | 9 | ||
10 | namespace { | 10 | namespace { |
11 | enum ParityIds { | 11 | enum ParityIds { |
12 | id_parity_none, | 12 | id_parity_none, |
13 | id_parity_odd, | 13 | id_parity_odd, |
14 | id_parity_even | 14 | id_parity_even |
15 | }; | 15 | }; |
16 | 16 | ||
17 | enum FlowIds { | 17 | enum FlowIds { |
18 | id_flow_hw, | 18 | id_flow_hw, |
19 | id_flow_sw, | 19 | id_flow_sw, |
20 | id_flow_none, | 20 | id_flow_none, |
21 | }; | 21 | }; |
22 | 22 | ||
23 | enum SpeedIds { | 23 | enum SpeedIds { |
24 | id_baud_115200, | 24 | id_baud_115200, |
25 | id_baud_57600, | 25 | id_baud_57600, |
26 | id_baud_38400, | 26 | id_baud_38400, |
27 | id_baud_19200, | 27 | id_baud_19200, |
28 | id_baud_9600 | 28 | id_baud_9600 |
29 | }; | 29 | }; |
30 | 30 | ||
31 | } | 31 | } |
32 | 32 | ||
33 | 33 | ||
34 | IOLayerBase::IOLayerBase( QWidget* par, const char* name ) | 34 | IOLayerBase::IOLayerBase( QWidget* par, const char* name ) |
35 | : QWidget( par, name ) | 35 | : QWidget( par, name ) |
36 | { | 36 | { |
37 | m_speedLabel = new QLabel(tr("Speed"), this ); | 37 | m_speedLabel = new QLabel(tr("Speed"), this ); |
38 | m_speedBox = new QComboBox(this ); | 38 | m_speedBox = new QComboBox(this ); |
39 | 39 | ||
40 | m_groupFlow = new QButtonGroup(tr("Flow control"),this ); | 40 | m_groupFlow = new QButtonGroup(tr("Flow control"),this ); |
41 | m_flowHw = new QRadioButton(tr("Hardware"), m_groupFlow ); | 41 | m_flowHw = new QRadioButton(tr("Hardware"), m_groupFlow ); |
42 | m_flowSw = new QRadioButton(tr("Software"), m_groupFlow ); | 42 | m_flowSw = new QRadioButton(tr("Software"), m_groupFlow ); |
43 | m_flowNone = new QRadioButton( tr("None"), m_groupFlow ); | 43 | m_flowNone = new QRadioButton( tr("None"), m_groupFlow ); |
44 | 44 | ||
45 | m_groupParity = new QButtonGroup(tr("Parity"), this ); | 45 | m_groupParity = new QButtonGroup(tr("Parity"), this ); |
46 | m_parityNone = new QRadioButton(tr("None"), m_groupParity ); | 46 | m_parityNone = new QRadioButton(tr("None"), m_groupParity ); |
47 | m_parityOdd = new QRadioButton(tr("Odd"), m_groupParity ); | 47 | m_parityOdd = new QRadioButton(tr("Odd"), m_groupParity ); |
48 | m_parityEven = new QRadioButton(tr("Even"), m_groupParity ); | 48 | m_parityEven = new QRadioButton(tr("Even"), m_groupParity ); |
49 | 49 | ||
50 | m_lroot = new QVBoxLayout( this ); | 50 | m_lroot = new QVBoxLayout( this ); |
51 | m_lroot->add(m_speedLabel ); | 51 | m_lroot->add(m_speedLabel ); |
52 | m_lroot->add(m_speedBox ); | 52 | m_lroot->add(m_speedBox ); |
53 | m_lroot->setStretchFactor(m_speedLabel, 1); | 53 | m_lroot->setStretchFactor(m_speedLabel, 1); |
54 | m_lroot->setStretchFactor(m_speedBox, 1 ); | 54 | m_lroot->setStretchFactor(m_speedBox, 1 ); |
55 | 55 | ||
56 | m_hbox = new QHBoxLayout(m_groupFlow, 2 ); | 56 | m_hbox = new QHBoxLayout(m_groupFlow, 2 ); |
57 | m_hbox->add(m_flowHw ); | 57 | m_hbox->add(m_flowHw ); |
58 | m_hbox->add(m_flowSw ); | 58 | m_hbox->add(m_flowSw ); |
59 | m_hbox->add(m_flowNone ); | 59 | m_hbox->add(m_flowNone ); |
60 | m_lroot->add(m_groupFlow ); | 60 | m_lroot->add(m_groupFlow ); |
61 | m_lroot->setStretchFactor(m_groupFlow, 2 ); | 61 | m_lroot->setStretchFactor(m_groupFlow, 2 ); |
62 | 62 | ||
63 | m_hboxPar = new QHBoxLayout( m_groupParity, 2 ); | 63 | m_hboxPar = new QHBoxLayout( m_groupParity, 2 ); |
64 | m_hboxPar->add(m_parityOdd ); | 64 | m_hboxPar->add(m_parityOdd ); |
65 | m_hboxPar->add(m_parityEven ); | 65 | m_hboxPar->add(m_parityEven ); |
66 | m_hboxPar->add(m_parityNone ); | 66 | m_hboxPar->add(m_parityNone ); |
67 | m_lroot->add(m_groupParity ); | 67 | m_lroot->add(m_groupParity ); |
68 | m_lroot->setStretchFactor(m_groupParity, 2 ); | 68 | m_lroot->setStretchFactor(m_groupParity, 2 ); |
69 | m_lroot->addStretch(2); | 69 | m_lroot->addStretch(2); |
70 | 70 | ||
71 | // profiles | 71 | // profiles |
72 | m_speedBox->insertItem(tr("115200 baud"), id_baud_115200 ); | 72 | m_speedBox->insertItem(tr("115200 baud"), id_baud_115200 ); |
73 | m_speedBox->insertItem(tr("57600 baud"), id_baud_57600 ); | 73 | m_speedBox->insertItem(tr("57600 baud"), id_baud_57600 ); |
74 | m_speedBox->insertItem(tr("38400 baud"), id_baud_38400 ); | 74 | m_speedBox->insertItem(tr("38400 baud"), id_baud_38400 ); |
75 | m_speedBox->insertItem(tr("19200 baud"), id_baud_19200 ); | 75 | m_speedBox->insertItem(tr("19200 baud"), id_baud_19200 ); |
76 | m_speedBox->insertItem(tr("9600 baud"), id_baud_9600 ); | 76 | m_speedBox->insertItem(tr("9600 baud"), id_baud_9600 ); |
77 | 77 | ||
78 | }; | 78 | }; |
79 | IOLayerBase::~IOLayerBase() { | 79 | IOLayerBase::~IOLayerBase() { |
80 | 80 | ||
81 | } | 81 | } |
82 | void IOLayerBase::setFlow( Flow flo ) { | 82 | void IOLayerBase::setFlow( Flow flo ) { |
83 | switch ( flo ) { | 83 | switch ( flo ) { |
84 | case Software: | 84 | case Software: |
85 | m_flowSw->setChecked( true ); | 85 | m_flowSw->setChecked( true ); |
86 | break; | 86 | break; |
87 | case Hardware: | 87 | case Hardware: |
88 | m_flowHw->setChecked( true ); | 88 | m_flowHw->setChecked( true ); |
89 | break; | 89 | break; |
90 | case None: | 90 | case None: |
91 | m_flowNone->setChecked( true ); | 91 | m_flowNone->setChecked( true ); |
92 | break; | 92 | break; |
93 | } | 93 | } |
94 | } | 94 | } |
95 | 95 | ||
96 | void IOLayerBase::setParity( Parity par ) { | 96 | void IOLayerBase::setParity( Parity par ) { |
97 | switch( par ) { | 97 | switch( par ) { |
98 | case NonePar: | 98 | case NonePar: |
99 | m_parityNone->setChecked( true ); | 99 | m_parityNone->setChecked( true ); |
100 | break; | 100 | break; |
101 | case Odd: | 101 | case Odd: |
102 | m_parityOdd->setChecked( true ); | 102 | m_parityOdd->setChecked( true ); |
103 | break; | 103 | break; |
104 | case Even: | 104 | case Even: |
105 | m_parityEven->setChecked( true ); | 105 | m_parityEven->setChecked( true ); |
106 | break; | 106 | break; |
107 | } | 107 | } |
108 | } | 108 | } |
109 | void IOLayerBase::setSpeed( Speed sp ) { | 109 | void IOLayerBase::setSpeed( Speed sp ) { |
110 | int index; | 110 | int index = -1; |
111 | switch( sp ) { | 111 | switch( sp ) { |
112 | case Baud_115200: | 112 | case Baud_115200: |
113 | index = id_baud_115200; | 113 | index = id_baud_115200; |
114 | break; | 114 | break; |
115 | case Baud_57600: | 115 | case Baud_57600: |
116 | index = id_baud_57600; | 116 | index = id_baud_57600; |
117 | break; | 117 | break; |
118 | case Baud_38400: | 118 | case Baud_38400: |
119 | index = id_baud_38400; | 119 | index = id_baud_38400; |
120 | break; | 120 | break; |
121 | case Baud_19200: | 121 | case Baud_19200: |
122 | index = id_baud_19200; | 122 | index = id_baud_19200; |
123 | break; | 123 | break; |
124 | default: | ||
124 | case Baud_9600: | 125 | case Baud_9600: |
125 | index = id_baud_9600; | 126 | index = id_baud_9600; |
126 | break; | 127 | break; |
127 | } | 128 | } |
128 | m_speedBox->setCurrentItem(index ); | 129 | m_speedBox->setCurrentItem(index ); |
129 | } | 130 | } |
130 | IOLayerBase::Flow IOLayerBase::flow()const { | 131 | IOLayerBase::Flow IOLayerBase::flow()const { |
131 | if (m_flowHw->isChecked() ) { | 132 | if (m_flowHw->isChecked() ) { |
132 | return Hardware; | 133 | return Hardware; |
133 | }else if( m_flowSw->isChecked() ) { | 134 | }else if( m_flowSw->isChecked() ) { |
134 | return Software; | 135 | return Software; |
135 | } else { | 136 | } else { |
136 | return None; | 137 | return None; |
137 | } | 138 | } |
138 | } | 139 | } |
139 | IOLayerBase::Parity IOLayerBase::parity()const { | 140 | IOLayerBase::Parity IOLayerBase::parity()const { |
140 | if ( m_parityOdd->isChecked() ) { | 141 | if ( m_parityOdd->isChecked() ) { |
141 | return Odd; | 142 | return Odd; |
142 | } else if ( m_parityEven->isChecked() ) { | 143 | } else if ( m_parityEven->isChecked() ) { |
143 | return Even; | 144 | return Even; |
144 | } else { | 145 | } else { |
145 | return NonePar; | 146 | return NonePar; |
146 | } | 147 | } |
147 | 148 | ||
148 | } | 149 | } |
149 | IOLayerBase::Speed IOLayerBase::speed()const{ | 150 | IOLayerBase::Speed IOLayerBase::speed()const{ |
150 | switch( m_speedBox->currentItem() ) { | 151 | switch( m_speedBox->currentItem() ) { |
151 | case id_baud_115200: | 152 | case id_baud_115200: |
152 | return Baud_115200; | 153 | return Baud_115200; |
153 | break; | 154 | break; |
154 | case id_baud_57600: | 155 | case id_baud_57600: |
155 | return Baud_57600; | 156 | return Baud_57600; |
156 | break; | 157 | break; |
157 | case id_baud_38400: | 158 | case id_baud_38400: |
158 | return Baud_38400; | 159 | return Baud_38400; |
159 | break; | 160 | break; |
160 | case id_baud_19200: | 161 | case id_baud_19200: |
161 | return Baud_19200; | 162 | return Baud_19200; |
162 | break; | 163 | break; |
164 | default: | ||
163 | case id_baud_9600: | 165 | case id_baud_9600: |
164 | return Baud_9600; | 166 | return Baud_9600; |
165 | break; | 167 | break; |
166 | } | 168 | } |
167 | } | 169 | } |
diff --git a/noncore/apps/opie-console/irdaconfigwidget.cpp b/noncore/apps/opie-console/irdaconfigwidget.cpp index 72e99a1..059530d 100644 --- a/noncore/apps/opie-console/irdaconfigwidget.cpp +++ b/noncore/apps/opie-console/irdaconfigwidget.cpp | |||
@@ -1,146 +1,148 @@ | |||
1 | #include <qlabel.h> | 1 | #include <qlabel.h> |
2 | #include <qlayout.h> | 2 | #include <qlayout.h> |
3 | #include <qcombobox.h> | 3 | #include <qcombobox.h> |
4 | 4 | ||
5 | #include "iolayerbase.h" | 5 | #include "iolayerbase.h" |
6 | #include "irdaconfigwidget.h" | 6 | #include "irdaconfigwidget.h" |
7 | 7 | ||
8 | namespace { | 8 | namespace { |
9 | void setCurrent( const QString& str, QComboBox* bo ) { | 9 | void setCurrent( const QString& str, QComboBox* bo ) { |
10 | uint b = bo->count(); | 10 | uint b = bo->count(); |
11 | for (uint i = 0; i < bo->count(); i++ ) { | 11 | for (int i = 0; i < bo->count(); i++ ) { |
12 | if ( bo->text(i) == str ) { | 12 | if ( bo->text(i) == str ) { |
13 | bo->setCurrentItem( i ); | 13 | bo->setCurrentItem( i ); |
14 | return; | 14 | return; |
15 | } | 15 | } |
16 | } | 16 | } |
17 | bo->insertItem( str ); | 17 | bo->insertItem( str ); |
18 | bo->setCurrentItem( b ); | 18 | bo->setCurrentItem( b ); |
19 | } | 19 | } |
20 | 20 | ||
21 | 21 | ||
22 | } | 22 | } |
23 | 23 | ||
24 | IrdaConfigWidget::IrdaConfigWidget( const QString& name, | 24 | IrdaConfigWidget::IrdaConfigWidget( const QString& name, |
25 | QWidget* parent, | 25 | QWidget* parent, |
26 | const char* na ) | 26 | const char* na ) |
27 | : ProfileDialogConnectionWidget( name, parent, na ) { | 27 | : ProfileDialogConnectionWidget( name, parent, na ) { |
28 | 28 | ||
29 | m_lay = new QVBoxLayout(this ); | 29 | m_lay = new QVBoxLayout(this ); |
30 | m_device = new QLabel(tr("Device"), this ); | 30 | m_device = new QLabel(tr("Device"), this ); |
31 | m_deviceCmb = new QComboBox(this ); | 31 | m_deviceCmb = new QComboBox(this ); |
32 | m_deviceCmb->setEditable( TRUE ); | 32 | m_deviceCmb->setEditable( TRUE ); |
33 | 33 | ||
34 | m_base = new IOLayerBase(this, "base"); | 34 | m_base = new IOLayerBase(this, "base"); |
35 | 35 | ||
36 | m_lay->addWidget( m_device ); | 36 | m_lay->addWidget( m_device ); |
37 | m_lay->addWidget( m_deviceCmb ); | 37 | m_lay->addWidget( m_deviceCmb ); |
38 | m_lay->addWidget( m_base ); | 38 | m_lay->addWidget( m_base ); |
39 | 39 | ||
40 | m_deviceCmb->insertItem( "/dev/ircomm0" ); | 40 | m_deviceCmb->insertItem( "/dev/ircomm0" ); |
41 | m_deviceCmb->insertItem( "/dev/ircomm1" ); | 41 | m_deviceCmb->insertItem( "/dev/ircomm1" ); |
42 | } | 42 | } |
43 | 43 | ||
44 | IrdaConfigWidget::~IrdaConfigWidget() { | 44 | IrdaConfigWidget::~IrdaConfigWidget() { |
45 | 45 | ||
46 | } | 46 | } |
47 | void IrdaConfigWidget::load( const Profile& prof ) { | 47 | void IrdaConfigWidget::load( const Profile& prof ) { |
48 | int rad_flow = prof.readNumEntry("Flow"); | 48 | int rad_flow = prof.readNumEntry("Flow"); |
49 | int rad_parity = prof.readNumEntry("Parity"); | 49 | int rad_parity = prof.readNumEntry("Parity"); |
50 | int speed = prof.readNumEntry("Speed"); | 50 | int speed = prof.readNumEntry("Speed"); |
51 | 51 | ||
52 | if (rad_flow == 1) { | 52 | if (rad_flow == 1) { |
53 | m_base->setFlow( IOLayerBase::Hardware ); | 53 | m_base->setFlow( IOLayerBase::Hardware ); |
54 | } else if (rad_flow == 2) { | 54 | } else if (rad_flow == 2) { |
55 | m_base->setFlow( IOLayerBase::Software ); | 55 | m_base->setFlow( IOLayerBase::Software ); |
56 | } else { | 56 | } else { |
57 | m_base->setFlow( IOLayerBase::None ); | 57 | m_base->setFlow( IOLayerBase::None ); |
58 | } | 58 | } |
59 | 59 | ||
60 | if (rad_parity == 1) { | 60 | if (rad_parity == 1) { |
61 | m_base->setParity( IOLayerBase::Even ); | 61 | m_base->setParity( IOLayerBase::Even ); |
62 | } else if ( rad_parity == 2 ) { | 62 | } else if ( rad_parity == 2 ) { |
63 | m_base->setParity( IOLayerBase::Odd ); | 63 | m_base->setParity( IOLayerBase::Odd ); |
64 | } else { | 64 | } else { |
65 | m_base->setParity( IOLayerBase::NonePar ); | 65 | m_base->setParity( IOLayerBase::NonePar ); |
66 | } | 66 | } |
67 | 67 | ||
68 | switch( speed ) { | 68 | switch( speed ) { |
69 | case 115200: | 69 | case 115200: |
70 | m_base->setSpeed(IOLayerBase::Baud_115200 ); | 70 | m_base->setSpeed(IOLayerBase::Baud_115200 ); |
71 | break; | 71 | break; |
72 | case 57600: | 72 | case 57600: |
73 | m_base->setSpeed( IOLayerBase::Baud_57600 ); | 73 | m_base->setSpeed( IOLayerBase::Baud_57600 ); |
74 | break; | 74 | break; |
75 | case 38400: | 75 | case 38400: |
76 | m_base->setSpeed(IOLayerBase::Baud_38400 ); | 76 | m_base->setSpeed(IOLayerBase::Baud_38400 ); |
77 | break; | 77 | break; |
78 | case 19200: | 78 | case 19200: |
79 | m_base->setSpeed( IOLayerBase::Baud_19200 ); | 79 | m_base->setSpeed( IOLayerBase::Baud_19200 ); |
80 | break; | 80 | break; |
81 | case 9600: | 81 | case 9600: |
82 | default: | 82 | default: |
83 | m_base->setSpeed(IOLayerBase::Baud_9600 ); | 83 | m_base->setSpeed(IOLayerBase::Baud_9600 ); |
84 | break; | 84 | break; |
85 | } | 85 | } |
86 | 86 | ||
87 | if ( prof.readEntry("Device").isEmpty() ) return; | 87 | if ( prof.readEntry("Device").isEmpty() ) return; |
88 | setCurrent( prof.readEntry("Device"), m_deviceCmb ); | 88 | setCurrent( prof.readEntry("Device"), m_deviceCmb ); |
89 | 89 | ||
90 | } | 90 | } |
91 | /* | 91 | /* |
92 | * save speed, | 92 | * save speed, |
93 | * flow, | 93 | * flow, |
94 | * parity | 94 | * parity |
95 | */ | 95 | */ |
96 | void IrdaConfigWidget::save( Profile& prof ) { | 96 | void IrdaConfigWidget::save( Profile& prof ) { |
97 | int flow, parity, speed; | 97 | int flow, parity, speed; |
98 | flow = parity = speed = 0; | ||
98 | prof.writeEntry("Device", m_deviceCmb->currentText() ); | 99 | prof.writeEntry("Device", m_deviceCmb->currentText() ); |
99 | 100 | ||
100 | switch( m_base->flow() ) { | 101 | switch( m_base->flow() ) { |
101 | case IOLayerBase::None: | 102 | case IOLayerBase::None: |
102 | flow = 0; | 103 | flow = 0; |
103 | break; | 104 | break; |
104 | case IOLayerBase::Software: | 105 | case IOLayerBase::Software: |
105 | flow = 2; | 106 | flow = 2; |
106 | break; | 107 | break; |
107 | case IOLayerBase::Hardware: | 108 | case IOLayerBase::Hardware: |
108 | flow = 1; | 109 | flow = 1; |
109 | break; | 110 | break; |
110 | } | 111 | } |
111 | 112 | ||
112 | 113 | ||
113 | switch( m_base->parity() ) { | 114 | switch( m_base->parity() ) { |
114 | case IOLayerBase::Odd: | 115 | case IOLayerBase::Odd: |
115 | parity = 2; | 116 | parity = 2; |
116 | break; | 117 | break; |
117 | case IOLayerBase::Even: | 118 | case IOLayerBase::Even: |
118 | parity = 1; | 119 | parity = 1; |
119 | break; | 120 | break; |
120 | case IOLayerBase::NonePar: | 121 | case IOLayerBase::NonePar: |
121 | parity = 0; | 122 | parity = 0; |
122 | break; | 123 | break; |
123 | } | 124 | } |
124 | 125 | ||
125 | switch( m_base->speed() ) { | 126 | switch( m_base->speed() ) { |
126 | case IOLayerBase::Baud_115200: | 127 | case IOLayerBase::Baud_115200: |
127 | speed = 115200; | 128 | speed = 115200; |
128 | break; | 129 | break; |
129 | case IOLayerBase::Baud_57600: | 130 | case IOLayerBase::Baud_57600: |
130 | speed = 57600; | 131 | speed = 57600; |
131 | break; | 132 | break; |
132 | case IOLayerBase::Baud_38400: | 133 | case IOLayerBase::Baud_38400: |
133 | speed = 38400; | 134 | speed = 38400; |
134 | break; | 135 | break; |
135 | case IOLayerBase::Baud_19200: | 136 | case IOLayerBase::Baud_19200: |
136 | speed = 19200; | 137 | speed = 19200; |
137 | break; | 138 | break; |
139 | default: | ||
138 | case IOLayerBase::Baud_9600: | 140 | case IOLayerBase::Baud_9600: |
139 | speed = 9600; | 141 | speed = 9600; |
140 | break; | 142 | break; |
141 | } | 143 | } |
142 | 144 | ||
143 | prof.writeEntry("Flow", flow); | 145 | prof.writeEntry("Flow", flow); |
144 | prof.writeEntry("Parity", parity); | 146 | prof.writeEntry("Parity", parity); |
145 | prof.writeEntry("Speed", speed); | 147 | prof.writeEntry("Speed", speed); |
146 | } | 148 | } |
diff --git a/noncore/apps/opie-console/main.cpp b/noncore/apps/opie-console/main.cpp index 78a91a2..7f9f038 100644 --- a/noncore/apps/opie-console/main.cpp +++ b/noncore/apps/opie-console/main.cpp | |||
@@ -1,113 +1,114 @@ | |||
1 | #include <sys/types.h> | 1 | #include <sys/types.h> |
2 | 2 | ||
3 | #include <stdio.h> | 3 | #include <stdio.h> |
4 | #include <stdlib.h> | 4 | #include <stdlib.h> |
5 | #include <signal.h> | 5 | #include <signal.h> |
6 | 6 | ||
7 | #include <qfile.h> | 7 | #include <qfile.h> |
8 | 8 | ||
9 | #include <qpe/qpeapplication.h> | 9 | #include <qpe/qpeapplication.h> |
10 | 10 | ||
11 | #include "mainwindow.h" | 11 | #include "mainwindow.h" |
12 | 12 | ||
13 | //#define FSCKED_DISTRIBUTION 1 | 13 | //#define FSCKED_DISTRIBUTION 1 |
14 | #ifdef FSCKED_DISTRIBUTION | 14 | #ifdef FSCKED_DISTRIBUTION |
15 | /* | 15 | /* |
16 | * The Zaurus rom | 16 | * The Zaurus rom |
17 | */ | 17 | */ |
18 | class FixIt { | 18 | class FixIt { |
19 | public: | 19 | public: |
20 | FixIt(); | 20 | FixIt(); |
21 | ~FixIt(); | 21 | ~FixIt(); |
22 | void fixIt(); | 22 | void fixIt(); |
23 | /* no real interested in implementing it */ | 23 | /* no real interested in implementing it */ |
24 | void breakIt() { | 24 | void breakIt() { |
25 | 25 | ||
26 | }; | 26 | }; |
27 | char* m_file; | 27 | char* m_file; |
28 | }; | 28 | }; |
29 | 29 | ||
30 | FixIt::FixIt() { | 30 | FixIt::FixIt() { |
31 | /* the new inittab */ | 31 | /* the new inittab */ |
32 | m_file = "#\n# /etc/inittab | 32 | m_file = "#\n# /etc/inittab |
33 | # | 33 | # |
34 | 34 | ||
35 | # 0 - halt (Do NOT set initdefault to this) | 35 | # 0 - halt (Do NOT set initdefault to this) |
36 | # 1 - Single user mode | 36 | # 1 - Single user mode |
37 | # 2 - Multiuser, without NFS (The same as 3, if you do not have networking) | 37 | # 2 - Multiuser, without NFS (The same as 3, if you do not have networking) |
38 | # 3 - Full multiuser mode | 38 | # 3 - Full multiuser mode |
39 | # 4 - JavaVM(Intent) developer mode | 39 | # 4 - JavaVM(Intent) developer mode |
40 | # 5 - JavaVM(Intent) | 40 | # 5 - JavaVM(Intent) |
41 | # 6 - reboot (Do NOT set initdefault to this) | 41 | # 6 - reboot (Do NOT set initdefault to this) |
42 | # | 42 | # |
43 | id:5:initdefault: | 43 | id:5:initdefault: |
44 | 44 | ||
45 | # Specify things to do when starting | 45 | # Specify things to do when starting |
46 | si::sysinit:/etc/rc.d/rc.sysinit | 46 | si::sysinit:/etc/rc.d/rc.sysinit |
47 | 47 | ||
48 | l0:0:wait:/root/etc/rc.d/rc 0 | 48 | l0:0:wait:/root/etc/rc.d/rc 0 |
49 | l1:1:wait:/etc/rc.d/rc 1 | 49 | l1:1:wait:/etc/rc.d/rc 1 |
50 | l2:2:wait:/etc/rc.d/rc 2 | 50 | l2:2:wait:/etc/rc.d/rc 2 |
51 | l3:3:wait:/etc/rc.d/rc 3 | 51 | l3:3:wait:/etc/rc.d/rc 3 |
52 | l4:4:wait:/etc/rc.d/rc 4 | 52 | l4:4:wait:/etc/rc.d/rc 4 |
53 | l5:5:wait:/etc/rc.d/rc 5 | 53 | l5:5:wait:/etc/rc.d/rc 5 |
54 | l6:6:wait:/root/etc/rc.d/rc 6 | 54 | l6:6:wait:/root/etc/rc.d/rc 6 |
55 | 55 | ||
56 | # Specify things to do before rebooting | 56 | # Specify things to do before rebooting |
57 | um::ctrlaltdel:/bin/umount -a -r > /dev/null 2>&1 | 57 | um::ctrlaltdel:/bin/umount -a -r > /dev/null 2>&1 |
58 | sw::ctrlaltdel:/sbin/swapoff -a > /dev/null 2>&1 | 58 | sw::ctrlaltdel:/sbin/swapoff -a > /dev/null 2>&1 |
59 | 59 | ||
60 | # Specify program to run on ttyS0 | 60 | # Specify program to run on ttyS0 |
61 | s0:24:respawn:/sbin/getty 9600 ttyS0 | 61 | s0:24:respawn:/sbin/getty 9600 ttyS0 |
62 | #pd:5:respawn:/etc/sync/serialctl | 62 | #pd:5:respawn:/etc/sync/serialctl |
63 | 63 | ||
64 | # Specify program to run on tty1 | 64 | # Specify program to run on tty1 |
65 | 1:2:respawn:/sbin/getty 9600 tty1 | 65 | 1:2:respawn:/sbin/getty 9600 tty1 |
66 | ln:345:respawn:survive -l 6 /sbin/launch | 66 | ln:345:respawn:survive -l 6 /sbin/launch |
67 | #qt:5:respawn:/sbin/qt | 67 | #qt:5:respawn:/sbin/qt |
68 | 68 | ||
69 | # collie sp. | 69 | # collie sp. |
70 | sy::respawn:/sbin/shsync\n"; | 70 | sy::respawn:/sbin/shsync\n"; |
71 | 71 | ||
72 | 72 | ||
73 | } | 73 | } |
74 | FixIt::~FixIt() { | 74 | FixIt::~FixIt() { |
75 | } | 75 | } |
76 | /* | 76 | /* |
77 | * the retail Zaurus is broken in many ways | 77 | * the retail Zaurus is broken in many ways |
78 | * one is that pppd is listening on our port... | 78 | * one is that pppd is listening on our port... |
79 | * we've to stop it from that and then do kill(SIGHUP,1); | 79 | * we've to stop it from that and then do kill(SIGHUP,1); |
80 | */ | 80 | */ |
81 | void FixIt::fixIt() { | 81 | void FixIt::fixIt() { |
82 | ::rename("/etc/inittab", QPEApplication::qpeDir() + "/etc/inittab" ); | 82 | ::rename("/etc/inittab", QPEApplication::qpeDir() + "/etc/inittab" ); |
83 | QFile file( "/etc/inittab" ); | 83 | QFile file( "/etc/inittab" ); |
84 | if ( file.open(IO_WriteOnly | IO_Raw ) ) { | 84 | if ( file.open(IO_WriteOnly | IO_Raw ) ) { |
85 | file.writeBlock(m_file,strlen(m_file) ); | 85 | file.writeBlock(m_file,strlen(m_file) ); |
86 | } | 86 | } |
87 | file.close(); | 87 | file.close(); |
88 | ::kill( SIGHUP, 1 ); | 88 | ::kill( SIGHUP, 1 ); |
89 | } | 89 | } |
90 | #endif | 90 | #endif |
91 | 91 | ||
92 | 92 | ||
93 | int main(int argc, char **argv) { | 93 | int main(int argc, char **argv) { |
94 | argv[0]="embeddedkonsole"; | ||
94 | QPEApplication app( argc, argv ); | 95 | QPEApplication app( argc, argv ); |
95 | 96 | ||
96 | #ifdef FSCKED_DISTRIBUTION | 97 | #ifdef FSCKED_DISTRIBUTION |
97 | qWarning("fscked"); | 98 | qWarning("fscked"); |
98 | FixIt it; | 99 | FixIt it; |
99 | it.fixIt(); | 100 | it.fixIt(); |
100 | #endif | 101 | #endif |
101 | 102 | ||
102 | MainWindow mw; | 103 | MainWindow mw; |
103 | mw.setCaption(QObject::tr("Opie console") ); | 104 | mw.setCaption(QObject::tr("Opie console") ); |
104 | app.showMainWidget( &mw ); | 105 | app.showMainWidget( &mw ); |
105 | 106 | ||
106 | int ap = app.exec(); | 107 | int ap = app.exec(); |
107 | 108 | ||
108 | #ifdef FSCKED_DISTRIBUTION | 109 | #ifdef FSCKED_DISTRIBUTION |
109 | /* should add a signal handler too */ | 110 | /* should add a signal handler too */ |
110 | it.breakIt(); | 111 | it.breakIt(); |
111 | #endif | 112 | #endif |
112 | return ap; | 113 | return ap; |
113 | } | 114 | } |
diff --git a/noncore/apps/opie-console/modemconfigwidget.cpp b/noncore/apps/opie-console/modemconfigwidget.cpp index d3a23fa..c37fafd 100644 --- a/noncore/apps/opie-console/modemconfigwidget.cpp +++ b/noncore/apps/opie-console/modemconfigwidget.cpp | |||
@@ -1,200 +1,201 @@ | |||
1 | #include <qlabel.h> | 1 | #include <qlabel.h> |
2 | #include <qlayout.h> | 2 | #include <qlayout.h> |
3 | #include <qcombobox.h> | 3 | #include <qcombobox.h> |
4 | #include <qlineedit.h> | 4 | #include <qlineedit.h> |
5 | #include <qpushbutton.h> | 5 | #include <qpushbutton.h> |
6 | #include <qhbox.h> | 6 | #include <qhbox.h> |
7 | #include <qregexp.h> | 7 | #include <qregexp.h> |
8 | 8 | ||
9 | #include "modemconfigwidget.h" | 9 | #include "modemconfigwidget.h" |
10 | #include "dialdialog.h" | 10 | #include "dialdialog.h" |
11 | 11 | ||
12 | namespace { | 12 | namespace { |
13 | void setCurrent( const QString& str, QComboBox* bo ) { | 13 | void setCurrent( const QString& str, QComboBox* bo ) { |
14 | uint b = bo->count(); | 14 | uint b = bo->count(); |
15 | for (uint i = 0; i < bo->count(); i++ ) { | 15 | for (int i = 0; i < bo->count(); i++ ) { |
16 | if ( bo->text(i) == str ) { | 16 | if ( bo->text(i) == str ) { |
17 | bo->setCurrentItem( i ); | 17 | bo->setCurrentItem( i ); |
18 | return; | 18 | return; |
19 | } | 19 | } |
20 | } | 20 | } |
21 | bo->insertItem( str ); | 21 | bo->insertItem( str ); |
22 | bo->setCurrentItem( b ); | 22 | bo->setCurrentItem( b ); |
23 | } | 23 | } |
24 | } | 24 | } |
25 | 25 | ||
26 | ModemConfigWidget::ModemConfigWidget( const QString& name, QWidget* parent, | 26 | ModemConfigWidget::ModemConfigWidget( const QString& name, QWidget* parent, |
27 | const char* na ) | 27 | const char* na ) |
28 | : ProfileDialogConnectionWidget( name, parent, na ) { | 28 | : ProfileDialogConnectionWidget( name, parent, na ) { |
29 | 29 | ||
30 | m_lay = new QVBoxLayout( this ); | 30 | m_lay = new QVBoxLayout( this ); |
31 | m_device = new QLabel(tr( "Modem is attached to:" ), this ); | 31 | m_device = new QLabel(tr( "Modem is attached to:" ), this ); |
32 | m_deviceCmb = new QComboBox(this ); | 32 | m_deviceCmb = new QComboBox(this ); |
33 | m_deviceCmb->setEditable( TRUE ); | 33 | m_deviceCmb->setEditable( TRUE ); |
34 | 34 | ||
35 | QLabel* telLabel = new QLabel( this ); | 35 | QLabel* telLabel = new QLabel( this ); |
36 | telLabel->setText( tr( "Enter telefon number here:" ) ); | 36 | telLabel->setText( tr( "Enter telefon number here:" ) ); |
37 | m_telNumber = new QLineEdit( this ); | 37 | m_telNumber = new QLineEdit( this ); |
38 | QHBox *buttonBox = new QHBox( this ); | 38 | QHBox *buttonBox = new QHBox( this ); |
39 | QPushButton *atButton = new QPushButton( buttonBox ); | 39 | QPushButton *atButton = new QPushButton( buttonBox ); |
40 | atButton->setText( tr( "AT commands" ) ); | 40 | atButton->setText( tr( "AT commands" ) ); |
41 | connect( atButton, SIGNAL( clicked() ), this, SLOT( slotAT() ) ); | 41 | connect( atButton, SIGNAL( clicked() ), this, SLOT( slotAT() ) ); |
42 | 42 | ||
43 | QPushButton *dialButton = new QPushButton( buttonBox ); | 43 | QPushButton *dialButton = new QPushButton( buttonBox ); |
44 | dialButton->setText( tr( "Enter number" ) ); | 44 | dialButton->setText( tr( "Enter number" ) ); |
45 | connect( dialButton, SIGNAL( clicked() ), this, SLOT( slotDial() ) ); | 45 | connect( dialButton, SIGNAL( clicked() ), this, SLOT( slotDial() ) ); |
46 | 46 | ||
47 | 47 | ||
48 | m_base = new IOLayerBase( this, "base" ); | 48 | m_base = new IOLayerBase( this, "base" ); |
49 | 49 | ||
50 | m_lay->addWidget( m_device ); | 50 | m_lay->addWidget( m_device ); |
51 | m_lay->addWidget( m_deviceCmb ); | 51 | m_lay->addWidget( m_deviceCmb ); |
52 | m_lay->addWidget( telLabel ); | 52 | m_lay->addWidget( telLabel ); |
53 | m_lay->addWidget( m_telNumber ); | 53 | m_lay->addWidget( m_telNumber ); |
54 | m_lay->addWidget( buttonBox ); | 54 | m_lay->addWidget( buttonBox ); |
55 | m_lay->addWidget( m_base ); | 55 | m_lay->addWidget( m_base ); |
56 | 56 | ||
57 | m_deviceCmb->insertItem( "/dev/ttyS0" ); | 57 | m_deviceCmb->insertItem( "/dev/ttyS0" ); |
58 | m_deviceCmb->insertItem( "/dev/ttyS1" ); | 58 | m_deviceCmb->insertItem( "/dev/ttyS1" ); |
59 | m_deviceCmb->insertItem( "/dev/ttyS2" ); | 59 | m_deviceCmb->insertItem( "/dev/ttyS2" ); |
60 | 60 | ||
61 | atConf = new ATConfigDialog( this, "ATConfig", true ); | 61 | atConf = new ATConfigDialog( this, "ATConfig", true ); |
62 | } | 62 | } |
63 | 63 | ||
64 | ModemConfigWidget::~ModemConfigWidget() { | 64 | ModemConfigWidget::~ModemConfigWidget() { |
65 | 65 | ||
66 | } | 66 | } |
67 | void ModemConfigWidget::load( const Profile& prof ) { | 67 | void ModemConfigWidget::load( const Profile& prof ) { |
68 | 68 | ||
69 | int rad_flow = prof.readNumEntry( "Flow" ); | 69 | int rad_flow = prof.readNumEntry( "Flow" ); |
70 | int rad_parity = prof.readNumEntry( "Parity" ); | 70 | int rad_parity = prof.readNumEntry( "Parity" ); |
71 | int speed = prof.readNumEntry( "Speed" ); | 71 | int speed = prof.readNumEntry( "Speed" ); |
72 | QString number = prof.readEntry( "Number" ); | 72 | QString number = prof.readEntry( "Number" ); |
73 | 73 | ||
74 | if ( !number.isEmpty() ) { | 74 | if ( !number.isEmpty() ) { |
75 | m_telNumber->setText( number ); | 75 | m_telNumber->setText( number ); |
76 | } | 76 | } |
77 | 77 | ||
78 | if ( rad_flow == 1 ) { | 78 | if ( rad_flow == 1 ) { |
79 | m_base->setFlow( IOLayerBase::Hardware ); | 79 | m_base->setFlow( IOLayerBase::Hardware ); |
80 | } else if (rad_flow == 2) { | 80 | } else if (rad_flow == 2) { |
81 | m_base->setFlow( IOLayerBase::Software ); | 81 | m_base->setFlow( IOLayerBase::Software ); |
82 | } else if (rad_flow == 0) { | 82 | } else if (rad_flow == 0) { |
83 | m_base->setFlow( IOLayerBase::None ); | 83 | m_base->setFlow( IOLayerBase::None ); |
84 | } | 84 | } |
85 | 85 | ||
86 | 86 | ||
87 | if ( rad_parity == 1 ) { | 87 | if ( rad_parity == 1 ) { |
88 | m_base->setParity( IOLayerBase::Even ); | 88 | m_base->setParity( IOLayerBase::Even ); |
89 | } else if ( rad_parity == 2 ){ | 89 | } else if ( rad_parity == 2 ){ |
90 | m_base->setParity( IOLayerBase::Odd ); | 90 | m_base->setParity( IOLayerBase::Odd ); |
91 | } else { | 91 | } else { |
92 | m_base->setParity( IOLayerBase::NonePar ); | 92 | m_base->setParity( IOLayerBase::NonePar ); |
93 | } | 93 | } |
94 | 94 | ||
95 | switch( speed ) { | 95 | switch( speed ) { |
96 | case 115200: | 96 | case 115200: |
97 | m_base->setSpeed( IOLayerBase::Baud_115200 ); | 97 | m_base->setSpeed( IOLayerBase::Baud_115200 ); |
98 | break; | 98 | break; |
99 | case 57600: | 99 | case 57600: |
100 | m_base->setSpeed( IOLayerBase::Baud_57600 ); | 100 | m_base->setSpeed( IOLayerBase::Baud_57600 ); |
101 | break; | 101 | break; |
102 | case 38400: | 102 | case 38400: |
103 | m_base->setSpeed( IOLayerBase::Baud_38400 ); | 103 | m_base->setSpeed( IOLayerBase::Baud_38400 ); |
104 | break; | 104 | break; |
105 | case 19200: | 105 | case 19200: |
106 | m_base->setSpeed( IOLayerBase::Baud_19200 ); | 106 | m_base->setSpeed( IOLayerBase::Baud_19200 ); |
107 | break; | 107 | break; |
108 | case 9600: | 108 | case 9600: |
109 | default: | 109 | default: |
110 | m_base->setSpeed( IOLayerBase::Baud_9600 ); | 110 | m_base->setSpeed( IOLayerBase::Baud_9600 ); |
111 | break; | 111 | break; |
112 | } | 112 | } |
113 | 113 | ||
114 | if ( prof.readEntry( "Device" ).isEmpty() ) { | 114 | if ( prof.readEntry( "Device" ).isEmpty() ) { |
115 | return; | 115 | return; |
116 | } | 116 | } |
117 | setCurrent( prof.readEntry( "Device" ), m_deviceCmb ); | 117 | setCurrent( prof.readEntry( "Device" ), m_deviceCmb ); |
118 | 118 | ||
119 | atConf->readConfig( prof ); | 119 | atConf->readConfig( prof ); |
120 | } | 120 | } |
121 | 121 | ||
122 | /* | 122 | /* |
123 | * save speed, | 123 | * save speed, |
124 | * flow, | 124 | * flow, |
125 | * parity | 125 | * parity |
126 | */ | 126 | */ |
127 | void ModemConfigWidget::save( Profile& prof ) { | 127 | void ModemConfigWidget::save( Profile& prof ) { |
128 | int flow, parity, speed; | 128 | int flow, parity, speed; |
129 | flow = parity = speed = 0; | ||
129 | prof.writeEntry( "Device", m_deviceCmb->currentText() ); | 130 | prof.writeEntry( "Device", m_deviceCmb->currentText() ); |
130 | 131 | ||
131 | 132 | ||
132 | switch( m_base->flow() ) { | 133 | switch( m_base->flow() ) { |
133 | case IOLayerBase::None: | 134 | case IOLayerBase::None: |
134 | flow = 0; | 135 | flow = 0; |
135 | break; | 136 | break; |
136 | case IOLayerBase::Software: | 137 | case IOLayerBase::Software: |
137 | flow = 2; | 138 | flow = 2; |
138 | break; | 139 | break; |
139 | case IOLayerBase::Hardware: | 140 | case IOLayerBase::Hardware: |
140 | flow = 1; | 141 | flow = 1; |
141 | break; | 142 | break; |
142 | } | 143 | } |
143 | 144 | ||
144 | switch( m_base->parity() ) { | 145 | switch( m_base->parity() ) { |
145 | case IOLayerBase::Odd: | 146 | case IOLayerBase::Odd: |
146 | parity = 2; | 147 | parity = 2; |
147 | break; | 148 | break; |
148 | case IOLayerBase::Even: | 149 | case IOLayerBase::Even: |
149 | parity = 1; | 150 | parity = 1; |
150 | break; | 151 | break; |
151 | case IOLayerBase::NonePar: | 152 | case IOLayerBase::NonePar: |
152 | parity = 0; | 153 | parity = 0; |
153 | break; | 154 | break; |
154 | } | 155 | } |
155 | 156 | ||
156 | switch( m_base->speed() ) { | 157 | switch( m_base->speed() ) { |
157 | case IOLayerBase::Baud_115200: | 158 | case IOLayerBase::Baud_115200: |
158 | speed = 115200; | 159 | speed = 115200; |
159 | break; | 160 | break; |
160 | case IOLayerBase::Baud_57600: | 161 | case IOLayerBase::Baud_57600: |
161 | speed = 57600; | 162 | speed = 57600; |
162 | break; | 163 | break; |
163 | case IOLayerBase::Baud_38400: | 164 | case IOLayerBase::Baud_38400: |
164 | speed = 38400; | 165 | speed = 38400; |
165 | break; | 166 | break; |
166 | case IOLayerBase::Baud_19200: | 167 | case IOLayerBase::Baud_19200: |
167 | speed = 19200; | 168 | speed = 19200; |
168 | break; | 169 | break; |
169 | case IOLayerBase::Baud_9600: | 170 | case IOLayerBase::Baud_9600: |
170 | speed = 9600; | 171 | speed = 9600; |
171 | break; | 172 | break; |
172 | } | 173 | } |
173 | 174 | ||
174 | prof.writeEntry( "Flow", flow ); | 175 | prof.writeEntry( "Flow", flow ); |
175 | prof.writeEntry( "Parity", parity ); | 176 | prof.writeEntry( "Parity", parity ); |
176 | prof.writeEntry( "Speed", speed ); | 177 | prof.writeEntry( "Speed", speed ); |
177 | prof.writeEntry( "Number", m_telNumber->text() ); | 178 | prof.writeEntry( "Number", m_telNumber->text() ); |
178 | 179 | ||
179 | 180 | ||
180 | atConf->writeConfig(prof); | 181 | atConf->writeConfig(prof); |
181 | } | 182 | } |
182 | 183 | ||
183 | void ModemConfigWidget::slotAT() { | 184 | void ModemConfigWidget::slotAT() { |
184 | // ATConfigDialog conf( this, "ATConfig", true ); | 185 | // ATConfigDialog conf( this, "ATConfig", true ); |
185 | atConf->showMaximized(); | 186 | atConf->showMaximized(); |
186 | if ( atConf->exec() != QDialog::Accepted ) { | 187 | if ( atConf->exec() != QDialog::Accepted ) { |
187 | // reload old settings | 188 | // reload old settings |
188 | } | 189 | } |
189 | } | 190 | } |
190 | 191 | ||
191 | void ModemConfigWidget::slotDial() { | 192 | void ModemConfigWidget::slotDial() { |
192 | DialDialog dial( this, "DialConfig", true ); | 193 | DialDialog dial( this, "DialConfig", true ); |
193 | if(!m_telNumber->text().isEmpty()) { | 194 | if(!m_telNumber->text().isEmpty()) { |
194 | dial.setNumber(m_telNumber->text().replace(QRegExp("[\\-\\/\\ \\.\\,]"), "")); | 195 | dial.setNumber(m_telNumber->text().replace(QRegExp("[\\-\\/\\ \\.\\,]"), "")); |
195 | } | 196 | } |
196 | dial.showMaximized(); | 197 | dial.showMaximized(); |
197 | if ( dial.exec() == QDialog::Accepted ) { | 198 | if ( dial.exec() == QDialog::Accepted ) { |
198 | m_telNumber->setText( dial.number() ); | 199 | m_telNumber->setText( dial.number() ); |
199 | } | 200 | } |
200 | } | 201 | } |
diff --git a/noncore/apps/opie-console/procctl.cpp b/noncore/apps/opie-console/procctl.cpp index ff6bea8..a44529b 100644 --- a/noncore/apps/opie-console/procctl.cpp +++ b/noncore/apps/opie-console/procctl.cpp | |||
@@ -1,96 +1,97 @@ | |||
1 | #include <sys/wait.h> | 1 | #include <sys/wait.h> |
2 | 2 | ||
3 | #include <fcntl.h> | 3 | #include <fcntl.h> |
4 | #include <unistd.h> | 4 | #include <unistd.h> |
5 | 5 | ||
6 | #include "procctl.h" | 6 | #include "procctl.h" |
7 | 7 | ||
8 | ProcContainer *ProcCtl::m_last = 0; | 8 | ProcContainer *ProcCtl::m_last = 0; |
9 | ProcCtl* ProcCtl::m_self = 0; | 9 | ProcCtl* ProcCtl::m_self = 0; |
10 | 10 | ||
11 | ProcCtl::ProcCtl() { | 11 | ProcCtl::ProcCtl() { |
12 | signal( SIGCHLD, signal_handler ); | 12 | signal( SIGCHLD, signal_handler ); |
13 | } | 13 | } |
14 | ProcCtl::~ProcCtl() { | 14 | ProcCtl::~ProcCtl() { |
15 | } | 15 | } |
16 | ProcCtl* ProcCtl::self() { | 16 | ProcCtl* ProcCtl::self() { |
17 | if (!m_self ) { | 17 | if (!m_self ) { |
18 | m_self = new ProcCtl; | 18 | m_self = new ProcCtl; |
19 | } | 19 | } |
20 | return m_self; | ||
20 | } | 21 | } |
21 | void ProcCtl::add(pid_t pi, int fd ) { | 22 | void ProcCtl::add(pid_t pi, int fd ) { |
22 | ProcContainer * con = new ProcContainer; | 23 | ProcContainer * con = new ProcContainer; |
23 | //memset(con, 0, sizeof(con) ); | 24 | //memset(con, 0, sizeof(con) ); |
24 | con->pid = pi; | 25 | con->pid = pi; |
25 | con->fd = fd; | 26 | con->fd = fd; |
26 | con->status = 0; | 27 | con->status = 0; |
27 | con->prev = m_last; | 28 | con->prev = m_last; |
28 | 29 | ||
29 | m_last = con; | 30 | m_last = con; |
30 | 31 | ||
31 | } | 32 | } |
32 | void ProcCtl::remove( pid_t pi ) { | 33 | void ProcCtl::remove( pid_t pi ) { |
33 | /* | 34 | /* |
34 | * We first check if the last item | 35 | * We first check if the last item |
35 | * is equal to pi the we | 36 | * is equal to pi the we |
36 | * | 37 | * |
37 | */ | 38 | */ |
38 | ProcContainer* con; | 39 | ProcContainer* con; |
39 | if (m_last->pid == pi ) { | 40 | if (m_last->pid == pi ) { |
40 | con = m_last; | 41 | con = m_last; |
41 | m_last = con->prev; | 42 | m_last = con->prev; |
42 | delete con; | 43 | delete con; |
43 | return; | 44 | return; |
44 | } | 45 | } |
45 | 46 | ||
46 | con = m_last; | 47 | con = m_last; |
47 | ProcContainer* forw = 0l; | 48 | ProcContainer* forw = 0l; |
48 | while (con ) { | 49 | while (con ) { |
49 | /* remove it */ | 50 | /* remove it */ |
50 | if ( pi == con->pid ) { | 51 | if ( pi == con->pid ) { |
51 | forw->prev = con->prev; | 52 | forw->prev = con->prev; |
52 | delete con; | 53 | delete con; |
53 | return; | 54 | return; |
54 | } | 55 | } |
55 | 56 | ||
56 | forw = con; | 57 | forw = con; |
57 | con = con->prev; | 58 | con = con->prev; |
58 | } | 59 | } |
59 | 60 | ||
60 | } | 61 | } |
61 | void ProcCtl::remove( ProcContainer con ) { | 62 | void ProcCtl::remove( ProcContainer con ) { |
62 | remove( con.pid ); | 63 | remove( con.pid ); |
63 | } | 64 | } |
64 | int ProcCtl::status(pid_t pid )const{ | 65 | int ProcCtl::status(pid_t pid )const{ |
65 | ProcContainer *con = m_last; | 66 | ProcContainer *con = m_last; |
66 | while (con) { | 67 | while (con) { |
67 | if (con->pid == pid ) | 68 | if (con->pid == pid ) |
68 | return con->status; | 69 | return con->status; |
69 | con = con->prev; | 70 | con = con->prev; |
70 | } | 71 | } |
71 | return -1; | 72 | return -1; |
72 | } | 73 | } |
73 | void ProcCtl::signal_handler(int) { | 74 | void ProcCtl::signal_handler(int) { |
74 | int status; | 75 | int status; |
75 | signal( SIGCHLD, signal_handler ); | 76 | signal( SIGCHLD, signal_handler ); |
76 | pid_t pi = waitpid( -1, &status, WNOHANG ); | 77 | pid_t pi = waitpid( -1, &status, WNOHANG ); |
77 | 78 | ||
78 | /* | 79 | /* |
79 | * find the container for pid | 80 | * find the container for pid |
80 | * | 81 | * |
81 | */ | 82 | */ |
82 | if ( pi < 0 ) { | 83 | if ( pi < 0 ) { |
83 | return; | 84 | return; |
84 | } | 85 | } |
85 | 86 | ||
86 | ProcContainer* con = m_last; | 87 | ProcContainer* con = m_last; |
87 | while (con) { | 88 | while (con) { |
88 | if ( con->pid == pi ) { | 89 | if ( con->pid == pi ) { |
89 | con->status = status; | 90 | con->status = status; |
90 | char result = 1; | 91 | char result = 1; |
91 | /* give a 'signal' */ | 92 | /* give a 'signal' */ |
92 | ::write(con->fd, &result, 1 ); | 93 | ::write(con->fd, &result, 1 ); |
93 | } | 94 | } |
94 | con = con->prev; | 95 | con = con->prev; |
95 | } | 96 | } |
96 | } | 97 | } |
diff --git a/noncore/apps/opie-console/profileeditordialog.cpp b/noncore/apps/opie-console/profileeditordialog.cpp index 413e80b..1765d42 100644 --- a/noncore/apps/opie-console/profileeditordialog.cpp +++ b/noncore/apps/opie-console/profileeditordialog.cpp | |||
@@ -1,215 +1,214 @@ | |||
1 | #include <qlayout.h> | 1 | #include <qlayout.h> |
2 | #include <qlineedit.h> | 2 | #include <qlineedit.h> |
3 | #include <qlabel.h> | 3 | #include <qlabel.h> |
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 | ||
14 | namespace { | 14 | namespace { |
15 | void setCurrent( const QString& str, QComboBox* bo ) { | 15 | void setCurrent( const QString& str, QComboBox* bo ) { |
16 | for (int 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 | } | 22 | } |
23 | 23 | ||
24 | ProfileEditorDialog::ProfileEditorDialog( MetaFactory* fact, | 24 | ProfileEditorDialog::ProfileEditorDialog( MetaFactory* fact, |
25 | const Profile& prof ) | 25 | const Profile& prof ) |
26 | : QDialog(0, 0, TRUE), m_fact( fact ), m_prof( prof ) | 26 | : QDialog(0, 0, TRUE), m_fact( fact ), m_prof( prof ) |
27 | { | 27 | { |
28 | initUI(); | 28 | initUI(); |
29 | 29 | ||
30 | // Apply current profile | 30 | // Apply current profile |
31 | // plugin_plugin->load(profile); | 31 | // plugin_plugin->load(profile); |
32 | // ... (reset profile name line edit etc.) | 32 | // ... (reset profile name line edit etc.) |
33 | } | 33 | } |
34 | 34 | ||
35 | ProfileEditorDialog::ProfileEditorDialog( MetaFactory* fact ) | 35 | ProfileEditorDialog::ProfileEditorDialog( MetaFactory* fact ) |
36 | : QDialog(0, 0, TRUE), m_fact( fact ) | 36 | : QDialog(0, 0, TRUE), m_fact( fact ) |
37 | { | 37 | { |
38 | // Default profile | 38 | // Default profile |
39 | 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); |
40 | 40 | ||
41 | initUI(); | 41 | initUI(); |
42 | 42 | ||
43 | // Apply current profile | 43 | // Apply current profile |
44 | // plugin_plugin->load(profile); | 44 | // plugin_plugin->load(profile); |
45 | } | 45 | } |
46 | 46 | ||
47 | Profile ProfileEditorDialog::profile() const | 47 | Profile ProfileEditorDialog::profile() const |
48 | { | 48 | { |
49 | return m_prof; | 49 | return m_prof; |
50 | } | 50 | } |
51 | 51 | ||
52 | void ProfileEditorDialog::initUI() | 52 | void ProfileEditorDialog::initUI() |
53 | { | 53 | { |
54 | m_con = m_term = m_key = 0l; | 54 | m_con = m_term = m_key = 0l; |
55 | 55 | ||
56 | QVBoxLayout *mainLayout = new QVBoxLayout( this ); | 56 | QVBoxLayout *mainLayout = new QVBoxLayout( this ); |
57 | tabWidget = new OTabWidget( this ); | 57 | tabWidget = new OTabWidget( this ); |
58 | tabWidget->setTabStyle(OTabWidget::TextTab); | 58 | tabWidget->setTabStyle(OTabWidget::TextTab); |
59 | mainLayout->add(tabWidget); | 59 | mainLayout->add(tabWidget); |
60 | 60 | ||
61 | /* base tabs */ | 61 | /* base tabs */ |
62 | tabprof = new QWidget(this); | 62 | tabprof = new QWidget(this); |
63 | m_tabTerm = new QWidget(this); | 63 | m_tabTerm = new QWidget(this); |
64 | m_tabCon = new QWidget(this); | 64 | m_tabCon = new QWidget(this); |
65 | m_tabKey = new QWidget(this); | 65 | m_tabKey = new QWidget(this); |
66 | 66 | ||
67 | /* base layout for tabs */ | 67 | /* base layout for tabs */ |
68 | m_layCon = new QHBoxLayout( m_tabCon , 2 ); | 68 | m_layCon = new QHBoxLayout( m_tabCon , 2 ); |
69 | m_layTerm = new QHBoxLayout( m_tabTerm, 2 ); | 69 | m_layTerm = new QHBoxLayout( m_tabTerm, 2 ); |
70 | m_layKey = new QHBoxLayout( m_tabKey, 2 ); | 70 | m_layKey = new QHBoxLayout( m_tabKey, 2 ); |
71 | 71 | ||
72 | // profile tab | 72 | // profile tab |
73 | 73 | ||
74 | QLabel *name = new QLabel(QObject::tr("Profile name"), tabprof); | 74 | QLabel *name = new QLabel(QObject::tr("Profile name"), tabprof); |
75 | m_name = new QLineEdit(tabprof); | 75 | m_name = new QLineEdit(tabprof); |
76 | QLabel *con = new QLabel(tr("Connection"), tabprof ); | 76 | QLabel *con = new QLabel(tr("Connection"), tabprof ); |
77 | QLabel *term = new QLabel(tr("Terminal"), tabprof ); | 77 | QLabel *term = new QLabel(tr("Terminal"), tabprof ); |
78 | m_conCmb = new QComboBox( tabprof ); | 78 | m_conCmb = new QComboBox( tabprof ); |
79 | m_termCmb = new QComboBox( tabprof ); | 79 | m_termCmb = new QComboBox( tabprof ); |
80 | m_autoConnect = new QCheckBox(tr("Auto connect after load"), tabprof); | 80 | m_autoConnect = new QCheckBox(tr("Auto connect after load"), tabprof); |
81 | 81 | ||
82 | // layouting | 82 | // layouting |
83 | QVBoxLayout *vbox3 = new QVBoxLayout(tabprof, 2); | 83 | QVBoxLayout *vbox3 = new QVBoxLayout(tabprof, 2); |
84 | vbox3->add(name); | 84 | vbox3->add(name); |
85 | vbox3->add(m_name); | 85 | vbox3->add(m_name); |
86 | vbox3->add(con ); | 86 | vbox3->add(con ); |
87 | vbox3->add(m_conCmb ); | 87 | vbox3->add(m_conCmb ); |
88 | vbox3->add(term ); | 88 | vbox3->add(term ); |
89 | vbox3->add(m_termCmb ); | 89 | vbox3->add(m_termCmb ); |
90 | vbox3->add(m_autoConnect); | 90 | vbox3->add(m_autoConnect); |
91 | vbox3->addStretch(1); | 91 | vbox3->addStretch(1); |
92 | 92 | ||
93 | m_showconntab = 0; | 93 | m_showconntab = 0; |
94 | tabWidget->addTab(tabprof, "", QObject::tr("Profile")); | 94 | tabWidget->addTab(tabprof, "", QObject::tr("Profile")); |
95 | //tabWidget->addTab(m_tabCon, "", QObject::tr("Connection")); | 95 | tabWidget->addTab(m_tabCon, "", QObject::tr("Connection")); |
96 | tabWidget->addTab(m_tabTerm, "", QObject::tr("Terminal")); | 96 | tabWidget->addTab(m_tabTerm, "", QObject::tr("Terminal")); |
97 | tabWidget->addTab(m_tabKey, "", QObject::tr("Special Keys")); | 97 | tabWidget->addTab(m_tabKey, "", QObject::tr("Special Keys")); |
98 | tabWidget->setCurrentTab( tabprof ); | 98 | tabWidget->setCurrentTab( tabprof ); |
99 | 99 | ||
100 | 100 | ||
101 | // fill the comboboxes | 101 | // fill the comboboxes |
102 | QStringList list = m_fact->connectionWidgets(); | 102 | QStringList list = m_fact->connectionWidgets(); |
103 | QStringList::Iterator it; | 103 | QStringList::Iterator it; |
104 | for (it =list.begin(); it != list.end(); ++it ) { | 104 | for (it =list.begin(); it != list.end(); ++it ) { |
105 | m_conCmb->insertItem( (*it) ); | 105 | m_conCmb->insertItem( (*it) ); |
106 | } | 106 | } |
107 | list = m_fact->terminalWidgets(); | 107 | list = m_fact->terminalWidgets(); |
108 | for (it =list.begin(); it != list.end(); ++it ) { | 108 | for (it =list.begin(); it != list.end(); ++it ) { |
109 | m_termCmb->insertItem( (*it) ); | 109 | m_termCmb->insertItem( (*it) ); |
110 | } | 110 | } |
111 | 111 | ||
112 | // load profile values | 112 | // load profile values |
113 | m_name->setText(m_prof.name()); | 113 | m_name->setText(m_prof.name()); |
114 | slotConActivated( m_fact->external(m_prof.ioLayerName() ) ); | 114 | slotConActivated( m_fact->external(m_prof.ioLayerName() ) ); |
115 | slotTermActivated( m_fact->external(m_prof.terminalName() ) ); | 115 | slotTermActivated( m_fact->external(m_prof.terminalName() ) ); |
116 | slotKeyActivated( "Default Keyboard" ); | 116 | slotKeyActivated( "Default Keyboard" ); |
117 | setCurrent( m_fact->external(m_prof.ioLayerName() ), m_conCmb ); | 117 | setCurrent( m_fact->external(m_prof.ioLayerName() ), m_conCmb ); |
118 | setCurrent( m_fact->external(m_prof.terminalName() ), m_termCmb ); | 118 | setCurrent( m_fact->external(m_prof.terminalName() ), m_termCmb ); |
119 | m_autoConnect->setChecked(m_prof.autoConnect()); | 119 | m_autoConnect->setChecked(m_prof.autoConnect()); |
120 | 120 | ||
121 | 121 | ||
122 | // signal and slots | 122 | // signal and slots |
123 | connect(m_conCmb, SIGNAL(activated(const QString& ) ), | 123 | connect(m_conCmb, SIGNAL(activated(const QString& ) ), |
124 | this, SLOT(slotConActivated(const QString&) ) ); | 124 | this, SLOT(slotConActivated(const QString&) ) ); |
125 | connect(m_termCmb, SIGNAL(activated(const QString& ) ), | 125 | connect(m_termCmb, SIGNAL(activated(const QString& ) ), |
126 | this, SLOT(slotTermActivated(const QString& ) ) ); | 126 | this, SLOT(slotTermActivated(const QString& ) ) ); |
127 | 127 | ||
128 | } | 128 | } |
129 | 129 | ||
130 | ProfileEditorDialog::~ProfileEditorDialog() { | 130 | ProfileEditorDialog::~ProfileEditorDialog() { |
131 | 131 | ||
132 | } | 132 | } |
133 | void ProfileEditorDialog::accept() | 133 | void ProfileEditorDialog::accept() |
134 | { | 134 | { |
135 | if(profName().isEmpty()) | 135 | if(profName().isEmpty()) |
136 | { | 136 | { |
137 | QMessageBox::information(this, | 137 | QMessageBox::information(this, |
138 | QObject::tr("Invalid profile"), | 138 | QObject::tr("Invalid profile"), |
139 | QObject::tr("Please enter a profile name.")); | 139 | QObject::tr("Please enter a profile name.")); |
140 | return; | 140 | return; |
141 | } | 141 | } |
142 | // Save profile and plugin profile | 142 | // Save profile and plugin profile |
143 | //if(plugin_plugin) plugin_plugin->save(); | 143 | //if(plugin_plugin) plugin_plugin->save(); |
144 | 144 | ||
145 | // Save general values | 145 | // Save general values |
146 | m_prof.setName(profName()); | 146 | m_prof.setName(profName()); |
147 | m_prof.setIOLayer( m_fact->internal(m_conCmb ->currentText() ) ); | 147 | m_prof.setIOLayer( m_fact->internal(m_conCmb ->currentText() ) ); |
148 | m_prof.setTerminalName( m_fact->internal(m_termCmb->currentText() ) ); | 148 | m_prof.setTerminalName( m_fact->internal(m_termCmb->currentText() ) ); |
149 | m_prof.setAutoConnect( m_autoConnect->isChecked() ); | 149 | m_prof.setAutoConnect( m_autoConnect->isChecked() ); |
150 | 150 | ||
151 | if (m_con ) | 151 | if (m_con ) |
152 | m_con->save( m_prof ); | 152 | m_con->save( m_prof ); |
153 | if (m_term ) | 153 | if (m_term ) |
154 | m_term->save( m_prof ); | 154 | m_term->save( m_prof ); |
155 | if (m_key) | 155 | if (m_key) |
156 | m_key->save( m_prof ); | 156 | m_key->save( m_prof ); |
157 | 157 | ||
158 | QDialog::accept(); | 158 | QDialog::accept(); |
159 | } | 159 | } |
160 | 160 | ||
161 | 161 | ||
162 | QString ProfileEditorDialog::profName()const | 162 | QString ProfileEditorDialog::profName()const |
163 | { | 163 | { |
164 | return m_name->text(); | 164 | return m_name->text(); |
165 | } | 165 | } |
166 | 166 | ||
167 | QCString ProfileEditorDialog::profType()const | 167 | QCString ProfileEditorDialog::profType()const |
168 | { | 168 | { |
169 | /*QStringList w = m_fact->configWidgets(); | 169 | /*QStringList w = m_fact->configWidgets(); |
170 | for(QStringList::Iterator it = w.begin(); it != w.end(); it++) | 170 | for(QStringList::Iterator it = w.begin(); it != w.end(); it++) |
171 | if(device_box->currentText() == m_fact->name((*it))) return (*it); | 171 | if(device_box->currentText() == m_fact->name((*it))) return (*it); |
172 | */ | 172 | */ |
173 | return QCString(); | 173 | return QCString(); |
174 | } | 174 | } |
175 | /* | 175 | /* |
176 | * we need to switch the widget | 176 | * we need to switch the widget |
177 | */ | 177 | */ |
178 | void ProfileEditorDialog::slotConActivated( const QString& str ) { | 178 | void ProfileEditorDialog::slotConActivated( const QString& str ) { |
179 | delete m_con; | 179 | delete m_con; |
180 | m_con = m_fact->newConnectionPlugin( str, m_tabCon ); | 180 | m_con = m_fact->newConnectionPlugin( str, m_tabCon ); |
181 | 181 | ||
182 | if ( !m_con ) { | 182 | if ( !m_con ) { |
183 | m_con = new NoOptions( str, m_tabCon, "name"); | 183 | m_con = new NoOptions( str, m_tabCon, "name"); |
184 | } | 184 | } |
185 | m_con->load( m_prof ); | 185 | m_con->load( m_prof ); |
186 | m_layCon->addWidget( m_con ); | 186 | m_layCon->addWidget( m_con ); |
187 | 187 | ||
188 | tabWidget->addTab( m_tabCon, "", QObject::tr("Connection") ); | ||
189 | tabWidget->setCurrentTab( tabprof ); | 188 | tabWidget->setCurrentTab( tabprof ); |
190 | 189 | ||
191 | } | 190 | } |
192 | /* | 191 | /* |
193 | * we need to switch the widget | 192 | * we need to switch the widget |
194 | */ | 193 | */ |
195 | void ProfileEditorDialog::slotTermActivated( const QString& str ) { | 194 | void ProfileEditorDialog::slotTermActivated( const QString& str ) { |
196 | delete m_term; | 195 | delete m_term; |
197 | m_term = m_fact->newTerminalPlugin( str, m_tabTerm ); | 196 | m_term = m_fact->newTerminalPlugin( str, m_tabTerm ); |
198 | 197 | ||
199 | if (m_term) { | 198 | if (m_term) { |
200 | m_term->load(m_prof ); | 199 | m_term->load(m_prof ); |
201 | m_layTerm->addWidget( m_term ); | 200 | m_layTerm->addWidget( m_term ); |
202 | } | 201 | } |
203 | } | 202 | } |
204 | 203 | ||
205 | void ProfileEditorDialog::slotKeyActivated(const QString &str) { | 204 | void ProfileEditorDialog::slotKeyActivated(const QString &str) { |
206 | delete m_key; | 205 | delete m_key; |
207 | m_key = m_fact->newKeyboardPlugin( str, m_tabKey ); | 206 | m_key = m_fact->newKeyboardPlugin( str, m_tabKey ); |
208 | 207 | ||
209 | if (m_key) { | 208 | if (m_key) { |
210 | 209 | ||
211 | m_key->load(m_prof); | 210 | m_key->load(m_prof); |
212 | m_layKey->addWidget(m_key); | 211 | m_layKey->addWidget(m_key); |
213 | } | 212 | } |
214 | 213 | ||
215 | } | 214 | } |
diff --git a/noncore/apps/opie-console/serialconfigwidget.cpp b/noncore/apps/opie-console/serialconfigwidget.cpp index bd0312a..5c6d975 100644 --- a/noncore/apps/opie-console/serialconfigwidget.cpp +++ b/noncore/apps/opie-console/serialconfigwidget.cpp | |||
@@ -1,149 +1,149 @@ | |||
1 | #include <qlabel.h> | 1 | #include <qlabel.h> |
2 | #include <qlayout.h> | 2 | #include <qlayout.h> |
3 | #include <qcombobox.h> | 3 | #include <qcombobox.h> |
4 | 4 | ||
5 | #include "iolayerbase.h" | 5 | #include "iolayerbase.h" |
6 | #include "serialconfigwidget.h" | 6 | #include "serialconfigwidget.h" |
7 | 7 | ||
8 | namespace { | 8 | namespace { |
9 | void setCurrent( const QString& str, QComboBox* bo ) { | 9 | void setCurrent( const QString& str, QComboBox* bo ) { |
10 | uint b = bo->count(); | 10 | uint b = bo->count(); |
11 | for (uint i = 0; i < bo->count(); i++ ) { | 11 | for (int i = 0; i < bo->count(); i++ ) { |
12 | if ( bo->text(i) == str ) { | 12 | if ( bo->text(i) == str ) { |
13 | bo->setCurrentItem( i ); | 13 | bo->setCurrentItem( i ); |
14 | return; | 14 | return; |
15 | } | 15 | } |
16 | } | 16 | } |
17 | bo->insertItem( str ); | 17 | bo->insertItem( str ); |
18 | bo->setCurrentItem( b ); | 18 | bo->setCurrentItem( b ); |
19 | } | 19 | } |
20 | 20 | ||
21 | 21 | ||
22 | } | 22 | } |
23 | 23 | ||
24 | SerialConfigWidget::SerialConfigWidget( const QString& name, | 24 | SerialConfigWidget::SerialConfigWidget( const QString& name, |
25 | QWidget* parent, | 25 | QWidget* parent, |
26 | const char* na ) | 26 | const char* na ) |
27 | : ProfileDialogConnectionWidget( name, parent, na ) { | 27 | : ProfileDialogConnectionWidget( name, parent, na ) { |
28 | 28 | ||
29 | m_lay = new QVBoxLayout(this ); | 29 | m_lay = new QVBoxLayout(this ); |
30 | m_device = new QLabel(tr("Device"), this ); | 30 | m_device = new QLabel(tr("Device"), this ); |
31 | m_deviceCmb = new QComboBox(this ); | 31 | m_deviceCmb = new QComboBox(this ); |
32 | m_deviceCmb->setEditable( TRUE ); | 32 | m_deviceCmb->setEditable( TRUE ); |
33 | 33 | ||
34 | m_base = new IOLayerBase(this, "base"); | 34 | m_base = new IOLayerBase(this, "base"); |
35 | 35 | ||
36 | m_lay->addWidget( m_device ); | 36 | m_lay->addWidget( m_device ); |
37 | m_lay->addWidget( m_deviceCmb ); | 37 | m_lay->addWidget( m_deviceCmb ); |
38 | m_lay->addWidget( m_base ); | 38 | m_lay->addWidget( m_base ); |
39 | 39 | ||
40 | m_deviceCmb->insertItem( "/dev/ttyS0" ); | 40 | m_deviceCmb->insertItem( "/dev/ttyS0" ); |
41 | m_deviceCmb->insertItem( "/dev/ttyS1" ); | 41 | m_deviceCmb->insertItem( "/dev/ttyS1" ); |
42 | m_deviceCmb->insertItem( "/dev/ttySA0"); | 42 | m_deviceCmb->insertItem( "/dev/ttySA0"); |
43 | m_deviceCmb->insertItem( "/dev/ttySA1"); | 43 | m_deviceCmb->insertItem( "/dev/ttySA1"); |
44 | 44 | ||
45 | } | 45 | } |
46 | SerialConfigWidget::~SerialConfigWidget() { | 46 | SerialConfigWidget::~SerialConfigWidget() { |
47 | 47 | ||
48 | } | 48 | } |
49 | void SerialConfigWidget::load( const Profile& prof ) { | 49 | void SerialConfigWidget::load( const Profile& prof ) { |
50 | int rad_flow = prof.readNumEntry("Flow"); | 50 | int rad_flow = prof.readNumEntry("Flow"); |
51 | int rad_parity = prof.readNumEntry("Parity"); | 51 | int rad_parity = prof.readNumEntry("Parity"); |
52 | int speed = prof.readNumEntry("Speed"); | 52 | int speed = prof.readNumEntry("Speed"); |
53 | 53 | ||
54 | if (rad_flow == 1) { | 54 | if (rad_flow == 1) { |
55 | m_base->setFlow( IOLayerBase::Hardware ); | 55 | m_base->setFlow( IOLayerBase::Hardware ); |
56 | } else if (rad_flow == 2) { | 56 | } else if (rad_flow == 2) { |
57 | m_base->setFlow( IOLayerBase::Software ); | 57 | m_base->setFlow( IOLayerBase::Software ); |
58 | } else { | 58 | } else { |
59 | m_base->setFlow( IOLayerBase::None ); | 59 | m_base->setFlow( IOLayerBase::None ); |
60 | } | 60 | } |
61 | 61 | ||
62 | if (rad_parity == 1) { | 62 | if (rad_parity == 1) { |
63 | m_base->setParity( IOLayerBase::Even ); | 63 | m_base->setParity( IOLayerBase::Even ); |
64 | } else if ( rad_parity == 2 ) { | 64 | } else if ( rad_parity == 2 ) { |
65 | m_base->setParity( IOLayerBase::Odd ); | 65 | m_base->setParity( IOLayerBase::Odd ); |
66 | } else { | 66 | } else { |
67 | m_base->setParity( IOLayerBase::NonePar ); | 67 | m_base->setParity( IOLayerBase::NonePar ); |
68 | } | 68 | } |
69 | 69 | ||
70 | switch( speed ) { | 70 | switch( speed ) { |
71 | case 115200: | 71 | case 115200: |
72 | m_base->setSpeed(IOLayerBase::Baud_115200 ); | 72 | m_base->setSpeed(IOLayerBase::Baud_115200 ); |
73 | break; | 73 | break; |
74 | case 57600: | 74 | case 57600: |
75 | m_base->setSpeed( IOLayerBase::Baud_57600 ); | 75 | m_base->setSpeed( IOLayerBase::Baud_57600 ); |
76 | break; | 76 | break; |
77 | case 38400: | 77 | case 38400: |
78 | m_base->setSpeed(IOLayerBase::Baud_38400 ); | 78 | m_base->setSpeed(IOLayerBase::Baud_38400 ); |
79 | break; | 79 | break; |
80 | case 19200: | 80 | case 19200: |
81 | m_base->setSpeed( IOLayerBase::Baud_19200 ); | 81 | m_base->setSpeed( IOLayerBase::Baud_19200 ); |
82 | break; | 82 | break; |
83 | case 9600: | 83 | case 9600: |
84 | default: | 84 | default: |
85 | m_base->setSpeed(IOLayerBase::Baud_9600 ); | 85 | m_base->setSpeed(IOLayerBase::Baud_9600 ); |
86 | break; | 86 | break; |
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 | */ |
98 | void SerialConfigWidget::save( Profile& prof ) { | 98 | void SerialConfigWidget::save( Profile& prof ) { |
99 | int flow, parity, speed ; | 99 | int flow, parity, speed ; |
100 | flow = parity = speed = 0; | 100 | flow = parity = speed = 0; |
101 | prof.writeEntry("Device", m_deviceCmb->currentText() ); | 101 | prof.writeEntry("Device", m_deviceCmb->currentText() ); |
102 | 102 | ||
103 | switch( m_base->flow() ) { | 103 | switch( m_base->flow() ) { |
104 | case IOLayerBase::None: | 104 | case IOLayerBase::None: |
105 | flow = 0; | 105 | flow = 0; |
106 | break; | 106 | break; |
107 | case IOLayerBase::Software: | 107 | case IOLayerBase::Software: |
108 | flow = 2; | 108 | flow = 2; |
109 | break; | 109 | break; |
110 | case IOLayerBase::Hardware: | 110 | case IOLayerBase::Hardware: |
111 | flow = 1; | 111 | flow = 1; |
112 | break; | 112 | break; |
113 | } | 113 | } |
114 | 114 | ||
115 | switch( m_base->parity() ) { | 115 | switch( m_base->parity() ) { |
116 | case IOLayerBase::Odd: | 116 | case IOLayerBase::Odd: |
117 | parity = 2; | 117 | parity = 2; |
118 | break; | 118 | break; |
119 | case IOLayerBase::Even: | 119 | case IOLayerBase::Even: |
120 | parity = 1; | 120 | parity = 1; |
121 | break; | 121 | break; |
122 | case IOLayerBase::NonePar: | 122 | case IOLayerBase::NonePar: |
123 | parity = 0; | 123 | parity = 0; |
124 | break; | 124 | break; |
125 | } | 125 | } |
126 | 126 | ||
127 | switch( m_base->speed() ) { | 127 | switch( m_base->speed() ) { |
128 | case IOLayerBase::Baud_115200: | 128 | case IOLayerBase::Baud_115200: |
129 | speed = 115200; | 129 | speed = 115200; |
130 | break; | 130 | break; |
131 | case IOLayerBase::Baud_57600: | 131 | case IOLayerBase::Baud_57600: |
132 | speed = 57600; | 132 | speed = 57600; |
133 | break; | 133 | break; |
134 | case IOLayerBase::Baud_38400: | 134 | case IOLayerBase::Baud_38400: |
135 | speed = 38400; | 135 | speed = 38400; |
136 | break; | 136 | break; |
137 | case IOLayerBase::Baud_19200: | 137 | case IOLayerBase::Baud_19200: |
138 | speed = 19200; | 138 | speed = 19200; |
139 | break; | 139 | break; |
140 | default: | 140 | default: |
141 | case IOLayerBase::Baud_9600: | 141 | case IOLayerBase::Baud_9600: |
142 | speed = 9600; | 142 | speed = 9600; |
143 | break; | 143 | break; |
144 | } | 144 | } |
145 | 145 | ||
146 | prof.writeEntry("Flow", flow); | 146 | prof.writeEntry("Flow", flow); |
147 | prof.writeEntry("Parity", parity); | 147 | prof.writeEntry("Parity", parity); |
148 | prof.writeEntry("Speed", speed); | 148 | prof.writeEntry("Speed", speed); |
149 | } | 149 | } |
diff --git a/noncore/apps/opie-console/transferdialog.cpp b/noncore/apps/opie-console/transferdialog.cpp index f89723c..75c4c72 100644 --- a/noncore/apps/opie-console/transferdialog.cpp +++ b/noncore/apps/opie-console/transferdialog.cpp | |||
@@ -1,266 +1,266 @@ | |||
1 | #include <qlayout.h> | 1 | #include <qlayout.h> |
2 | #include <qcombobox.h> | 2 | #include <qcombobox.h> |
3 | #include <qlabel.h> | 3 | #include <qlabel.h> |
4 | #include <qlineedit.h> | 4 | #include <qlineedit.h> |
5 | #include <qpushbutton.h> | 5 | #include <qpushbutton.h> |
6 | #include <qmessagebox.h> | 6 | #include <qmessagebox.h> |
7 | #include <qprogressbar.h> | 7 | #include <qprogressbar.h> |
8 | #include <qradiobutton.h> | 8 | #include <qradiobutton.h> |
9 | #include <qbuttongroup.h> | 9 | #include <qbuttongroup.h> |
10 | 10 | ||
11 | #include <opie/ofiledialog.h> | 11 | #include <opie/ofiledialog.h> |
12 | 12 | ||
13 | #include "file_layer.h" | 13 | #include "file_layer.h" |
14 | #include "receive_layer.h" | 14 | #include "receive_layer.h" |
15 | #include "metafactory.h" | 15 | #include "metafactory.h" |
16 | #include "mainwindow.h" | 16 | #include "mainwindow.h" |
17 | 17 | ||
18 | #include "transferdialog.h" | 18 | #include "transferdialog.h" |
19 | 19 | ||
20 | TransferDialog::TransferDialog(QWidget *parent, MainWindow *mainwindow, const char *name) | 20 | TransferDialog::TransferDialog(QWidget *parent, MainWindow *mainwindow, const char *) |
21 | : QDialog(parent, 0l, true), m_win(mainwindow) | 21 | : QDialog(parent, 0l, true), m_win(mainwindow) |
22 | { | 22 | { |
23 | m_lay = 0l; | 23 | m_lay = 0l; |
24 | m_recvlay = 0l; | 24 | m_recvlay = 0l; |
25 | QVBoxLayout *vbox, *vbox2; | 25 | QVBoxLayout *vbox, *vbox2; |
26 | QHBoxLayout *hbox, *hbox2, *hbox3; | 26 | QHBoxLayout *hbox, *hbox2, *hbox3; |
27 | QLabel *file, *mode, *progress, *status; | 27 | QLabel *file, *mode, *progress, *status; |
28 | QButtonGroup *group; | 28 | QButtonGroup *group; |
29 | QRadioButton *mode_send, *mode_receive; | 29 | QRadioButton *mode_send, *mode_receive; |
30 | 30 | ||
31 | m_autocleanup = 0; | 31 | m_autocleanup = 0; |
32 | 32 | ||
33 | group = new QButtonGroup(QObject::tr("Transfer mode"), this); | 33 | group = new QButtonGroup(QObject::tr("Transfer mode"), this); |
34 | mode_send = new QRadioButton(QObject::tr("Send"), group); | 34 | mode_send = new QRadioButton(QObject::tr("Send"), group); |
35 | mode_receive = new QRadioButton(QObject::tr("Receive"), group); | 35 | mode_receive = new QRadioButton(QObject::tr("Receive"), group); |
36 | group->insert(mode_send, id_send); | 36 | group->insert(mode_send, id_send); |
37 | group->insert(mode_receive, id_receive); | 37 | group->insert(mode_receive, id_receive); |
38 | vbox2 = new QVBoxLayout(group, 2); | 38 | vbox2 = new QVBoxLayout(group, 2); |
39 | vbox2->addSpacing(10); | 39 | vbox2->addSpacing(10); |
40 | hbox3 = new QHBoxLayout(vbox2, 2); | 40 | hbox3 = new QHBoxLayout(vbox2, 2); |
41 | hbox3->add(mode_send); | 41 | hbox3->add(mode_send); |
42 | hbox3->add(mode_receive); | 42 | hbox3->add(mode_receive); |
43 | mode_send->setChecked(true); | 43 | mode_send->setChecked(true); |
44 | m_transfermode = id_send; | 44 | m_transfermode = id_send; |
45 | 45 | ||
46 | file = new QLabel(QObject::tr("Send file"), this); | 46 | file = new QLabel(QObject::tr("Send file"), this); |
47 | mode = new QLabel(QObject::tr("Transfer protocol"), this); | 47 | mode = new QLabel(QObject::tr("Transfer protocol"), this); |
48 | progress = new QLabel(QObject::tr("Progress"), this); | 48 | progress = new QLabel(QObject::tr("Progress"), this); |
49 | status = new QLabel(QObject::tr("Status"), this); | 49 | status = new QLabel(QObject::tr("Status"), this); |
50 | 50 | ||
51 | statusbar = new QLabel(QObject::tr("Ready"), this); | 51 | statusbar = new QLabel(QObject::tr("Ready"), this); |
52 | statusbar->setFrameStyle(QFrame::Panel | QFrame::Sunken); | 52 | statusbar->setFrameStyle(QFrame::Panel | QFrame::Sunken); |
53 | 53 | ||
54 | protocol = new QComboBox(this); | 54 | protocol = new QComboBox(this); |
55 | QStringList list = m_win->factory()->fileTransferLayers(); | 55 | QStringList list = m_win->factory()->fileTransferLayers(); |
56 | for (QStringList::Iterator it = list.begin(); it != list.end(); ++it) | 56 | for (QStringList::Iterator it = list.begin(); it != list.end(); ++it) |
57 | protocol->insertItem((*it)); | 57 | protocol->insertItem((*it)); |
58 | 58 | ||
59 | filename = new QLineEdit(this); | 59 | filename = new QLineEdit(this); |
60 | 60 | ||
61 | progressbar = new QProgressBar(this); | 61 | progressbar = new QProgressBar(this); |
62 | progressbar->setProgress(0); | 62 | progressbar->setProgress(0); |
63 | 63 | ||
64 | selector = new QPushButton("...", this); | 64 | selector = new QPushButton("...", this); |
65 | ok = new QPushButton(QObject::tr("Start transfer"), this); | 65 | ok = new QPushButton(QObject::tr("Start transfer"), this); |
66 | cancel = new QPushButton(QObject::tr("Cancel"), this); | 66 | cancel = new QPushButton(QObject::tr("Cancel"), this); |
67 | 67 | ||
68 | vbox = new QVBoxLayout(this, 2); | 68 | vbox = new QVBoxLayout(this, 2); |
69 | vbox->add(group); | 69 | vbox->add(group); |
70 | vbox->add(file); | 70 | vbox->add(file); |
71 | hbox = new QHBoxLayout(vbox, 0); | 71 | hbox = new QHBoxLayout(vbox, 0); |
72 | hbox->add(filename); | 72 | hbox->add(filename); |
73 | hbox->add(selector); | 73 | hbox->add(selector); |
74 | vbox->add(mode); | 74 | vbox->add(mode); |
75 | vbox->add(protocol); | 75 | vbox->add(protocol); |
76 | vbox->add(progress); | 76 | vbox->add(progress); |
77 | vbox->add(progressbar); | 77 | vbox->add(progressbar); |
78 | vbox->add(status); | 78 | vbox->add(status); |
79 | vbox->add(statusbar); | 79 | vbox->add(statusbar); |
80 | vbox->addStretch(1); | 80 | vbox->addStretch(1); |
81 | hbox2 = new QHBoxLayout(vbox, 2); | 81 | hbox2 = new QHBoxLayout(vbox, 2); |
82 | hbox2->add(ok); | 82 | hbox2->add(ok); |
83 | hbox2->add(cancel); | 83 | hbox2->add(cancel); |
84 | 84 | ||
85 | setCaption(QObject::tr("File transfer")); | 85 | setCaption(QObject::tr("File transfer")); |
86 | show(); | 86 | show(); |
87 | 87 | ||
88 | connect(selector, SIGNAL(clicked()), SLOT(slotFilename())); | 88 | connect(selector, SIGNAL(clicked()), SLOT(slotFilename())); |
89 | connect(ok, SIGNAL(clicked()), SLOT(slotTransfer())); | 89 | connect(ok, SIGNAL(clicked()), SLOT(slotTransfer())); |
90 | connect(cancel, SIGNAL(clicked()), SLOT(slotCancel())); | 90 | connect(cancel, SIGNAL(clicked()), SLOT(slotCancel())); |
91 | connect(group, SIGNAL(clicked(int)), SLOT(slotMode(int))); | 91 | connect(group, SIGNAL(clicked(int)), SLOT(slotMode(int))); |
92 | } | 92 | } |
93 | 93 | ||
94 | TransferDialog::~TransferDialog() | 94 | TransferDialog::~TransferDialog() |
95 | { | 95 | { |
96 | } | 96 | } |
97 | 97 | ||
98 | void TransferDialog::slotFilename() | 98 | void TransferDialog::slotFilename() |
99 | { | 99 | { |
100 | QString f; | 100 | QString f; |
101 | 101 | ||
102 | f = OFileDialog::getOpenFileName(0); | 102 | f = OFileDialog::getOpenFileName(0); |
103 | if(!f.isNull()) filename->setText(f); | 103 | if(!f.isNull()) filename->setText(f); |
104 | } | 104 | } |
105 | 105 | ||
106 | void TransferDialog::slotTransfer() | 106 | void TransferDialog::slotTransfer() |
107 | { | 107 | { |
108 | if((m_transfermode == id_send) && (filename->text().isEmpty())) | 108 | if((m_transfermode == id_send) && (filename->text().isEmpty())) |
109 | { | 109 | { |
110 | QMessageBox::information(this, | 110 | QMessageBox::information(this, |
111 | QObject::tr("Attention"), | 111 | QObject::tr("Attention"), |
112 | QObject::tr("No file has been specified.")); | 112 | QObject::tr("No file has been specified.")); |
113 | return; | 113 | return; |
114 | } | 114 | } |
115 | 115 | ||
116 | ok->setEnabled(false); | 116 | ok->setEnabled(false); |
117 | 117 | ||
118 | cleanup(); | 118 | cleanup(); |
119 | m_autocleanup = 0; | 119 | m_autocleanup = 0; |
120 | 120 | ||
121 | if(m_transfermode == id_send) statusbar->setText(QObject::tr("Sending...")); | 121 | if(m_transfermode == id_send) statusbar->setText(QObject::tr("Sending...")); |
122 | else statusbar->setText(QObject::tr("Receiving...")); | 122 | else statusbar->setText(QObject::tr("Receiving...")); |
123 | 123 | ||
124 | if(m_transfermode == id_send) | 124 | if(m_transfermode == id_send) |
125 | { | 125 | { |
126 | m_lay = m_win->factory()->newFileTransfer(protocol->currentText(), m_win->currentSession()->layer()); | 126 | m_lay = m_win->factory()->newFileTransfer(protocol->currentText(), m_win->currentSession()->layer()); |
127 | m_lay->sendFile(filename->text()); | 127 | m_lay->sendFile(filename->text()); |
128 | 128 | ||
129 | connect(m_lay, SIGNAL(progress(const QString&, int, int, int, int, int)), | 129 | connect(m_lay, SIGNAL(progress(const QString&, int, int, int, int, int)), |
130 | SLOT(slotProgress(const QString&, int, int, int, int, int))); | 130 | SLOT(slotProgress(const QString&, int, int, int, int, int))); |
131 | connect(m_lay, SIGNAL(error(int, const QString&)), SLOT(slotError(int, const QString&))); | 131 | connect(m_lay, SIGNAL(error(int, const QString&)), SLOT(slotError(int, const QString&))); |
132 | connect(m_lay, SIGNAL(sent()), SLOT(slotSent())); | 132 | connect(m_lay, SIGNAL(sent()), SLOT(slotSent())); |
133 | } | 133 | } |
134 | else | 134 | else |
135 | { | 135 | { |
136 | m_recvlay = m_win->factory()->newReceive(protocol->currentText(), m_win->currentSession()->layer()); | 136 | m_recvlay = m_win->factory()->newReceive(protocol->currentText(), m_win->currentSession()->layer()); |
137 | m_recvlay->receive(); | 137 | m_recvlay->receive(); |
138 | 138 | ||
139 | connect(m_recvlay, SIGNAL(progress(const QString&, int, int, int, int, int)), | 139 | connect(m_recvlay, SIGNAL(progress(const QString&, int, int, int, int, int)), |
140 | SLOT(slotProgress(const QString&, int, int, int, int, int))); | 140 | SLOT(slotProgress(const QString&, int, int, int, int, int))); |
141 | connect(m_recvlay, SIGNAL(error(int, const QString&)), SLOT(slotError(int, const QString&))); | 141 | connect(m_recvlay, SIGNAL(error(int, const QString&)), SLOT(slotError(int, const QString&))); |
142 | connect(m_recvlay, SIGNAL(received(const QString&)), SLOT(slotReceived(const QString&))); | 142 | connect(m_recvlay, SIGNAL(received(const QString&)), SLOT(slotReceived(const QString&))); |
143 | } | 143 | } |
144 | } | 144 | } |
145 | 145 | ||
146 | void TransferDialog::cleanup() | 146 | void TransferDialog::cleanup() |
147 | { | 147 | { |
148 | if(m_lay) | 148 | if(m_lay) |
149 | { | 149 | { |
150 | m_lay->cancel(); | 150 | m_lay->cancel(); |
151 | delete m_lay; | 151 | delete m_lay; |
152 | m_lay = 0l; | 152 | m_lay = 0l; |
153 | } | 153 | } |
154 | if(m_recvlay) | 154 | if(m_recvlay) |
155 | { | 155 | { |
156 | m_recvlay->cancel(); | 156 | m_recvlay->cancel(); |
157 | delete m_recvlay; | 157 | delete m_recvlay; |
158 | m_recvlay = 0l; | 158 | m_recvlay = 0l; |
159 | } | 159 | } |
160 | } | 160 | } |
161 | 161 | ||
162 | void TransferDialog::slotCancel() | 162 | void TransferDialog::slotCancel() |
163 | { | 163 | { |
164 | ok->setEnabled(true); | 164 | ok->setEnabled(true); |
165 | statusbar->setText(QObject::tr("Ready")); | 165 | statusbar->setText(QObject::tr("Ready")); |
166 | 166 | ||
167 | if((m_lay) || (m_recvlay)) | 167 | if((m_lay) || (m_recvlay)) |
168 | { | 168 | { |
169 | cleanup(); | 169 | cleanup(); |
170 | if(m_autocleanup) close(); | 170 | if(m_autocleanup) close(); |
171 | else | 171 | else |
172 | { | 172 | { |
173 | QMessageBox::information(this, | 173 | QMessageBox::information(this, |
174 | QObject::tr("Cancelled"), | 174 | QObject::tr("Cancelled"), |
175 | QObject::tr("The file transfer has been cancelled.")); | 175 | QObject::tr("The file transfer has been cancelled.")); |
176 | } | 176 | } |
177 | } | 177 | } |
178 | else | 178 | else |
179 | { | 179 | { |
180 | close(); | 180 | close(); |
181 | } | 181 | } |
182 | } | 182 | } |
183 | 183 | ||
184 | void TransferDialog::slotProgress(const QString& file, int progress, int speed, int hours, int minutes, int seconds) | 184 | void TransferDialog::slotProgress(const QString& , int progress, int , int , int, int ) |
185 | { | 185 | { |
186 | progressbar->setProgress(progress); | 186 | progressbar->setProgress(progress); |
187 | } | 187 | } |
188 | 188 | ||
189 | void TransferDialog::slotError(int error, const QString& message) | 189 | void TransferDialog::slotError(int error, const QString& ) |
190 | { | 190 | { |
191 | statusbar->setText(QObject::tr("Ready")); | 191 | statusbar->setText(QObject::tr("Ready")); |
192 | 192 | ||
193 | switch(error) | 193 | switch(error) |
194 | { | 194 | { |
195 | case FileTransferLayer::NotSupported: | 195 | case FileTransferLayer::NotSupported: |
196 | QMessageBox::critical(this, | 196 | QMessageBox::critical(this, |
197 | QObject::tr("Error"), | 197 | QObject::tr("Error"), |
198 | QObject::tr("Operation not supported.")); | 198 | QObject::tr("Operation not supported.")); |
199 | break; | 199 | break; |
200 | case FileTransferLayer::StartError: | 200 | case FileTransferLayer::StartError: |
201 | QMessageBox::critical(this, | 201 | QMessageBox::critical(this, |
202 | QObject::tr("Error"), | 202 | QObject::tr("Error"), |
203 | QObject::tr("Transfer could not be started.")); | 203 | QObject::tr("Transfer could not be started.")); |
204 | break; | 204 | break; |
205 | case FileTransferLayer::NoError: | 205 | case FileTransferLayer::NoError: |
206 | QMessageBox::critical(this, | 206 | QMessageBox::critical(this, |
207 | QObject::tr("Error"), | 207 | QObject::tr("Error"), |
208 | QObject::tr("No error.")); | 208 | QObject::tr("No error.")); |
209 | break; | 209 | break; |
210 | case FileTransferLayer::Undefined: | 210 | case FileTransferLayer::Undefined: |
211 | QMessageBox::critical(this, | 211 | QMessageBox::critical(this, |
212 | QObject::tr("Error"), | 212 | QObject::tr("Error"), |
213 | QObject::tr("Undefined error occured.")); | 213 | QObject::tr("Undefined error occured.")); |
214 | break; | 214 | break; |
215 | case FileTransferLayer::Incomplete: | 215 | case FileTransferLayer::Incomplete: |
216 | QMessageBox::critical(this, | 216 | QMessageBox::critical(this, |
217 | QObject::tr("Error"), | 217 | QObject::tr("Error"), |
218 | QObject::tr("Incomplete transfer.")); | 218 | QObject::tr("Incomplete transfer.")); |
219 | break; | 219 | break; |
220 | case FileTransferLayer::Unknown: | 220 | case FileTransferLayer::Unknown: |
221 | default: | 221 | default: |
222 | QMessageBox::critical(this, | 222 | QMessageBox::critical(this, |
223 | QObject::tr("Error"), | 223 | QObject::tr("Error"), |
224 | QObject::tr("Unknown error occured.")); | 224 | QObject::tr("Unknown error occured.")); |
225 | break; | 225 | break; |
226 | } | 226 | } |
227 | 227 | ||
228 | m_autocleanup = 1; | 228 | m_autocleanup = 1; |
229 | } | 229 | } |
230 | 230 | ||
231 | void TransferDialog::slotSent() | 231 | void TransferDialog::slotSent() |
232 | { | 232 | { |
233 | progressbar->setProgress(100); | 233 | progressbar->setProgress(100); |
234 | QMessageBox::information(this, QObject::tr("Sent"), QObject::tr("File has been sent.")); | 234 | QMessageBox::information(this, QObject::tr("Sent"), QObject::tr("File has been sent.")); |
235 | ok->setEnabled(true); | 235 | ok->setEnabled(true); |
236 | progressbar->setProgress(0); | 236 | progressbar->setProgress(0); |
237 | statusbar->setText(QObject::tr("Ready")); | 237 | statusbar->setText(QObject::tr("Ready")); |
238 | m_autocleanup = 1; | 238 | m_autocleanup = 1; |
239 | } | 239 | } |
240 | 240 | ||
241 | void TransferDialog::slotReceived(const QString& file) | 241 | void TransferDialog::slotReceived(const QString& ) |
242 | { | 242 | { |
243 | progressbar->setProgress(100); | 243 | progressbar->setProgress(100); |
244 | QMessageBox::information(this, QObject::tr("Received"), QObject::tr("File has been received.")); | 244 | QMessageBox::information(this, QObject::tr("Received"), QObject::tr("File has been received.")); |
245 | //QMessageBox::information(this, QObject::tr("Sent"), QObject::tr("File has been received as %1.").arg(file)); | 245 | //QMessageBox::information(this, QObject::tr("Sent"), QObject::tr("File has been received as %1.").arg(file)); |
246 | ok->setEnabled(true); | 246 | ok->setEnabled(true); |
247 | progressbar->setProgress(0); | 247 | progressbar->setProgress(0); |
248 | statusbar->setText(QObject::tr("Ready")); | 248 | statusbar->setText(QObject::tr("Ready")); |
249 | m_autocleanup = 1; | 249 | m_autocleanup = 1; |
250 | } | 250 | } |
251 | 251 | ||
252 | void TransferDialog::slotMode(int id) | 252 | void TransferDialog::slotMode(int id) |
253 | { | 253 | { |
254 | if(id == id_send) | 254 | if(id == id_send) |
255 | { | 255 | { |
256 | selector->setEnabled(true); | 256 | selector->setEnabled(true); |
257 | filename->setEnabled(true); | 257 | filename->setEnabled(true); |
258 | } | 258 | } |
259 | else | 259 | else |
260 | { | 260 | { |
261 | selector->setEnabled(false); | 261 | selector->setEnabled(false); |
262 | filename->setEnabled(false); | 262 | filename->setEnabled(false); |
263 | } | 263 | } |
264 | m_transfermode = id; | 264 | m_transfermode = id; |
265 | } | 265 | } |
266 | 266 | ||