summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/settings/networksettings/ppp/connect.cpp4
-rw-r--r--noncore/settings/networksettings/ppp/general.cpp34
-rw-r--r--noncore/settings/networksettings/ppp/general.h4
-rw-r--r--noncore/settings/networksettings/ppp/modem.cpp16
-rw-r--r--noncore/settings/networksettings/ppp/pppdata.cpp12
-rw-r--r--noncore/settings/networksettings/ppp/pppdata.h19
6 files changed, 45 insertions, 44 deletions
diff --git a/noncore/settings/networksettings/ppp/connect.cpp b/noncore/settings/networksettings/ppp/connect.cpp
index 128877a..8981e01 100644
--- a/noncore/settings/networksettings/ppp/connect.cpp
+++ b/noncore/settings/networksettings/ppp/connect.cpp
@@ -834,635 +834,635 @@ void ConnectWidget::timerEvent(QTimerEvent *) {
834 // The port is still held open by the helper process. 834 // The port is still held open by the helper process.
835 835
836 /* Er, there _is_ not QTimer::singleShot() in Modem::readtty(), 836 /* Er, there _is_ not QTimer::singleShot() in Modem::readtty(),
837 and closing the thing prevents pppd from using it later. */ 837 and closing the thing prevents pppd from using it later. */
838 //_ifaceppp->modem()->closetty(); 838 //_ifaceppp->modem()->closetty();
839 839
840 killTimer( main_timer_ID ); 840 killTimer( main_timer_ID );
841 841
842 if_timeout_timer->start(_ifaceppp->data()->pppdTimeout()*1000); 842 if_timeout_timer->start(_ifaceppp->data()->pppdTimeout()*1000);
843 odebug << "started if timeout timer with " << _ifaceppp->data()->pppdTimeout()*1000 << "" << oendl; 843 odebug << "started if timeout timer with " << _ifaceppp->data()->pppdTimeout()*1000 << "" << oendl;
844 844
845 // find out PPP interface and notify the stats module 845 // find out PPP interface and notify the stats module
846// stats->setUnit(pppInterfaceNumber()); 846// stats->setUnit(pppInterfaceNumber());
847 847
848 qApp->flushX(); 848 qApp->flushX();
849 semaphore = true; 849 semaphore = true;
850 result = execppp(); 850 result = execppp();
851 851
852 emit debugMessage(QObject::tr("Starting pppd...")); 852 emit debugMessage(QObject::tr("Starting pppd..."));
853 odebug << "execppp() returned with return-code " << result << "" << oendl; 853 odebug << "execppp() returned with return-code " << result << "" << oendl;
854 854
855 if(result) { 855 if(result) {
856 if(!_ifaceppp->data()->autoDNS()) 856 if(!_ifaceppp->data()->autoDNS())
857 adddns( _ifaceppp ); 857 adddns( _ifaceppp );
858 858
859 // O.K we are done here, let's change over to the if_waiting loop 859 // O.K we are done here, let's change over to the if_waiting loop
860 // where we wait for the ppp if (interface) to come up. 860 // where we wait for the ppp if (interface) to come up.
861 861
862 emit if_waiting_signal(); 862 emit if_waiting_signal();
863 } else { 863 } else {
864 864
865 // starting pppd wasn't successful. Error messages were 865 // starting pppd wasn't successful. Error messages were
866 // handled by execppp(); 866 // handled by execppp();
867 if_timeout_timer->stop(); 867 if_timeout_timer->stop();
868 this->hide(); 868 this->hide();
869 messg->setText(""); 869 messg->setText("");
870 //p_kppp->quit_b->setFocus(); 870 //p_kppp->quit_b->setFocus();
871 //p_kppp->show(); 871 //p_kppp->show();
872 qApp->processEvents(); 872 qApp->processEvents();
873 _ifaceppp->modem()->hangup(); 873 _ifaceppp->modem()->hangup();
874 emit stopAccounting(); 874 emit stopAccounting();
875 //p_kppp->con_win->stopClock(); 875 //p_kppp->con_win->stopClock();
876 _ifaceppp->modem()->closetty(); 876 _ifaceppp->modem()->closetty();
877 _ifaceppp->modem()->unlockdevice(); 877 _ifaceppp->modem()->unlockdevice();
878 878
879 } 879 }
880 880
881 return; 881 return;
882 } 882 }
883 } 883 }
884 884
885 // this is a "wait until cancel" entry 885 // this is a "wait until cancel" entry
886 886
887 if(vmain == 20) { 887 if(vmain == 20) {
888 } 888 }
889} 889}
890 890
891 891
892void ConnectWidget::set_con_speed_string() { 892void ConnectWidget::set_con_speed_string() {
893 // Here we are trying to determine the speed at which we are connected. 893 // Here we are trying to determine the speed at which we are connected.
894 // Usually the modem responds after connect with something like 894 // Usually the modem responds after connect with something like
895 // CONNECT 115200, so all we need to do is find the number after CONNECT 895 // CONNECT 115200, so all we need to do is find the number after CONNECT
896 // or whatever the modemConnectResp() is. 896 // or whatever the modemConnectResp() is.
897// p_kppp->con_speed = _ifaceppp->modem()->parseModemSpeed(myreadbuffer); 897// p_kppp->con_speed = _ifaceppp->modem()->parseModemSpeed(myreadbuffer);
898} 898}
899 899
900 900
901 901
902void ConnectWidget::readChar(unsigned char c) { 902void ConnectWidget::readChar(unsigned char c) {
903 if(semaphore) 903 if(semaphore)
904 return; 904 return;
905 905
906 readbuffer += c; 906 readbuffer += c;
907 myreadbuffer += c; 907 myreadbuffer += c;
908 908
909 // While in scanning mode store each char to the scan buffer 909 // While in scanning mode store each char to the scan buffer
910 // for use in the prompt command 910 // for use in the prompt command
911 if( scanning ) 911 if( scanning )
912 scanbuffer += c; 912 scanbuffer += c;
913 913
914 // add to debug window 914 // add to debug window
915 emit debugPutChar(c); 915 emit debugPutChar(c);
916 916
917 checkBuffers(); 917 checkBuffers();
918} 918}
919 919
920 920
921void ConnectWidget::checkBuffers() { 921void ConnectWidget::checkBuffers() {
922 // Let's check if we are finished with scanning: 922 // Let's check if we are finished with scanning:
923 // The scanstring have to be in the buffer and the latest character 923 // The scanstring have to be in the buffer and the latest character
924 // was a carriage return or an linefeed (depending on modem setup) 924 // was a carriage return or an linefeed (depending on modem setup)
925 if( scanning && scanbuffer.contains(scanstr) && 925 if( scanning && scanbuffer.contains(scanstr) &&
926 ( scanbuffer.right(1) == "\n" || scanbuffer.right(1) == "\r") ) { 926 ( scanbuffer.right(1) == "\n" || scanbuffer.right(1) == "\r") ) {
927 scanning = false; 927 scanning = false;
928 928
929 int vstart = scanbuffer.find( scanstr ) + scanstr.length(); 929 int vstart = scanbuffer.find( scanstr ) + scanstr.length();
930 scanvar = scanbuffer.mid( vstart, scanbuffer.length() - vstart); 930 scanvar = scanbuffer.mid( vstart, scanbuffer.length() - vstart);
931 scanvar = scanvar.stripWhiteSpace(); 931 scanvar = scanvar.stripWhiteSpace();
932 932
933 // Show the Variabel content in the debug window 933 // Show the Variabel content in the debug window
934 QString sv = QObject::tr("Scan Var: %1").arg(scanvar); 934 QString sv = QObject::tr("Scan Var: %1").arg(scanvar);
935 emit debugMessage(sv); 935 emit debugMessage(sv);
936 } 936 }
937 937
938 if(expecting) { 938 if(expecting) {
939 if(readbuffer.contains(expectstr)) { 939 if(readbuffer.contains(expectstr)) {
940 expecting = false; 940 expecting = false;
941 // keep everything after the expected string 941 // keep everything after the expected string
942 readbuffer.remove(0, readbuffer.find(expectstr) + expectstr.length()); 942 readbuffer.remove(0, readbuffer.find(expectstr) + expectstr.length());
943 943
944 QString ts = QObject::tr("Found: %1").arg(expectstr); 944 QString ts = QObject::tr("Found: %1").arg(expectstr);
945 emit debugMessage(ts); 945 emit debugMessage(ts);
946 946
947 if (loopend) { 947 if (loopend) {
948 loopend=false; 948 loopend=false;
949 } 949 }
950 } 950 }
951 951
952 if (loopend && readbuffer.contains(loopstr[loopnest])) { 952 if (loopend && readbuffer.contains(loopstr[loopnest])) {
953 expecting = false; 953 expecting = false;
954 readbuffer = ""; 954 readbuffer = "";
955 QString ts = QObject::tr("Looping: %1").arg(loopstr[loopnest]); 955 QString ts = QObject::tr("Looping: %1").arg(loopstr[loopnest]);
956 emit debugMessage(ts); 956 emit debugMessage(ts);
957 scriptindex = loopstartindex[loopnest]; 957 scriptindex = loopstartindex[loopnest];
958 loopend = false; 958 loopend = false;
959 loopnest++; 959 loopnest++;
960 } 960 }
961 // notify event loop if expected string was found 961 // notify event loop if expected string was found
962 if(!expecting) 962 if(!expecting)
963 timerEvent((QTimerEvent *) 0); 963 timerEvent((QTimerEvent *) 0);
964 } 964 }
965} 965}
966 966
967 967
968 968
969void ConnectWidget::pause() { 969void ConnectWidget::pause() {
970 pausing = false; 970 pausing = false;
971 pausetimer->stop(); 971 pausetimer->stop();
972} 972}
973 973
974 974
975void ConnectWidget::cancelbutton() { 975void ConnectWidget::cancelbutton() {
976 _ifaceppp->modem()->stop(); 976 _ifaceppp->modem()->stop();
977 killTimer(main_timer_ID); 977 killTimer(main_timer_ID);
978 timeout_timer->stop(); 978 timeout_timer->stop();
979 if_timer->stop(); 979 if_timer->stop();
980 if_timeout_timer->stop(); 980 if_timeout_timer->stop();
981 981
982// if (termwindow) { 982// if (termwindow) {
983// delete termwindow; 983// delete termwindow;
984// termwindow = 0L; 984// termwindow = 0L;
985// this->show(); 985// this->show();
986// } 986// }
987 987
988 messg->setText(QObject::tr("One moment please...")); 988 messg->setText(QObject::tr("One moment please..."));
989 989
990 // just to be sure 990 // just to be sure
991 _ifaceppp->modem()->removeSecret(AUTH_PAP); 991 _ifaceppp->modem()->removeSecret(AUTH_PAP);
992 _ifaceppp->modem()->removeSecret(AUTH_CHAP); 992 _ifaceppp->modem()->removeSecret(AUTH_CHAP);
993 removedns(_ifaceppp); 993 removedns(_ifaceppp);
994 994
995 qApp->processEvents(); 995 qApp->processEvents();
996 996
997 _ifaceppp->modem()->killPPPDaemon(); 997 _ifaceppp->modem()->killPPPDaemon();
998 _ifaceppp->modem()->hangup(); 998 _ifaceppp->modem()->hangup();
999 999
1000 1000
1001// p_kppp->quit_b->setFocus(); 1001// p_kppp->quit_b->setFocus();
1002// p_kppp->show(); 1002// p_kppp->show();
1003 // emit stopAccounting();// just to be sure 1003 // emit stopAccounting();// just to be sure
1004// p_kppp->con_win->stopClock(); 1004// p_kppp->con_win->stopClock();
1005 _ifaceppp->modem()->closetty(); 1005 _ifaceppp->modem()->closetty();
1006 _ifaceppp->modem()->unlockdevice(); 1006 _ifaceppp->modem()->unlockdevice();
1007 1007
1008 //abort prompt window... 1008 //abort prompt window...
1009 if (prompt->isVisible()) { 1009 if (prompt->isVisible()) {
1010 prompt->hide(); 1010 prompt->hide();
1011 } 1011 }
1012 prompt->setConsumed(); 1012 prompt->setConsumed();
1013 1013
1014 _ifaceppp->setStatus( false ); 1014 _ifaceppp->setStatus( false );
1015 _ifaceppp->refresh(); 1015 _ifaceppp->refresh();
1016// messg->setText(tr("offline")); 1016// messg->setText(tr("offline"));
1017 refresh(); 1017 refresh();
1018} 1018}
1019 1019
1020 1020
1021void ConnectWidget::script_timed_out() { 1021void ConnectWidget::script_timed_out() {
1022 if(vmain == 20) { // we are in the 'wait for the user to cancel' state 1022 if(vmain == 20) { // we are in the 'wait for the user to cancel' state
1023 timeout_timer->stop(); 1023 timeout_timer->stop();
1024 emit stopAccounting(); 1024 emit stopAccounting();
1025// p_kppp->con_win->stopClock(); 1025// p_kppp->con_win->stopClock();
1026 return; 1026 return;
1027 } 1027 }
1028 1028
1029 if (prompt->isVisible()) 1029 if (prompt->isVisible())
1030 prompt->hide(); 1030 prompt->hide();
1031 1031
1032 prompt->setConsumed(); 1032 prompt->setConsumed();
1033 messg->setText(QObject::tr("Script timed out!")); 1033 messg->setText(QObject::tr("Script timed out!"));
1034 _ifaceppp->modem()->hangup(); 1034 _ifaceppp->modem()->hangup();
1035 emit stopAccounting(); 1035 emit stopAccounting();
1036// p_kppp->con_win->stopClock(); 1036// p_kppp->con_win->stopClock();
1037 1037
1038 vmain = 0; // let's try again. 1038 vmain = 0; // let's try again.
1039 substate = -1; 1039 substate = -1;
1040} 1040}
1041 1041
1042 1042
1043void ConnectWidget::setScan(const QString &n) { 1043void ConnectWidget::setScan(const QString &n) {
1044 scanning = true; 1044 scanning = true;
1045 scanstr = n; 1045 scanstr = n;
1046 scanbuffer = ""; 1046 scanbuffer = "";
1047 1047
1048 QString ts = QObject::tr("Scanning: %1").arg(n); 1048 QString ts = QObject::tr("Scanning: %1").arg(n);
1049 emit debugMessage(ts); 1049 emit debugMessage(ts);
1050} 1050}
1051 1051
1052 1052
1053void ConnectWidget::setExpect(const QString &n) { 1053void ConnectWidget::setExpect(const QString &n) {
1054 expecting = true; 1054 expecting = true;
1055 expectstr = n; 1055 expectstr = n;
1056 1056
1057 QString ts = QObject::tr("Expecting: %1").arg(n); 1057 QString ts = QObject::tr("Expecting: %1").arg(n);
1058 ts.replace(QRegExp("\n"), "<LF>"); 1058 ts.replace(QRegExp("\n"), "<LF>");
1059 emit debugMessage(ts); 1059 emit debugMessage(ts);
1060 1060
1061 // check if the expected string is in the read buffer already. 1061 // check if the expected string is in the read buffer already.
1062 checkBuffers(); 1062 checkBuffers();
1063} 1063}
1064 1064
1065 1065
1066void ConnectWidget::if_waiting_timed_out() { 1066void ConnectWidget::if_waiting_timed_out() {
1067 if_timer->stop(); 1067 if_timer->stop();
1068 if_timeout_timer->stop(); 1068 if_timeout_timer->stop();
1069 odebug << "if_waiting_timed_out()" << oendl; 1069 odebug << "if_waiting_timed_out()" << oendl;
1070 1070
1071 _ifaceppp->data()->setpppdError(E_IF_TIMEOUT); 1071 _ifaceppp->data()->setpppdError(E_IF_TIMEOUT);
1072 1072
1073 // let's kill the stuck pppd 1073 // let's kill the stuck pppd
1074 _ifaceppp->modem()->killPPPDaemon(); 1074 _ifaceppp->modem()->killPPPDaemon();
1075 1075
1076 emit stopAccounting(); 1076 emit stopAccounting();
1077// p_kppp->con_win->stopClock(); 1077// p_kppp->con_win->stopClock();
1078 1078
1079 1079
1080 // killing ppp will generate a SIGCHLD which will be caught in pppdie() 1080 // killing ppp will generate a SIGCHLD which will be caught in pppdie()
1081 // in main.cpp what happens next will depend on the boolean 1081 // in main.cpp what happens next will depend on the boolean
1082 // reconnect_on_disconnect which is set in ConnectWidget::init(); 1082 // reconnect_on_disconnect which is set in ConnectWidget::init();
1083} 1083}
1084 1084
1085void ConnectWidget::pppdDied() 1085void ConnectWidget::pppdDied()
1086{ 1086{
1087 if_timer->stop(); 1087 if_timer->stop();
1088 if_timeout_timer->stop(); 1088 if_timeout_timer->stop();
1089} 1089}
1090 1090
1091void ConnectWidget::if_waiting_slot() { 1091void ConnectWidget::if_waiting_slot() {
1092 messg->setText(QObject::tr("Logging on to network...")); 1092 messg->setText(QObject::tr("Logging on to network..."));
1093 1093
1094// if(!stats->ifIsUp()) { 1094// if(!stats->ifIsUp()) {
1095 1095
1096// if(_ifaceppp->data()->pppdError() != 0) { 1096// if(_ifaceppp->data()->pppdError() != 0) {
1097// // we are here if pppd died immediately after starting it. 1097// // we are here if pppd died immediately after starting it.
1098// pppdDied(); 1098// pppdDied();
1099// // error message handled in main.cpp: sigPPPDDied() 1099// // error message handled in main.cpp: sigPPPDDied()
1100// return; 1100// return;
1101// } 1101// }
1102 1102
1103// if_timer->start(100, TRUE); // single shot 1103// if_timer->start(100, TRUE); // single shot
1104// return; 1104// return;
1105// } 1105// }
1106 1106
1107 // O.K the ppp interface is up and running 1107 // O.K the ppp interface is up and running
1108 // give it a few time to come up completly (0.2 seconds) 1108 // give it a few time to come up completly (0.2 seconds)
1109 if_timeout_timer->stop(); 1109 if_timeout_timer->stop();
1110 if_timer->stop(); 1110 if_timer->stop();
1111 usleep(200000); 1111 usleep(200000);
1112 1112
1113 if(_ifaceppp->data()->autoDNS()) 1113 if(_ifaceppp->data()->autoDNS())
1114 addpeerdns( _ifaceppp ); 1114 addpeerdns( _ifaceppp );
1115 1115
1116 // Close the debugging window. If we are connected, we 1116 // Close the debugging window. If we are connected, we
1117 // are not really interested in debug output 1117 // are not really interested in debug output
1118 emit closeDebugWindow(); 1118 emit closeDebugWindow();
1119// p_kppp->statdlg->take_stats(); // start taking ppp statistics 1119// p_kppp->statdlg->take_stats(); // start taking ppp statistics
1120 auto_hostname(_ifaceppp); 1120 auto_hostname(_ifaceppp);
1121 1121
1122 if(!_ifaceppp->data()->command_on_connect().isEmpty()) { 1122 if(!_ifaceppp->data()->command_on_connect().isEmpty()) {
1123 messg->setText(QObject::tr("Running startup command...")); 1123 messg->setText(QObject::tr("Running startup command..."));
1124 1124
1125 // make sure that we don't get any async errors 1125 // make sure that we don't get any async errors
1126 qApp->flushX(); 1126 qApp->flushX();
1127 execute_command(_ifaceppp->data()->command_on_connect()); 1127 execute_command(_ifaceppp->data()->command_on_connect());
1128 messg->setText(QObject::tr("Done")); 1128 messg->setText(QObject::tr("Done"));
1129 } 1129 }
1130 1130
1131 // remove the authentication file 1131 // remove the authentication file
1132 _ifaceppp->modem()->removeSecret(AUTH_PAP); 1132 _ifaceppp->modem()->removeSecret(AUTH_PAP);
1133 _ifaceppp->modem()->removeSecret(AUTH_CHAP); 1133 _ifaceppp->modem()->removeSecret(AUTH_CHAP);
1134 1134
1135 emit debugMessage(QObject::tr("Done")); 1135 emit debugMessage(QObject::tr("Done"));
1136 set_con_speed_string(); 1136 set_con_speed_string();
1137 1137
1138// p_kppp->con_win->setConnectionSpeed(p_kppp->con_speed); 1138// p_kppp->con_win->setConnectionSpeed(p_kppp->con_speed);
1139// this->hide(); 1139// this->hide();
1140// messg->setText(""); 1140// messg->setText("");
1141 1141
1142 _ifaceppp->setStatus( true ); 1142 _ifaceppp->setStatus( true );
1143 1143
1144 m_refreshTimer = new QTimer( this ); 1144 m_refreshTimer = new QTimer( this );
1145 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) ); 1145 connect( m_refreshTimer, SIGNAL( timeout() ), this, SLOT( refresh() ) );
1146 m_refreshTimer->start( 3000 ); 1146 m_refreshTimer->start( 3000 );
1147 //_ifaceppp->refresh(); 1147 //_ifaceppp->refresh();
1148 // emit _ifaceppp->updateInterface(_ifaceppp); 1148 // emit _ifaceppp->updateInterface(_ifaceppp);
1149 1149
1150 // prepare the con_win so as to have the right size for 1150 // prepare the con_win so as to have the right size for
1151 // accounting / non-accounting mode 1151 // accounting / non-accounting mode
1152// if(p_kppp->acct != 0) 1152// if(p_kppp->acct != 0)
1153// p_kppp->con_win->accounting(p_kppp->acct->running()); 1153// p_kppp->con_win->accounting(p_kppp->acct->running());
1154// else 1154// else
1155// p_kppp->con_win->accounting(false); 1155// p_kppp->con_win->accounting(false);
1156 1156
1157// if (_ifaceppp->data()->get_dock_into_panel()) { 1157// if (_ifaceppp->data()->get_dock_into_panel()) {
1158// // DockWidget::dock_widget->show(); 1158// // DockWidget::dock_widget->show();
1159// // DockWidget::dock_widget->take_stats(); 1159// // DockWidget::dock_widget->take_stats();
1160// // this->hide(); 1160// // this->hide();
1161// } 1161// }
1162// else { 1162// else {
1163// // p_kppp->con_win->show(); 1163// // p_kppp->con_win->show();
1164 1164
1165// if(_ifaceppp->data()->get_iconify_on_connect()) { 1165// if(_ifaceppp->data()->get_iconify_on_connect()) {
1166// // p_kppp->con_win->showMinimized(); 1166// // p_kppp->con_win->showMinimized();
1167// } 1167// }
1168// } 1168// }
1169 1169
1170 _ifaceppp->modem()->closetty(); 1170 _ifaceppp->modem()->closetty();
1171} 1171}
1172 1172
1173void ConnectWidget::refresh() { 1173void ConnectWidget::refresh() {
1174 _ifaceppp->refresh(); 1174 _ifaceppp->refresh();
1175 if ( _ifaceppp->getStatus() ) { 1175 if ( _ifaceppp->getStatus() ) {
1176 messg->setText(QObject::tr("Online")); 1176 messg->setText(QObject::tr("Online"));
1177 } else { 1177 } else {
1178 messg->setText(QObject::tr("Offline")); 1178 messg->setText(QObject::tr("Offline"));
1179 } 1179 }
1180} 1180}
1181 1181
1182 1182
1183bool ConnectWidget::execppp() { 1183bool ConnectWidget::execppp() {
1184 QString command; 1184 QString command;
1185 1185
1186 command = "pppd"; 1186 command = "pppd";
1187 1187
1188 // as of version 2.3.6 pppd falls back to the real user rights when 1188 // as of version 2.3.6 pppd falls back to the real user rights when
1189 // opening a device given in a command line. To avoid permission conflicts 1189 // opening a device given in a command line. To avoid permission conflicts
1190 // we'll simply leave this argument away. pppd will then use the default tty 1190 // we'll simply leave this argument away. pppd will then use the default tty
1191 // which is the serial port we connected stdin/stdout to in opener.cpp. 1191 // which is the serial port we connected stdin/stdout to in opener.cpp.
1192 // command += " "; 1192 // command += " ";
1193 // command += _ifaceppp->data()->modemDevice(); 1193 // command += _ifaceppp->data()->modemDevice();
1194 1194
1195 command += " " + _ifaceppp->data()->speed(); 1195 command += " " + _ifaceppp->data()->speed();
1196 1196
1197 command += " -detach"; 1197 command += " -detach";
1198 1198
1199 if(_ifaceppp->data()->ipaddr() != "0.0.0.0" || 1199 if(_ifaceppp->data()->ipaddr() != "0.0.0.0" ||
1200 _ifaceppp->data()->gateway() != "0.0.0.0") { 1200 _ifaceppp->data()->gateway() != "0.0.0.0") {
1201 if(_ifaceppp->data()->ipaddr() != "0.0.0.0") { 1201 if(_ifaceppp->data()->ipaddr() != "0.0.0.0") {
1202 command += " "; 1202 command += " ";
1203 command += _ifaceppp->data()->ipaddr(); 1203 command += _ifaceppp->data()->ipaddr();
1204 command += ":"; 1204 command += ":";
1205 } 1205 }
1206 else { 1206 else {
1207 command += " "; 1207 command += " ";
1208 command += ":"; 1208 command += ":";
1209 } 1209 }
1210 1210
1211 if(_ifaceppp->data()->gateway() != "0.0.0.0") 1211 if(_ifaceppp->data()->gateway() != "0.0.0.0")
1212 command += _ifaceppp->data()->gateway(); 1212 command += _ifaceppp->data()->gateway();
1213 } 1213 }
1214 1214
1215 if(_ifaceppp->data()->subnetmask() != "0.0.0.0") 1215 if(_ifaceppp->data()->subnetmask() != "0.0.0.0")
1216 command += " netmask " + _ifaceppp->data()->subnetmask(); 1216 command += " netmask " + _ifaceppp->data()->subnetmask();
1217 1217
1218 if(_ifaceppp->data()->flowcontrol() != "None") { 1218 if(_ifaceppp->data()->flowcontrol() != PPPData::FlowNone) {
1219 if(_ifaceppp->data()->flowcontrol() == "CRTSCTS") 1219 if(_ifaceppp->data()->flowcontrol() == PPPData::FlowHardware)
1220 command += " crtscts"; 1220 command += " crtscts";
1221 else 1221 else
1222 command += " xonxoff"; 1222 command += " xonxoff";
1223 } 1223 }
1224 1224
1225 if(_ifaceppp->data()->defaultroute()) 1225 if(_ifaceppp->data()->defaultroute())
1226 command += " defaultroute"; 1226 command += " defaultroute";
1227 1227
1228 if(_ifaceppp->data()->autoDNS()) 1228 if(_ifaceppp->data()->autoDNS())
1229 command += " usepeerdns"; 1229 command += " usepeerdns";
1230 1230
1231 1231
1232 // PAP settings 1232 // PAP settings
1233 if(_ifaceppp->data()->authMethod() == AUTH_PAP) { 1233 if(_ifaceppp->data()->authMethod() == AUTH_PAP) {
1234 command += " -chap user "; 1234 command += " -chap user ";
1235 command = command + _ifaceppp->data()->storedUsername(); 1235 command = command + _ifaceppp->data()->storedUsername();
1236 } 1236 }
1237 1237
1238 // CHAP settings 1238 // CHAP settings
1239 if(_ifaceppp->data()->authMethod() == AUTH_CHAP) { 1239 if(_ifaceppp->data()->authMethod() == AUTH_CHAP) {
1240 command += " -pap user "; 1240 command += " -pap user ";
1241 command = command + _ifaceppp->data()->storedUsername(); 1241 command = command + _ifaceppp->data()->storedUsername();
1242 } 1242 }
1243 1243
1244 // PAP/CHAP settings 1244 // PAP/CHAP settings
1245 if(_ifaceppp->data()->authMethod() == AUTH_PAPCHAP) { 1245 if(_ifaceppp->data()->authMethod() == AUTH_PAPCHAP) {
1246 QString tmpName = _ifaceppp->data()->storedUsername(); 1246 QString tmpName = _ifaceppp->data()->storedUsername();
1247 if ( !tmpName.isEmpty() ) { 1247 if ( !tmpName.isEmpty() ) {
1248 command += " user "; 1248 command += " user ";
1249 command = command + tmpName; 1249 command = command + tmpName;
1250 } 1250 }
1251 } 1251 }
1252 1252
1253 // check for debug 1253 // check for debug
1254 if(_ifaceppp->data()->getPPPDebug()) 1254 if(_ifaceppp->data()->getPPPDebug())
1255 command += " debug"; 1255 command += " debug";
1256 1256
1257 QStringList &arglist = _ifaceppp->data()->pppdArgument(); 1257 QStringList &arglist = _ifaceppp->data()->pppdArgument();
1258 for ( QStringList::Iterator it = arglist.begin(); 1258 for ( QStringList::Iterator it = arglist.begin();
1259 it != arglist.end(); 1259 it != arglist.end();
1260 ++it ) 1260 ++it )
1261 { 1261 {
1262 command += " " + *it; 1262 command += " " + *it;
1263 } 1263 }
1264 1264
1265 command += " call opie-kppp logfd 11"; 1265 command += " call opie-kppp logfd 11";
1266 1266
1267 if (command.length() > MAX_CMDLEN) { 1267 if (command.length() > MAX_CMDLEN) {
1268 QMessageBox::critical(this, "error", QObject::tr( 1268 QMessageBox::critical(this, "error", QObject::tr(
1269 "pppd command + command-line arguments exceed " 1269 "pppd command + command-line arguments exceed "
1270 "2024 characters in length." 1270 "2024 characters in length."
1271 )); 1271 ));
1272 1272
1273 return false; // nonsensically long command which would bust my buffer buf. 1273 return false; // nonsensically long command which would bust my buffer buf.
1274 } 1274 }
1275 1275
1276 owarn << "Command IS: " << command.latin1() << "" << oendl; 1276 owarn << "Command IS: " << command.latin1() << "" << oendl;
1277 1277
1278 qApp->flushX(); 1278 qApp->flushX();
1279 1279
1280 return _ifaceppp->modem()->execPPPDaemon(command); 1280 return _ifaceppp->modem()->execPPPDaemon(command);
1281} 1281}
1282 1282
1283 1283
1284void ConnectWidget::closeEvent( QCloseEvent *e ) { 1284void ConnectWidget::closeEvent( QCloseEvent *e ) {
1285 e->ignore(); 1285 e->ignore();
1286 emit cancelbutton(); 1286 emit cancelbutton();
1287} 1287}
1288 1288
1289 1289
1290void ConnectWidget::setMsg(const QString &msg) { 1290void ConnectWidget::setMsg(const QString &msg) {
1291 messg->setText(msg); 1291 messg->setText(msg);
1292} 1292}
1293 1293
1294void ConnectWidget::writeline(const QString &s) { 1294void ConnectWidget::writeline(const QString &s) {
1295 _ifaceppp->modem()->writeLine(s.local8Bit()); 1295 _ifaceppp->modem()->writeLine(s.local8Bit());
1296} 1296}
1297 1297
1298// Set the hostname and domain from DNS Server 1298// Set the hostname and domain from DNS Server
1299void auto_hostname(InterfacePPP *_ifaceppp) { 1299void auto_hostname(InterfacePPP *_ifaceppp) {
1300 struct in_addr local_ip; 1300 struct in_addr local_ip;
1301 struct hostent *hostname_entry; 1301 struct hostent *hostname_entry;
1302 QString new_hostname; 1302 QString new_hostname;
1303 int dot; 1303 int dot;
1304 char tmp_str[100]; // buffer overflow safe 1304 char tmp_str[100]; // buffer overflow safe
1305 1305
1306 gethostname(tmp_str, sizeof(tmp_str)); 1306 gethostname(tmp_str, sizeof(tmp_str));
1307 tmp_str[sizeof(tmp_str)-1]=0; // panic 1307 tmp_str[sizeof(tmp_str)-1]=0; // panic
1308 old_hostname=tmp_str; // copy to QString 1308 old_hostname=tmp_str; // copy to QString
1309 1309
1310 // if (!p_kppp->stats->local_ip_address.isEmpty() && _ifaceppp->data()->autoname()) { 1310 // if (!p_kppp->stats->local_ip_address.isEmpty() && _ifaceppp->data()->autoname()) {
1311 if ( _ifaceppp->data()->autoname()) { 1311 if ( _ifaceppp->data()->autoname()) {
1312// local_ip.s_addr=inet_addr(p_kppp->stats->local_ip_address.ascii()); 1312// local_ip.s_addr=inet_addr(p_kppp->stats->local_ip_address.ascii());
1313 hostname_entry=gethostbyaddr((const char *)&local_ip,sizeof(in_addr),AF_INET); 1313 hostname_entry=gethostbyaddr((const char *)&local_ip,sizeof(in_addr),AF_INET);
1314 1314
1315 if (hostname_entry != 0L) { 1315 if (hostname_entry != 0L) {
1316 new_hostname=hostname_entry->h_name; 1316 new_hostname=hostname_entry->h_name;
1317 dot=new_hostname.find('.'); 1317 dot=new_hostname.find('.');
1318 new_hostname=new_hostname.remove(dot,new_hostname.length()-dot); 1318 new_hostname=new_hostname.remove(dot,new_hostname.length()-dot);
1319 _ifaceppp->modem()->setHostname(new_hostname); 1319 _ifaceppp->modem()->setHostname(new_hostname);
1320 modified_hostname = TRUE; 1320 modified_hostname = TRUE;
1321 1321
1322 new_hostname=hostname_entry->h_name; 1322 new_hostname=hostname_entry->h_name;
1323 new_hostname.remove(0,dot+1); 1323 new_hostname.remove(0,dot+1);
1324 1324
1325 add_domain(new_hostname, _ifaceppp); 1325 add_domain(new_hostname, _ifaceppp);
1326 } 1326 }
1327 } 1327 }
1328 1328
1329} 1329}
1330 1330
1331// Replace the DNS domain entry in the /etc/resolv.conf file and 1331// Replace the DNS domain entry in the /etc/resolv.conf file and
1332// disable the nameserver entries if option is enabled 1332// disable the nameserver entries if option is enabled
1333void add_domain(const QString &domain, InterfacePPP *_ifaceppp) { 1333void add_domain(const QString &domain, InterfacePPP *_ifaceppp) {
1334 1334
1335 int fd; 1335 int fd;
1336 char c; 1336 char c;
1337 QString resolv[MAX_RESOLVCONF_LINES]; 1337 QString resolv[MAX_RESOLVCONF_LINES];
1338 1338
1339 if (domain.isEmpty()) 1339 if (domain.isEmpty())
1340 return; 1340 return;
1341 1341
1342 if((fd = _ifaceppp->modem()->openResolv(O_RDONLY)) >= 0) { 1342 if((fd = _ifaceppp->modem()->openResolv(O_RDONLY)) >= 0) {
1343 1343
1344 int i=0; 1344 int i=0;
1345 while((read(fd, &c, 1) == 1) && (i < MAX_RESOLVCONF_LINES)) { 1345 while((read(fd, &c, 1) == 1) && (i < MAX_RESOLVCONF_LINES)) {
1346 if(c == '\n') { 1346 if(c == '\n') {
1347 i++; 1347 i++;
1348 } 1348 }
1349 else { 1349 else {
1350 resolv[i] += c; 1350 resolv[i] += c;
1351 } 1351 }
1352 } 1352 }
1353 close(fd); 1353 close(fd);
1354 if ((c != '\n') && (i < MAX_RESOLVCONF_LINES)) i++; 1354 if ((c != '\n') && (i < MAX_RESOLVCONF_LINES)) i++;
1355 1355
1356 if((fd = _ifaceppp->modem()->openResolv(O_WRONLY|O_TRUNC)) >= 0) { 1356 if((fd = _ifaceppp->modem()->openResolv(O_WRONLY|O_TRUNC)) >= 0) {
1357 QCString tmp = "domain " + domain.local8Bit() + 1357 QCString tmp = "domain " + domain.local8Bit() +
1358 " \t\t#kppp temp entry\n"; 1358 " \t\t#kppp temp entry\n";
1359 write(fd, tmp.data(), tmp.length()); 1359 write(fd, tmp.data(), tmp.length());
1360 1360
1361 for(int j=0; j < i; j++) { 1361 for(int j=0; j < i; j++) {
1362 if((resolv[j].contains("domain") || 1362 if((resolv[j].contains("domain") ||
1363 ( resolv[j].contains("nameserver") 1363 ( resolv[j].contains("nameserver")
1364 && !resolv[j].contains("#kppp temp entry") 1364 && !resolv[j].contains("#kppp temp entry")
1365 && _ifaceppp->data()->exDNSDisabled())) 1365 && _ifaceppp->data()->exDNSDisabled()))
1366 && !resolv[j].contains("#entry disabled by kppp")) { 1366 && !resolv[j].contains("#entry disabled by kppp")) {
1367 QCString tmp = "# " + resolv[j].local8Bit() + 1367 QCString tmp = "# " + resolv[j].local8Bit() +
1368 " \t#entry disabled by kppp\n"; 1368 " \t#entry disabled by kppp\n";
1369 write(fd, tmp, tmp.length()); 1369 write(fd, tmp, tmp.length());
1370 } 1370 }
1371 else { 1371 else {
1372 QCString tmp = resolv[j].local8Bit() + "\n"; 1372 QCString tmp = resolv[j].local8Bit() + "\n";
1373 write(fd, tmp, tmp.length()); 1373 write(fd, tmp, tmp.length());
1374 } 1374 }
1375 } 1375 }
1376 } 1376 }
1377 close(fd); 1377 close(fd);
1378 } 1378 }
1379} 1379}
1380 1380
1381 1381
1382// adds the DNS entries in the /etc/resolv.conf file 1382// adds the DNS entries in the /etc/resolv.conf file
1383void adddns( InterfacePPP *_ifaceppp) 1383void adddns( InterfacePPP *_ifaceppp)
1384{ 1384{
1385 int fd; 1385 int fd;
1386 1386
1387 if ((fd = _ifaceppp->modem()->openResolv(O_WRONLY|O_APPEND)) >= 0) { 1387 if ((fd = _ifaceppp->modem()->openResolv(O_WRONLY|O_APPEND)) >= 0) {
1388 QStringList &dnslist = _ifaceppp->data()->dns(); 1388 QStringList &dnslist = _ifaceppp->data()->dns();
1389 for ( QStringList::Iterator it = dnslist.begin(); 1389 for ( QStringList::Iterator it = dnslist.begin();
1390 it != dnslist.end(); 1390 it != dnslist.end();
1391 ++it ) 1391 ++it )
1392 { 1392 {
1393 QCString dns = "nameserver " + (*it).local8Bit() + 1393 QCString dns = "nameserver " + (*it).local8Bit() +
1394 " \t#kppp temp entry\n"; 1394 " \t#kppp temp entry\n";
1395 write(fd, dns.data(), dns.length()); 1395 write(fd, dns.data(), dns.length());
1396 } 1396 }
1397 close(fd); 1397 close(fd);
1398 } 1398 }
1399 add_domain(_ifaceppp->data()->domain(), _ifaceppp); 1399 add_domain(_ifaceppp->data()->domain(), _ifaceppp);
1400} 1400}
1401 1401
1402void addpeerdns(InterfacePPP *_ifaceppp) { 1402void addpeerdns(InterfacePPP *_ifaceppp) {
1403 int fd, fd2; 1403 int fd, fd2;
1404 1404
1405 if((fd = _ifaceppp->modem()->openResolv(O_WRONLY|O_APPEND)) >= 0) { 1405 if((fd = _ifaceppp->modem()->openResolv(O_WRONLY|O_APPEND)) >= 0) {
1406 if((fd2 = open("/etc/ppp/resolv.conf", O_RDONLY)) >= 0) { 1406 if((fd2 = open("/etc/ppp/resolv.conf", O_RDONLY)) >= 0) {
1407 char c; 1407 char c;
1408 int i = 0; 1408 int i = 0;
1409 while(i++ < 100 && read(fd2, &c, 1) == 1) { 1409 while(i++ < 100 && read(fd2, &c, 1) == 1) {
1410 if(c == '\n') 1410 if(c == '\n')
1411 write(fd, "\t#kppp temp entry\n", 18); 1411 write(fd, "\t#kppp temp entry\n", 18);
1412 else 1412 else
1413 write(fd, &c, 1); 1413 write(fd, &c, 1);
1414 } 1414 }
1415 close(fd2); 1415 close(fd2);
1416 } else 1416 } else
1417 fprintf(stderr, "failed to read from /etc/ppp/resolv.conf\n"); 1417 fprintf(stderr, "failed to read from /etc/ppp/resolv.conf\n");
1418 close(fd); 1418 close(fd);
1419 } 1419 }
1420 add_domain(_ifaceppp->data()->domain(), _ifaceppp); 1420 add_domain(_ifaceppp->data()->domain(), _ifaceppp);
1421} 1421}
1422 1422
1423// remove the dns entries from the /etc/resolv.conf file 1423// remove the dns entries from the /etc/resolv.conf file
1424void removedns(InterfacePPP *_ifaceppp) { 1424void removedns(InterfacePPP *_ifaceppp) {
1425 1425
1426 int fd; 1426 int fd;
1427 char c; 1427 char c;
1428 QString resolv[MAX_RESOLVCONF_LINES]; 1428 QString resolv[MAX_RESOLVCONF_LINES];
1429 1429
1430 if((fd = _ifaceppp->modem()->openResolv(O_RDONLY)) >= 0) { 1430 if((fd = _ifaceppp->modem()->openResolv(O_RDONLY)) >= 0) {
1431 1431
1432 int i=0; 1432 int i=0;
1433 while(read(fd, &c, 1) == 1 && i < MAX_RESOLVCONF_LINES) { 1433 while(read(fd, &c, 1) == 1 && i < MAX_RESOLVCONF_LINES) {
1434 if(c == '\n') { 1434 if(c == '\n') {
1435 i++; 1435 i++;
1436 } 1436 }
1437 else { 1437 else {
1438 resolv[i] += c; 1438 resolv[i] += c;
1439 } 1439 }
1440 } 1440 }
1441 close(fd); 1441 close(fd);
1442 1442
1443 if((fd = _ifaceppp->modem()->openResolv(O_WRONLY|O_TRUNC)) >= 0) { 1443 if((fd = _ifaceppp->modem()->openResolv(O_WRONLY|O_TRUNC)) >= 0) {
1444 for(int j=0; j < i; j++) { 1444 for(int j=0; j < i; j++) {
1445 if(resolv[j].contains("#kppp temp entry")) continue; 1445 if(resolv[j].contains("#kppp temp entry")) continue;
1446 if(resolv[j].contains("#entry disabled by kppp")) { 1446 if(resolv[j].contains("#entry disabled by kppp")) {
1447 QCString tmp = resolv[j].local8Bit(); 1447 QCString tmp = resolv[j].local8Bit();
1448 write(fd, tmp.data()+2, tmp.length() - 27); 1448 write(fd, tmp.data()+2, tmp.length() - 27);
1449 write(fd, "\n", 1); 1449 write(fd, "\n", 1);
1450 } 1450 }
1451 else { 1451 else {
1452 QCString tmp = resolv[j].local8Bit() + "\n"; 1452 QCString tmp = resolv[j].local8Bit() + "\n";
1453 write(fd, tmp, tmp.length()); 1453 write(fd, tmp, tmp.length());
1454 } 1454 }
1455 } 1455 }
1456 } 1456 }
1457 close(fd); 1457 close(fd);
1458 1458
1459 } 1459 }
1460 1460
1461 if ( modified_hostname ) { 1461 if ( modified_hostname ) {
1462 _ifaceppp->modem()->setHostname(old_hostname); 1462 _ifaceppp->modem()->setHostname(old_hostname);
1463 modified_hostname = FALSE; 1463 modified_hostname = FALSE;
1464 } 1464 }
1465 1465
1466} 1466}
1467 1467
1468 1468
diff --git a/noncore/settings/networksettings/ppp/general.cpp b/noncore/settings/networksettings/ppp/general.cpp
index 5e2a04f..9457173 100644
--- a/noncore/settings/networksettings/ppp/general.cpp
+++ b/noncore/settings/networksettings/ppp/general.cpp
@@ -1,558 +1,544 @@
1/* 1/*
2 * kPPP: A pppd front end for the KDE project 2 * kPPP: A pppd front end for the KDE project
3 * 3 *
4 * $Id$ 4 * $Id$
5 * 5 *
6 * Copyright (C) 1997 Bernd Johannes Wuebben 6 * Copyright (C) 1997 Bernd Johannes Wuebben
7 * wuebben@math.cornell.edu 7 * wuebben@math.cornell.edu
8 * 8 *
9 * based on EzPPP: 9 * based on EzPPP:
10 * Copyright (C) 1997 Jay Painter 10 * Copyright (C) 1997 Jay Painter
11 * 11 *
12 * This program is free software; you can redistribute it and/or 12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU Library General Public 13 * modify it under the terms of the GNU Library General Public
14 * License as published by the Free Software Foundation; either 14 * License as published by the Free Software Foundation; either
15 * version 2 of the License, or (at your option) any later version. 15 * version 2 of the License, or (at your option) any later version.
16 * 16 *
17 * This program is distributed in the hope that it will be useful, 17 * This program is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of 18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 * Library General Public License for more details. 20 * Library General Public License for more details.
21 * 21 *
22 * You should have received a copy of the GNU Library General Public 22 * You should have received a copy of the GNU Library General Public
23 * License along with this program; if not, write to the Free 23 * License along with this program; if not, write to the Free
24 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 24 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
25 */ 25 */
26 26
27#include "general.h" 27#include "general.h"
28#include "interfaceppp.h" 28#include "interfaceppp.h"
29#include "modeminfo.h" 29#include "modeminfo.h"
30#include "modemcmds.h" 30#include "modemcmds.h"
31#include "pppdata.h" 31#include "pppdata.h"
32 32
33/* OPIE */ 33/* OPIE */
34#include <opie2/odebug.h> 34#include <opie2/odebug.h>
35#include <qpe/config.h> 35#include <qpe/config.h>
36#include <qpe/qpeapplication.h> 36#include <qpe/qpeapplication.h>
37using namespace Opie::Core; 37using namespace Opie::Core;
38 38
39/* QT */ 39/* QT */
40#include <qcheckbox.h> 40#include <qcheckbox.h>
41#include <qcombobox.h> 41#include <qcombobox.h>
42#include <qlabel.h> 42#include <qlabel.h>
43#include <qlayout.h> 43#include <qlayout.h>
44#include <qpushbutton.h> 44#include <qpushbutton.h>
45#include <qslider.h> 45#include <qslider.h>
46#include <qspinbox.h> 46#include <qspinbox.h>
47#include <qwhatsthis.h> 47#include <qwhatsthis.h>
48 48
49/* STD */ 49/* STD */
50#include <termios.h> 50#include <termios.h>
51#include <string.h> 51#include <string.h>
52 52
53 53
54ModemWidget::ModemWidget( PPPData *pd, QWidget *parent, const char *name ) 54ModemWidget::ModemWidget( PPPData *pd, QWidget *parent, const char *name )
55 : QWidget(parent, name), _pppdata(pd) 55 : QWidget(parent, name), _pppdata(pd)
56{ 56{
57 int k; 57 int k;
58 58
59 QGridLayout *tl = new QGridLayout(this, 8, 2, 0 );//, KDialog::spacingHint()); 59 QGridLayout *tl = new QGridLayout(this, 8, 2, 0 );//, KDialog::spacingHint());
60 60
61 QLabel *label1; 61 QLabel *label1;
62 62
63 label1 = new QLabel(tr("Modem &name:"), this); 63 label1 = new QLabel(tr("Modem &name:"), this);
64 tl->addWidget(label1, 0, 0); 64 tl->addWidget(label1, 0, 0);
65 65
66 modemname = new QLineEdit(this, "modemName"); 66 modemname = new QLineEdit(this, "modemName");
67 modemname->setText( _pppdata->devname() ); 67 modemname->setText( _pppdata->devname() );
68 label1->setBuddy(modemname); 68 label1->setBuddy(modemname);
69 tl->addWidget(modemname, 0, 1); 69 tl->addWidget(modemname, 0, 1);
70 70
71 label1 = new QLabel(tr("Modem de&vice:"), this); 71 label1 = new QLabel(tr("Modem de&vice:"), this);
72 tl->addWidget(label1, 1, 0); 72 tl->addWidget(label1, 1, 0);
73 73
74 modemdevice = new QComboBox(false, this); 74 modemdevice = new QComboBox(false, this);
75 modemdevice->setEditable( true ); 75 modemdevice->setEditable( true );
76 modemdevice->setDuplicatesEnabled ( false ); 76 modemdevice->setDuplicatesEnabled ( false );
77 modemdevice->setInsertionPolicy( QComboBox::AtTop ); 77 modemdevice->setInsertionPolicy( QComboBox::AtTop );
78 label1->setBuddy(modemdevice); 78 label1->setBuddy(modemdevice);
79 79
80 Config cfg("NetworkSetupPPP"); 80 Config cfg("NetworkSetupPPP");
81 cfg.setGroup("Devices_General"); 81 cfg.setGroup("Devices_General");
82 QStringList devs = cfg.readListEntry("devices",','); 82 QStringList devs = cfg.readListEntry("devices",',');
83 if (devs.isEmpty()) devs << "/dev/modem" << "/dev/ircomm0" << "/dev/ttyS0"; 83 if (devs.isEmpty()) devs << "/dev/modem" << "/dev/ircomm0" << "/dev/ttyS0";
84 modemdevice->insertStringList( devs ); 84 modemdevice->insertStringList( devs );
85 tl->addWidget(modemdevice, 1, 1); 85 tl->addWidget(modemdevice, 1, 1);
86 86
87 // connect(modemdevice, SIGNAL(activated(int)), 87 // connect(modemdevice, SIGNAL(activated(int)),
88 // SLOT(setmodemdc(int))); 88 // SLOT(setmodemdc(int)));
89 // connect(modemdevice, SIGNAL(textChanged(const QString&) ), 89 // connect(modemdevice, SIGNAL(textChanged(const QString&) ),
90 // SLOT( setmodemdc(const QString&) ) ); 90 // SLOT( setmodemdc(const QString&) ) );
91 91
92 QString tmp = tr("This specifies the serial port your modem is attached \n" 92 QString tmp = tr("This specifies the serial port your modem is attached \n"
93 "to. On Linux/x86, typically this is either /dev/ttyS0 \n" 93 "to. On Linux/x86, typically this is either /dev/ttyS0 \n"
94 "(COM1 under DOS) or /dev/ttyS1 (COM2 under DOS).\n" 94 "(COM1 under DOS) or /dev/ttyS1 (COM2 under DOS).\n"
95 "\n" 95 "\n"
96 "If you have an internal ISDN card with AT command\n" 96 "If you have an internal ISDN card with AT command\n"
97 "emulation (most cards under Linux support this), you\n" 97 "emulation (most cards under Linux support this), you\n"
98 "should select one of the /dev/ttyIx devices."); 98 "should select one of the /dev/ttyIx devices.");
99 99
100 QWhatsThis::add(label1,tmp); 100 QWhatsThis::add(label1,tmp);
101 QWhatsThis::add(modemdevice,tmp); 101 QWhatsThis::add(modemdevice,tmp);
102 102
103 103
104 label1 = new QLabel(tr("&Flow control:"), this); 104 label1 = new QLabel(tr("&Flow control:"), this);
105 tl->addWidget(label1, 2, 0); 105 tl->addWidget(label1, 2, 0);
106 106
107 flowcontrol = new QComboBox(false, this); 107 flowcontrol = new QComboBox(false, this);
108 label1->setBuddy(flowcontrol); 108 label1->setBuddy(flowcontrol);
109 flowcontrol->insertItem(tr("Hardware [CRTSCTS]")); 109 flowcontrol->insertItem(tr("Hardware [CRTSCTS]"));
110 flowcontrol->insertItem(tr("Software [XON/XOFF]")); 110 flowcontrol->insertItem(tr("Software [XON/XOFF]"));
111 flowcontrol->insertItem(tr("None")); 111 flowcontrol->insertItem(tr("None"));
112 tl->addWidget(flowcontrol, 2, 1); 112 tl->addWidget(flowcontrol, 2, 1);
113 // connect(flowcontrol, SIGNAL(activated(int)), 113 // connect(flowcontrol, SIGNAL(activated(int)),
114 // SLOT(setflowcontrol(int))); 114 // SLOT(setflowcontrol(int)));
115 115
116 tmp = tr("<p>Specifies how the serial port and modem\n" 116 tmp = tr("<p>Specifies how the serial port and modem\n"
117 "communicate. You should not change this unless\n" 117 "communicate. You should not change this unless\n"
118 "you know what you are doing.\n" 118 "you know what you are doing.\n"
119 "\n" 119 "\n"
120 "<b>Default</b>: CRTSCTS"); 120 "<b>Default</b>: CRTSCTS");
121 121
122 QWhatsThis::add(label1,tmp); 122 QWhatsThis::add(label1,tmp);
123 QWhatsThis::add(flowcontrol,tmp); 123 QWhatsThis::add(flowcontrol,tmp);
124 124
125 QLabel *labelenter = new QLabel(tr("&Line termination:"), this); 125 QLabel *labelenter = new QLabel(tr("&Line termination:"), this);
126 tl->addWidget(labelenter, 3, 0); 126 tl->addWidget(labelenter, 3, 0);
127 127
128 enter = new QComboBox(false, this); 128 enter = new QComboBox(false, this);
129 labelenter->setBuddy(enter); 129 labelenter->setBuddy(enter);
130 enter->insertItem("CR"); 130 enter->insertItem("CR");
131 enter->insertItem("LF"); 131 enter->insertItem("LF");
132 enter->insertItem("CR/LF"); 132 enter->insertItem("CR/LF");
133 tl->addWidget(enter, 3, 1); 133 tl->addWidget(enter, 3, 1);
134 // connect(enter, SIGNAL(activated(int)), SLOT(setenter(int))); 134 // connect(enter, SIGNAL(activated(int)), SLOT(setenter(int)));
135 tmp = tr("<p>Specifies how AT commands are sent to your\n" 135 tmp = tr("<p>Specifies how AT commands are sent to your\n"
136 "modem. Most modems will work fine with the\n" 136 "modem. Most modems will work fine with the\n"
137 "default <i>CR/LF</i>. If your modem does not react\n" 137 "default <i>CR/LF</i>. If your modem does not react\n"
138 "to the init string, you should try different\n" 138 "to the init string, you should try different\n"
139 "settings here\n" 139 "settings here\n"
140 "\n" 140 "\n"
141 "<b>Default</b>: CR/LF"); 141 "<b>Default</b>: CR/LF");
142 142
143 QWhatsThis::add(labelenter,tmp); 143 QWhatsThis::add(labelenter,tmp);
144 QWhatsThis::add(enter, tmp); 144 QWhatsThis::add(enter, tmp);
145 145
146 QLabel *baud_label = new QLabel(tr("Co&nnection speed:"), this); 146 QLabel *baud_label = new QLabel(tr("Co&nnection speed:"), this);
147 tl->addWidget(baud_label, 4, 0); 147 tl->addWidget(baud_label, 4, 0);
148 baud_c = new QComboBox(this); 148 baud_c = new QComboBox(this);
149 baud_label->setBuddy(baud_c); 149 baud_label->setBuddy(baud_c);
150 150
151 static const char *baudrates[] = 151 static const char *baudrates[] =
152 { 152 {
153 153
154#ifdef B460800 154#ifdef B460800
155 "460800", 155 "460800",
156#endif 156#endif
157 157
158#ifdef B230400 158#ifdef B230400
159 "230400", 159 "230400",
160#endif 160#endif
161 161
162#ifdef B115200 162#ifdef B115200
163 "115200", 163 "115200",
164#endif 164#endif
165 165
166#ifdef B57600 166#ifdef B57600
167 "57600", 167 "57600",
168#endif 168#endif
169 169
170 "38400", 170 "38400",
171 "19200", 171 "19200",
172 "9600", 172 "9600",
173 "2400", 173 "2400",
174 0 174 0
175 }; 175 };
176 176
177 for(k = 0; baudrates[k]; k++) 177 for(k = 0; baudrates[k]; k++)
178 baud_c->insertItem(baudrates[k]); 178 baud_c->insertItem(baudrates[k]);
179 179
180 baud_c->setCurrentItem(3); 180 baud_c->setCurrentItem(3);
181 // connect(baud_c, SIGNAL(activated(int)), 181 // connect(baud_c, SIGNAL(activated(int)),
182 // this, SLOT(speed_selection(int))); 182 // this, SLOT(speed_selection(int)));
183 tl->addWidget(baud_c, 4, 1); 183 tl->addWidget(baud_c, 4, 1);
184 184
185 tmp = tr("Specifies the speed your modem and the serial\n" 185 tmp = tr("Specifies the speed your modem and the serial\n"
186 "port talk to each other. You should begin with\n" 186 "port talk to each other. You should begin with\n"
187 "the default of 38400 bits/sec. If everything\n" 187 "the default of 38400 bits/sec. If everything\n"
188 "works you can try to increase this value, but to\n" 188 "works you can try to increase this value, but to\n"
189 "no more than 115200 bits/sec (unless you know\n" 189 "no more than 115200 bits/sec (unless you know\n"
190 "that your serial port supports higher speeds)."); 190 "that your serial port supports higher speeds).");
191 191
192 QWhatsThis::add(baud_label,tmp); 192 QWhatsThis::add(baud_label,tmp);
193 QWhatsThis::add(baud_c,tmp); 193 QWhatsThis::add(baud_c,tmp);
194 194
195 for(int i=0; i <= enter->count()-1; i++)
196 {
197 if(_pppdata->enter() == enter->text(i))
198 enter->setCurrentItem(i);
199 }
200
201 tl->addRowSpacing(5, 10); 195 tl->addRowSpacing(5, 10);
202 196
203 //Modem Lock File 197 //Modem Lock File
204 modemlockfile = new QCheckBox(tr("&Use lock file"), this); 198 modemlockfile = new QCheckBox(tr("&Use lock file"), this);
205
206 modemlockfile->setChecked(_pppdata->modemLockFile()); 199 modemlockfile->setChecked(_pppdata->modemLockFile());
207 // connect(modemlockfile, SIGNAL(toggled(bool)), 200 // connect(modemlockfile, SIGNAL(toggled(bool)),
208 // SLOT(modemlockfilechanged(bool))); 201 // SLOT(modemlockfilechanged(bool)));
209 tl->addMultiCellWidget(modemlockfile, 6, 6, 0, 1); 202 tl->addMultiCellWidget(modemlockfile, 6, 6, 0, 1);
210 // l12->addStretch(1); 203 // l12->addStretch(1);
211 QWhatsThis::add(modemlockfile, 204 QWhatsThis::add(modemlockfile,
212 tr("<p>To prevent other programs from accessing the\n" 205 tr("<p>To prevent other programs from accessing the\n"
213 "modem while a connection is established, a\n" 206 "modem while a connection is established, a\n"
214 "file can be created to indicate that the modem\n" 207 "file can be created to indicate that the modem\n"
215 "is in use. On Linux an example file would be\n" 208 "is in use. On Linux an example file would be\n"
216 "<tt>/var/lock/LCK..ttyS1</tt>\n" 209 "<tt>/var/lock/LCK..ttyS1</tt>\n"
217 "Here you can select whether this locking will\n" 210 "Here you can select whether this locking will\n"
218 "be done.\n" 211 "be done.\n"
219 "\n" 212 "\n"
220 "<b>Default</b>: On")); 213 "<b>Default</b>: On"));
221 214
222 // Modem Timeout Line Edit Box 215 // Modem Timeout Line Edit Box
223 QHBoxLayout *timeoutLayout = new QHBoxLayout( this ); 216 QHBoxLayout *timeoutLayout = new QHBoxLayout( this );
224 QLabel *timeoutlabel = new QLabel( tr("Modem timeout:") ,this, "timeout" ); 217 QLabel *timeoutlabel = new QLabel( tr("Modem timeout:") ,this, "timeout" );
225 modemtimeout = new QSpinBox( 1, 120, 1, this, "modemTimeout" ); 218 modemtimeout = new QSpinBox( 1, 120, 1, this, "modemTimeout" );
226 // modemtimeout = new KIntNumInput(_pppdata->modemTimeout(), this); 219 // modemtimeout = new KIntNumInput(_pppdata->modemTimeout(), this);
227 // modemtimeout->setLabel(tr("Modem &timeout:")); 220 // modemtimeout->setLabel(tr("Modem &timeout:"));
228 // modemtimeout->setRange(1, 120, 1); 221 // modemtimeout->setRange(1, 120, 1);
229 modemtimeout->setSuffix(tr(" sec")); 222 modemtimeout->setSuffix(tr(" sec"));
230 modemtimeout->setValue( _pppdata->modemTimeout() ); 223 modemtimeout->setValue( _pppdata->modemTimeout() );
231 // connect(modemtimeout, SIGNAL(valueChanged(int)), 224 // connect(modemtimeout, SIGNAL(valueChanged(int)),
232 // SLOT(modemtimeoutchanged(int))); 225 // SLOT(modemtimeoutchanged(int)));
233 timeoutLayout->addWidget(timeoutlabel); 226 timeoutLayout->addWidget(timeoutlabel);
234 timeoutLayout->addWidget(modemtimeout); 227 timeoutLayout->addWidget(modemtimeout);
235 tl->addMultiCellLayout(timeoutLayout, 7, 7, 0, 1); 228 tl->addMultiCellLayout(timeoutLayout, 7, 7, 0, 1);
236 229
237 QWhatsThis::add(modemtimeout, 230 QWhatsThis::add(modemtimeout,
238 tr("This specifies how long <i>kppp</i> waits for a\n" 231 tr("This specifies how long <i>kppp</i> waits for a\n"
239 "<i>CONNECT</i> response from your modem. The\n" 232 "<i>CONNECT</i> response from your modem. The\n"
240 "recommended value is 30 seconds.")); 233 "recommended value is 30 seconds."));
241 234
242 //set stuff from gpppdata 235 //set stuff from gpppdata
243 for(int i=0; i <= enter->count()-1; i++) 236 enter->setCurrentItem( static_cast<int>(_pppdata->enter()) );
244 { 237 flowcontrol->setCurrentItem( static_cast<int>( _pppdata->flowcontrol() ) );
245 if(_pppdata->enter() == enter->text(i))
246 enter->setCurrentItem(i);
247 }
248 238
249 for(int i=0; i <= modemdevice->count()-1; i++) 239 for(int i=0; i <= modemdevice->count()-1; i++)
250 { 240 {
251 if(_pppdata->modemDevice() == modemdevice->text(i)) 241 if(_pppdata->modemDevice() == modemdevice->text(i))
252 modemdevice->setCurrentItem(i); 242 modemdevice->setCurrentItem(i);
253 } 243 }
254 244
255 for(int i=0; i <= flowcontrol->count()-1; i++)
256 {
257 if(_pppdata->flowcontrol() == flowcontrol->text(i))
258 flowcontrol->setCurrentItem(i);
259 }
260
261 //set the modem speed 245 //set the modem speed
262 for(int i=0; i < baud_c->count(); i++) 246 for(int i=0; i < baud_c->count(); i++)
263 if(baud_c->text(i) == _pppdata->speed()) 247 if(baud_c->text(i) == _pppdata->speed())
264 baud_c->setCurrentItem(i); 248 baud_c->setCurrentItem(i);
265 249
266 tl->setRowStretch(1, 1); 250 tl->setRowStretch(1, 1);
267} 251}
268 252
269ModemWidget::~ModemWidget() 253ModemWidget::~ModemWidget()
270{ 254{
271 QStringList devs; 255 QStringList devs;
272 256
273 for (int i=0;i<modemdevice->count();i++) 257 for (int i=0;i<modemdevice->count();i++)
274 { 258 {
275 QString s = modemdevice->text(i); 259 QString s = modemdevice->text(i);
276 s.simplifyWhiteSpace(); 260 s.simplifyWhiteSpace();
277 if (! s.isEmpty() ) devs << s; 261 if (! s.isEmpty() ) devs << s;
278 } 262 }
279 263
280 264
281 QString edited = modemdevice->currentText(); 265 QString edited = modemdevice->currentText();
282 if ( !( edited ).isEmpty() ) 266 if ( !( edited ).isEmpty() )
283 { 267 {
284 edited.simplifyWhiteSpace(); 268 edited.simplifyWhiteSpace();
285 if ( devs.contains( edited ) == 0 ) 269 if ( devs.contains( edited ) == 0 )
286 { 270 {
287 devs << edited; 271 devs << edited;
288 } 272 }
289 } 273 }
290 274
291 275
292 Config cfg("NetworkSetupPPP"); 276 Config cfg("NetworkSetupPPP");
293 cfg.setGroup("Devices_General"); 277 cfg.setGroup("Devices_General");
294 cfg.writeEntry("devices",devs,','); 278 cfg.writeEntry("devices",devs,',');
295 279
296} 280}
297 281
298// void ModemWidget::speed_selection(int) { 282// void ModemWidget::speed_selection(int) {
299// _pppdata->setSpeed(baud_c->text(baud_c->currentItem())); 283// _pppdata->setSpeed(baud_c->text(baud_c->currentItem()));
300// } 284// }
301 285
302 286
303// void ModemWidget::setenter(int ) { 287// void ModemWidget::setenter(int ) {
304// _pppdata->setEnter(enter->text(enter->currentItem())); 288// _pppdata->setEnter(enter->text(enter->currentItem()));
305// } 289// }
306 290
307 291
308// void ModemWidget::setmodemdc(int i) { 292// void ModemWidget::setmodemdc(int i) {
309// _pppdata->setModemDevice(modemdevice->text(i)); 293// _pppdata->setModemDevice(modemdevice->text(i));
310// } 294// }
311 295
312// void ModemWidget::setmodemdc( const QString &string ) { 296// void ModemWidget::setmodemdc( const QString &string ) {
313// _pppdata->setModemDevice( string ); 297// _pppdata->setModemDevice( string );
314// } 298// }
315 299
316// void ModemWidget::setflowcontrol(int i) { 300// void ModemWidget::setflowcontrol(int i) {
317// _pppdata->setFlowcontrol(flowcontrol->text(i)); 301// _pppdata->setFlowcontrol(flowcontrol->text(i));
318// } 302// }
319 303
320 304
321// void ModemWidget::modemlockfilechanged(bool set) { 305// void ModemWidget::modemlockfilechanged(bool set) {
322// _pppdata->setModemLockFile(set); 306// _pppdata->setModemLockFile(set);
323// } 307// }
324 308
325 309
326// void ModemWidget::modemtimeoutchanged(int n) { 310// void ModemWidget::modemtimeoutchanged(int n) {
327// _pppdata->setModemTimeout(n); 311// _pppdata->setModemTimeout(n);
328// } 312// }
329 313
330 314
331 315
332bool ModemWidget::save() 316bool ModemWidget::save()
333{ 317{
334 //first check to make sure that the device name is unique! 318 //first check to make sure that the device name is unique!
335 if(modemname->text().isEmpty() || 319 if(modemname->text().isEmpty() ||
336 !_pppdata->isUniqueDevname(modemname->text())) 320 !_pppdata->isUniqueDevname(modemname->text()))
337 return false; 321 return false;
338 322
339 _pppdata->setDevname( modemname->text() ); 323 _pppdata->setDevname( modemname->text() );
340 _pppdata->setModemDevice( modemdevice->currentText() ); 324 _pppdata->setModemDevice( modemdevice->currentText() );
341 _pppdata->setFlowcontrol(flowcontrol->currentText()); 325 _pppdata->setFlowcontrol(static_cast<PPPData::FlowControl>(flowcontrol->currentItem()));
342 _pppdata->setFlowcontrol(flowcontrol->currentText()); 326 _pppdata->setEnter( static_cast<PPPData::LineTermination>(enter->currentItem()));
343 _pppdata->setSpeed(baud_c->currentText()); 327 _pppdata->setSpeed(baud_c->currentText());
344 _pppdata->setModemLockFile( modemlockfile->isChecked()); 328 _pppdata->setModemLockFile( modemlockfile->isChecked());
345 _pppdata->setModemTimeout( modemtimeout->value() ); 329 _pppdata->setModemTimeout( modemtimeout->value() );
346 return true; 330 return true;
347 331
348} 332}
349 333
350void ModemWidget::slotBeforeModemQuery() 334void ModemWidget::slotBeforeModemQuery()
351{ 335{
352 m_oldModemDev = _pppdata->modemDevice(); 336 m_oldModemDev = _pppdata->modemDevice();
353 m_oldFlowControl = _pppdata->flowcontrol(); 337 m_oldFlowControl = static_cast<int>( _pppdata->flowcontrol() );
354 m_oldSpeed = _pppdata->speed(); 338 m_oldSpeed = _pppdata->speed();
355 m_oldModemLock = _pppdata->modemLockFile(); 339 m_oldModemLock = _pppdata->modemLockFile();
356 m_oldModemTimeout = _pppdata->modemTimeout(); 340 m_oldModemTimeout = _pppdata->modemTimeout();
341 m_oldLineEnd = static_cast<int>( _pppdata->enter() );
357 342
358 343
359 _pppdata->setModemDevice( modemdevice->currentText() ); 344 _pppdata->setModemDevice( modemdevice->currentText() );
360 _pppdata->setFlowcontrol(flowcontrol->currentText()); 345 _pppdata->setFlowcontrol(static_cast<PPPData::FlowControl>(flowcontrol->currentItem()));
361 _pppdata->setFlowcontrol(flowcontrol->currentText()); 346 _pppdata->setEnter(static_cast<PPPData::LineTermination>(enter->currentItem()));
362 _pppdata->setSpeed(baud_c->currentText()); 347 _pppdata->setSpeed(baud_c->currentText());
363 _pppdata->setModemLockFile( modemlockfile->isChecked()); 348 _pppdata->setModemLockFile( modemlockfile->isChecked());
364 _pppdata->setModemTimeout( modemtimeout->value() ); 349 _pppdata->setModemTimeout( modemtimeout->value() );
365} 350}
366 351
367 352
368void ModemWidget::slotAfterModemQuery() 353void ModemWidget::slotAfterModemQuery()
369{ 354{
370 _pppdata->setModemDevice( m_oldModemDev ); 355 _pppdata->setModemDevice( m_oldModemDev );
371 _pppdata->setFlowcontrol( m_oldFlowControl ); 356 _pppdata->setFlowcontrol( static_cast<PPPData::FlowControl>(m_oldFlowControl) );
357 _pppdata->setEnter( static_cast<PPPData::LineTermination>(m_oldLineEnd) );
372 _pppdata->setSpeed( m_oldSpeed ); 358 _pppdata->setSpeed( m_oldSpeed );
373 _pppdata->setModemLockFile( m_oldModemLock ); 359 _pppdata->setModemLockFile( m_oldModemLock );
374 _pppdata->setModemTimeout( m_oldModemTimeout ); 360 _pppdata->setModemTimeout( m_oldModemTimeout );
375} 361}
376 362
377 363
378ModemWidget2::ModemWidget2( PPPData *pd, InterfacePPP *ip, QWidget *parent, 364ModemWidget2::ModemWidget2( PPPData *pd, InterfacePPP *ip, QWidget *parent,
379 const char *name) 365 const char *name)
380 : QWidget(parent, name), _pppdata(pd), _ifaceppp(ip) 366 : QWidget(parent, name), _pppdata(pd), _ifaceppp(ip)
381{ 367{
382 QVBoxLayout *l1 = new QVBoxLayout(this, 0 );//, KDialog::spacingHint()); 368 QVBoxLayout *l1 = new QVBoxLayout(this, 0 );//, KDialog::spacingHint());
383 369
384 370
385 waitfordt = new QCheckBox(tr("&Wait for dial tone before dialing"), this); 371 waitfordt = new QCheckBox(tr("&Wait for dial tone before dialing"), this);
386 waitfordt->setChecked(_pppdata->waitForDialTone()); 372 waitfordt->setChecked(_pppdata->waitForDialTone());
387 // connect(waitfordt, SIGNAL(toggled(bool)), SLOT(waitfordtchanged(bool))); 373 // connect(waitfordt, SIGNAL(toggled(bool)), SLOT(waitfordtchanged(bool)));
388 l1->addWidget(waitfordt); 374 l1->addWidget(waitfordt);
389 QWhatsThis::add(waitfordt, 375 QWhatsThis::add(waitfordt,
390 tr("<p>Normally the modem waits for a dial tone\n" 376 tr("<p>Normally the modem waits for a dial tone\n"
391 "from your phone line, indicating that it can\n" 377 "from your phone line, indicating that it can\n"
392 "start to dial a number. If your modem does not\n" 378 "start to dial a number. If your modem does not\n"
393 "recognize this sound, or your local phone system\n" 379 "recognize this sound, or your local phone system\n"
394 "does not emit such a tone, uncheck this option\n" 380 "does not emit such a tone, uncheck this option\n"
395 "\n" 381 "\n"
396 "<b>Default:</b>: On")); 382 "<b>Default:</b>: On"));
397 383
398 QHBoxLayout *waitLayout = new QHBoxLayout( this ); 384 QHBoxLayout *waitLayout = new QHBoxLayout( this );
399 QLabel *waitLabel = new QLabel( tr("Busy wait:"), this, "busyWait" ); 385 QLabel *waitLabel = new QLabel( tr("Busy wait:"), this, "busyWait" );
400 busywait = new QSpinBox( 0, 300, 5, this, "busyWait" ); 386 busywait = new QSpinBox( 0, 300, 5, this, "busyWait" );
401 // busywait = new KIntNumInput(_pppdata->busyWait(), this); 387 // busywait = new KIntNumInput(_pppdata->busyWait(), this);
402 // busywait->setLabel(tr("B&usy wait:")); 388 // busywait->setLabel(tr("B&usy wait:"));
403 // busywait->setRange(0, 300, 5, true); 389 // busywait->setRange(0, 300, 5, true);
404 busywait->setSuffix(tr(" sec")); 390 busywait->setSuffix(tr(" sec"));
405 // connect(busywait, SIGNAL(valueChanged(int)), SLOT(busywaitchanged(int))); 391 // connect(busywait, SIGNAL(valueChanged(int)), SLOT(busywaitchanged(int)));
406 waitLayout->addWidget(waitLabel); 392 waitLayout->addWidget(waitLabel);
407 waitLayout->addWidget(busywait); 393 waitLayout->addWidget(busywait);
408 l1->addLayout( waitLayout ); 394 l1->addLayout( waitLayout );
409 395
410 QWhatsThis::add(busywait, 396 QWhatsThis::add(busywait,
411 tr("Specifies the number of seconds to wait before\n" 397 tr("Specifies the number of seconds to wait before\n"
412 "redial if all dialed numbers are busy. This is\n" 398 "redial if all dialed numbers are busy. This is\n"
413 "necessary because some modems get stuck if the\n" 399 "necessary because some modems get stuck if the\n"
414 "same number is busy too often.\n" 400 "same number is busy too often.\n"
415 "\n" 401 "\n"
416 "The default is 0 seconds, you should not change\n" 402 "The default is 0 seconds, you should not change\n"
417 "this unless you need to.")); 403 "this unless you need to."));
418 404
419 l1->addSpacing(10); 405 l1->addSpacing(10);
420 406
421 QHBoxLayout *hbl = new QHBoxLayout; 407 QHBoxLayout *hbl = new QHBoxLayout;
422 hbl->setSpacing(2);//KDialog::spacingHint()); 408 hbl->setSpacing(2);//KDialog::spacingHint());
423 409
424 QLabel *volumeLabel = new QLabel(tr("Modem &volume:"), this); 410 QLabel *volumeLabel = new QLabel(tr("Modem &volume:"), this);
425 hbl->addWidget(volumeLabel); 411 hbl->addWidget(volumeLabel);
426 volume = new QSlider(0, 2, 1, _pppdata->volume(), 412 volume = new QSlider(0, 2, 1, _pppdata->volume(),
427 QSlider::Horizontal, this); 413 QSlider::Horizontal, this);
428 volumeLabel->setBuddy(volume); 414 volumeLabel->setBuddy(volume);
429 volume->setTickmarks(QSlider::Below); 415 volume->setTickmarks(QSlider::Below);
430 hbl->addWidget(volume); 416 hbl->addWidget(volume);
431 417
432 l1->addLayout(hbl); 418 l1->addLayout(hbl);
433 419
434 // connect(volume, SIGNAL(valueChanged(int)), 420 // connect(volume, SIGNAL(valueChanged(int)),
435 // this, SLOT(volumeChanged(int))); 421 // this, SLOT(volumeChanged(int)));
436 QString tmp = tr("Most modems have a speaker which makes\n" 422 QString tmp = tr("Most modems have a speaker which makes\n"
437 "a lot of noise when dialing. Here you can\n" 423 "a lot of noise when dialing. Here you can\n"
438 "either turn this completely off or select a\n" 424 "either turn this completely off or select a\n"
439 "lower volume.\n" 425 "lower volume.\n"
440 "\n" 426 "\n"
441 "If this does not work for your modem,\n" 427 "If this does not work for your modem,\n"
442 "you must modify the modem volume command."); 428 "you must modify the modem volume command.");
443 429
444 QWhatsThis::add(volumeLabel,tmp); 430 QWhatsThis::add(volumeLabel,tmp);
445 QWhatsThis::add(volume, tmp); 431 QWhatsThis::add(volume, tmp);
446 432
447 l1->addSpacing(20); 433 l1->addSpacing(20);
448 434
449#if 0 435#if 0
450 chkbox1 = new QCheckBox(tr("Modem asserts CD line"), this); 436 chkbox1 = new QCheckBox(tr("Modem asserts CD line"), this);
451 chkbox1->setChecked(_pppdata->UseCDLine()); 437 chkbox1->setChecked(_pppdata->UseCDLine());
452 connect(chkbox1,SIGNAL(toggled(bool)), 438 connect(chkbox1,SIGNAL(toggled(bool)),
453 this,SLOT(use_cdline_toggled(bool))); 439 this,SLOT(use_cdline_toggled(bool)));
454 l12->addWidget(chkbox1); 440 l12->addWidget(chkbox1);
455 l12->addStretch(1); 441 l12->addStretch(1);
456 l1->addStretch(1); 442 l1->addStretch(1);
457 QWhatsThis::add(chkbox1, 443 QWhatsThis::add(chkbox1,
458 tr("This controls how <i>kppp</i> detects that the modem\n" 444 tr("This controls how <i>kppp</i> detects that the modem\n"
459 "is not responding. Unless you are having\n" 445 "is not responding. Unless you are having\n"
460 "problems with this, do not modify this setting.\n" 446 "problems with this, do not modify this setting.\n"
461 "\n" 447 "\n"
462 "<b>Default</b>: Off")); 448 "<b>Default</b>: Off"));
463#endif 449#endif
464 450
465 modemcmds = new QPushButton(tr("Mod&em Commands..."), this); 451 modemcmds = new QPushButton(tr("Mod&em Commands..."), this);
466 QWhatsThis::add(modemcmds, 452 QWhatsThis::add(modemcmds,
467 tr("Allows you to change the AT command for\n" 453 tr("Allows you to change the AT command for\n"
468 "your modem.")); 454 "your modem."));
469 455
470 modeminfo_button = new QPushButton(tr("&Query Modem..."), this); 456 modeminfo_button = new QPushButton(tr("&Query Modem..."), this);
471 QWhatsThis::add(modeminfo_button, 457 QWhatsThis::add(modeminfo_button,
472 tr("Most modems support the ATI command set to\n" 458 tr("Most modems support the ATI command set to\n"
473 "find out vendor and revision of your modem.\n" 459 "find out vendor and revision of your modem.\n"
474 "\n" 460 "\n"
475 "Press this button to query your modem for\n" 461 "Press this button to query your modem for\n"
476 "this information. It can be useful to help\n" 462 "this information. It can be useful to help\n"
477 "you setup the modem")); 463 "you setup the modem"));
478 464
479 // terminal_button = new QPushButton(tr("&Terminal..."), this); 465 // terminal_button = new QPushButton(tr("&Terminal..."), this);
480 // QWhatsThis::add(terminal_button, 466 // QWhatsThis::add(terminal_button,
481 // tr("Opens the built-in terminal program. You\n" 467 // tr("Opens the built-in terminal program. You\n"
482 // "can use this if you want to play around\n" 468 // "can use this if you want to play around\n"
483 // "with your modem's AT command set")); 469 // "with your modem's AT command set"));
484 470
485 QHBoxLayout *hbox = new QHBoxLayout(); 471 QHBoxLayout *hbox = new QHBoxLayout();
486 l1->addLayout(hbox); 472 l1->addLayout(hbox);
487 hbox->addStretch(1); 473 hbox->addStretch(1);
488 QVBoxLayout *vbox = new QVBoxLayout(); 474 QVBoxLayout *vbox = new QVBoxLayout();
489 hbox->addLayout(vbox); 475 hbox->addLayout(vbox);
490 476
491 vbox->addWidget(modemcmds); 477 vbox->addWidget(modemcmds);
492 vbox->addWidget(modeminfo_button); 478 vbox->addWidget(modeminfo_button);
493 // vbox->addWidget(terminal_button); 479 // vbox->addWidget(terminal_button);
494 480
495 hbox->addStretch(1); 481 hbox->addStretch(1);
496 l1->addStretch(1); 482 l1->addStretch(1);
497 483
498 connect(modemcmds, SIGNAL(clicked()), 484 connect(modemcmds, SIGNAL(clicked()),
499 SLOT(modemcmdsbutton())); 485 SLOT(modemcmdsbutton()));
500 connect(modeminfo_button, SIGNAL(clicked()), 486 connect(modeminfo_button, SIGNAL(clicked()),
501 SLOT(query_modem())); 487 SLOT(query_modem()));
502 // connect(terminal_button, SIGNAL(clicked()), 488 // connect(terminal_button, SIGNAL(clicked()),
503 // SLOT(terminal())); 489 // SLOT(terminal()));
504} 490}
505 491
506 492
507void ModemWidget2::modemcmdsbutton() 493void ModemWidget2::modemcmdsbutton()
508{ 494{
509 ModemCommands mc(_ifaceppp->data(), this, "commands" , true, Qt::WStyle_ContextHelp); 495 ModemCommands mc(_ifaceppp->data(), this, "commands" , true, Qt::WStyle_ContextHelp);
510 496
511 QPEApplication::execDialog( &mc ); 497 QPEApplication::execDialog( &mc );
512} 498}
513 499
514 500
515void ModemWidget2::query_modem() 501void ModemWidget2::query_modem()
516{ 502{
517 emit sig_beforeQueryModem(); 503 emit sig_beforeQueryModem();
518 504
519 ModemTransfer mt(_ifaceppp->modem(), this); 505 ModemTransfer mt(_ifaceppp->modem(), this);
520 mt.exec(); 506 mt.exec();
521 507
522 emit sig_afterQueryModem(); 508 emit sig_afterQueryModem();
523} 509}
524 510
525 511
526// void ModemWidget2::terminal() { 512// void ModemWidget2::terminal() {
527// MiniTerm terminal(NULL,NULL); 513// MiniTerm terminal(NULL,NULL);
528// terminal.exec(); 514// terminal.exec();
529// } 515// }
530 516
531 517
532// #if 0 518// #if 0
533// void ModemWidget2::use_cdline_toggled(bool on) { 519// void ModemWidget2::use_cdline_toggled(bool on) {
534// _pppdata->setUseCDLine(on); 520// _pppdata->setUseCDLine(on);
535// } 521// }
536// #endif 522// #endif
537 523
538// void ModemWidget2::waitfordtchanged(bool b) { 524// void ModemWidget2::waitfordtchanged(bool b) {
539// _pppdata->setWaitForDialTone((int)b); 525// _pppdata->setWaitForDialTone((int)b);
540// } 526// }
541 527
542// void ModemWidget2::busywaitchanged(int n) { 528// void ModemWidget2::busywaitchanged(int n) {
543// _pppdata->setbusyWait(n); 529// _pppdata->setbusyWait(n);
544// } 530// }
545 531
546 532
547// void ModemWidget2::volumeChanged(int v) { 533// void ModemWidget2::volumeChanged(int v) {
548// _pppdata->setVolume(v); 534// _pppdata->setVolume(v);
549// } 535// }
550 536
551bool ModemWidget2::save() 537bool ModemWidget2::save()
552{ 538{
553 _pppdata->setWaitForDialTone(waitfordt->isChecked()); 539 _pppdata->setWaitForDialTone(waitfordt->isChecked());
554 _pppdata->setbusyWait(busywait->value()); 540 _pppdata->setbusyWait(busywait->value());
555 _pppdata->setVolume(volume->value()); 541 _pppdata->setVolume(volume->value());
556 return true; 542 return true;
557} 543}
558 544
diff --git a/noncore/settings/networksettings/ppp/general.h b/noncore/settings/networksettings/ppp/general.h
index a4dece4..0bb3136 100644
--- a/noncore/settings/networksettings/ppp/general.h
+++ b/noncore/settings/networksettings/ppp/general.h
@@ -1,125 +1,125 @@
1/* 1/*
2 * 2 *
3 * kPPP: A pppd front end for the KDE project 3 * kPPP: A pppd front end for the KDE project
4 * 4 *
5 * $Id$ 5 * $Id$
6 * 6 *
7 * Copyright (C) 1997 Bernd Johannes Wuebben 7 * Copyright (C) 1997 Bernd Johannes Wuebben
8 * wuebben@math.cornell.edu 8 * wuebben@math.cornell.edu
9 * 9 *
10 * 10 *
11 * This program is free software; you can redistribute it and/or 11 * This program is free software; you can redistribute it and/or
12 * modify it under the terms of the GNU Library General Public 12 * modify it under the terms of the GNU Library General Public
13 * License as published by the Free Software Foundation; either 13 * License as published by the Free Software Foundation; either
14 * version 2 of the License, or (at your option) any later version. 14 * version 2 of the License, or (at your option) any later version.
15 * 15 *
16 * This program is distributed in the hope that it will be useful, 16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of 17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 * Library General Public License for more details. 19 * Library General Public License for more details.
20 * 20 *
21 * You should have received a copy of the GNU Library General Public 21 * You should have received a copy of the GNU Library General Public
22 * License along with this program; if not, write to the Free 22 * License along with this program; if not, write to the Free
23 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 23 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
24 */ 24 */
25 25
26#ifndef _GENERAL_H_ 26#ifndef _GENERAL_H_
27#define _GENERAL_H_ 27#define _GENERAL_H_
28 28
29#include <qwidget.h> 29#include <qwidget.h>
30 30
31class QSlider; 31class QSlider;
32class QSpinBox; 32class QSpinBox;
33class QCombobox; 33class QCombobox;
34class QLabel; 34class QLabel;
35class QCheckBox; 35class QCheckBox;
36class QComboBox; 36class QComboBox;
37class PPPData; 37class PPPData;
38class InterfacePPP; 38class InterfacePPP;
39class QLineEdit; 39class QLineEdit;
40 40
41class ModemWidget : public QWidget { 41class ModemWidget : public QWidget {
42 Q_OBJECT 42 Q_OBJECT
43public: 43public:
44 ModemWidget(PPPData*, QWidget *parent=0, const char *name=0 ); 44 ModemWidget(PPPData*, QWidget *parent=0, const char *name=0 );
45 ~ModemWidget(); 45 ~ModemWidget();
46 46
47 bool save(); 47 bool save();
48 48
49private slots: 49private slots:
50 /* 50 /*
51 * temporarily commit configuration so queryModem 51 * temporarily commit configuration so queryModem
52 * will use 'current' settings 52 * will use 'current' settings
53 */ 53 */
54 void slotBeforeModemQuery(); 54 void slotBeforeModemQuery();
55 void slotAfterModemQuery(); 55 void slotAfterModemQuery();
56 56
57/* private slots: */ 57/* private slots: */
58 /* void setmodemdc(int); */ 58 /* void setmodemdc(int); */
59/* void setmodemdc(const QString &); */ 59/* void setmodemdc(const QString &); */
60 /* void setflowcontrol(int); */ 60 /* void setflowcontrol(int); */
61 /* void modemtimeoutchanged(int); */ 61 /* void modemtimeoutchanged(int); */
62 /* void modemlockfilechanged(bool); */ 62 /* void modemlockfilechanged(bool); */
63 /* void setenter(int); */ 63 /* void setenter(int); */
64/* void speed_selection(int); */ 64/* void speed_selection(int); */
65 65
66private: 66private:
67 QComboBox *enter; 67 QComboBox *enter;
68 /* QLabel *label1; */ 68 /* QLabel *label1; */
69 /* QLabel *label2; */ 69 /* QLabel *label2; */
70 /* QLabel *labeltmp; */ 70 /* QLabel *labeltmp; */
71 /* QLabel *labelenter; */ 71 /* QLabel *labelenter; */
72 QLineEdit *modemname; 72 QLineEdit *modemname;
73 QComboBox *modemdevice; 73 QComboBox *modemdevice;
74 QComboBox *flowcontrol; 74 QComboBox *flowcontrol;
75 75
76 QComboBox *baud_c; 76 QComboBox *baud_c;
77 QLabel *baud_label; 77 QLabel *baud_label;
78 78
79 QSpinBox *modemtimeout; 79 QSpinBox *modemtimeout;
80 QCheckBox *modemlockfile; 80 QCheckBox *modemlockfile;
81 PPPData *_pppdata; 81 PPPData *_pppdata;
82 82
83private: 83private:
84 QString m_oldModemDev, m_oldFlowControl, m_oldSpeed; 84 QString m_oldModemDev, m_oldSpeed;
85 bool m_oldModemLock; 85 bool m_oldModemLock;
86 int m_oldModemTimeout; 86 int m_oldModemTimeout, m_oldFlowControl, m_oldLineEnd;
87}; 87};
88 88
89 89
90class ModemWidget2 : public QWidget { 90class ModemWidget2 : public QWidget {
91 Q_OBJECT 91 Q_OBJECT
92public: 92public:
93 ModemWidget2( PPPData*, InterfacePPP*, QWidget *parent=0, const char *name=0 ); 93 ModemWidget2( PPPData*, InterfacePPP*, QWidget *parent=0, const char *name=0 );
94 bool save(); 94 bool save();
95 95
96signals: 96signals:
97 void sig_beforeQueryModem(); 97 void sig_beforeQueryModem();
98 void sig_afterQueryModem(); 98 void sig_afterQueryModem();
99 99
100private slots: 100private slots:
101/* void waitfordtchanged(bool); */ 101/* void waitfordtchanged(bool); */
102 /* void busywaitchanged(int); */ 102 /* void busywaitchanged(int); */
103 // void use_cdline_toggled(bool); 103 // void use_cdline_toggled(bool);
104 void modemcmdsbutton(); 104 void modemcmdsbutton();
105 // void terminal(); 105 // void terminal();
106 void query_modem(); 106 void query_modem();
107 // void volumeChanged(int); 107 // void volumeChanged(int);
108 108
109private: 109private:
110 QLabel *labeltmp; 110 QLabel *labeltmp;
111 QPushButton *modemcmds; 111 QPushButton *modemcmds;
112 QPushButton *modeminfo_button; 112 QPushButton *modeminfo_button;
113 // QPushButton *terminal_button; 113 // QPushButton *terminal_button;
114 // QFrame *fline; 114 // QFrame *fline;
115 QCheckBox *waitfordt; 115 QCheckBox *waitfordt;
116 QSpinBox *busywait; 116 QSpinBox *busywait;
117 QCheckBox *chkbox1; 117 QCheckBox *chkbox1;
118 QSlider *volume; 118 QSlider *volume;
119 PPPData *_pppdata; 119 PPPData *_pppdata;
120 InterfacePPP *_ifaceppp; 120 InterfacePPP *_ifaceppp;
121}; 121};
122 122
123#endif 123#endif
124 124
125 125
diff --git a/noncore/settings/networksettings/ppp/modem.cpp b/noncore/settings/networksettings/ppp/modem.cpp
index 79f015b..7b2e2a3 100644
--- a/noncore/settings/networksettings/ppp/modem.cpp
+++ b/noncore/settings/networksettings/ppp/modem.cpp
@@ -1,750 +1,754 @@
1/* 1/*
2 * kPPP: A pppd Front End for the KDE project 2 * kPPP: A pppd Front End for the KDE project
3 * 3 *
4 * $Id$ 4 * $Id$
5 * 5 *
6 * Copyright (C) 1997 Bernd Johannes Wuebben 6 * Copyright (C) 1997 Bernd Johannes Wuebben
7 * wuebben@math.cornell.edu 7 * wuebben@math.cornell.edu
8 * 8 *
9 * This file was added by Harri Porten <porten@tu-harburg.de> 9 * This file was added by Harri Porten <porten@tu-harburg.de>
10 * 10 *
11 * 11 *
12 * This program is free software; you can redistribute it and/or 12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU Library General Public 13 * modify it under the terms of the GNU Library General Public
14 * License as published by the Free Software Foundation; either 14 * License as published by the Free Software Foundation; either
15 * version 2 of the License, or (at your option) any later version. 15 * version 2 of the License, or (at your option) any later version.
16 * 16 *
17 * This program is distributed in the hope that it will be useful, 17 * This program is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of 18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 * Library General Public License for more details. 20 * Library General Public License for more details.
21 * 21 *
22 * You should have received a copy of the GNU Library General Public 22 * You should have received a copy of the GNU Library General Public
23 * License along with this program; if not, write to the Free 23 * License along with this program; if not, write to the Free
24 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 24 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
25 */ 25 */
26 26
27/* OPIE */ 27/* OPIE */
28#include <opie2/odebug.h> 28#include <opie2/odebug.h>
29using namespace Opie::Core; 29using namespace Opie::Core;
30 30
31/* STD */ 31/* STD */
32#include <errno.h> 32#include <errno.h>
33#include <stdlib.h> 33#include <stdlib.h>
34#include <unistd.h> 34#include <unistd.h>
35#include <fcntl.h> 35#include <fcntl.h>
36#include <signal.h> 36#include <signal.h>
37#include <sys/ioctl.h> 37#include <sys/ioctl.h>
38#include <sys/types.h> 38#include <sys/types.h>
39#include <sys/stat.h> 39#include <sys/stat.h>
40#include <setjmp.h> 40#include <setjmp.h>
41#include <regex.h> 41#include <regex.h>
42#include <qregexp.h> 42#include <qregexp.h>
43#include <assert.h> 43#include <assert.h>
44#include <string.h> 44#include <string.h>
45 45
46#ifdef HAVE_RESOLV_H 46#ifdef HAVE_RESOLV_H
47# include <arpa/nameser.h> 47# include <arpa/nameser.h>
48# include <resolv.h> 48# include <resolv.h>
49#endif 49#endif
50 50
51#ifndef _PATH_RESCONF 51#ifndef _PATH_RESCONF
52#define _PATH_RESCONF "/etc/resolv.conf" 52#define _PATH_RESCONF "/etc/resolv.conf"
53#endif 53#endif
54 54
55#define strlcpy strcpy 55#define strlcpy strcpy
56#include "auth.h" 56#include "auth.h"
57#include "modem.h" 57#include "modem.h"
58#include "pppdata.h" 58#include "pppdata.h"
59 59
60 60
61#define MY_ASSERT(x) if (!(x)) { \ 61#define MY_ASSERT(x) if (!(x)) { \
62 ofatal << "ASSERT: \"" << #x << "\" in " << __FILE__ << " (" << __LINE__ << ")\n" << oendl; \ 62 ofatal << "ASSERT: \"" << #x << "\" in " << __FILE__ << " (" << __LINE__ << ")\n" << oendl; \
63 exit(1); } 63 exit(1); }
64 64
65 65
66static sigjmp_buf jmp_buffer; 66static sigjmp_buf jmp_buffer;
67 67
68//Modem *Modem::modem = 0; 68//Modem *Modem::modem = 0;
69 69
70 70
71const char* pppdPath() { 71const char* pppdPath() {
72 // wasting a few bytes 72 // wasting a few bytes
73 static char buffer[sizeof(PPPDSEARCHPATH)+sizeof(PPPDNAME)]; 73 static char buffer[sizeof(PPPDSEARCHPATH)+sizeof(PPPDNAME)];
74 static char *pppdPath = 0L; 74 static char *pppdPath = 0L;
75 char *p; 75 char *p;
76 76
77 if(pppdPath == 0L) { 77 if(pppdPath == 0L) {
78 const char *c = PPPDSEARCHPATH; 78 const char *c = PPPDSEARCHPATH;
79 while(*c != '\0') { 79 while(*c != '\0') {
80 while(*c == ':') 80 while(*c == ':')
81 c++; 81 c++;
82 p = buffer; 82 p = buffer;
83 while(*c != '\0' && *c != ':') 83 while(*c != '\0' && *c != ':')
84 *p++ = *c++; 84 *p++ = *c++;
85 *p = '\0'; 85 *p = '\0';
86 strcat(p, "/"); 86 strcat(p, "/");
87 strcat(p, PPPDNAME); 87 strcat(p, PPPDNAME);
88 if(access(buffer, F_OK) == 0) 88 if(access(buffer, F_OK) == 0)
89 return (pppdPath = buffer); 89 return (pppdPath = buffer);
90 } 90 }
91 } 91 }
92 92
93 return pppdPath; 93 return pppdPath;
94} 94}
95 95
96 96
97Modem::Modem( PPPData* pd ) 97Modem::Modem( PPPData* pd )
98{ 98{
99 _pppdata = pd; 99 _pppdata = pd;
100 modemfd = -1; 100 modemfd = -1;
101 _pppdExitStatus = -1; 101 _pppdExitStatus = -1;
102 pppdPid = -1; 102 pppdPid = -1;
103 sn = m_modemDebug = 0L; 103 sn = m_modemDebug = 0L;
104 data_mode = false; 104 data_mode = false;
105 modem_is_locked = false; 105 modem_is_locked = false;
106 lockfile[0] = '\0'; 106 lockfile[0] = '\0';
107 device = "/dev/modem"; 107 device = "/dev/modem";
108} 108}
109 109
110 110
111Modem::~Modem() 111Modem::~Modem()
112{ 112{
113} 113}
114 114
115 115
116speed_t Modem::modemspeed() { 116speed_t Modem::modemspeed() {
117 // convert the string modem speed int the gpppdata object to a t_speed type 117 // convert the string modem speed int the gpppdata object to a t_speed type
118 // to set the modem. The constants here should all be ifdef'd because 118 // to set the modem. The constants here should all be ifdef'd because
119 // other systems may not have them 119 // other systems may not have them
120 int i = _pppdata->speed().toInt()/100; 120 int i = _pppdata->speed().toInt()/100;
121 121
122 switch(i) { 122 switch(i) {
123 case 24: 123 case 24:
124 return B2400; 124 return B2400;
125 break; 125 break;
126 case 96: 126 case 96:
127 return B9600; 127 return B9600;
128 break; 128 break;
129 case 192: 129 case 192:
130 return B19200; 130 return B19200;
131 break; 131 break;
132 case 384: 132 case 384:
133 return B38400; 133 return B38400;
134 break; 134 break;
135#ifdef B57600 135#ifdef B57600
136 case 576: 136 case 576:
137 return B57600; 137 return B57600;
138 break; 138 break;
139#endif 139#endif
140 140
141#ifdef B115200 141#ifdef B115200
142 case 1152: 142 case 1152:
143 return B115200; 143 return B115200;
144 break; 144 break;
145#endif 145#endif
146 146
147#ifdef B230400 147#ifdef B230400
148 case 2304: 148 case 2304:
149 return B230400; 149 return B230400;
150 break; 150 break;
151#endif 151#endif
152 152
153#ifdef B460800 153#ifdef B460800
154 case 4608: 154 case 4608:
155 return B460800; 155 return B460800;
156 break; 156 break;
157#endif 157#endif
158 158
159 default: 159 default:
160 return B38400; 160 return B38400;
161 break; 161 break;
162 } 162 }
163} 163}
164 164
165bool Modem::opentty() { 165bool Modem::opentty() {
166 // int flags; 166 // int flags;
167 167
168//begin if((modemfd = Requester::rq->openModem(gpppdata.modemDevice()))<0) { 168//begin if((modemfd = Requester::rq->openModem(gpppdata.modemDevice()))<0) {
169 close(modemfd); 169 close(modemfd);
170 device = _pppdata->modemDevice(); 170 device = _pppdata->modemDevice();
171 if ((modemfd = open(device, O_RDWR|O_NDELAY|O_NOCTTY)) == -1) { 171 if ((modemfd = open(device, O_RDWR|O_NDELAY|O_NOCTTY)) == -1) {
172 odebug << "error opening modem device !" << oendl; 172 odebug << "error opening modem device !" << oendl;
173 errmsg = QObject::tr("Unable to open modem."); 173 errmsg = QObject::tr("Unable to open modem.");
174 return false; 174 return false;
175 } 175 }
176//bend if((modemfd = Requester::rq->openModem(gpppdata.modemDevice()))<0) { 176//bend if((modemfd = Requester::rq->openModem(gpppdata.modemDevice()))<0) {
177//} 177//}
178 178
179#if 0 179#if 0
180 if(_pppdata->UseCDLine()) { 180 if(_pppdata->UseCDLine()) {
181 if(ioctl(modemfd, TIOCMGET, &flags) == -1) { 181 if(ioctl(modemfd, TIOCMGET, &flags) == -1) {
182 errmsg = QObject::tr("Unable to detect state of CD line."); 182 errmsg = QObject::tr("Unable to detect state of CD line.");
183 ::close(modemfd); 183 ::close(modemfd);
184 modemfd = -1; 184 modemfd = -1;
185 return false; 185 return false;
186 } 186 }
187 if ((flags&TIOCM_CD) == 0) { 187 if ((flags&TIOCM_CD) == 0) {
188 errmsg = QObject::tr("The modem is not ready."); 188 errmsg = QObject::tr("The modem is not ready.");
189 ::close(modemfd); 189 ::close(modemfd);
190 modemfd = -1; 190 modemfd = -1;
191 return false; 191 return false;
192 } 192 }
193 } 193 }
194#endif 194#endif
195 195
196 tcdrain (modemfd); 196 tcdrain (modemfd);
197 tcflush (modemfd, TCIOFLUSH); 197 tcflush (modemfd, TCIOFLUSH);
198 198
199 if(tcgetattr(modemfd, &tty) < 0){ 199 if(tcgetattr(modemfd, &tty) < 0){
200 // this helps in some cases 200 // this helps in some cases
201 tcsendbreak(modemfd, 0); 201 tcsendbreak(modemfd, 0);
202 sleep(1); 202 sleep(1);
203 if(tcgetattr(modemfd, &tty) < 0){ 203 if(tcgetattr(modemfd, &tty) < 0){
204 errmsg = QObject::tr("The modem is busy."); 204 errmsg = QObject::tr("The modem is busy.");
205 ::close(modemfd); 205 ::close(modemfd);
206 modemfd = -1; 206 modemfd = -1;
207 return false; 207 return false;
208 } 208 }
209 } 209 }
210 210
211 memset(&initial_tty,'\0',sizeof(initial_tty)); 211 memset(&initial_tty,'\0',sizeof(initial_tty));
212 212
213 initial_tty = tty; 213 initial_tty = tty;
214 214
215 tty.c_cc[VMIN] = 0; // nonblocking 215 tty.c_cc[VMIN] = 0; // nonblocking
216 tty.c_cc[VTIME] = 0; 216 tty.c_cc[VTIME] = 0;
217 tty.c_oflag = 0; 217 tty.c_oflag = 0;
218 tty.c_lflag = 0; 218 tty.c_lflag = 0;
219 219
220 tty.c_cflag &= ~(CSIZE | CSTOPB | PARENB); 220 tty.c_cflag &= ~(CSIZE | CSTOPB | PARENB);
221 tty.c_cflag |= CS8 | CREAD; 221 tty.c_cflag |= CS8 | CREAD;
222 tty.c_cflag |= CLOCAL; // ignore modem status lines 222 tty.c_cflag |= CLOCAL; // ignore modem status lines
223 tty.c_iflag = IGNBRK | IGNPAR /* | ISTRIP */ ; 223 tty.c_iflag = IGNBRK | IGNPAR /* | ISTRIP */ ;
224 tty.c_lflag &= ~ICANON; // non-canonical mode 224 tty.c_lflag &= ~ICANON; // non-canonical mode
225 tty.c_lflag &= ~(ECHO|ECHOE|ECHOK|ECHOKE); 225 tty.c_lflag &= ~(ECHO|ECHOE|ECHOK|ECHOKE);
226 226
227 227
228 if(_pppdata->flowcontrol() != "None") { 228 if(_pppdata->flowcontrol() != PPPData::FlowNone) {
229 if(_pppdata->flowcontrol() == "CRTSCTS") { 229 if(_pppdata->flowcontrol() == PPPData::FlowHardware) {
230 tty.c_cflag |= CRTSCTS; 230 tty.c_cflag |= CRTSCTS;
231 } 231 }
232 else { 232 else {
233 tty.c_iflag |= IXON | IXOFF; 233 tty.c_iflag |= IXON | IXOFF;
234 tty.c_cc[VSTOP] = 0x13; /* DC3 = XOFF = ^S */ 234 tty.c_cc[VSTOP] = 0x13; /* DC3 = XOFF = ^S */
235 tty.c_cc[VSTART] = 0x11; /* DC1 = XON = ^Q */ 235 tty.c_cc[VSTART] = 0x11; /* DC1 = XON = ^Q */
236 } 236 }
237 } 237 }
238 else { 238 else {
239 tty.c_cflag &= ~CRTSCTS; 239 tty.c_cflag &= ~CRTSCTS;
240 tty.c_iflag &= ~(IXON | IXOFF); 240 tty.c_iflag &= ~(IXON | IXOFF);
241 } 241 }
242 242
243 cfsetospeed(&tty, modemspeed()); 243 cfsetospeed(&tty, modemspeed());
244 cfsetispeed(&tty, modemspeed()); 244 cfsetispeed(&tty, modemspeed());
245 245
246 tcdrain(modemfd); 246 tcdrain(modemfd);
247 247
248 if(tcsetattr(modemfd, TCSANOW, &tty) < 0){ 248 if(tcsetattr(modemfd, TCSANOW, &tty) < 0){
249 errmsg = QObject::tr("The modem is busy."); 249 errmsg = QObject::tr("The modem is busy.");
250 ::close(modemfd); 250 ::close(modemfd);
251 modemfd=-1; 251 modemfd=-1;
252 return false; 252 return false;
253 } 253 }
254 254
255 errmsg = QObject::tr("Modem Ready."); 255 errmsg = QObject::tr("Modem Ready.");
256 return true; 256 return true;
257} 257}
258 258
259 259
260bool Modem::closetty() { 260bool Modem::closetty() {
261 if(modemfd >=0 ) { 261 if(modemfd >=0 ) {
262 stop(); 262 stop();
263 /* discard data not read or transmitted */ 263 /* discard data not read or transmitted */
264 tcflush(modemfd, TCIOFLUSH); 264 tcflush(modemfd, TCIOFLUSH);
265 265
266 if(tcsetattr(modemfd, TCSANOW, &initial_tty) < 0){ 266 if(tcsetattr(modemfd, TCSANOW, &initial_tty) < 0){
267 errmsg = QObject::tr("Can't restore tty settings: tcsetattr()\n"); 267 errmsg = QObject::tr("Can't restore tty settings: tcsetattr()\n");
268 ::close(modemfd); 268 ::close(modemfd);
269 modemfd = -1; 269 modemfd = -1;
270 return false; 270 return false;
271 } 271 }
272 ::close(modemfd); 272 ::close(modemfd);
273 modemfd = -1; 273 modemfd = -1;
274 } 274 }
275 275
276 return true; 276 return true;
277} 277}
278 278
279 279
280void Modem::readtty(int) { 280void Modem::readtty(int) {
281 char buffer[200]; 281 char buffer[200];
282 unsigned char c; 282 unsigned char c;
283 int len; 283 int len;
284 284
285 // read data in chunks of up to 200 bytes 285 // read data in chunks of up to 200 bytes
286 if((len = ::read(modemfd, buffer, 200)) > 0) { 286 if((len = ::read(modemfd, buffer, 200)) > 0) {
287 // split buffer into single characters for further processing 287 // split buffer into single characters for further processing
288 for(int i = 0; i < len; i++) { 288 for(int i = 0; i < len; i++) {
289 c = buffer[i] & 0x7F; 289 c = buffer[i] & 0x7F;
290 emit charWaiting(c); 290 emit charWaiting(c);
291 } 291 }
292 } 292 }
293} 293}
294 294
295 295
296void Modem::notify(const QObject *receiver, const char *member) { 296void Modem::notify(const QObject *receiver, const char *member) {
297 connect(this, SIGNAL(charWaiting(unsigned char)), receiver, member); 297 connect(this, SIGNAL(charWaiting(unsigned char)), receiver, member);
298 startNotifier(); 298 startNotifier();
299} 299}
300 300
301 301
302void Modem::stop() { 302void Modem::stop() {
303 disconnect(SIGNAL(charWaiting(unsigned char))); 303 disconnect(SIGNAL(charWaiting(unsigned char)));
304 stopNotifier(); 304 stopNotifier();
305} 305}
306 306
307 307
308void Modem::startNotifier() { 308void Modem::startNotifier() {
309 if(modemfd >= 0) { 309 if(modemfd >= 0) {
310 if(sn == 0) { 310 if(sn == 0) {
311 sn = new QSocketNotifier(modemfd, QSocketNotifier::Read, this); 311 sn = new QSocketNotifier(modemfd, QSocketNotifier::Read, this);
312 connect(sn, SIGNAL(activated(int)), SLOT(readtty(int))); 312 connect(sn, SIGNAL(activated(int)), SLOT(readtty(int)));
313 odebug << "QSocketNotifier started!" << oendl; 313 odebug << "QSocketNotifier started!" << oendl;
314 } else { 314 } else {
315 odebug << "QSocketNotifier re-enabled!" << oendl; 315 odebug << "QSocketNotifier re-enabled!" << oendl;
316 sn->setEnabled(true); 316 sn->setEnabled(true);
317 } 317 }
318 } 318 }
319} 319}
320 320
321 321
322void Modem::stopNotifier() { 322void Modem::stopNotifier() {
323 if(sn != 0) { 323 if(sn != 0) {
324 sn->setEnabled(false); 324 sn->setEnabled(false);
325 disconnect(sn); 325 disconnect(sn);
326 delete sn; 326 delete sn;
327 sn = 0; 327 sn = 0;
328 odebug << "QSocketNotifier stopped!" << oendl; 328 odebug << "QSocketNotifier stopped!" << oendl;
329 } 329 }
330} 330}
331 331
332 332
333void Modem::flush() { 333void Modem::flush() {
334 char c; 334 char c;
335 while(read(modemfd, &c, 1) == 1); 335 while(read(modemfd, &c, 1) == 1);
336} 336}
337 337
338 338
339bool Modem::writeChar(unsigned char c) { 339bool Modem::writeChar(unsigned char c) {
340 int s; 340 int s;
341 do { 341 do {
342 s = write(modemfd, &c, 1); 342 s = write(modemfd, &c, 1);
343 if (s < 0) { 343 if (s < 0) {
344 oerr << "write() in Modem::writeChar failed" << oendl; 344 oerr << "write() in Modem::writeChar failed" << oendl;
345 return false; 345 return false;
346 } 346 }
347 } while(s == 0); 347 } while(s == 0);
348 348
349 return true; 349 return true;
350} 350}
351 351
352 352
353bool Modem::writeLine(const char *buf) { 353bool Modem::writeLine(const char *buf) {
354 int len = strlen(buf); 354 int len = strlen(buf);
355 char *b = new char[len+2]; 355 char *b = new char[len+2];
356 memcpy(b, buf, len); 356 memcpy(b, buf, len);
357 // different modems seem to need different line terminations 357 // different modems seem to need different line terminations
358 QString term = _pppdata->enter(); 358 switch( _pppdata->enter() ) {
359 if(term == "LF") 359 case PPPData::EndLF:
360 b[len++]='\n'; 360 b[len++]='\n';
361 else if(term == "CR") 361 break;
362 case PPPData::EndCR:
362 b[len++]='\r'; 363 b[len++]='\r';
363 else if(term == "CR/LF") { 364 break;
365 case PPPData::EndCRLF:
364 b[len++]='\r'; 366 b[len++]='\r';
365 b[len++]='\n'; 367 b[len++]='\n';
368 break;
366 } 369 }
370
367 int l = len; 371 int l = len;
368 while(l) { 372 while(l) {
369 int wr = write(modemfd, &b[len-l], l); 373 int wr = write(modemfd, &b[len-l], l);
370 if(wr < 0) { 374 if(wr < 0) {
371 // TODO do something meaningful with the error code (or ignore it 375 // TODO do something meaningful with the error code (or ignore it
372 oerr << "write() in Modem::writeLine failed" << oendl; 376 oerr << "write() in Modem::writeLine failed" << oendl;
373 delete[] b; 377 delete[] b;
374 return false; 378 return false;
375 } 379 }
376 l -= wr; 380 l -= wr;
377 } 381 }
378 delete[] b; 382 delete[] b;
379 return true; 383 return true;
380} 384}
381 385
382 386
383bool Modem::hangup() { 387bool Modem::hangup() {
384 // this should really get the modem to hang up and go into command mode 388 // this should really get the modem to hang up and go into command mode
385 // If anyone sees a fault in the following please let me know, since 389 // If anyone sees a fault in the following please let me know, since
386 // this is probably the most imporant snippet of code in the whole of 390 // this is probably the most imporant snippet of code in the whole of
387 // kppp. If people complain about kppp being stuck, this piece of code 391 // kppp. If people complain about kppp being stuck, this piece of code
388 // is most likely the reason. 392 // is most likely the reason.
389 struct termios temptty; 393 struct termios temptty;
390 394
391 if(modemfd >= 0) { 395 if(modemfd >= 0) {
392 396
393 // is this Escape & HangupStr stuff really necessary ? (Harri) 397 // is this Escape & HangupStr stuff really necessary ? (Harri)
394 398
395 if (data_mode) escape_to_command_mode(); 399 if (data_mode) escape_to_command_mode();
396 400
397 // Then hangup command 401 // Then hangup command
398 writeLine(_pppdata->modemHangupStr().local8Bit()); 402 writeLine(_pppdata->modemHangupStr().local8Bit());
399 403
400 usleep(_pppdata->modemInitDelay() * 10000); // 0.01 - 3.0 sec 404 usleep(_pppdata->modemInitDelay() * 10000); // 0.01 - 3.0 sec
401 405
402#ifndef DEBUG_WO_DIALING 406#ifndef DEBUG_WO_DIALING
403 if (sigsetjmp(jmp_buffer, 1) == 0) { 407 if (sigsetjmp(jmp_buffer, 1) == 0) {
404 // set alarm in case tcsendbreak() hangs 408 // set alarm in case tcsendbreak() hangs
405 signal(SIGALRM, alarm_handler); 409 signal(SIGALRM, alarm_handler);
406 alarm(2); 410 alarm(2);
407 411
408 tcsendbreak(modemfd, 0); 412 tcsendbreak(modemfd, 0);
409 413
410 alarm(0); 414 alarm(0);
411 signal(SIGALRM, SIG_IGN); 415 signal(SIGALRM, SIG_IGN);
412 } else { 416 } else {
413 // we reach this point if the alarm handler got called 417 // we reach this point if the alarm handler got called
414 closetty(); 418 closetty();
415 close(modemfd); 419 close(modemfd);
416 modemfd = -1; 420 modemfd = -1;
417 errmsg = QObject::tr("The modem does not respond."); 421 errmsg = QObject::tr("The modem does not respond.");
418 return false; 422 return false;
419 } 423 }
420 424
421#ifndef __svr4__ // drops DTR but doesn't set it afterwards again. not good for init. 425#ifndef __svr4__ // drops DTR but doesn't set it afterwards again. not good for init.
422 tcgetattr(modemfd, &temptty); 426 tcgetattr(modemfd, &temptty);
423 cfsetospeed(&temptty, B0); 427 cfsetospeed(&temptty, B0);
424 cfsetispeed(&temptty, B0); 428 cfsetispeed(&temptty, B0);
425 tcsetattr(modemfd, TCSAFLUSH, &temptty); 429 tcsetattr(modemfd, TCSAFLUSH, &temptty);
426#else 430#else
427 int modemstat; 431 int modemstat;
428 ioctl(modemfd, TIOCMGET, &modemstat); 432 ioctl(modemfd, TIOCMGET, &modemstat);
429 modemstat &= ~TIOCM_DTR; 433 modemstat &= ~TIOCM_DTR;
430 ioctl(modemfd, TIOCMSET, &modemstat); 434 ioctl(modemfd, TIOCMSET, &modemstat);
431 ioctl(modemfd, TIOCMGET, &modemstat); 435 ioctl(modemfd, TIOCMGET, &modemstat);
432 modemstat |= TIOCM_DTR; 436 modemstat |= TIOCM_DTR;
433 ioctl(modemfd, TIOCMSET, &modemstat); 437 ioctl(modemfd, TIOCMSET, &modemstat);
434#endif 438#endif
435 439
436 usleep(_pppdata->modemInitDelay() * 10000); // 0.01 - 3.0 secs 440 usleep(_pppdata->modemInitDelay() * 10000); // 0.01 - 3.0 secs
437 441
438 cfsetospeed(&temptty, modemspeed()); 442 cfsetospeed(&temptty, modemspeed());
439 cfsetispeed(&temptty, modemspeed()); 443 cfsetispeed(&temptty, modemspeed());
440 tcsetattr(modemfd, TCSAFLUSH, &temptty); 444 tcsetattr(modemfd, TCSAFLUSH, &temptty);
441#endif 445#endif
442 return true; 446 return true;
443 } else 447 } else
444 return false; 448 return false;
445} 449}
446 450
447 451
448void Modem::escape_to_command_mode() { 452void Modem::escape_to_command_mode() {
449 // Send Properly bracketed escape code to put the modem back into command state. 453 // Send Properly bracketed escape code to put the modem back into command state.
450 // A modem will accept AT commands only when it is in command state. 454 // A modem will accept AT commands only when it is in command state.
451 // When a modem sends the host the CONNECT string, that signals 455 // When a modem sends the host the CONNECT string, that signals
452 // that the modem is now in the connect state (no long accepts AT commands.) 456 // that the modem is now in the connect state (no long accepts AT commands.)
453 // Need to send properly timed escape sequence to put modem in command state. 457 // Need to send properly timed escape sequence to put modem in command state.
454 // Escape codes and guard times are controlled by S2 and S12 values. 458 // Escape codes and guard times are controlled by S2 and S12 values.
455 // 459 //
456 tcflush(modemfd, TCIOFLUSH); 460 tcflush(modemfd, TCIOFLUSH);
457 461
458 // +3 because quiet time must be greater than guard time. 462 // +3 because quiet time must be greater than guard time.
459 usleep((_pppdata->modemEscapeGuardTime()+3)*20000); 463 usleep((_pppdata->modemEscapeGuardTime()+3)*20000);
460 QCString tmp = _pppdata->modemEscapeStr().local8Bit(); 464 QCString tmp = _pppdata->modemEscapeStr().local8Bit();
461 write(modemfd, tmp.data(), tmp.length()); 465 write(modemfd, tmp.data(), tmp.length());
462 tcflush(modemfd, TCIOFLUSH); 466 tcflush(modemfd, TCIOFLUSH);
463 usleep((_pppdata->modemEscapeGuardTime()+3)*20000); 467 usleep((_pppdata->modemEscapeGuardTime()+3)*20000);
464 468
465 data_mode = false; 469 data_mode = false;
466} 470}
467 471
468 472
469const QString Modem::modemMessage() { 473const QString Modem::modemMessage() {
470 return errmsg; 474 return errmsg;
471} 475}
472 476
473 477
474QString Modem::parseModemSpeed(const QString &s) { 478QString Modem::parseModemSpeed(const QString &s) {
475 // this is a small (and bad) parser for modem speeds 479 // this is a small (and bad) parser for modem speeds
476 int rx = -1; 480 int rx = -1;
477 int tx = -1; 481 int tx = -1;
478 int i; 482 int i;
479 QString result; 483 QString result;
480 484
481 odebug << "Modem reported result string: " << s.latin1() << "" << oendl; 485 odebug << "Modem reported result string: " << s.latin1() << "" << oendl;
482 486
483 const int RXMAX = 7; 487 const int RXMAX = 7;
484 const int TXMAX = 2; 488 const int TXMAX = 2;
485 QRegExp rrx[RXMAX] = { 489 QRegExp rrx[RXMAX] = {
486 QRegExp("[0-9]+[:/ ]RX", false), 490 QRegExp("[0-9]+[:/ ]RX", false),
487 QRegExp("[0-9]+RX", false), 491 QRegExp("[0-9]+RX", false),
488 QRegExp("[/: -][0-9]+[/: ]", false), 492 QRegExp("[/: -][0-9]+[/: ]", false),
489 QRegExp("[/: -][0-9]+$", false), 493 QRegExp("[/: -][0-9]+$", false),
490 QRegExp("CARRIER [^0-9]*[0-9]+", false), 494 QRegExp("CARRIER [^0-9]*[0-9]+", false),
491 QRegExp("CONNECT [^0-9]*[0-9]+", false), 495 QRegExp("CONNECT [^0-9]*[0-9]+", false),
492 QRegExp("[0-9]+") // panic mode 496 QRegExp("[0-9]+") // panic mode
493 }; 497 };
494 498
495 QRegExp trx[TXMAX] = { 499 QRegExp trx[TXMAX] = {
496 QRegExp("[0-9]+[:/ ]TX", false), 500 QRegExp("[0-9]+[:/ ]TX", false),
497 QRegExp("[0-9]+TX", false) 501 QRegExp("[0-9]+TX", false)
498 }; 502 };
499 503
500 for(i = 0; i < RXMAX; i++) { 504 for(i = 0; i < RXMAX; i++) {
501 int len, idx, result; 505 int len, idx, result;
502 if((idx = rrx[i].match(s,0,&len)) > -1) { 506 if((idx = rrx[i].match(s,0,&len)) > -1) {
503// if((idx = rrx[i].search(s)) > -1) { 507// if((idx = rrx[i].search(s)) > -1) {
504 // len = rrx[i].matchedLength(); 508 // len = rrx[i].matchedLength();
505 509
506 // 510 //
507 // rrx[i] has been matched, idx contains the start of the match 511 // rrx[i] has been matched, idx contains the start of the match
508 // and len contains how long the match is. Extract the match. 512 // and len contains how long the match is. Extract the match.
509 // 513 //
510 QString sub = s.mid(idx, len); 514 QString sub = s.mid(idx, len);
511 515
512 // 516 //
513 // Now extract the digits only from the match, which will 517 // Now extract the digits only from the match, which will
514 // then be converted to an int. 518 // then be converted to an int.
515 // 519 //
516 if ((idx = rrx[RXMAX-1].match( sub,0,&len )) > -1) { 520 if ((idx = rrx[RXMAX-1].match( sub,0,&len )) > -1) {
517// if ((idx = rrx[RXMAX-1].search( sub )) > -1) { 521// if ((idx = rrx[RXMAX-1].search( sub )) > -1) {
518// len = rrx[RXMAX-1].matchedLength(); 522// len = rrx[RXMAX-1].matchedLength();
519 sub = sub.mid(idx, len); 523 sub = sub.mid(idx, len);
520 result = sub.toInt(); 524 result = sub.toInt();
521 if(result > 0) { 525 if(result > 0) {
522 rx = result; 526 rx = result;
523 break; 527 break;
524 } 528 }
525 } 529 }
526 } 530 }
527 } 531 }
528 532
529 for(i = 0; i < TXMAX; i++) { 533 for(i = 0; i < TXMAX; i++) {
530 int len, idx, result; 534 int len, idx, result;
531 if((idx = trx[i].match(s,0,&len)) > -1) { 535 if((idx = trx[i].match(s,0,&len)) > -1) {
532// if((idx = trx[i].search(s)) > -1) { 536// if((idx = trx[i].search(s)) > -1) {
533// len = trx[i].matchedLength(); 537// len = trx[i].matchedLength();
534 538
535 // 539 //
536 // trx[i] has been matched, idx contains the start of the match 540 // trx[i] has been matched, idx contains the start of the match
537 // and len contains how long the match is. Extract the match. 541 // and len contains how long the match is. Extract the match.
538 // 542 //
539 QString sub = s.mid(idx, len); 543 QString sub = s.mid(idx, len);
540 544
541 // 545 //
542 // Now extract the digits only from the match, which will then 546 // Now extract the digits only from the match, which will then
543 // be converted to an int. 547 // be converted to an int.
544 // 548 //
545 if((idx = rrx[RXMAX-1].match(sub,0,&len)) > -1) { 549 if((idx = rrx[RXMAX-1].match(sub,0,&len)) > -1) {
546// if((idx = rrx[RXMAX-1].search(sub)) > -1) { 550// if((idx = rrx[RXMAX-1].search(sub)) > -1) {
547// len = rrx[RXMAX-1].matchedLength(); 551// len = rrx[RXMAX-1].matchedLength();
548 sub = sub.mid(idx, len); 552 sub = sub.mid(idx, len);
549 result = sub.toInt(); 553 result = sub.toInt();
550 if(result > 0) { 554 if(result > 0) {
551 tx = result; 555 tx = result;
552 break; 556 break;
553 } 557 }
554 } 558 }
555 } 559 }
556 } 560 }
557 561
558 if(rx == -1 && tx == -1) 562 if(rx == -1 && tx == -1)
559 result = QObject::tr("Unknown speed"); 563 result = QObject::tr("Unknown speed");
560 else if(tx == -1) 564 else if(tx == -1)
561 result.setNum(rx); 565 result.setNum(rx);
562 else if(rx == -1) // should not happen 566 else if(rx == -1) // should not happen
563 result.setNum(tx); 567 result.setNum(tx);
564 else 568 else
565 result.sprintf("%d/%d", rx, tx); 569 result.sprintf("%d/%d", rx, tx);
566 570
567 odebug << "The parsed result is: " << result.latin1() << "" << oendl; 571 odebug << "The parsed result is: " << result.latin1() << "" << oendl;
568 572
569 return result; 573 return result;
570} 574}
571 575
572 576
573// Lock modem device. Returns 0 on success 1 if the modem is locked and -1 if 577// Lock modem device. Returns 0 on success 1 if the modem is locked and -1 if
574// a lock file can't be created ( permission problem ) 578// a lock file can't be created ( permission problem )
575int Modem::lockdevice() { 579int Modem::lockdevice() {
576 int fd; 580 int fd;
577 char newlock[80]=""; // safe 581 char newlock[80]=""; // safe
578 582
579 if(!_pppdata->modemLockFile()) { 583 if(!_pppdata->modemLockFile()) {
580 odebug << "The user doesn't want a lockfile." << oendl; 584 odebug << "The user doesn't want a lockfile." << oendl;
581 return 0; 585 return 0;
582 } 586 }
583 587
584 if (modem_is_locked) 588 if (modem_is_locked)
585 return 1; 589 return 1;
586 590
587 QString lockfile = LOCK_DIR"/LCK.."; 591 QString lockfile = LOCK_DIR"/LCK..";
588 lockfile += _pppdata->modemDevice().mid(5); // append everything after /dev/ 592 lockfile += _pppdata->modemDevice().mid(5); // append everything after /dev/
589 593
590 if(access(QFile::encodeName(lockfile), F_OK) == 0) { 594 if(access(QFile::encodeName(lockfile), F_OK) == 0) {
591// if ((fd = Requester::rq-> 595// if ((fd = Requester::rq->
592if ((fd = openLockfile(QFile::encodeName(lockfile), O_RDONLY)) >= 0) { 596if ((fd = openLockfile(QFile::encodeName(lockfile), O_RDONLY)) >= 0) {
593 // Mario: it's not necessary to read more than lets say 32 bytes. If 597 // Mario: it's not necessary to read more than lets say 32 bytes. If
594 // file has more than 32 bytes, skip the rest 598 // file has more than 32 bytes, skip the rest
595 char oldlock[33]; // safe 599 char oldlock[33]; // safe
596 int sz = read(fd, &oldlock, 32); 600 int sz = read(fd, &oldlock, 32);
597 close (fd); 601 close (fd);
598 if (sz <= 0) 602 if (sz <= 0)
599 return 1; 603 return 1;
600 oldlock[sz] = '\0'; 604 oldlock[sz] = '\0';
601 605
602 odebug << "Device is locked by: " << oldlock << "" << oendl; 606 odebug << "Device is locked by: " << oldlock << "" << oendl;
603 607
604 int oldpid; 608 int oldpid;
605 int match = sscanf(oldlock, "%d", &oldpid); 609 int match = sscanf(oldlock, "%d", &oldpid);
606 610
607 // found a pid in lockfile ? 611 // found a pid in lockfile ?
608 if (match < 1 || oldpid <= 0) 612 if (match < 1 || oldpid <= 0)
609 return 1; 613 return 1;
610 614
611 // check if process exists 615 // check if process exists
612 if (kill((pid_t)oldpid, 0) == 0 || errno != ESRCH) 616 if (kill((pid_t)oldpid, 0) == 0 || errno != ESRCH)
613 return 1; 617 return 1;
614 618
615 odebug << "lockfile is stale" << oendl; 619 odebug << "lockfile is stale" << oendl;
616 } 620 }
617 } 621 }
618 622
619 fd = openLockfile(_pppdata->modemDevice(),O_WRONLY|O_TRUNC|O_CREAT); 623 fd = openLockfile(_pppdata->modemDevice(),O_WRONLY|O_TRUNC|O_CREAT);
620 if(fd >= 0) { 624 if(fd >= 0) {
621 sprintf(newlock,"%010d\n", getpid()); 625 sprintf(newlock,"%010d\n", getpid());
622 odebug << "Locking Device: " << newlock << "" << oendl; 626 odebug << "Locking Device: " << newlock << "" << oendl;
623 627
624 write(fd, newlock, strlen(newlock)); 628 write(fd, newlock, strlen(newlock));
625 close(fd); 629 close(fd);
626 modem_is_locked=true; 630 modem_is_locked=true;
627 631
628 return 0; 632 return 0;
629 } 633 }
630 634
631 return -1; 635 return -1;
632 636
633} 637}
634 638
635 639
636// UnLock modem device 640// UnLock modem device
637void Modem::unlockdevice() { 641void Modem::unlockdevice() {
638 if (modem_is_locked) { 642 if (modem_is_locked) {
639 odebug << "UnLocking Modem Device" << oendl; 643 odebug << "UnLocking Modem Device" << oendl;
640 close(modemfd); 644 close(modemfd);
641 modemfd = -1; 645 modemfd = -1;
642 unlink(lockfile); 646 unlink(lockfile);
643 lockfile[0] = '\0'; 647 lockfile[0] = '\0';
644 modem_is_locked=false; 648 modem_is_locked=false;
645 } 649 }
646} 650}
647 651
648int Modem::openLockfile( QString lockfile, int flags) 652int Modem::openLockfile( QString lockfile, int flags)
649{ 653{
650 int fd; 654 int fd;
651 int mode; 655 int mode;
652 flags = O_RDONLY; 656 flags = O_RDONLY;
653 if(flags == O_WRONLY|O_TRUNC|O_CREAT) 657 if(flags == O_WRONLY|O_TRUNC|O_CREAT)
654 mode = 0644; 658 mode = 0644;
655 else 659 else
656 mode = 0; 660 mode = 0;
657 661
658 lockfile = LOCK_DIR; 662 lockfile = LOCK_DIR;
659 lockfile += "/LCK.."; 663 lockfile += "/LCK..";
660 lockfile += device.right( device.length() - device.findRev("/") -1 ); 664 lockfile += device.right( device.length() - device.findRev("/") -1 );
661 odebug << "lockfile >" << lockfile.latin1() << "<" << oendl; 665 odebug << "lockfile >" << lockfile.latin1() << "<" << oendl;
662 // TODO: 666 // TODO:
663 // struct stat st; 667 // struct stat st;
664 // if(stat(lockfile.data(), &st) == -1) { 668 // if(stat(lockfile.data(), &st) == -1) {
665 // if(errno == EBADF) 669 // if(errno == EBADF)
666 // return -1; 670 // return -1;
667 // } else { 671 // } else {
668 // // make sure that this is a regular file 672 // // make sure that this is a regular file
669 // if(!S_ISREG(st.st_mode)) 673 // if(!S_ISREG(st.st_mode))
670 // return -1; 674 // return -1;
671 // } 675 // }
672 if ((fd = open(lockfile, flags, mode)) == -1) { 676 if ((fd = open(lockfile, flags, mode)) == -1) {
673 odebug << "error opening lockfile!" << oendl; 677 odebug << "error opening lockfile!" << oendl;
674 lockfile = QString::null; 678 lockfile = QString::null;
675 fd = open(DEVNULL, O_RDONLY); 679 fd = open(DEVNULL, O_RDONLY);
676 } else 680 } else
677 fchown(fd, 0, 0); 681 fchown(fd, 0, 0);
678 return fd; 682 return fd;
679} 683}
680 684
681 685
682 686
683void alarm_handler(int) { 687void alarm_handler(int) {
684 // fprintf(stderr, "alarm_handler(): Received SIGALRM\n"); 688 // fprintf(stderr, "alarm_handler(): Received SIGALRM\n");
685 689
686 // jump 690 // jump
687 siglongjmp(jmp_buffer, 1); 691 siglongjmp(jmp_buffer, 1);
688} 692}
689 693
690 694
691const char* Modem::authFile(Auth method, int version) { 695const char* Modem::authFile(Auth method, int version) {
692 switch(method|version) { 696 switch(method|version) {
693 case PAP|Original: 697 case PAP|Original:
694 return PAP_AUTH_FILE; 698 return PAP_AUTH_FILE;
695 break; 699 break;
696 case PAP|New: 700 case PAP|New:
697 return PAP_AUTH_FILE".new"; 701 return PAP_AUTH_FILE".new";
698 break; 702 break;
699 case PAP|Old: 703 case PAP|Old:
700 return PAP_AUTH_FILE".old"; 704 return PAP_AUTH_FILE".old";
701 break; 705 break;
702 case CHAP|Original: 706 case CHAP|Original:
703 return CHAP_AUTH_FILE; 707 return CHAP_AUTH_FILE;
704 break; 708 break;
705 case CHAP|New: 709 case CHAP|New:
706 return CHAP_AUTH_FILE".new"; 710 return CHAP_AUTH_FILE".new";
707 break; 711 break;
708 case CHAP|Old: 712 case CHAP|Old:
709 return CHAP_AUTH_FILE".old"; 713 return CHAP_AUTH_FILE".old";
710 break; 714 break;
711 default: 715 default:
712 return 0L; 716 return 0L;
713 } 717 }
714} 718}
715 719
716 720
717bool Modem::createAuthFile(Auth method, const char *username, const char *password) { 721bool Modem::createAuthFile(Auth method, const char *username, const char *password) {
718 const char *authfile, *oldName, *newName; 722 const char *authfile, *oldName, *newName;
719 char line[100]; 723 char line[100];
720 char regexp[2*MaxStrLen+30]; 724 char regexp[2*MaxStrLen+30];
721 regex_t preg; 725 regex_t preg;
722 726
723 if(!(authfile = authFile(method))) 727 if(!(authfile = authFile(method)))
724 return false; 728 return false;
725 729
726 if(!(newName = authFile(method, New))) 730 if(!(newName = authFile(method, New)))
727 return false; 731 return false;
728 732
729 // look for username, "username" or 'username' 733 // look for username, "username" or 'username'
730 // if you modify this RE you have to adapt regexp's size above 734 // if you modify this RE you have to adapt regexp's size above
731 snprintf(regexp, sizeof(regexp), "^[ \t]*%s[ \t]\\|^[ \t]*[\"\']%s[\"\']", 735 snprintf(regexp, sizeof(regexp), "^[ \t]*%s[ \t]\\|^[ \t]*[\"\']%s[\"\']",
732 username,username); 736 username,username);
733 MY_ASSERT(regcomp(&preg, regexp, 0) == 0); 737 MY_ASSERT(regcomp(&preg, regexp, 0) == 0);
734 738
735 // copy to new file pap- or chap-secrets 739 // copy to new file pap- or chap-secrets
736 int old_umask = umask(0077); 740 int old_umask = umask(0077);
737 FILE *fout = fopen(newName, "w"); 741 FILE *fout = fopen(newName, "w");
738 if(fout) { 742 if(fout) {
739 // copy old file 743 // copy old file
740 FILE *fin = fopen(authfile, "r"); 744 FILE *fin = fopen(authfile, "r");
741 if(fin) { 745 if(fin) {
742 while(fgets(line, sizeof(line), fin)) { 746 while(fgets(line, sizeof(line), fin)) {
743 if(regexec(&preg, line, 0, 0L, 0) == 0) 747 if(regexec(&preg, line, 0, 0L, 0) == 0)
744 continue; 748 continue;
745 fputs(line, fout); 749 fputs(line, fout);
746 } 750 }
747 fclose(fin); 751 fclose(fin);
748 } 752 }
749 753
750 // append user/pass pair 754 // append user/pass pair
diff --git a/noncore/settings/networksettings/ppp/pppdata.cpp b/noncore/settings/networksettings/ppp/pppdata.cpp
index eb03ef4..1491ea2 100644
--- a/noncore/settings/networksettings/ppp/pppdata.cpp
+++ b/noncore/settings/networksettings/ppp/pppdata.cpp
@@ -6,1107 +6,1107 @@
6 * Copyright (C) 1997 Bernd Johannes Wuebben 6 * Copyright (C) 1997 Bernd Johannes Wuebben
7 * wuebben@math.cornell.edu 7 * wuebben@math.cornell.edu
8 * 8 *
9 * based on EzPPP: 9 * based on EzPPP:
10 * Copyright (C) 1997 Jay Painter 10 * Copyright (C) 1997 Jay Painter
11 * 11 *
12 * This program is free software; you can redistribute it and/or 12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU Library General Public 13 * modify it under the terms of the GNU Library General Public
14 * License as published by the Free Software Foundation; either 14 * License as published by the Free Software Foundation; either
15 * version 2 of the License, or (at your option) any later version. 15 * version 2 of the License, or (at your option) any later version.
16 * 16 *
17 * This program is distributed in the hope that it will be useful, 17 * This program is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of 18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 * Library General Public License for more details. 20 * Library General Public License for more details.
21 * 21 *
22 * You should have received a copy of the GNU Library General Public 22 * You should have received a copy of the GNU Library General Public
23 * License along with this program; if not, write to the Free 23 * License along with this program; if not, write to the Free
24 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 24 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
25 */ 25 */
26 26
27#include "pppdata.h" 27#include "pppdata.h"
28#include "runtests.h" 28#include "runtests.h"
29 29
30/* OPIE */ 30/* OPIE */
31#include <opie2/odebug.h> 31#include <opie2/odebug.h>
32#include <qpe/config.h> 32#include <qpe/config.h>
33using namespace Opie::Core; 33using namespace Opie::Core;
34 34
35/* QT */ 35/* QT */
36#include <qmessagebox.h> 36#include <qmessagebox.h>
37#include <qapplication.h> 37#include <qapplication.h>
38 38
39/* STD */ 39/* STD */
40#include <assert.h> 40#include <assert.h>
41 41
42#define SEPARATOR -sseepp- 42#define SEPARATOR -sseepp-
43#define SEP QString("%1SEPARATOR%1") 43#define SEP QString("%1SEPARATOR%1")
44 44
45PPPData::PPPData() 45PPPData::PPPData()
46 : passwd(""), 46 : passwd(""),
47 _modemName(""), 47 _modemName(""),
48 highcount(-1), // start out with no entries 48 highcount(-1), // start out with no entries
49 highcountdev(-1), // start out with no entries 49 highcountdev(-1), // start out with no entries
50// caccount(-1), // set the current account index also 50// caccount(-1), // set the current account index also
51 suidprocessid(-1), // process ID of setuid child 51 suidprocessid(-1), // process ID of setuid child
52 pppdisrunning(false), 52 pppdisrunning(false),
53 pppderror(0) 53 pppderror(0)
54{ 54{
55 highcount = readNumConfig(GENERAL_GRP, NUMACCOUNTS_KEY, 0) - 1; 55 highcount = readNumConfig(GENERAL_GRP, NUMACCOUNTS_KEY, 0) - 1;
56 highcountdev = readNumConfig(GENERAL_GRP, NUMDEVICES_KEY, 0) - 1; 56 highcountdev = readNumConfig(GENERAL_GRP, NUMDEVICES_KEY, 0) - 1;
57 Config cfg = config(); 57 Config cfg = config();
58 cfg.setGroup(GENERAL_GRP); 58 cfg.setGroup(GENERAL_GRP);
59 accountList = cfg.readListEntry(ACCOUNT_LIST, ',' ); 59 accountList = cfg.readListEntry(ACCOUNT_LIST, ',' );
60 deviceList = cfg.readListEntry(DEVICESNAMES_LIST, ',' ); 60 deviceList = cfg.readListEntry(DEVICESNAMES_LIST, ',' );
61 odebug << "PPPData::PPPData has a accountList " << accountList.join("---").latin1() << "" << oendl; 61 odebug << "PPPData::PPPData has a accountList " << accountList.join("---").latin1() << "" << oendl;
62 odebug << "PPPData::PPPData has a deviceList " << deviceList.join("---").latin1() << "" << oendl; 62 odebug << "PPPData::PPPData has a deviceList " << deviceList.join("---").latin1() << "" << oendl;
63 63
64// if (highcount > MAX_ACCOUNTS) 64// if (highcount > MAX_ACCOUNTS)
65// highcount = MAX_ACCOUNTS; 65// highcount = MAX_ACCOUNTS;
66 66
67 // if(highcount >= 0 && defaultAccount().isEmpty()) { 67 // if(highcount >= 0 && defaultAccount().isEmpty()) {
68// setAccountbyIndex(0); 68// setAccountbyIndex(0);
69// setDefaultAccount(accname()); 69// setDefaultAccount(accname());
70// } else if(!setAccount(defaultAccount())) 70// } else if(!setAccount(defaultAccount()))
71 setDefaultAccount(accname()); 71 setDefaultAccount(accname());
72 72
73 // start out with internal debugging disabled 73 // start out with internal debugging disabled
74 // the user is still free to specify `debug' on his own 74 // the user is still free to specify `debug' on his own
75 setPPPDebug(false); 75 setPPPDebug(false);
76 76
77 ::pppdVersion(&pppdVer, &pppdMod, &pppdPatch); 77 ::pppdVersion(&pppdVer, &pppdMod, &pppdPatch);
78 78
79} 79}
80 80
81Config PPPData::config() 81Config PPPData::config()
82{ 82{
83 return Config("NetworkSetupPPP"); 83 return Config("NetworkSetupPPP");
84} 84}
85 85
86// 86//
87// save configuration 87// save configuration
88// 88//
89void PPPData::save() 89void PPPData::save()
90{ 90{
91 odebug << "PPPData saving data" << oendl; 91 odebug << "PPPData saving data" << oendl;
92 writeConfig(GENERAL_GRP, NUMACCOUNTS_KEY, count()); 92 writeConfig(GENERAL_GRP, NUMACCOUNTS_KEY, count());
93 writeConfig(GENERAL_GRP, NUMDEVICES_KEY, highcountdev + 1); 93 writeConfig(GENERAL_GRP, NUMDEVICES_KEY, highcountdev + 1);
94 QString key; 94 QString key;
95 QStringList keys; 95 QStringList keys;
96 Config cfg = config(); 96 Config cfg = config();
97 cfg.setGroup(GENERAL_GRP); 97 cfg.setGroup(GENERAL_GRP);
98 cfg.writeEntry(ACCOUNT_LIST, accountList, ',' ); 98 cfg.writeEntry(ACCOUNT_LIST, accountList, ',' );
99 cfg.writeEntry(DEVICESNAMES_LIST, deviceList, ',' ); 99 cfg.writeEntry(DEVICESNAMES_LIST, deviceList, ',' );
100 100
101 for( QMap<QString,QString>::Iterator it = stringEntries.begin(); 101 for( QMap<QString,QString>::Iterator it = stringEntries.begin();
102 it != stringEntries.end(); ++it ){ 102 it != stringEntries.end(); ++it ){
103 QString val = it.data(); 103 QString val = it.data();
104 key = it.key(); 104 key = it.key();
105// odebug << "saving " << key.latin1() << " -> " << val.latin1() << "" << oendl; 105// odebug << "saving " << key.latin1() << " -> " << val.latin1() << "" << oendl;
106 keys = QStringList::split( "SEPARATOR", key ); 106 keys = QStringList::split( "SEPARATOR", key );
107 //odebug << "group >" << keys[0].latin1() << "< key >" << keys[1].latin1() << "< value >" << val.latin1() << "<" << oendl; 107 //odebug << "group >" << keys[0].latin1() << "< key >" << keys[1].latin1() << "< value >" << val.latin1() << "<" << oendl;
108 cfg.setGroup(keys[0]); 108 cfg.setGroup(keys[0]);
109 cfg.writeEntry(keys[1], val); 109 cfg.writeEntry(keys[1], val);
110 } 110 }
111 for( QMap<QString,int>::Iterator it = intEntries.begin(); 111 for( QMap<QString,int>::Iterator it = intEntries.begin();
112 it != intEntries.end(); ++it ){ 112 it != intEntries.end(); ++it ){
113 int val = it.data(); 113 int val = it.data();
114 key = it.key(); 114 key = it.key();
115// odebug << "saving " << key.latin1() << " -> " << val << "" << oendl; 115// odebug << "saving " << key.latin1() << " -> " << val << "" << oendl;
116 keys = QStringList::split( "SEPARATOR", key ); 116 keys = QStringList::split( "SEPARATOR", key );
117 //odebug << "group >" << keys[0].latin1() << "< key >" << keys[1].latin1() << "< val " << val << "" << oendl; 117 //odebug << "group >" << keys[0].latin1() << "< key >" << keys[1].latin1() << "< val " << val << "" << oendl;
118 cfg.setGroup(keys[0]); 118 cfg.setGroup(keys[0]);
119 cfg.writeEntry(keys[1], val); 119 cfg.writeEntry(keys[1], val);
120 } 120 }
121 for( QMap<QString,QStringList>::Iterator it = listEntries.begin(); 121 for( QMap<QString,QStringList>::Iterator it = listEntries.begin();
122 it != listEntries.end(); ++it ){ 122 it != listEntries.end(); ++it ){
123 QStringList val = it.data(); 123 QStringList val = it.data();
124 key = it.key(); 124 key = it.key();
125 QChar sep = sepEntries[key]; 125 QChar sep = sepEntries[key];
126// odebug << "saving " << key.latin1() << " -> " << val.join(sep).latin1() << "" << oendl; 126// odebug << "saving " << key.latin1() << " -> " << val.join(sep).latin1() << "" << oendl;
127 keys = QStringList::split( "SEPARATOR", key ); 127 keys = QStringList::split( "SEPARATOR", key );
128 cfg.setGroup(keys[0]); 128 cfg.setGroup(keys[0]);
129 cfg.writeEntry(keys[1], val, sep); 129 cfg.writeEntry(keys[1], val, sep);
130 } 130 }
131} 131}
132 132
133 133
134// 134//
135// cancel changes 135// cancel changes
136// 136//
137void PPPData::cancel() { 137void PPPData::cancel() {
138 stringEntries.clear(); 138 stringEntries.clear();
139 intEntries.clear(); 139 intEntries.clear();
140 listEntries.clear(); 140 listEntries.clear();
141} 141}
142 142
143// functions to read/write date to configuration file 143// functions to read/write date to configuration file
144QString PPPData::readConfig(const QString &group, const QString &key, 144QString PPPData::readConfig(const QString &group, const QString &key,
145 const QString &defvalue = "") 145 const QString &defvalue = "")
146{ 146{
147// odebug << "PPPData::readConfig key >" << key.latin1() << "< group >" << group.latin1() << "<" << oendl; 147// odebug << "PPPData::readConfig key >" << key.latin1() << "< group >" << group.latin1() << "<" << oendl;
148 QString idx = SEP.arg(group).arg(key); 148 QString idx = SEP.arg(group).arg(key);
149 if (stringEntries.find(idx) != stringEntries.end()) 149 if (stringEntries.find(idx) != stringEntries.end())
150 return stringEntries[idx]; 150 return stringEntries[idx];
151 Config cfg = config(); 151 Config cfg = config();
152 cfg.setGroup(group); 152 cfg.setGroup(group);
153 return cfg.readEntry(key, defvalue); 153 return cfg.readEntry(key, defvalue);
154} 154}
155 155
156 156
157int PPPData::readNumConfig(const QString &group, const QString &key, 157int PPPData::readNumConfig(const QString &group, const QString &key,
158 int defvalue) 158 int defvalue)
159{ 159{
160 QString idx = SEP.arg(group).arg(key); 160 QString idx = SEP.arg(group).arg(key);
161 if (intEntries.find(idx) != intEntries.end()) 161 if (intEntries.find(idx) != intEntries.end())
162 return intEntries[idx]; 162 return intEntries[idx];
163 Config cfg = config(); 163 Config cfg = config();
164 cfg.setGroup(group); 164 cfg.setGroup(group);
165 return cfg.readNumEntry(key, defvalue); 165 return cfg.readNumEntry(key, defvalue);
166 166
167// if (config) { 167// if (config) {
168// config->setGroup(group); 168// config->setGroup(group);
169// return config->readNumEntry(key, defvalue); 169// return config->readNumEntry(key, defvalue);
170// } else 170// } else
171// return defvalue; 171// return defvalue;
172 172
173} 173}
174 174
175 175
176bool PPPData::readListConfig(const QString &group, const QString &key, 176bool PPPData::readListConfig(const QString &group, const QString &key,
177 QStringList &list, char sep) { 177 QStringList &list, char sep) {
178 list.clear(); 178 list.clear();
179 QString idx = SEP.arg(group).arg(key); 179 QString idx = SEP.arg(group).arg(key);
180 if (listEntries.find(idx) != listEntries.end()){ 180 if (listEntries.find(idx) != listEntries.end()){
181 list = listEntries[idx]; 181 list = listEntries[idx];
182 return true; 182 return true;
183 } 183 }
184 Config cfg = config(); 184 Config cfg = config();
185 cfg.setGroup(group); 185 cfg.setGroup(group);
186 list = cfg.readListEntry(key, sep); 186 list = cfg.readListEntry(key, sep);
187 if (list.count() > 0) return true; 187 if (list.count() > 0) return true;
188 return false; 188 return false;
189 189
190// if (config) { 190// if (config) {
191// config->setGroup(group); 191// config->setGroup(group);
192// list = config->readListEntry(key, sep); 192// list = config->readListEntry(key, sep);
193// return true; 193// return true;
194// } else 194// } else
195// return false; 195// return false;
196} 196}
197 197
198 198
199void PPPData::writeConfig(const QString &group, const QString &key, 199void PPPData::writeConfig(const QString &group, const QString &key,
200 const QString &value) { 200 const QString &value) {
201 stringEntries.insert( SEP.arg(group).arg(key), value ); 201 stringEntries.insert( SEP.arg(group).arg(key), value );
202// if (config) { 202// if (config) {
203// config->setGroup(group); 203// config->setGroup(group);
204// config->writeEntry(key, value); 204// config->writeEntry(key, value);
205// } 205// }
206} 206}
207 207
208 208
209void PPPData::writeConfig(const QString &group, const QString &key, int value) 209void PPPData::writeConfig(const QString &group, const QString &key, int value)
210{ 210{
211 intEntries.insert( SEP.arg(group).arg(key), value ); 211 intEntries.insert( SEP.arg(group).arg(key), value );
212// if (config) { 212// if (config) {
213// config->setGroup(group); 213// config->setGroup(group);
214// config->writeEntry(key, value); 214// config->writeEntry(key, value);
215// } 215// }
216} 216}
217 217
218 218
219void PPPData::writeListConfig(const QString &group, const QString &key, 219void PPPData::writeListConfig(const QString &group, const QString &key,
220 QStringList &list, char sep) 220 QStringList &list, char sep)
221{ 221{
222 listEntries.insert( SEP.arg(group).arg(key), list ); 222 listEntries.insert( SEP.arg(group).arg(key), list );
223 sepEntries.insert( SEP.arg(group).arg(key), sep ); 223 sepEntries.insert( SEP.arg(group).arg(key), sep );
224// if (config) { 224// if (config) {
225// config->setGroup(group); 225// config->setGroup(group);
226// config->writeEntry(key, list, sep); 226// config->writeEntry(key, list, sep);
227// } 227// }
228} 228}
229 229
230 230
231// 231//
232// functions to set/return general information 232// functions to set/return general information
233// 233//
234QString PPPData::password(){ 234QString PPPData::password(){
235 if ( storePassword() ) return storedPassword(); 235 if ( storePassword() ) return storedPassword();
236 else return passwd; 236 else return passwd;
237} 237}
238 238
239 239
240void PPPData::setPassword(const QString &pw) { 240void PPPData::setPassword(const QString &pw) {
241 passwd = pw; 241 passwd = pw;
242} 242}
243 243
244 244
245const QString PPPData::defaultAccount() { 245const QString PPPData::defaultAccount() {
246 return readConfig(GENERAL_GRP, DEFAULTACCOUNT_KEY); 246 return readConfig(GENERAL_GRP, DEFAULTACCOUNT_KEY);
247} 247}
248 248
249 249
250void PPPData::setDefaultAccount(const QString &n) { 250void PPPData::setDefaultAccount(const QString &n) {
251 writeConfig(GENERAL_GRP, DEFAULTACCOUNT_KEY, n); 251 writeConfig(GENERAL_GRP, DEFAULTACCOUNT_KEY, n);
252 252
253 //now set the current account index to the default account 253 //now set the current account index to the default account
254 setAccount(defaultAccount()); 254 setAccount(defaultAccount());
255} 255}
256 256
257 257
258bool PPPData::get_show_clock_on_caption() { 258bool PPPData::get_show_clock_on_caption() {
259 return (bool) readNumConfig(GENERAL_GRP, SHOWCLOCK_KEY, true); 259 return (bool) readNumConfig(GENERAL_GRP, SHOWCLOCK_KEY, true);
260} 260}
261 261
262 262
263void PPPData::set_show_clock_on_caption(bool set) { 263void PPPData::set_show_clock_on_caption(bool set) {
264 writeConfig(GENERAL_GRP, SHOWCLOCK_KEY, (int) set); 264 writeConfig(GENERAL_GRP, SHOWCLOCK_KEY, (int) set);
265} 265}
266 266
267 267
268bool PPPData::get_xserver_exit_disconnect() { 268bool PPPData::get_xserver_exit_disconnect() {
269 return (bool) readNumConfig(GENERAL_GRP, DISCONNECT_KEY, true); 269 return (bool) readNumConfig(GENERAL_GRP, DISCONNECT_KEY, true);
270} 270}
271 271
272 272
273void PPPData::setPPPDebug(bool set) { 273void PPPData::setPPPDebug(bool set) {
274 writeConfig(GENERAL_GRP, PPP_DEBUG_OPTION, (int)set); 274 writeConfig(GENERAL_GRP, PPP_DEBUG_OPTION, (int)set);
275} 275}
276 276
277 277
278bool PPPData::getPPPDebug() { 278bool PPPData::getPPPDebug() {
279 return (bool)readNumConfig(GENERAL_GRP, PPP_DEBUG_OPTION, false); 279 return (bool)readNumConfig(GENERAL_GRP, PPP_DEBUG_OPTION, false);
280} 280}
281 281
282 282
283void PPPData::set_xserver_exit_disconnect(bool set) { 283void PPPData::set_xserver_exit_disconnect(bool set) {
284 writeConfig(GENERAL_GRP, DISCONNECT_KEY, (int) set); 284 writeConfig(GENERAL_GRP, DISCONNECT_KEY, (int) set);
285} 285}
286 286
287 287
288bool PPPData::quit_on_disconnect() { 288bool PPPData::quit_on_disconnect() {
289 return (bool) readNumConfig(GENERAL_GRP, QUITONDISCONNECT_KEY, false); 289 return (bool) readNumConfig(GENERAL_GRP, QUITONDISCONNECT_KEY, false);
290} 290}
291 291
292 292
293void PPPData::set_quit_on_disconnect(bool set) { 293void PPPData::set_quit_on_disconnect(bool set) {
294 writeConfig(GENERAL_GRP, QUITONDISCONNECT_KEY, (int) set); 294 writeConfig(GENERAL_GRP, QUITONDISCONNECT_KEY, (int) set);
295} 295}
296 296
297 297
298bool PPPData::get_show_log_window() { 298bool PPPData::get_show_log_window() {
299 return (bool) readNumConfig (GENERAL_GRP, SHOWLOGWIN_KEY, false); 299 return (bool) readNumConfig (GENERAL_GRP, SHOWLOGWIN_KEY, false);
300} 300}
301 301
302 302
303void PPPData::set_show_log_window(bool set) { 303void PPPData::set_show_log_window(bool set) {
304 writeConfig(GENERAL_GRP, SHOWLOGWIN_KEY, (int) set); 304 writeConfig(GENERAL_GRP, SHOWLOGWIN_KEY, (int) set);
305} 305}
306 306
307 307
308bool PPPData::automatic_redial() { 308bool PPPData::automatic_redial() {
309 return (bool) readNumConfig(GENERAL_GRP, AUTOREDIAL_KEY, FALSE); 309 return (bool) readNumConfig(GENERAL_GRP, AUTOREDIAL_KEY, FALSE);
310} 310}
311 311
312 312
313void PPPData::set_automatic_redial(bool set) { 313void PPPData::set_automatic_redial(bool set) {
314 writeConfig(GENERAL_GRP, AUTOREDIAL_KEY, (int) set); 314 writeConfig(GENERAL_GRP, AUTOREDIAL_KEY, (int) set);
315} 315}
316 316
317 317
318// bool PPPData::get_iconify_on_connect() { 318// bool PPPData::get_iconify_on_connect() {
319// return (bool) readNumConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, TRUE); 319// return (bool) readNumConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, TRUE);
320// } 320// }
321 321
322 322
323// void PPPData::set_iconify_on_connect(bool set) { 323// void PPPData::set_iconify_on_connect(bool set) {
324// writeConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, (int) set); 324// writeConfig(GENERAL_GRP, ICONIFY_ON_CONNECT_KEY, (int) set);
325// } 325// }
326 326
327 327
328// bool PPPData::get_dock_into_panel() { 328// bool PPPData::get_dock_into_panel() {
329// return (bool) readNumConfig(GENERAL_GRP, DOCKING_KEY, false); 329// return (bool) readNumConfig(GENERAL_GRP, DOCKING_KEY, false);
330// } 330// }
331 331
332 332
333// void PPPData::set_dock_into_panel(bool set) { 333// void PPPData::set_dock_into_panel(bool set) {
334// writeConfig(GENERAL_GRP, DOCKING_KEY, (int) set); 334// writeConfig(GENERAL_GRP, DOCKING_KEY, (int) set);
335// } 335// }
336 336
337 337
338QString PPPData::pppdVersion() { 338QString PPPData::pppdVersion() {
339 return QString("%1.%2.%3").arg(pppdVer).arg(pppdMod).arg(pppdPatch); 339 return QString("%1.%2.%3").arg(pppdVer).arg(pppdMod).arg(pppdPatch);
340} 340}
341 341
342bool PPPData::pppdVersionMin(int ver, int mod, int patch) { 342bool PPPData::pppdVersionMin(int ver, int mod, int patch) {
343 // check if pppd version fulfills minimum requirement 343 // check if pppd version fulfills minimum requirement
344 return (pppdVer > ver 344 return (pppdVer > ver
345 || (pppdVer == ver && pppdMod > mod) 345 || (pppdVer == ver && pppdMod > mod)
346 || (pppdVer == ver && pppdMod == mod && pppdPatch >= patch)); 346 || (pppdVer == ver && pppdMod == mod && pppdPatch >= patch));
347} 347}
348 348
349int PPPData::pppdTimeout() { 349int PPPData::pppdTimeout() {
350 return readNumConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, PPPD_TIMEOUT); 350 return readNumConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, PPPD_TIMEOUT);
351} 351}
352 352
353 353
354void PPPData::setpppdTimeout(int n) { 354void PPPData::setpppdTimeout(int n) {
355 writeConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, n); 355 writeConfig(GENERAL_GRP, PPPDTIMEOUT_KEY, n);
356} 356}
357 357
358 358
359const QString PPPData::modemDevice() { 359const QString PPPData::modemDevice() {
360 return readConfig (modemGroup(), MODEMDEV_KEY, "/dev/modem" ); 360 return readConfig (modemGroup(), MODEMDEV_KEY, "/dev/modem" );
361} 361}
362 362
363 363
364// const QString PPPData::modemName() 364// const QString PPPData::modemName()
365// { 365// {
366// return readConfig(modemGroup(), MODEMNAME_KEY); 366// return readConfig(modemGroup(), MODEMNAME_KEY);
367// } 367// }
368 368
369// bool PPPData::setModemName(const QString &n) { 369// bool PPPData::setModemName(const QString &n) {
370// odebug << "Setting modem name to >" << n.latin1() << "<" << oendl; 370// odebug << "Setting modem name to >" << n.latin1() << "<" << oendl;
371// _modemName = n; 371// _modemName = n;
372// writeConfig(cgroup, MODEMNAME_KEY, n); 372// writeConfig(cgroup, MODEMNAME_KEY, n);
373// return true; //FIXME 373// return true; //FIXME
374// } 374// }
375 375
376// bool PPPData::changeModemName(const QString &n) { 376// bool PPPData::changeModemName(const QString &n) {
377// odebug << "Setting modem name to >" << n.latin1() << "<" << oendl; 377// odebug << "Setting modem name to >" << n.latin1() << "<" << oendl;
378// _modemName = n; 378// _modemName = n;
379// writeConfig(modemGroup(), MODEMNAME_KEY, n); 379// writeConfig(modemGroup(), MODEMNAME_KEY, n);
380// return true; //FIXME 380// return true; //FIXME
381// } 381// }
382 382
383bool PPPData::setModemDevice(const QString &n) { 383bool PPPData::setModemDevice(const QString &n) {
384 odebug << "Setting modem dev to >" << n.latin1() << "<" << oendl; 384 odebug << "Setting modem dev to >" << n.latin1() << "<" << oendl;
385 writeConfig(modemGroup(), MODEMDEV_KEY, n); 385 writeConfig(modemGroup(), MODEMDEV_KEY, n);
386 return true; //FIXME 386 return true; //FIXME
387} 387}
388 388
389 389
390const QString PPPData::flowcontrol() { 390enum PPPData::FlowControl PPPData::flowcontrol() {
391 return readConfig(modemGroup(), FLOWCONTROL_KEY, "CRTSCTS"); 391 return static_cast<FlowControl>(readNumConfig(modemGroup(), FLOWCONTROL_KEY, FlowHardware));
392} 392}
393 393
394 394
395void PPPData::setFlowcontrol(const QString &n) { 395void PPPData::setFlowcontrol(enum FlowControl n) {
396 writeConfig(modemGroup(), FLOWCONTROL_KEY, n); 396 writeConfig(modemGroup(), FLOWCONTROL_KEY, n);
397} 397}
398 398
399 399
400const QString PPPData::speed() { 400const QString PPPData::speed() {
401 QString s = readConfig(modemGroup(), SPEED_KEY, "57600"); 401 QString s = readConfig(modemGroup(), SPEED_KEY, "57600");
402 // undo the damage of a bug in former versions. It left an empty Speed= 402 // undo the damage of a bug in former versions. It left an empty Speed=
403 // entry in kppprc. kppp did set the serial port to 57600 as default but 403 // entry in kppprc. kppp did set the serial port to 57600 as default but
404 // pppd wouldn't receive the speed via the command line. 404 // pppd wouldn't receive the speed via the command line.
405 if(s.toUInt() == 0) 405 if(s.toUInt() == 0)
406 s = "57600"; 406 s = "57600";
407 return s; 407 return s;
408} 408}
409 409
410 410
411void PPPData::setSpeed(const QString &n) { 411void PPPData::setSpeed(const QString &n) {
412 writeConfig(modemGroup(), SPEED_KEY, n); 412 writeConfig(modemGroup(), SPEED_KEY, n);
413} 413}
414 414
415 415
416#if 0 416#if 0
417void PPPData::setUseCDLine(const int n) { 417void PPPData::setUseCDLine(const int n) {
418 writeConfig(modemGroup(),USECDLINE_KEY,n); 418 writeConfig(modemGroup(),USECDLINE_KEY,n);
419} 419}
420 420
421 421
422int PPPData::UseCDLine() { 422int PPPData::UseCDLine() {
423 return readNumConfig(modemGroup(),USECDLINE_KEY,0); 423 return readNumConfig(modemGroup(),USECDLINE_KEY,0);
424} 424}
425#endif 425#endif
426 426
427const QString PPPData::modemEscapeStr() { 427const QString PPPData::modemEscapeStr() {
428 return readConfig(modemGroup(),ESCAPESTR_KEY,"+++"); 428 return readConfig(modemGroup(),ESCAPESTR_KEY,"+++");
429} 429}
430 430
431 431
432void PPPData::setModemEscapeStr(const QString &n) { 432void PPPData::setModemEscapeStr(const QString &n) {
433 writeConfig(modemGroup(),ESCAPESTR_KEY,n); 433 writeConfig(modemGroup(),ESCAPESTR_KEY,n);
434} 434}
435 435
436 436
437const QString PPPData::modemEscapeResp() { 437const QString PPPData::modemEscapeResp() {
438 return readConfig(modemGroup(),ESCAPERESP_KEY,"OK"); 438 return readConfig(modemGroup(),ESCAPERESP_KEY,"OK");
439} 439}
440 440
441 441
442void PPPData::setModemEscapeResp(const QString &n) { 442void PPPData::setModemEscapeResp(const QString &n) {
443 writeConfig(modemGroup(),ESCAPERESP_KEY,n); 443 writeConfig(modemGroup(),ESCAPERESP_KEY,n);
444} 444}
445 445
446 446
447int PPPData::modemEscapeGuardTime() { 447int PPPData::modemEscapeGuardTime() {
448 return readNumConfig(modemGroup(),ESCAPEGUARDTIME_KEY,50); 448 return readNumConfig(modemGroup(),ESCAPEGUARDTIME_KEY,50);
449} 449}
450 450
451 451
452void PPPData::setModemEscapeGuardTime(int n) { 452void PPPData::setModemEscapeGuardTime(int n) {
453 writeConfig(modemGroup(),ESCAPEGUARDTIME_KEY,n); 453 writeConfig(modemGroup(),ESCAPEGUARDTIME_KEY,n);
454} 454}
455 455
456 456
457bool PPPData::modemLockFile() { 457bool PPPData::modemLockFile() {
458 return readNumConfig(modemGroup(), LOCKFILE_KEY, 1); 458 return readNumConfig(modemGroup(), LOCKFILE_KEY, 1);
459} 459}
460 460
461 461
462void PPPData::setModemLockFile(bool set) { 462void PPPData::setModemLockFile(bool set) {
463 writeConfig(modemGroup(), LOCKFILE_KEY, set); 463 writeConfig(modemGroup(), LOCKFILE_KEY, set);
464} 464}
465 465
466 466
467int PPPData::modemTimeout() { 467int PPPData::modemTimeout() {
468 return readNumConfig(modemGroup(), TIMEOUT_KEY, MODEM_TIMEOUT); 468 return readNumConfig(modemGroup(), TIMEOUT_KEY, MODEM_TIMEOUT);
469} 469}
470 470
471 471
472void PPPData::setModemTimeout(int n) { 472void PPPData::setModemTimeout(int n) {
473 writeConfig(modemGroup(), TIMEOUT_KEY, n); 473 writeConfig(modemGroup(), TIMEOUT_KEY, n);
474} 474}
475 475
476 476
477int PPPData::modemToneDuration() { 477int PPPData::modemToneDuration() {
478 return readNumConfig(modemGroup(), TONEDURATION_KEY,MODEM_TONEDURATION); 478 return readNumConfig(modemGroup(), TONEDURATION_KEY,MODEM_TONEDURATION);
479} 479}
480 480
481 481
482void PPPData::setModemToneDuration(int n) { 482void PPPData::setModemToneDuration(int n) {
483 writeConfig(modemGroup(), TONEDURATION_KEY, n); 483 writeConfig(modemGroup(), TONEDURATION_KEY, n);
484} 484}
485 485
486 486
487int PPPData::busyWait() { 487int PPPData::busyWait() {
488 return readNumConfig(modemGroup(), BUSYWAIT_KEY, BUSY_WAIT); 488 return readNumConfig(modemGroup(), BUSYWAIT_KEY, BUSY_WAIT);
489} 489}
490 490
491 491
492void PPPData::setbusyWait(int n) { 492void PPPData::setbusyWait(int n) {
493 writeConfig(modemGroup(), BUSYWAIT_KEY, n); 493 writeConfig(modemGroup(), BUSYWAIT_KEY, n);
494} 494}
495 495
496 496
497// 497//
498//Advanced "Modem" dialog 498//Advanced "Modem" dialog
499// 499//
500// defaults: InitString=ATZ, InitString1="" etc. 500// defaults: InitString=ATZ, InitString1="" etc.
501const QString PPPData::modemInitStr(int i) { 501const QString PPPData::modemInitStr(int i) {
502 assert(i >= 0 && i < NumInitStrings); 502 assert(i >= 0 && i < NumInitStrings);
503 if(i == 0) 503 if(i == 0)
504 return readConfig(modemGroup(), INITSTR_KEY, "ATZ"); 504 return readConfig(modemGroup(), INITSTR_KEY, "ATZ");
505 else 505 else
506 return readConfig(modemGroup(), INITSTR_KEY + QString::number(i), ""); 506 return readConfig(modemGroup(), INITSTR_KEY + QString::number(i), "");
507} 507}
508 508
509 509
510void PPPData::setModemInitStr(int i, const QString &n) { 510void PPPData::setModemInitStr(int i, const QString &n) {
511 assert(i >= 0 && i < NumInitStrings); 511 assert(i >= 0 && i < NumInitStrings);
512 QString k = INITSTR_KEY + (i > 0 ? QString::number(i) : QString("")); 512 QString k = INITSTR_KEY + (i > 0 ? QString::number(i) : QString(""));
513 writeConfig(modemGroup(), k, n); 513 writeConfig(modemGroup(), k, n);
514} 514}
515 515
516 516
517const QString PPPData::modemInitResp() { 517const QString PPPData::modemInitResp() {
518 return readConfig(modemGroup(), INITRESP_KEY, "OK"); 518 return readConfig(modemGroup(), INITRESP_KEY, "OK");
519} 519}
520 520
521 521
522void PPPData::setModemInitResp(const QString &n) { 522void PPPData::setModemInitResp(const QString &n) {
523 writeConfig(modemGroup(), INITRESP_KEY, n); 523 writeConfig(modemGroup(), INITRESP_KEY, n);
524} 524}
525 525
526 526
527int PPPData::modemPreInitDelay() { 527int PPPData::modemPreInitDelay() {
528 return readNumConfig(modemGroup(), PREINITDELAY_KEY, 50); 528 return readNumConfig(modemGroup(), PREINITDELAY_KEY, 50);
529} 529}
530 530
531 531
532void PPPData::setModemPreInitDelay(int n) { 532void PPPData::setModemPreInitDelay(int n) {
533 writeConfig(modemGroup(), PREINITDELAY_KEY, n); 533 writeConfig(modemGroup(), PREINITDELAY_KEY, n);
534} 534}
535 535
536 536
537int PPPData::modemInitDelay() { 537int PPPData::modemInitDelay() {
538 return readNumConfig(modemGroup(), INITDELAY_KEY, 50); 538 return readNumConfig(modemGroup(), INITDELAY_KEY, 50);
539} 539}
540 540
541 541
542void PPPData::setModemInitDelay(int n) { 542void PPPData::setModemInitDelay(int n) {
543 writeConfig(modemGroup(), INITDELAY_KEY, n); 543 writeConfig(modemGroup(), INITDELAY_KEY, n);
544} 544}
545 545
546QString PPPData::modemNoDialToneDetectionStr() { 546QString PPPData::modemNoDialToneDetectionStr() {
547 return readConfig(modemGroup(), NODTDETECT_KEY, "ATX3"); 547 return readConfig(modemGroup(), NODTDETECT_KEY, "ATX3");
548} 548}
549 549
550void PPPData::setModemNoDialToneDetectionStr(const QString &n) { 550void PPPData::setModemNoDialToneDetectionStr(const QString &n) {
551 writeConfig(modemGroup(), NODTDETECT_KEY, n); 551 writeConfig(modemGroup(), NODTDETECT_KEY, n);
552} 552}
553 553
554const QString PPPData::modemDialStr() { 554const QString PPPData::modemDialStr() {
555 return readConfig(modemGroup(), DIALSTR_KEY, "ATDT"); 555 return readConfig(modemGroup(), DIALSTR_KEY, "ATDT");
556} 556}
557 557
558 558
559void PPPData::setModemDialStr(const QString &n) { 559void PPPData::setModemDialStr(const QString &n) {
560 writeConfig(modemGroup(), DIALSTR_KEY, n); 560 writeConfig(modemGroup(), DIALSTR_KEY, n);
561} 561}
562 562
563 563
564const QString PPPData::modemConnectResp() { 564const QString PPPData::modemConnectResp() {
565 return readConfig(modemGroup(), CONNECTRESP_KEY, "CONNECT"); 565 return readConfig(modemGroup(), CONNECTRESP_KEY, "CONNECT");
566} 566}
567 567
568 568
569void PPPData::setModemConnectResp(const QString &n) { 569void PPPData::setModemConnectResp(const QString &n) {
570 writeConfig(modemGroup(), CONNECTRESP_KEY, n); 570 writeConfig(modemGroup(), CONNECTRESP_KEY, n);
571} 571}
572 572
573 573
574const QString PPPData::modemBusyResp() { 574const QString PPPData::modemBusyResp() {
575 return readConfig(modemGroup(), BUSYRESP_KEY, "BUSY"); 575 return readConfig(modemGroup(), BUSYRESP_KEY, "BUSY");
576} 576}
577 577
578 578
579void PPPData::setModemBusyResp(const QString &n) { 579void PPPData::setModemBusyResp(const QString &n) {
580 writeConfig(modemGroup(), BUSYRESP_KEY, n); 580 writeConfig(modemGroup(), BUSYRESP_KEY, n);
581} 581}
582 582
583 583
584const QString PPPData::modemNoCarrierResp() { 584const QString PPPData::modemNoCarrierResp() {
585 return readConfig(modemGroup(), NOCARRIERRESP_KEY, "NO CARRIER"); 585 return readConfig(modemGroup(), NOCARRIERRESP_KEY, "NO CARRIER");
586} 586}
587 587
588 588
589void PPPData::setModemNoCarrierResp(const QString &n) { 589void PPPData::setModemNoCarrierResp(const QString &n) {
590 writeConfig(modemGroup(), NOCARRIERRESP_KEY, n); 590 writeConfig(modemGroup(), NOCARRIERRESP_KEY, n);
591} 591}
592 592
593 593
594const QString PPPData::modemNoDialtoneResp() { 594const QString PPPData::modemNoDialtoneResp() {
595 return readConfig(modemGroup(), NODIALTONERESP_KEY, "NO DIALTONE"); 595 return readConfig(modemGroup(), NODIALTONERESP_KEY, "NO DIALTONE");
596} 596}
597 597
598 598
599void PPPData::setModemNoDialtoneResp(const QString &n) { 599void PPPData::setModemNoDialtoneResp(const QString &n) {
600 writeConfig(modemGroup(), NODIALTONERESP_KEY, n); 600 writeConfig(modemGroup(), NODIALTONERESP_KEY, n);
601} 601}
602 602
603 603
604const QString PPPData::modemHangupStr() { 604const QString PPPData::modemHangupStr() {
605 return readConfig(modemGroup(), HANGUPSTR_KEY, "+++ATH"); 605 return readConfig(modemGroup(), HANGUPSTR_KEY, "+++ATH");
606} 606}
607 607
608void PPPData::setModemHangupStr(const QString &n) { 608void PPPData::setModemHangupStr(const QString &n) {
609 writeConfig(modemGroup(), HANGUPSTR_KEY, n); 609 writeConfig(modemGroup(), HANGUPSTR_KEY, n);
610} 610}
611 611
612 612
613const QString PPPData::modemHangupResp() { 613const QString PPPData::modemHangupResp() {
614 return readConfig(modemGroup(), HANGUPRESP_KEY, "OK"); 614 return readConfig(modemGroup(), HANGUPRESP_KEY, "OK");
615} 615}
616 616
617void PPPData::setModemHangupResp(const QString &n) { 617void PPPData::setModemHangupResp(const QString &n) {
618 writeConfig(modemGroup(), HANGUPRESP_KEY, n); 618 writeConfig(modemGroup(), HANGUPRESP_KEY, n);
619} 619}
620 620
621 621
622const QString PPPData::modemAnswerStr() { 622const QString PPPData::modemAnswerStr() {
623 return readConfig(modemGroup(), ANSWERSTR_KEY, "ATA"); 623 return readConfig(modemGroup(), ANSWERSTR_KEY, "ATA");
624} 624}
625 625
626 626
627QString PPPData::volumeOff() { 627QString PPPData::volumeOff() {
628 return readConfig(modemGroup(), VOLUME_OFF, "M0L0"); 628 return readConfig(modemGroup(), VOLUME_OFF, "M0L0");
629} 629}
630 630
631 631
632void PPPData::setVolumeOff(const QString &s) { 632void PPPData::setVolumeOff(const QString &s) {
633 writeConfig(modemGroup(), VOLUME_OFF, s); 633 writeConfig(modemGroup(), VOLUME_OFF, s);
634} 634}
635 635
636 636
637QString PPPData::volumeMedium() { 637QString PPPData::volumeMedium() {
638 return readConfig(modemGroup(), VOLUME_MEDIUM, "M1L1"); 638 return readConfig(modemGroup(), VOLUME_MEDIUM, "M1L1");
639} 639}
640 640
641 641
642void PPPData::setVolumeMedium(const QString &s) { 642void PPPData::setVolumeMedium(const QString &s) {
643 writeConfig(modemGroup(), VOLUME_MEDIUM, s); 643 writeConfig(modemGroup(), VOLUME_MEDIUM, s);
644} 644}
645 645
646 646
647QString PPPData::volumeHigh() { 647QString PPPData::volumeHigh() {
648 QString tmp = readConfig(modemGroup(), VOLUME_HIGH, "M1L3"); 648 QString tmp = readConfig(modemGroup(), VOLUME_HIGH, "M1L3");
649 if(tmp == "M1L4") 649 if(tmp == "M1L4")
650 tmp = "M1L3"; 650 tmp = "M1L3";
651 return tmp; 651 return tmp;
652} 652}
653 653
654 654
655void PPPData::setVolumeHigh(const QString &s) { 655void PPPData::setVolumeHigh(const QString &s) {
656 writeConfig(modemGroup(), VOLUME_HIGH, s); 656 writeConfig(modemGroup(), VOLUME_HIGH, s);
657} 657}
658 658
659 659
660QString PPPData::volumeInitString() { 660QString PPPData::volumeInitString() {
661 QString s; 661 QString s;
662 662
663 switch(volume()) { 663 switch(volume()) {
664 case 0: 664 case 0:
665 s = volumeOff(); 665 s = volumeOff();
666 break; 666 break;
667 case 1: 667 case 1:
668 s = volumeMedium(); 668 s = volumeMedium();
669 break; 669 break;
670 case 2: 670 case 2:
671 s = volumeHigh(); 671 s = volumeHigh();
672 break; 672 break;
673 default: 673 default:
674 s = volumeMedium(); 674 s = volumeMedium();
675 } 675 }
676 676
677 return s; 677 return s;
678} 678}
679 679
680 680
681int PPPData::volume() { 681int PPPData::volume() {
682 return readNumConfig(modemGroup(), VOLUME_KEY, 1); 682 return readNumConfig(modemGroup(), VOLUME_KEY, 1);
683} 683}
684 684
685 685
686void PPPData::setVolume(int i) { 686void PPPData::setVolume(int i) {
687 writeConfig(modemGroup(), VOLUME_KEY, i); 687 writeConfig(modemGroup(), VOLUME_KEY, i);
688} 688}
689 689
690int PPPData::waitForDialTone() { 690int PPPData::waitForDialTone() {
691 return readNumConfig(modemGroup(), DIALTONEWAIT_KEY, 1); 691 return readNumConfig(modemGroup(), DIALTONEWAIT_KEY, 1);
692} 692}
693 693
694void PPPData::setWaitForDialTone(int i) { 694void PPPData::setWaitForDialTone(int i) {
695 writeConfig(modemGroup(), DIALTONEWAIT_KEY, i); 695 writeConfig(modemGroup(), DIALTONEWAIT_KEY, i);
696} 696}
697 697
698void PPPData::setModemAnswerStr(const QString &n) { 698void PPPData::setModemAnswerStr(const QString &n) {
699 writeConfig(modemGroup(), ANSWERSTR_KEY, n); 699 writeConfig(modemGroup(), ANSWERSTR_KEY, n);
700} 700}
701 701
702 702
703const QString PPPData::modemRingResp() { 703const QString PPPData::modemRingResp() {
704 return readConfig(modemGroup(), RINGRESP_KEY, "RING"); 704 return readConfig(modemGroup(), RINGRESP_KEY, "RING");
705} 705}
706 706
707 707
708void PPPData::setModemRingResp(const QString &n) { 708void PPPData::setModemRingResp(const QString &n) {
709 writeConfig(modemGroup(), RINGRESP_KEY, n); 709 writeConfig(modemGroup(), RINGRESP_KEY, n);
710} 710}
711 711
712 712
713const QString PPPData::modemAnswerResp() { 713const QString PPPData::modemAnswerResp() {
714 return readConfig(modemGroup(), ANSWERRESP_KEY, "CONNECT"); 714 return readConfig(modemGroup(), ANSWERRESP_KEY, "CONNECT");
715} 715}
716 716
717 717
718void PPPData::setModemAnswerResp(const QString &n) { 718void PPPData::setModemAnswerResp(const QString &n) {
719 writeConfig(modemGroup(), ANSWERRESP_KEY, n); 719 writeConfig(modemGroup(), ANSWERRESP_KEY, n);
720} 720}
721 721
722 722
723const QString PPPData::enter() { 723enum PPPData::LineTermination PPPData::enter(){
724 return readConfig(modemGroup(), ENTER_KEY, "CR"); 724 return static_cast<PPPData::LineTermination>(readNumConfig(modemGroup(), ENTER_KEY, EndCR));
725} 725}
726 726
727 727
728void PPPData::setEnter(const QString &n) { 728void PPPData::setEnter(enum PPPData::LineTermination n) {
729 writeConfig(modemGroup(), ENTER_KEY, n); 729 writeConfig(modemGroup(), ENTER_KEY, n);
730} 730}
731 731
732 732
733// 733//
734// functions to set/return account information 734// functions to set/return account information
735// 735//
736 736
737//returns number of accounts 737//returns number of accounts
738int PPPData::count() const { 738int PPPData::count() const {
739 return highcount + 1; 739 return highcount + 1;
740} 740}
741 741
742 742
743bool PPPData::setAccount(const QString &aname) { 743bool PPPData::setAccount(const QString &aname) {
744 odebug << "setting account to >" << aname.latin1() << "<" << oendl; 744 odebug << "setting account to >" << aname.latin1() << "<" << oendl;
745 for ( QStringList::Iterator it = accountList.begin(); it != accountList.end(); ++it ) { 745 for ( QStringList::Iterator it = accountList.begin(); it != accountList.end(); ++it ) {
746 cgroup = *it; 746 cgroup = *it;
747 odebug << "PPPData::setAccount " << cgroup.latin1() << "" << oendl; 747 odebug << "PPPData::setAccount " << cgroup.latin1() << "" << oendl;
748 odebug << "iterator " << (*it).latin1() << "" << oendl; 748 odebug << "iterator " << (*it).latin1() << "" << oendl;
749 if(accname() == aname) { 749 if(accname() == aname) {
750 odebug << "SUCCESS" << oendl; 750 odebug << "SUCCESS" << oendl;
751 return true; 751 return true;
752 } 752 }
753 753
754 } 754 }
755 odebug << "FAILURE" << oendl; 755 odebug << "FAILURE" << oendl;
756 return false; 756 return false;
757} 757}
758 758
759/* 759/*
760bool PPPData::setAccountbyIndex(int i) { 760bool PPPData::setAccountbyIndex(int i) {
761 if(i >= 0 && i <= highcount) { 761 if(i >= 0 && i <= highcount) {
762 QString tmp; 762 QString tmp;
763 tmp.sprintf("%s%i", ACCOUNT_GRP, i); 763 tmp.sprintf("%s%i", ACCOUNT_GRP, i);
764 if (_deleted.find(tmp)!=_deleted.end()) return false; 764 if (_deleted.find(tmp)!=_deleted.end()) return false;
765 caccount = i; 765 caccount = i;
766 cgroup = tmp; 766 cgroup = tmp;
767 return true; 767 return true;
768 } 768 }
769 return false; 769 return false;
770} 770}
771*/ 771*/
772 772
773bool PPPData::isUniqueAccname(const QString &n) { 773bool PPPData::isUniqueAccname(const QString &n) {
774 QString save_cgroup = cgroup; 774 QString save_cgroup = cgroup;
775 for ( QStringList::Iterator it = accountList.begin(); it != accountList.end(); ++it ) { 775 for ( QStringList::Iterator it = accountList.begin(); it != accountList.end(); ++it ) {
776 cgroup = *it; 776 cgroup = *it;
777 odebug << "PPPData::setAccount " << cgroup.latin1() << "" << oendl; 777 odebug << "PPPData::setAccount " << cgroup.latin1() << "" << oendl;
778 odebug << "" << (*it).latin1() << " \n" << oendl; 778 odebug << "" << (*it).latin1() << " \n" << oendl;
779 if(accname() == n && cgroup != save_cgroup) { 779 if(accname() == n && cgroup != save_cgroup) {
780 cgroup = save_cgroup; 780 cgroup = save_cgroup;
781 odebug << "SUCCESS" << oendl; 781 odebug << "SUCCESS" << oendl;
782 return false; 782 return false;
783 } 783 }
784 784
785 } 785 }
786 cgroup = save_cgroup; 786 cgroup = save_cgroup;
787 return true; 787 return true;
788} 788}
789 789
790 790
791bool PPPData::isUniqueDevname(const QString &n) { 791bool PPPData::isUniqueDevname(const QString &n) {
792 QString save_mName = _modemName; 792 QString save_mName = _modemName;
793 odebug << "PPPData::isUniqueDevname checking if " << n.latin1() << " is unique" << oendl; 793 odebug << "PPPData::isUniqueDevname checking if " << n.latin1() << " is unique" << oendl;
794 for ( QStringList::Iterator it = deviceList.begin(); it != deviceList.end(); ++it ) { 794 for ( QStringList::Iterator it = deviceList.begin(); it != deviceList.end(); ++it ) {
795 _modemName = *it; 795 _modemName = *it;
796 odebug << "PPPData::isUniqueDevname " << n.latin1() << " == " << devname().latin1() << "" << oendl; 796 odebug << "PPPData::isUniqueDevname " << n.latin1() << " == " << devname().latin1() << "" << oendl;
797 if(devname() == n && _modemName != save_mName) { 797 if(devname() == n && _modemName != save_mName) {
798 _modemName = save_mName; 798 _modemName = save_mName;
799 odebug << "NOT UNIQUE" << oendl; 799 odebug << "NOT UNIQUE" << oendl;
800 return false; 800 return false;
801 } 801 }
802 802
803 } 803 }
804 _modemName = save_mName; 804 _modemName = save_mName;
805 return true; 805 return true;
806} 806}
807 807
808 808
809bool PPPData::deleteAccount() { 809bool PPPData::deleteAccount() {
810 // FIXME: check if this account exists in a config... 810 // FIXME: check if this account exists in a config...
811 Config cfg = PPPData::config(); 811 Config cfg = PPPData::config();
812 cfg.setGroup(cgroup); 812 cfg.setGroup(cgroup);
813 cfg.clearGroup(); 813 cfg.clearGroup();
814 accountList.remove(cgroup); 814 accountList.remove(cgroup);
815 815
816 QString key; 816 QString key;
817 QStringList keys; 817 QStringList keys;
818 for( QMap<QString,QString>::Iterator it = stringEntries.begin(); 818 for( QMap<QString,QString>::Iterator it = stringEntries.begin();
819 it != stringEntries.end(); ++it ){ 819 it != stringEntries.end(); ++it ){
820 QString val = it.data(); 820 QString val = it.data();
821 key = it.key(); 821 key = it.key();
822 keys = QStringList::split( "SEPARATOR", key ); 822 keys = QStringList::split( "SEPARATOR", key );
823 if(keys[0]==cgroup){ 823 if(keys[0]==cgroup){
824 stringEntries.remove( it ); 824 stringEntries.remove( it );
825 odebug << "deleting >" << keys[0].latin1() << "< key >" << keys[1].latin1() << "< value >" << val.latin1() << "<" << oendl; 825 odebug << "deleting >" << keys[0].latin1() << "< key >" << keys[1].latin1() << "< value >" << val.latin1() << "<" << oendl;
826 } 826 }
827 } 827 }
828 for( QMap<QString,int>::Iterator it = intEntries.begin(); 828 for( QMap<QString,int>::Iterator it = intEntries.begin();
829 it != intEntries.end(); ++it ){ 829 it != intEntries.end(); ++it ){
830 int val = it.data(); 830 int val = it.data();
831 key = it.key(); 831 key = it.key();
832 keys = QStringList::split( "SEPARATOR", key ); 832 keys = QStringList::split( "SEPARATOR", key );
833 if(keys[0]==cgroup){ 833 if(keys[0]==cgroup){
834 intEntries.remove( it ); 834 intEntries.remove( it );
835 odebug << "deleting >" << keys[0].latin1() << "< key >" << keys[1].latin1() << "< value >" << val << "<" << oendl; 835 odebug << "deleting >" << keys[0].latin1() << "< key >" << keys[1].latin1() << "< value >" << val << "<" << oendl;
836 } 836 }
837 } 837 }
838 for( QMap<QString,QStringList>::Iterator it = listEntries.begin(); 838 for( QMap<QString,QStringList>::Iterator it = listEntries.begin();
839 it != listEntries.end(); ++it ){ 839 it != listEntries.end(); ++it ){
840 QStringList val = it.data(); 840 QStringList val = it.data();
841 key = it.key(); 841 key = it.key();
842 if(keys[0]==cgroup){ 842 if(keys[0]==cgroup){
843 listEntries.remove( it ); 843 listEntries.remove( it );
844 sepEntries.remove( key ); 844 sepEntries.remove( key );
845 odebug << "deleting >" << keys[0].latin1() << "< key >" << keys[1].latin1() << "< value >" << val.join("").latin1() << "<" << oendl; 845 odebug << "deleting >" << keys[0].latin1() << "< key >" << keys[1].latin1() << "< value >" << val.join("").latin1() << "<" << oendl;
846 } 846 }
847 } 847 }
848 848
849 return true; 849 return true;
850} 850}
851 851
852 852
853bool PPPData::deleteAccount(const QString &aname) { 853bool PPPData::deleteAccount(const QString &aname) {
854 if(!setAccount(aname)) 854 if(!setAccount(aname))
855 return false; 855 return false;
856 856
857 deleteAccount(); 857 deleteAccount();
858 858
859 return true; 859 return true;
860} 860}
861 861
862 862
863int PPPData::newaccount() { 863int PPPData::newaccount() {
864 864
865 odebug << "PPPData::newaccount highcount " << highcount << "/" << MAX_ACCOUNTS << "" << oendl; 865 odebug << "PPPData::newaccount highcount " << highcount << "/" << MAX_ACCOUNTS << "" << oendl;
866// if(!config) open(); 866// if(!config) open();
867// if (highcount >= MAX_ACCOUNTS) return -1; 867// if (highcount >= MAX_ACCOUNTS) return -1;
868 868
869 869
870 QString tmp; 870 QString tmp;
871 tmp.sprintf("%s%i", ACCOUNT_GRP, ++highcount); 871 tmp.sprintf("%s%i", ACCOUNT_GRP, ++highcount);
872 cgroup = QString(tmp); 872 cgroup = QString(tmp);
873 accountList << tmp; 873 accountList << tmp;
874 odebug << "PPPData::newaccount() Group: >" << cgroup.latin1() << "<" << oendl; 874 odebug << "PPPData::newaccount() Group: >" << cgroup.latin1() << "<" << oendl;
875 setpppdArgumentDefaults(); 875 setpppdArgumentDefaults();
876 return highcount; 876 return highcount;
877} 877}
878 878
879int PPPData::copyaccount(const QString&) { 879int PPPData::copyaccount(const QString&) {
880// FIXME: PPPData::copyaccount 880// FIXME: PPPData::copyaccount
881// if(highcount >= MAX_ACCOUNTS) 881// if(highcount >= MAX_ACCOUNTS)
882 return -1; 882 return -1;
883 883
884// setAccountbyIndex(i); 884// setAccountbyIndex(i);
885 885
886// QMap <QString, QString> map = config->entryMap(cgroup); 886// QMap <QString, QString> map = config->entryMap(cgroup);
887// QMap <QString, QString>::ConstIterator it = map.begin(); 887// QMap <QString, QString>::ConstIterator it = map.begin();
888 888
889// QString newname = QObject::tr("%1_copy").arg(accname()); 889// QString newname = QObject::tr("%1_copy").arg(accname());
890 890
891// newaccount(); 891// newaccount();
892 892
893// while (it != map.end()) { 893// while (it != map.end()) {
894// config->writeEntry(it.key(), *it); 894// config->writeEntry(it.key(), *it);
895// it++; 895// it++;
896// } 896// }
897 897
898// setAccname(newname); 898// setAccname(newname);
899 899
900// return caccount; 900// return caccount;
901} 901}
902 902
903 903
904const QString PPPData::accname() { 904const QString PPPData::accname() {
905 return readConfig(cgroup, NAME_KEY); 905 return readConfig(cgroup, NAME_KEY);
906} 906}
907 907
908void PPPData::setAccname(const QString &n) { 908void PPPData::setAccname(const QString &n) {
909 if(!cgroup.isNull()) { 909 if(!cgroup.isNull()) {
910 // are we manipulating the default account's name ? then change it, too. 910 // are we manipulating the default account's name ? then change it, too.
911 bool def = accname() == defaultAccount(); 911 bool def = accname() == defaultAccount();
912 writeConfig(cgroup, NAME_KEY, n); 912 writeConfig(cgroup, NAME_KEY, n);
913 if (def) 913 if (def)
914 setDefaultAccount(n); 914 setDefaultAccount(n);
915 } 915 }
916 writeConfig(cgroup, NAME_KEY, n); 916 writeConfig(cgroup, NAME_KEY, n);
917} 917}
918 918
919 919
920#define SEPARATOR_CHAR '&' 920#define SEPARATOR_CHAR '&'
921QStringList &PPPData::phonenumbers() { 921QStringList &PPPData::phonenumbers() {
922 922
923 readListConfig(cgroup, PHONENUMBER_KEY, phonelist, SEPARATOR_CHAR); 923 readListConfig(cgroup, PHONENUMBER_KEY, phonelist, SEPARATOR_CHAR);
924 return phonelist; 924 return phonelist;
925 925
926} 926}
927 927
928 928
929const QString PPPData::phonenumber() { 929const QString PPPData::phonenumber() {
930 return readConfig(cgroup, PHONENUMBER_KEY); 930 return readConfig(cgroup, PHONENUMBER_KEY);
931} 931}
932 932
933 933
934void PPPData::setPhonenumber(const QString &n) { 934void PPPData::setPhonenumber(const QString &n) {
935 writeConfig(cgroup, PHONENUMBER_KEY, n); 935 writeConfig(cgroup, PHONENUMBER_KEY, n);
936} 936}
937 937
938 938
939const QString PPPData::dialPrefix() { 939const QString PPPData::dialPrefix() {
940 return readConfig(cgroup, DIAL_PREFIX_KEY, ""); 940 return readConfig(cgroup, DIAL_PREFIX_KEY, "");
941} 941}
942 942
943 943
944void PPPData::setDialPrefix(const QString &s) { 944void PPPData::setDialPrefix(const QString &s) {
945 writeConfig(cgroup, DIAL_PREFIX_KEY, s); 945 writeConfig(cgroup, DIAL_PREFIX_KEY, s);
946} 946}
947 947
948 948
949int PPPData::authMethod() { 949int PPPData::authMethod() {
950 return readNumConfig(cgroup, AUTH_KEY, 0); 950 return readNumConfig(cgroup, AUTH_KEY, 0);
951} 951}
952 952
953 953
954void PPPData::setAuthMethod(int value) { 954void PPPData::setAuthMethod(int value) {
955 writeConfig(cgroup, AUTH_KEY, value); 955 writeConfig(cgroup, AUTH_KEY, value);
956} 956}
957 957
958 958
959const QString PPPData::storedUsername() { 959const QString PPPData::storedUsername() {
960 return readConfig(cgroup, STORED_USERNAME_KEY, ""); 960 return readConfig(cgroup, STORED_USERNAME_KEY, "");
961} 961}
962 962
963 963
964void PPPData::setStoredUsername(const QString &b) { 964void PPPData::setStoredUsername(const QString &b) {
965 writeConfig(cgroup, STORED_USERNAME_KEY, b); 965 writeConfig(cgroup, STORED_USERNAME_KEY, b);
966} 966}
967 967
968 968
969const QString PPPData::storedPassword() { 969const QString PPPData::storedPassword() {
970 odebug << "getting stored pw" << oendl; 970 odebug << "getting stored pw" << oendl;
971 odebug << "g " << cgroup.latin1() << "" << oendl; 971 odebug << "g " << cgroup.latin1() << "" << oendl;
972 odebug << "k " << STORED_PASSWORD_KEY << "" << oendl; 972 odebug << "k " << STORED_PASSWORD_KEY << "" << oendl;
973 return readConfig(cgroup, STORED_PASSWORD_KEY, ""); 973 return readConfig(cgroup, STORED_PASSWORD_KEY, "");
974} 974}
975 975
976 976
977void PPPData::setStoredPassword(const QString &b) { 977void PPPData::setStoredPassword(const QString &b) {
978 writeConfig(cgroup, STORED_PASSWORD_KEY, b); 978 writeConfig(cgroup, STORED_PASSWORD_KEY, b);
979} 979}
980 980
981 981
982bool PPPData::storePassword() { 982bool PPPData::storePassword() {
983 return (bool)readNumConfig(cgroup, STORE_PASSWORD_KEY, 1); 983 return (bool)readNumConfig(cgroup, STORE_PASSWORD_KEY, 1);
984} 984}
985 985
986 986
987const QString PPPData::command_before_connect() { 987const QString PPPData::command_before_connect() {
988 return readConfig(cgroup, BEFORE_CONNECT_KEY); 988 return readConfig(cgroup, BEFORE_CONNECT_KEY);
989} 989}
990 990
991 991
992void PPPData::setCommand_before_connect(const QString &n) { 992void PPPData::setCommand_before_connect(const QString &n) {
993 writeConfig(cgroup, BEFORE_CONNECT_KEY, n); 993 writeConfig(cgroup, BEFORE_CONNECT_KEY, n);
994} 994}
995 995
996 996
997void PPPData::setStorePassword(bool b) { 997void PPPData::setStorePassword(bool b) {
998 writeConfig(cgroup, STORE_PASSWORD_KEY, (int)b); 998 writeConfig(cgroup, STORE_PASSWORD_KEY, (int)b);
999} 999}
1000 1000
1001 1001
1002const QString PPPData::command_on_connect() { 1002const QString PPPData::command_on_connect() {
1003 return readConfig(cgroup, COMMAND_KEY); 1003 return readConfig(cgroup, COMMAND_KEY);
1004} 1004}
1005 1005
1006 1006
1007void PPPData::setCommand_on_connect(const QString &n) { 1007void PPPData::setCommand_on_connect(const QString &n) {
1008 writeConfig(cgroup, COMMAND_KEY, n); 1008 writeConfig(cgroup, COMMAND_KEY, n);
1009} 1009}
1010 1010
1011 1011
1012const QString PPPData::command_on_disconnect() { 1012const QString PPPData::command_on_disconnect() {
1013 return readConfig(cgroup, DISCONNECT_COMMAND_KEY); 1013 return readConfig(cgroup, DISCONNECT_COMMAND_KEY);
1014} 1014}
1015 1015
1016 1016
1017void PPPData::setCommand_on_disconnect(const QString &n) { 1017void PPPData::setCommand_on_disconnect(const QString &n) {
1018 writeConfig(cgroup, DISCONNECT_COMMAND_KEY, n); 1018 writeConfig(cgroup, DISCONNECT_COMMAND_KEY, n);
1019} 1019}
1020 1020
1021 1021
1022const QString PPPData::command_before_disconnect() { 1022const QString PPPData::command_before_disconnect() {
1023 return readConfig(cgroup, BEFORE_DISCONNECT_KEY); 1023 return readConfig(cgroup, BEFORE_DISCONNECT_KEY);
1024} 1024}
1025 1025
1026 1026
1027void PPPData::setCommand_before_disconnect(const QString &n) { 1027void PPPData::setCommand_before_disconnect(const QString &n) {
1028 writeConfig(cgroup, BEFORE_DISCONNECT_KEY, n); 1028 writeConfig(cgroup, BEFORE_DISCONNECT_KEY, n);
1029} 1029}
1030 1030
1031 1031
1032const QString PPPData::ipaddr() { 1032const QString PPPData::ipaddr() {
1033 return readConfig(cgroup, IPADDR_KEY); 1033 return readConfig(cgroup, IPADDR_KEY);
1034} 1034}
1035 1035
1036 1036
1037void PPPData::setIpaddr(const QString &n) { 1037void PPPData::setIpaddr(const QString &n) {
1038 writeConfig(cgroup, IPADDR_KEY, n); 1038 writeConfig(cgroup, IPADDR_KEY, n);
1039} 1039}
1040 1040
1041 1041
1042const QString PPPData::subnetmask() { 1042const QString PPPData::subnetmask() {
1043 return readConfig(cgroup, SUBNETMASK_KEY); 1043 return readConfig(cgroup, SUBNETMASK_KEY);
1044} 1044}
1045 1045
1046 1046
1047void PPPData::setSubnetmask(const QString &n) { 1047void PPPData::setSubnetmask(const QString &n) {
1048 writeConfig(cgroup, SUBNETMASK_KEY, n); 1048 writeConfig(cgroup, SUBNETMASK_KEY, n);
1049} 1049}
1050 1050
1051 1051
1052bool PPPData::autoname() { 1052bool PPPData::autoname() {
1053 return (bool) readNumConfig(cgroup, AUTONAME_KEY, false); 1053 return (bool) readNumConfig(cgroup, AUTONAME_KEY, false);
1054} 1054}
1055 1055
1056 1056
1057void PPPData::setAutoname(bool set) { 1057void PPPData::setAutoname(bool set) {
1058 writeConfig(cgroup, AUTONAME_KEY, (int) set); 1058 writeConfig(cgroup, AUTONAME_KEY, (int) set);
1059} 1059}
1060 1060
1061 1061
1062bool PPPData::AcctEnabled() { 1062bool PPPData::AcctEnabled() {
1063 return (bool) readNumConfig(cgroup, ACCTENABLED_KEY, false); 1063 return (bool) readNumConfig(cgroup, ACCTENABLED_KEY, false);
1064} 1064}
1065 1065
1066 1066
1067void PPPData::setAcctEnabled(bool set) { 1067void PPPData::setAcctEnabled(bool set) {
1068 writeConfig(cgroup, ACCTENABLED_KEY, (int) set); 1068 writeConfig(cgroup, ACCTENABLED_KEY, (int) set);
1069} 1069}
1070 1070
1071 1071
1072// int PPPData::VolAcctEnabled() { 1072// int PPPData::VolAcctEnabled() {
1073// return readNumConfig(cgroup, VOLACCTENABLED_KEY, 0); 1073// return readNumConfig(cgroup, VOLACCTENABLED_KEY, 0);
1074// } 1074// }
1075 1075
1076 1076
1077// void PPPData::setVolAcctEnabled(int set) { 1077// void PPPData::setVolAcctEnabled(int set) {
1078// writeConfig(cgroup, VOLACCTENABLED_KEY, set); 1078// writeConfig(cgroup, VOLACCTENABLED_KEY, set);
1079// } 1079// }
1080 1080
1081 1081
1082const QString PPPData::gateway() { 1082const QString PPPData::gateway() {
1083 return readConfig(cgroup, GATEWAY_KEY); 1083 return readConfig(cgroup, GATEWAY_KEY);
1084} 1084}
1085 1085
1086 1086
1087void PPPData::setGateway(const QString &n ) { 1087void PPPData::setGateway(const QString &n ) {
1088 writeConfig(cgroup, GATEWAY_KEY, n); 1088 writeConfig(cgroup, GATEWAY_KEY, n);
1089} 1089}
1090 1090
1091 1091
1092bool PPPData::defaultroute() { 1092bool PPPData::defaultroute() {
1093 // default route is by default 'on'. 1093 // default route is by default 'on'.
1094 return (bool) readNumConfig(cgroup, DEFAULTROUTE_KEY, true); 1094 return (bool) readNumConfig(cgroup, DEFAULTROUTE_KEY, true);
1095} 1095}
1096 1096
1097 1097
1098void PPPData::setDefaultroute(bool set) { 1098void PPPData::setDefaultroute(bool set) {
1099 writeConfig(cgroup, DEFAULTROUTE_KEY, (int) set); 1099 writeConfig(cgroup, DEFAULTROUTE_KEY, (int) set);
1100} 1100}
1101 1101
1102 1102
1103bool PPPData::autoDNS() { 1103bool PPPData::autoDNS() {
1104 bool set = (bool) readNumConfig(cgroup, AUTODNS_KEY, true); 1104 bool set = (bool) readNumConfig(cgroup, AUTODNS_KEY, true);
1105 return (set && pppdVersionMin(2, 3, 7)); 1105 return (set && pppdVersionMin(2, 3, 7));
1106} 1106}
1107 1107
1108 1108
1109void PPPData::setAutoDNS(bool set) { 1109void PPPData::setAutoDNS(bool set) {
1110 writeConfig(cgroup, AUTODNS_KEY, (int) set); 1110 writeConfig(cgroup, AUTODNS_KEY, (int) set);
1111} 1111}
1112 1112
diff --git a/noncore/settings/networksettings/ppp/pppdata.h b/noncore/settings/networksettings/ppp/pppdata.h
index d1cbeb5..d731b62 100644
--- a/noncore/settings/networksettings/ppp/pppdata.h
+++ b/noncore/settings/networksettings/ppp/pppdata.h
@@ -1,467 +1,478 @@
1/* -*- C++ -*- 1/* -*- C++ -*-
2 * 2 *
3 * kPPP: A pppd front end for the KDE project 3 * kPPP: A pppd front end for the KDE project
4 * 4 *
5 * $Id$ 5 * $Id$
6 * 6 *
7 * Copyright (C) 1997 Bernd Johannes Wuebben 7 * Copyright (C) 1997 Bernd Johannes Wuebben
8 * wuebben@math.cornell.edu 8 * wuebben@math.cornell.edu
9 * 9 *
10 * based on EzPPP: 10 * based on EzPPP:
11 * Copyright (C) 1997 Jay Painter 11 * Copyright (C) 1997 Jay Painter
12 * 12 *
13 * This program is free software; you can redistribute it and/or 13 * This program is free software; you can redistribute it and/or
14 * modify it under the terms of the GNU Library General Public 14 * modify it under the terms of the GNU Library General Public
15 * License as published by the Free Software Foundation; either 15 * License as published by the Free Software Foundation; either
16 * version 2 of the License, or (at your option) any later version. 16 * version 2 of the License, or (at your option) any later version.
17 * 17 *
18 * This program is distributed in the hope that it will be useful, 18 * This program is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of 19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
21 * Library General Public License for more details. 21 * Library General Public License for more details.
22 * 22 *
23 * You should have received a copy of the GNU Library General Public 23 * You should have received a copy of the GNU Library General Public
24 * License along with this program; if not, write to the Free 24 * License along with this program; if not, write to the Free
25 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 25 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
26 */ 26 */
27 27
28#ifndef _PPPDATA_H_ 28#ifndef _PPPDATA_H_
29#define _PPPDATA_H_ 29#define _PPPDATA_H_
30 30
31#include <unistd.h> 31#include <unistd.h>
32#include <sys/types.h> 32#include <sys/types.h>
33 33
34#include <qcolor.h> 34#include <qcolor.h>
35#include <qmap.h> 35#include <qmap.h>
36#include <qstring.h> 36#include <qstring.h>
37#include <qstringlist.h> 37#include <qstringlist.h>
38 38
39#include "kpppconfig.h" 39#include "kpppconfig.h"
40 40
41class Config; 41class Config;
42 42
43// string lengths 43// string lengths
44 44
45#define PATH_SIZE 120 45#define PATH_SIZE 120
46#define MODEMSTR_SIZE 80 46#define MODEMSTR_SIZE 80
47#define ACCNAME_SIZE 50 47#define ACCNAME_SIZE 50
48#define PHONENUMBER_SIZE 60 48#define PHONENUMBER_SIZE 60
49#define COMMAND_SIZE 255 49#define COMMAND_SIZE 255
50#define IPADDR_SIZE 15 50#define IPADDR_SIZE 15
51#define DOMAIN_SIZE 50 51#define DOMAIN_SIZE 50
52#define TIMEOUT_SIZE 60 52#define TIMEOUT_SIZE 60
53 53
54// 54//
55// keys for config file 55// keys for config file
56// 56//
57 57
58// groups 58// groups
59#define GENERAL_GRP "PPP_General" 59#define GENERAL_GRP "PPP_General"
60#define MODEM_GRP "PPP_Modem" 60#define MODEM_GRP "PPP_Modem"
61#define ACCOUNT_GRP "PPP_Account" 61#define ACCOUNT_GRP "PPP_Account"
62#define ACCLIST_GRP "PPP_Accounts_List" 62#define ACCLIST_GRP "PPP_Accounts_List"
63//#define GRAPH_GRP "Graph" 63//#define GRAPH_GRP "Graph"
64//#define WINPOS_GRP "WindowPosition" 64//#define WINPOS_GRP "WindowPosition"
65 65
66// general 66// general
67#define ACCOUNT_LIST "AccountList" 67#define ACCOUNT_LIST "AccountList"
68#define DEVICE_LIST "DeviceList" 68#define DEVICE_LIST "DeviceList"
69#define DEFAULTACCOUNT_KEY "DefaultAccount" 69#define DEFAULTACCOUNT_KEY "DefaultAccount"
70#define PPPDVERSION_KEY "pppdVersion" 70#define PPPDVERSION_KEY "pppdVersion"
71#define PPPDTIMEOUT_KEY "pppdTimeout" 71#define PPPDTIMEOUT_KEY "pppdTimeout"
72#define SHOWCLOCK_KEY "ShowClock" 72#define SHOWCLOCK_KEY "ShowClock"
73#define SHOWLOGWIN_KEY "ShowLogWindow" 73#define SHOWLOGWIN_KEY "ShowLogWindow"
74#define AUTOREDIAL_KEY "AutomaticRedial" 74#define AUTOREDIAL_KEY "AutomaticRedial"
75#define DISCONNECT_KEY "DisconnectOnXServerExit" 75#define DISCONNECT_KEY "DisconnectOnXServerExit"
76#define QUITONDISCONNECT_KEY "QuitOnDisconnect" 76#define QUITONDISCONNECT_KEY "QuitOnDisconnect"
77#define NUMACCOUNTS_KEY "HighcountAccounts" 77#define NUMACCOUNTS_KEY "HighcountAccounts"
78#define NUMDEVICES_KEY "HighcountDevices" 78#define NUMDEVICES_KEY "HighcountDevices"
79 #define ID_KEY "ID" 79 #define ID_KEY "ID"
80 80
81// modem 81// modem
82#define MODEMNAME_KEY "Modem_Name" 82#define MODEMNAME_KEY "Modem_Name"
83#define MODEMDEV_KEY "Device" 83#define MODEMDEV_KEY "Device"
84#define LOCKFILE_KEY "UseLockFile" 84#define LOCKFILE_KEY "UseLockFile"
85#define FLOWCONTROL_KEY "FlowControl" 85#define FLOWCONTROL_KEY "FlowControl"
86#define SPEED_KEY "Speed" 86#define SPEED_KEY "Speed"
87#define TIMEOUT_KEY "Timeout" 87#define TIMEOUT_KEY "Timeout"
88#define TONEDURATION_KEY "ToneDuration" 88#define TONEDURATION_KEY "ToneDuration"
89#define BUSYWAIT_KEY "BusyWait" 89#define BUSYWAIT_KEY "BusyWait"
90#define INITSTR_KEY "InitString" 90#define INITSTR_KEY "InitString"
91#define INITRESP_KEY "InitResponse" 91#define INITRESP_KEY "InitResponse"
92#define PREINITDELAY_KEY "PreInitDelay" 92#define PREINITDELAY_KEY "PreInitDelay"
93#define INITDELAY_KEY "InitDelay" 93#define INITDELAY_KEY "InitDelay"
94#define NODTDETECT_KEY "NoDialToneDetection" 94#define NODTDETECT_KEY "NoDialToneDetection"
95#define DIALTONEWAIT_KEY "WaitForDialTone" 95#define DIALTONEWAIT_KEY "WaitForDialTone"
96#define DIALSTR_KEY "DialString" 96#define DIALSTR_KEY "DialString"
97#define CONNECTRESP_KEY "ConnectResponse" 97#define CONNECTRESP_KEY "ConnectResponse"
98#define BUSYRESP_KEY "BusyResponse" 98#define BUSYRESP_KEY "BusyResponse"
99#define NOCARRIERRESP_KEY "NoCarrierResponse" 99#define NOCARRIERRESP_KEY "NoCarrierResponse"
100#define NODIALTONERESP_KEY "NoDialToneResp" 100#define NODIALTONERESP_KEY "NoDialToneResp"
101#define HANGUPSTR_KEY "HangupString" 101#define HANGUPSTR_KEY "HangupString"
102#define HANGUPRESP_KEY "HangUpResponse" 102#define HANGUPRESP_KEY "HangUpResponse"
103#define ANSWERSTR_KEY "AnswerString" 103#define ANSWERSTR_KEY "AnswerString"
104#define RINGRESP_KEY "RingResponse" 104#define RINGRESP_KEY "RingResponse"
105#define ANSWERRESP_KEY "AnswerResponse" 105#define ANSWERRESP_KEY "AnswerResponse"
106#define ENTER_KEY "Enter" 106#define ENTER_KEY "Enter"
107#define ESCAPESTR_KEY "EscapeString" 107#define ESCAPESTR_KEY "EscapeString"
108#define ESCAPERESP_KEY "EscapeResponse" 108#define ESCAPERESP_KEY "EscapeResponse"
109#define ESCAPEGUARDTIME_KEY "EscapeGuardTime" 109#define ESCAPEGUARDTIME_KEY "EscapeGuardTime"
110#define USECDLINE_KEY "UseCDLine" 110#define USECDLINE_KEY "UseCDLine"
111#define VOLUME_HIGH "VolumeHigh" 111#define VOLUME_HIGH "VolumeHigh"
112#define VOLUME_MEDIUM "VolumeMedium" 112#define VOLUME_MEDIUM "VolumeMedium"
113#define VOLUME_OFF "VolumeOff" 113#define VOLUME_OFF "VolumeOff"
114#define VOLUME_KEY "Volume" 114#define VOLUME_KEY "Volume"
115 115
116// account 116// account
117#define NAME_KEY "Name" 117#define NAME_KEY "Name"
118#define PHONENUMBER_KEY "Phonenumber" 118#define PHONENUMBER_KEY "Phonenumber"
119#define DIAL_PREFIX_KEY "DialPrefix" 119#define DIAL_PREFIX_KEY "DialPrefix"
120#define AUTH_KEY "Authentication" 120#define AUTH_KEY "Authentication"
121#define STORED_PASSWORD_KEY "Password" 121#define STORED_PASSWORD_KEY "Password"
122#define STORED_USERNAME_KEY "Username" 122#define STORED_USERNAME_KEY "Username"
123#define STORE_PASSWORD_KEY "StorePassword" 123#define STORE_PASSWORD_KEY "StorePassword"
124#define BEFORE_CONNECT_KEY "BeforeConnect" 124#define BEFORE_CONNECT_KEY "BeforeConnect"
125#define COMMAND_KEY "Command" 125#define COMMAND_KEY "Command"
126#define DISCONNECT_COMMAND_KEY "DisconnectCommand" 126#define DISCONNECT_COMMAND_KEY "DisconnectCommand"
127#define BEFORE_DISCONNECT_KEY "BeforeDisconnect" 127#define BEFORE_DISCONNECT_KEY "BeforeDisconnect"
128#define IPADDR_KEY "IPAddr" 128#define IPADDR_KEY "IPAddr"
129#define SUBNETMASK_KEY "SubnetMask" 129#define SUBNETMASK_KEY "SubnetMask"
130#define ACCTENABLED_KEY "AccountingEnabled" 130#define ACCTENABLED_KEY "AccountingEnabled"
131#define VOLACCTENABLED_KEY "VolumeAccountingEnabled" 131#define VOLACCTENABLED_KEY "VolumeAccountingEnabled"
132#define ACCTFILE_KEY "AccountingFile" 132#define ACCTFILE_KEY "AccountingFile"
133#define AUTONAME_KEY "AutoName" 133#define AUTONAME_KEY "AutoName"
134#define GATEWAY_KEY "Gateway" 134#define GATEWAY_KEY "Gateway"
135#define DEFAULTROUTE_KEY "DefaultRoute" 135#define DEFAULTROUTE_KEY "DefaultRoute"
136#define DOMAIN_KEY "Domain" 136#define DOMAIN_KEY "Domain"
137#define DNS_KEY "DNS" 137#define DNS_KEY "DNS"
138#define AUTODNS_KEY "AutoDNS" 138#define AUTODNS_KEY "AutoDNS"
139#define EXDNSDISABLED_KEY "ExDNSDisabled" 139#define EXDNSDISABLED_KEY "ExDNSDisabled"
140#define SCRIPTCOM_KEY "ScriptCommands" 140#define SCRIPTCOM_KEY "ScriptCommands"
141#define SCRIPTARG_KEY "ScriptArguments" 141#define SCRIPTARG_KEY "ScriptArguments"
142#define PPPDARG_KEY "pppdArguments" 142#define PPPDARG_KEY "pppdArguments"
143#define PPP_DEBUG_OPTION "PPPDebug" 143#define PPP_DEBUG_OPTION "PPPDebug"
144#define ICONIFY_ON_CONNECT_KEY "iconifyOnConnect" 144#define ICONIFY_ON_CONNECT_KEY "iconifyOnConnect"
145#define DOCKING_KEY "DockIntoPanel" 145#define DOCKING_KEY "DockIntoPanel"
146#define TOTALCOSTS_KEY "TotalCosts" 146#define TOTALCOSTS_KEY "TotalCosts"
147#define TOTALBYTES_KEY "TotalBytes" 147#define TOTALBYTES_KEY "TotalBytes"
148 148
149// pppd errors 149// pppd errors
150#define E_IF_TIMEOUT 1 150#define E_IF_TIMEOUT 1
151#define E_PPPD_DIED 2 151#define E_PPPD_DIED 2
152 152
153// account list 153// account list
154#define ACCOUNTS_COUNT "Accounts_Count" 154#define ACCOUNTS_COUNT "Accounts_Count"
155#define ACOUNTS_DEV "Accounts_Modem" 155#define ACOUNTS_DEV "Accounts_Modem"
156#define ACOUNTS_ACC "Accounts_Account" 156#define ACOUNTS_ACC "Accounts_Account"
157 157
158#define DEVICESNAMES_LIST "DevicesNames_List" 158#define DEVICESNAMES_LIST "DevicesNames_List"
159#define DEVICES_LIST "Devices_List" 159#define DEVICES_LIST "Devices_List"
160#define DEVICES_LIST_SEP ',' 160#define DEVICES_LIST_SEP ','
161 161
162class PPPData { 162class PPPData {
163public: 163public:
164 PPPData(); 164 PPPData();
165 ~PPPData() {}; 165 ~PPPData() {};
166 166
167 enum { NumInitStrings = 2 }; 167 enum { NumInitStrings = 2 };
168 enum LineTermination {
169 EndCR,
170 EndLF,
171 EndCRLF
172 };
173
174 enum FlowControl {
175 FlowHardware,
176 FlowSoftware,
177 FlowNone
178 };
168 179
169 // general functions 180 // general functions
170 void save(); 181 void save();
171 void cancel(); 182 void cancel();
172 183
173 QStringList getAccountList(); 184 QStringList getAccountList();
174 185
175 static QMap<QString,QString> getConfiguredInterfaces(); 186 static QMap<QString,QString> getConfiguredInterfaces();
176 static void setConfiguredInterfaces( QMap<QString,QString> ); 187 static void setConfiguredInterfaces( QMap<QString,QString> );
177 188
178 // function to read/write date to configuration file 189 // function to read/write date to configuration file
179 static Config config(); 190 static Config config();
180 QString readConfig(const QString &, const QString &, const QString &); 191 QString readConfig(const QString &, const QString &, const QString &);
181 int readNumConfig(const QString &, const QString &, int); 192 int readNumConfig(const QString &, const QString &, int);
182 bool readListConfig(const QString &, const QString &, 193 bool readListConfig(const QString &, const QString &,
183 QStringList &, char sep = ','); 194 QStringList &, char sep = ',');
184 void writeConfig(const QString &, const QString &, const QString &); 195 void writeConfig(const QString &, const QString &, const QString &);
185 void writeConfig(const QString &, const QString &, int); 196 void writeConfig(const QString &, const QString &, int);
186 void writeListConfig(const QString &, const QString &, 197 void writeListConfig(const QString &, const QString &,
187 QStringList &, char sep = ','); 198 QStringList &, char sep = ',');
188 199
189 // return the current account group 200 // return the current account group
190 QString currentGroup() { return cgroup; } 201 QString currentGroup() { return cgroup; }
191 QString modemGroup(); 202 QString modemGroup();
192 203
193 // functions to set/get general kppp info 204 // functions to set/get general kppp info
194 QString password(); 205 QString password();
195 void setPassword(const QString &); 206 void setPassword(const QString &);
196 207
197// int currentAccountID() { return caccount; }; 208// int currentAccountID() { return caccount; };
198 const QString defaultAccount(); 209 const QString defaultAccount();
199 void setDefaultAccount(const QString &); 210 void setDefaultAccount(const QString &);
200 211
201 void set_xserver_exit_disconnect(bool set); 212 void set_xserver_exit_disconnect(bool set);
202 bool get_xserver_exit_disconnect(); 213 bool get_xserver_exit_disconnect();
203 214
204 void setPPPDebug(bool set); 215 void setPPPDebug(bool set);
205 bool getPPPDebug(); 216 bool getPPPDebug();
206 217
207 void set_quit_on_disconnect(bool); 218 void set_quit_on_disconnect(bool);
208 bool quit_on_disconnect(); 219 bool quit_on_disconnect();
209 220
210 void set_show_clock_on_caption(bool set); 221 void set_show_clock_on_caption(bool set);
211 bool get_show_clock_on_caption(); 222 bool get_show_clock_on_caption();
212 223
213 void set_show_log_window(bool set); 224 void set_show_log_window(bool set);
214 bool get_show_log_window(); 225 bool get_show_log_window();
215 226
216 void set_automatic_redial(bool set); 227 void set_automatic_redial(bool set);
217 bool automatic_redial(); 228 bool automatic_redial();
218 229
219// void set_iconify_on_connect(bool set); 230// void set_iconify_on_connect(bool set);
220// bool get_iconify_on_connect(); 231// bool get_iconify_on_connect();
221 232
222// void set_dock_into_panel(bool set); 233// void set_dock_into_panel(bool set);
223// bool get_dock_into_panel(); 234// bool get_dock_into_panel();
224 235
225 const QString enter(); 236 enum LineTermination enter();
226 void setEnter(const QString &); 237 void setEnter(enum LineTermination);
227 238
228 QString pppdVersion(); 239 QString pppdVersion();
229 bool pppdVersionMin(int ver, int mod, int patch); 240 bool pppdVersionMin(int ver, int mod, int patch);
230 241
231 int pppdTimeout(); 242 int pppdTimeout();
232 void setpppdTimeout(int); 243 void setpppdTimeout(int);
233 244
234 int busyWait(); 245 int busyWait();
235 void setbusyWait(int); 246 void setbusyWait(int);
236 247
237 bool modemLockFile(); 248 bool modemLockFile();
238 void setModemLockFile(bool set); 249 void setModemLockFile(bool set);
239 250
240 int modemEscapeGuardTime(); 251 int modemEscapeGuardTime();
241 void setModemEscapeGuardTime(int i); 252 void setModemEscapeGuardTime(int i);
242 253
243 void setModemEscapeStr(const QString &); 254 void setModemEscapeStr(const QString &);
244 const QString modemEscapeStr(); 255 const QString modemEscapeStr();
245 256
246 void setModemEscapeResp(const QString &); 257 void setModemEscapeResp(const QString &);
247 const QString modemEscapeResp(); 258 const QString modemEscapeResp();
248 259
249// const QString modemName(); 260// const QString modemName();
250// bool setModemName(const QString &); 261// bool setModemName(const QString &);
251// bool changeModemName(const QString &); 262// bool changeModemName(const QString &);
252 263
253 const QString modemDevice(); 264 const QString modemDevice();
254 bool setModemDevice(const QString &); 265 bool setModemDevice(const QString &);
255 266
256 const QString flowcontrol(); 267 enum FlowControl flowcontrol();
257 void setFlowcontrol(const QString &); 268 void setFlowcontrol(enum FlowControl);
258 269
259 int modemTimeout(); 270 int modemTimeout();
260 void setModemTimeout(int); 271 void setModemTimeout(int);
261 272
262 int modemToneDuration(); 273 int modemToneDuration();
263 void setModemToneDuration(int); 274 void setModemToneDuration(int);
264 275
265 QString volumeInitString(); 276 QString volumeInitString();
266 int volume(); 277 int volume();
267 void setVolume(int); 278 void setVolume(int);
268 279
269 int waitForDialTone(); 280 int waitForDialTone();
270 void setWaitForDialTone(int i); 281 void setWaitForDialTone(int i);
271 282
272 // modem command strings/responses 283 // modem command strings/responses
273 const QString modemInitStr(int i); 284 const QString modemInitStr(int i);
274 void setModemInitStr(int i, const QString &); 285 void setModemInitStr(int i, const QString &);
275 286
276 const QString modemInitResp(); 287 const QString modemInitResp();
277 void setModemInitResp(const QString &); 288 void setModemInitResp(const QString &);
278 289
279 int modemPreInitDelay(); 290 int modemPreInitDelay();
280 void setModemPreInitDelay(int); 291 void setModemPreInitDelay(int);
281 292
282 int modemInitDelay(); 293 int modemInitDelay();
283 void setModemInitDelay(int); 294 void setModemInitDelay(int);
284 295
285 QString modemNoDialToneDetectionStr(); 296 QString modemNoDialToneDetectionStr();
286 void setModemNoDialToneDetectionStr(const QString &); 297 void setModemNoDialToneDetectionStr(const QString &);
287 298
288 const QString modemDialStr(); 299 const QString modemDialStr();
289 void setModemDialStr(const QString &); 300 void setModemDialStr(const QString &);
290 301
291 const QString modemConnectResp(); 302 const QString modemConnectResp();
292 void setModemConnectResp(const QString &); 303 void setModemConnectResp(const QString &);
293 304
294 const QString modemBusyResp(); 305 const QString modemBusyResp();
295 void setModemBusyResp(const QString &); 306 void setModemBusyResp(const QString &);
296 307
297 const QString modemNoCarrierResp(); 308 const QString modemNoCarrierResp();
298 void setModemNoCarrierResp(const QString &); 309 void setModemNoCarrierResp(const QString &);
299 310
300 const QString modemNoDialtoneResp(); 311 const QString modemNoDialtoneResp();
301 void setModemNoDialtoneResp(const QString &); 312 void setModemNoDialtoneResp(const QString &);
302 313
303 const QString modemHangupStr(); 314 const QString modemHangupStr();
304 void setModemHangupStr(const QString &); 315 void setModemHangupStr(const QString &);
305 316
306 const QString modemHangupResp(); 317 const QString modemHangupResp();
307 void setModemHangupResp(const QString &); 318 void setModemHangupResp(const QString &);
308 319
309 const QString modemAnswerStr(); 320 const QString modemAnswerStr();
310 void setModemAnswerStr(const QString &); 321 void setModemAnswerStr(const QString &);
311 322
312 const QString modemRingResp(); 323 const QString modemRingResp();
313 void setModemRingResp(const QString &); 324 void setModemRingResp(const QString &);
314 325
315 const QString modemAnswerResp(); 326 const QString modemAnswerResp();
316 void setModemAnswerResp(const QString &); 327 void setModemAnswerResp(const QString &);
317 328
318 QString volumeOff(); 329 QString volumeOff();
319 void setVolumeOff(const QString &); 330 void setVolumeOff(const QString &);
320 331
321 QString volumeMedium(); 332 QString volumeMedium();
322 void setVolumeMedium(const QString &); 333 void setVolumeMedium(const QString &);
323 334
324 QString volumeHigh(); 335 QString volumeHigh();
325 void setVolumeHigh(const QString &); 336 void setVolumeHigh(const QString &);
326 337
327 // functions to set/get account information 338 // functions to set/get account information
328 int count() const; 339 int count() const;
329 bool setAccount(const QString &); 340 bool setAccount(const QString &);
330// bool setAccountbyIndex(int); 341// bool setAccountbyIndex(int);
331 342
332 bool isUniqueAccname(const QString &); 343 bool isUniqueAccname(const QString &);
333 bool isUniqueDevname(const QString &); 344 bool isUniqueDevname(const QString &);
334 345
335 bool deleteAccount(); 346 bool deleteAccount();
336 bool deleteAccount(const QString &); 347 bool deleteAccount(const QString &);
337 int newaccount(); 348 int newaccount();
338 int copyaccount(const QString&); 349 int copyaccount(const QString&);
339 350
340 const QString accname(); 351 const QString accname();
341 void setAccname(const QString &); 352 void setAccname(const QString &);
342 353
343 QStringList &phonenumbers(); 354 QStringList &phonenumbers();
344 const QString phonenumber(); 355 const QString phonenumber();
345 void setPhonenumber(const QString &); 356 void setPhonenumber(const QString &);
346 357
347 const QString dialPrefix(); 358 const QString dialPrefix();
348 void setDialPrefix(const QString &); 359 void setDialPrefix(const QString &);
349 360
350 int authMethod(); 361 int authMethod();
351 void setAuthMethod(int); 362 void setAuthMethod(int);
352 363
353 const QString storedUsername(); 364 const QString storedUsername();
354 void setStoredUsername(const QString &); 365 void setStoredUsername(const QString &);
355 366
356 const QString storedPassword(); 367 const QString storedPassword();
357 void setStoredPassword(const QString &); 368 void setStoredPassword(const QString &);
358 369
359 bool storePassword(); 370 bool storePassword();
360 void setStorePassword(bool); 371 void setStorePassword(bool);
361 372
362 const QString speed(); 373 const QString speed();
363 void setSpeed(const QString &); 374 void setSpeed(const QString &);
364 375
365 const QString command_before_connect(); 376 const QString command_before_connect();
366 void setCommand_before_connect(const QString &); 377 void setCommand_before_connect(const QString &);
367 378
368 const QString command_on_connect(); 379 const QString command_on_connect();
369 void setCommand_on_connect(const QString &); 380 void setCommand_on_connect(const QString &);
370 381
371 const QString command_on_disconnect(); 382 const QString command_on_disconnect();
372 void setCommand_on_disconnect(const QString &); 383 void setCommand_on_disconnect(const QString &);
373 384
374 const QString command_before_disconnect(); 385 const QString command_before_disconnect();
375 void setCommand_before_disconnect(const QString &); 386 void setCommand_before_disconnect(const QString &);
376 387
377 const QString ipaddr(); 388 const QString ipaddr();
378 void setIpaddr(const QString &); 389 void setIpaddr(const QString &);
379 390
380 const QString subnetmask(); 391 const QString subnetmask();
381 void setSubnetmask(const QString &); 392 void setSubnetmask(const QString &);
382 393
383 bool AcctEnabled(); 394 bool AcctEnabled();
384 void setAcctEnabled(bool set); 395 void setAcctEnabled(bool set);
385 396
386// int VolAcctEnabled(); 397// int VolAcctEnabled();
387// void setVolAcctEnabled(int set); 398// void setVolAcctEnabled(int set);
388 399
389 bool autoDNS(); 400 bool autoDNS();
390 void setAutoDNS(bool set); 401 void setAutoDNS(bool set);
391 402
392 bool exDNSDisabled(); 403 bool exDNSDisabled();
393 void setExDNSDisabled(bool set); 404 void setExDNSDisabled(bool set);
394 405
395 bool autoname(); 406 bool autoname();
396 void setAutoname(bool set); 407 void setAutoname(bool set);
397 408
398 const QString gateway(); 409 const QString gateway();
399 void setGateway(const QString &); 410 void setGateway(const QString &);
400 411
401 bool defaultroute(); 412 bool defaultroute();
402 void setDefaultroute(bool set); 413 void setDefaultroute(bool set);
403 414
404 QStringList &dns(); 415 QStringList &dns();
405 void setDns(QStringList &); 416 void setDns(QStringList &);
406 417
407 const QString domain(); 418 const QString domain();
408 void setDomain(const QString &); 419 void setDomain(const QString &);
409 420
410 QStringList &scriptType(); 421 QStringList &scriptType();
411 void setScriptType(QStringList &); 422 void setScriptType(QStringList &);
412 423
413 QStringList &script(); 424 QStringList &script();
414 void setScript(QStringList &); 425 void setScript(QStringList &);
415 426
416 QStringList &pppdArgument(); 427 QStringList &pppdArgument();
417 void setpppdArgumentDefaults(); 428 void setpppdArgumentDefaults();
418 void setpppdArgument(QStringList &); 429 void setpppdArgument(QStringList &);
419 430
420 //functions to change/set the child pppd process info 431 //functions to change/set the child pppd process info
421 bool pppdRunning() const; 432 bool pppdRunning() const;
422 void setpppdRunning(bool set); 433 void setpppdRunning(bool set);
423 434
424 int pppdError() const; 435 int pppdError() const;
425 void setpppdError(int err); 436 void setpppdError(int err);
426 437
427 QStringList getDevicesList(); 438 QStringList getDevicesList();
428 439
429 static QString encodeWord(const QString &s); 440 static QString encodeWord(const QString &s);
430 441
431 const QString devname(); 442 const QString devname();
432 void setDevname(const QString &); 443 void setDevname(const QString &);
433 bool setDevice(const QString& ); 444 bool setDevice(const QString& );
434 bool deleteDevice(); 445 bool deleteDevice();
435 bool deleteDevice(const QString &); 446 bool deleteDevice(const QString &);
436 int newdevice(); 447 int newdevice();
437 int copydevice(const QString&); 448 int copydevice(const QString&);
438 QStringList getDevicesNamesList(); 449 QStringList getDevicesNamesList();
439 450
440private: 451private:
441 452
442 //static PPPData *_data; 453 //static PPPData *_data;
443// int modemDeviceGroup; 454// int modemDeviceGroup;
444 QString passwd; 455 QString passwd;
445 QString _modemName; 456 QString _modemName;
446 int highcount; // index of highest account 457 int highcount; // index of highest account
447 int highcountdev; // index of highest device 458 int highcountdev; // index of highest device
448// int caccount; // index of the current account 459// int caccount; // index of the current account
449 QString cgroup; // name of current config group 460 QString cgroup; // name of current config group
450 pid_t suidprocessid; // process ID of setuid child 461 pid_t suidprocessid; // process ID of setuid child
451 bool pppdisrunning; // pppd process 462 bool pppdisrunning; // pppd process
452 // daemon 463 // daemon
453 int pppderror; // error encounterd running pppd 464 int pppderror; // error encounterd running pppd
454 int pppdVer, pppdMod, pppdPatch; // pppd version 465 int pppdVer, pppdMod, pppdPatch; // pppd version
455 466
456 467
457 QStringList phonelist; 468 QStringList phonelist;
458 QStringList accountList; 469 QStringList accountList;
459 QStringList deviceList; 470 QStringList deviceList;
460 QMap<QString,QString> stringEntries; 471 QMap<QString,QString> stringEntries;
461 QMap<QString,int> intEntries; 472 QMap<QString,int> intEntries;
462 QMap<QString,QStringList> listEntries; 473 QMap<QString,QStringList> listEntries;
463 QMap<QString,QChar> sepEntries; 474 QMap<QString,QChar> sepEntries;
464 475
465}; 476};
466 477
467#endif 478#endif